. */ namespace SP\Modules\Web\Controllers\User; use Exception; use JsonException; use SP\Core\Events\Event; use SP\Core\Events\EventMessage; use SP\Domain\Core\Acl\AclActionsInterface; use SP\Domain\Http\Dtos\JsonMessage; use SP\Modules\Web\Controllers\Traits\JsonTrait; use SP\Mvc\Controller\ItemTrait; /** * Class DeleteController */ final class DeleteController extends UserSaveBase { use ItemTrait; use JsonTrait; /** * Delete action * * @param int|null $id * * @return bool * @throws JsonException */ public function deleteAction(?int $id = null): bool { try { if (!$this->acl->checkUserAccess(AclActionsInterface::USER_DELETE)) { return $this->returnJsonResponse( JsonMessage::JSON_ERROR, __u('You don\'t have permission to do this operation') ); } if ($id === null) { $this->userService->deleteByIdBatch($this->getItemsIdFromRequest($this->request)); $this->eventDispatcher->notify( 'delete.user.selection', new Event( $this, EventMessage::build() ->addDescription(__u('Users deleted')) ->setExtra('userId', $this->getItemsIdFromRequest($this->request)) ) ); $this->deleteCustomFieldsForItem(AclActionsInterface::USER, $id, $this->customFieldService); return $this->returnJsonResponse(JsonMessage::JSON_SUCCESS, __u('Users deleted')); } $this->userService->delete($id); $this->deleteCustomFieldsForItem(AclActionsInterface::USER, $id, $this->customFieldService); $this->eventDispatcher->notify( 'delete.user', new Event( $this, EventMessage::build() ->addDescription(__u('User deleted')) ->addDetail(__u('User'), $id) ->addExtra('userId', $id) ) ); return $this->returnJsonResponse(JsonMessage::JSON_SUCCESS, __u('User deleted')); } catch (Exception $e) { processException($e); $this->eventDispatcher->notify('exception', new Event($e)); return $this->returnJsonResponseException($e); } } }