. */ namespace SP\Modules\Web\Controllers\Client; use Exception; use JsonException; use SP\Core\Events\Event; use SP\Core\Events\EventMessage; use SP\Domain\Core\Acl\AclActionsInterface; use SP\Domain\Core\Exceptions\ValidationException; use SP\Http\JsonMessage; use SP\Modules\Web\Controllers\Traits\JsonTrait; use SP\Mvc\Controller\ItemTrait; /** * Class SaveCreateController */ final class SaveCreateController extends ClientSaveBase { use ItemTrait; use JsonTrait; /** * @return bool * @throws JsonException */ public function saveCreateAction(): bool { try { if (!$this->acl->checkUserAccess(AclActionsInterface::CLIENT_CREATE)) { return $this->returnJsonResponse( JsonMessage::JSON_ERROR, __u('You don\'t have permission to do this operation') ); } $this->form->validateFor(AclActionsInterface::CLIENT_CREATE); $itemData = $this->form->getItemData(); $id = $this->clientService->create($itemData); $this->eventDispatcher->notify( 'create.client', new Event( $this, EventMessage::factory() ->addDescription(__u('Client added')) ->addDetail(__u('Client'), $itemData->getName()) ) ); $this->addCustomFieldsForItem( AclActionsInterface::CLIENT, $id, $this->request, $this->customFieldService ); return $this->returnJsonResponse(JsonMessage::JSON_SUCCESS, __u('Client added')); } catch (ValidationException $e) { return $this->returnJsonResponseException($e); } catch (Exception $e) { processException($e); $this->eventDispatcher->notify('exception', new Event($e)); return $this->returnJsonResponseException($e); } } }