opensupports/server/controllers/user/get.php

55 lines
1.2 KiB
PHP
Raw Normal View History

<?php
use Respect\Validation\Validator as DataValidator;
DataValidator::with('CustomValidations', true);
2017-04-16 07:35:04 +02:00
/**
2017-04-21 08:09:24 +02:00
* @api {post} /user/get Retrieve the information of yourself.
2017-04-16 07:35:04 +02:00
*
2017-04-21 08:09:24 +02:00
* @apiName Get
2017-04-16 07:35:04 +02:00
*
* @apiGroup User
*
2017-04-21 08:09:24 +02:00
* @apiDescription This path retrieve the information of a user.
2017-04-16 07:35:04 +02:00
*
* @apiPermission User
*
2017-04-21 08:09:24 +02:00
* @apiUse NO_PERMISSION
* @apiUse INVALID_CREDENTIALS
2017-04-16 07:35:04 +02:00
*
* @apiSuccess {Object} data
*
*/
class GetUserController extends Controller {
const PATH = '/get';
const METHOD = 'POST';
public function validations() {
return [
'permission' => 'user',
'requestData' => []
];
}
public function handler() {
if (Controller::isStaffLogged()) {
Response::respondError(ERRORS::INVALID_CREDENTIALS);
return;
}
$user = Controller::getLoggedUser();
$parsedTicketList = [];
$ticketList = $user->sharedTicketList;
foreach($ticketList as $ticket) {
$parsedTicketList[] = $ticket->toArray();
}
Response::respondSuccess([
'name' => $user->name,
'email' => $user->email,
'verified' => !$user->verificationToken,
'tickets' => $parsedTicketList
]);
}
}