66 lines
1.9 KiB
PHP
Executable File
66 lines
1.9 KiB
PHP
Executable File
<?php
|
|
use Respect\Validation\Validator as DataValidator;
|
|
DataValidator::with('CustomValidations', true);
|
|
|
|
/**
|
|
* @api {post} /user/get Get my information
|
|
* @apiVersion 4.10.0
|
|
*
|
|
* @apiName Get my Information
|
|
*
|
|
* @apiGroup User
|
|
*
|
|
* @apiDescription This path retrieves information about the logged user.
|
|
*
|
|
* @apiPermission user
|
|
*
|
|
* @apiUse NO_PERMISSION
|
|
* @apiUse INVALID_CREDENTIALS
|
|
*
|
|
* @apiSuccess {Object} data Information about an user
|
|
* @apiSuccess {String} data.name Name of the user
|
|
* @apiSuccess {String} data.email Email of the user
|
|
* @apiSuccess {Boolean} data.verified Indicates if the user is verified
|
|
* @apiSuccess {Object} data Information about an user
|
|
* @apiSuccess {[Ticket](#api-Data_Structures-ObjectTicket)[]} data.tickets Array of tickets of the user
|
|
*
|
|
*/
|
|
|
|
class GetUserController extends Controller {
|
|
const PATH = '/get';
|
|
const METHOD = 'POST';
|
|
|
|
public function validations() {
|
|
return [
|
|
'permission' => 'user',
|
|
'requestData' => []
|
|
];
|
|
}
|
|
|
|
public function handler() {
|
|
|
|
if (Controller::isStaffLogged()) {
|
|
throw new RequestException(ERRORS::INVALID_CREDENTIALS);
|
|
return;
|
|
}
|
|
|
|
$user = Controller::getLoggedUser();
|
|
$parsedTicketList = [];
|
|
$ticketList = $user->sharedTicketList;
|
|
|
|
foreach($ticketList as $ticket) {
|
|
$parsedTicketList[] = $ticket->toArray(true);
|
|
}
|
|
|
|
Response::respondSuccess([
|
|
'name' => $user->name,
|
|
'email' => $user->email,
|
|
'staff' => false,
|
|
'verified' => !$user->verificationToken,
|
|
'tickets' => $parsedTicketList,
|
|
'customfields' => $user->xownCustomfieldvalueList->toArray(),
|
|
'users' => $user->supervisedrelation ? $user->supervisedrelation->sharedUserList->toArray() : null
|
|
]);
|
|
}
|
|
}
|