. */ namespace SP\Modules\Web\Controllers\AuthToken; use Defuse\Crypto\Exception\CryptoException; use Defuse\Crypto\Exception\EnvironmentIsBrokenException; use Exception; use SP\Core\Events\Event; use SP\Core\Events\EventMessage; use SP\Domain\Common\Attributes\Action; use SP\Domain\Common\Dtos\ActionResponse; use SP\Domain\Common\Enums\ResponseType; use SP\Domain\Common\Services\ServiceException; use SP\Domain\Core\Acl\AclActionsInterface; use SP\Domain\Core\Exceptions\ConstraintException; use SP\Domain\Core\Exceptions\QueryException; use SP\Domain\Core\Exceptions\SPException; use SP\Domain\Core\Exceptions\ValidationException; use SP\Infrastructure\Common\Repositories\DuplicatedItemException; use SP\Infrastructure\Common\Repositories\NoSuchItemException; use function SP\__u; /** * Class SaveEditController * * @package SP\Modules\Web\Controllers */ final class SaveEditController extends AuthTokenSaveBase { /** * Saves edit action * * @param int $id * * @return ActionResponse * @throws SPException * @throws CryptoException * @throws EnvironmentIsBrokenException * @throws ServiceException * @throws ConstraintException * @throws QueryException * @throws ValidationException * @throws DuplicatedItemException * @throws NoSuchItemException * @throws Exception */ #[Action(ResponseType::JSON)] public function saveEditAction(int $id): ActionResponse { if (!$this->acl->checkUserAccess(AclActionsInterface::AUTHTOKEN_EDIT)) { return ActionResponse::error(__u('You don\'t have permission to do this operation')); } $this->form->validateFor(AclActionsInterface::AUTHTOKEN_EDIT, $id); if ($this->form->isRefresh()) { $this->authTokenService->refreshAndUpdate($this->form->getItemData()); $this->eventDispatcher->notify( 'refresh.authToken', new Event( $this, EventMessage::build(__u('Authorization updated'))->addDetail(__u('Authorization'), $id) ) ); } else { $this->authTokenService->update($this->form->getItemData()); $this->eventDispatcher->notify( 'edit.authToken', new Event( $this, EventMessage::build(__u('Authorization updated'))->addDetail(__u('Authorization'), $id) ) ); } $this->updateCustomFieldsForItem( AclActionsInterface::AUTHTOKEN, $id, $this->request, $this->customFieldService ); return ActionResponse::ok(__u('Authorization updated')); } }