opensupports/server/controllers/system/disable-user-system.php

83 lines
2.1 KiB
PHP
Raw Normal View History

<?php
2017-04-18 02:09:16 +02:00
/**
* @api {post} /system/disable-user-system Disable user system
2018-09-20 22:19:47 +02:00
* @apiVersion 4.3.0
2017-04-18 02:09:16 +02:00
*
* @apiName Disable user system
*
* @apiGroup System
2017-04-18 02:09:16 +02:00
*
* @apiDescription This path disables the user system.
2017-04-18 02:09:16 +02:00
*
* @apiPermission staff3
2017-04-18 02:09:16 +02:00
*
2017-04-21 08:09:24 +02:00
* @apiParam {String} password The password of the current staff.
2017-04-18 02:09:16 +02:00
*
2017-04-21 08:09:24 +02:00
* @apiUse NO_PERMISSION
* @apiUse INVALID_PASSWORD
* @apiUse SYSTEM_USER_IS_ALREADY_DISABLED
2018-06-06 02:52:22 +02:00
*
* @apiSuccess {Object} data Empty object
2017-04-18 02:09:16 +02:00
*
*/
class DisableUserSystemController extends Controller {
const PATH = '/disable-user-system';
const METHOD = 'POST';
public function validations() {
return [
'permission' => 'staff_3',
'requestData' => []
];
}
public function handler() {
$password = Controller::request('password');
if(!Hashing::verifyPassword($password, Controller::getLoggedUser()->password)) {
2018-11-20 23:41:00 +01:00
throw new RequestException(ERRORS::INVALID_PASSWORD);
}
if(!Controller::isUserSystemEnabled()) {
2018-11-20 23:41:00 +01:00
throw new RequestException(ERRORS::SYSTEM_USER_IS_ALREADY_DISABLED);
}
$userSystemEnabled = Setting::getSetting('user-system-enabled');
$userSystemEnabled->value = 0 ;
$userSystemEnabled->store();
$userList = User::getAll();
foreach($userList as $user) {
$ticketNumberList = '';
2018-06-06 02:52:22 +02:00
foreach($user->sharedTicketList as $ticket) {
$ticket->authorEmail = $user->email;
$ticket->authorName = $user->name;
$ticket->author = null;
2018-06-06 02:52:22 +02:00
$ticketNumberList .= $ticket->ticketNumber . ' - ' . $ticket->title . '<br />';
$ticket->store();
}
$mailSender = MailSender::getInstance();
$mailSender->setTemplate(MailTemplate::USER_SYSTEM_DISABLED, [
'to' => $user->email,
'name' => $user->name,
2018-06-06 02:52:22 +02:00
'tickets' => $ticketNumberList,
'url' => Setting::getSetting('url')->getValue()
]);
$mailSender->send();
2018-06-06 02:52:22 +02:00
$user->delete();
}
2018-06-06 02:52:22 +02:00
Response::respondSuccess();
}
2018-06-06 02:52:22 +02:00
}