opensupports/server/controllers/user/disable.php

53 lines
1.2 KiB
PHP
Raw Normal View History

2018-09-28 00:46:30 +02:00
<?php
use Respect\Validation\Validator as DataValidator;
/**
* @api {post} /user/disable Ban email
* @apiVersion 4.3.0
*
* @apiName Disable User
*
* @apiGroup User
*
* @apiDescription This path takes an user id and disabled access for it
*
* @apiPermission staff1
*
* @apiParam {String} userId Id of the user to disable
*
* @apiUse NO_PERMISSION
* @apiUse INVALID_USER
* @apiUse ALREADY_DISABLED
*
* @apiSuccess {Object} data Empty object
*
*/
class DisableUserController extends Controller {
const PATH = '/disable';
const METHOD = 'POST';
public function validations() {
return [
'permission' => 'staff_1',
'requestData' => [
'userId' => [
'validation' => DataValidator::dataStoreId('user'),
'error' => ERRORS::INVALID_USER
]
]
];
}
public function handler() {
$user = User::getDataStore(Controller::request('userId'));
if($user->disabled) {
throw new Exception(ERRORS::ALREADY_DISABLED);
}
$user->disabled = 1;
$user->store();
Response::respondSuccess();
}
}