. */ namespace SP\Modules\Web\Controllers\AuthToken; use Exception; use SP\Core\Acl\ActionsInterface; use SP\Core\Events\Event; use SP\Core\Exceptions\ValidationException; use SP\Http\JsonResponse; /** * Class SaveCreateController * * @package SP\Modules\Web\Controllers */ final class SaveCreateController extends AuthTokenSaveBase { /** * @return bool * @throws \JsonException */ public function saveCreateAction(): bool { try { if (!$this->acl->checkUserAccess(ActionsInterface::AUTHTOKEN_CREATE)) { return $this->returnJsonResponse( JsonResponse::JSON_ERROR, __u('You don\'t have permission to do this operation') ); } $this->form->validateFor(ActionsInterface::AUTHTOKEN_CREATE); $id = $this->authTokenService->create($this->form->getItemData()); $this->addCustomFieldsForItem( ActionsInterface::AUTHTOKEN, $id, $this->request, $this->customFieldService ); $this->eventDispatcher->notify('create.authToken', new Event($this)); return $this->returnJsonResponse(JsonResponse::JSON_SUCCESS, __u('Authorization added')); } catch (ValidationException $e) { return $this->returnJsonResponse(JsonResponse::JSON_ERROR, $e->getMessage()); } catch (Exception $e) { processException($e); $this->eventDispatcher->notify('exception', new Event($e)); return $this->returnJsonResponseException($e); } } }