. */ namespace SP\Modules\Web\Controllers\PublicLink; use Exception; use SP\Core\Acl\ActionsInterface; use SP\Core\Events\Event; use SP\DataModel\PublicLinkData; use SP\Domain\Account\Services\PublicLinkService; use SP\Http\JsonResponse; use SP\Modules\Web\Controllers\Traits\JsonTrait; use SP\Util\PasswordUtil; /** * Class SaveCreateFromAccountController */ final class SaveCreateFromAccountController extends PublicLinkSaveBase { use JsonTrait; /** * Saves create action * * @param int $accountId * @param int $notify * * @return bool * @throws \JsonException */ public function saveCreateFromAccountAction(int $accountId, int $notify): bool { try { if (!$this->acl->checkUserAccess(ActionsInterface::PUBLICLINK_CREATE)) { return $this->returnJsonResponse( JsonResponse::JSON_ERROR, __u('You don\'t have permission to do this operation') ); } $publicLinkData = new PublicLinkData(); $publicLinkData->setTypeId(PublicLinkService::TYPE_ACCOUNT); $publicLinkData->setItemId($accountId); $publicLinkData->setNotify((bool)$notify); $publicLinkData->setHash(PasswordUtil::generateRandomBytes()); $this->publicLinkService->create($publicLinkData); $this->eventDispatcher->notify('create.publicLink.account', new Event($this)); return $this->returnJsonResponse(JsonResponse::JSON_SUCCESS, __u('Link created')); } catch (Exception $e) { processException($e); $this->eventDispatcher->notify('exception', new Event($e)); return $this->returnJsonResponseException($e); } } }