diff --git a/app/modules/web/Controllers/UserProfile/CreateController.php b/app/modules/web/Controllers/UserProfile/CreateController.php new file mode 100644 index 00000000..e9138874 --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/CreateController.php @@ -0,0 +1,72 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + + +use Exception; +use SP\Core\Acl\ActionsInterface; +use SP\Core\Events\Event; +use SP\Http\JsonResponse; +use SP\Modules\Web\Controllers\Traits\JsonTrait; + +/** + * Class CreateController + */ +final class CreateController extends UserProfileViewBase +{ + use JsonTrait; + + /** + * @return bool + * @throws \JsonException + */ + public function createAction(): bool + { + try { + if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_CREATE)) { + return $this->returnJsonResponse( + JsonResponse::JSON_ERROR, + __u('You don\'t have permission to do this operation') + ); + } + + $this->view->assign('header', __('New Profile')); + $this->view->assign('isView', false); + $this->view->assign('route', 'userProfile/saveCreate'); + + $this->setViewData(); + + $this->eventDispatcher->notifyEvent('show.userProfile.create', new Event($this)); + + return $this->returnJsonResponseData(['html' => $this->render()]); + } catch (Exception $e) { + processException($e); + + $this->eventDispatcher->notifyEvent('exception', new Event($e)); + + return $this->returnJsonResponseException($e); + } + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfile/DeleteController.php b/app/modules/web/Controllers/UserProfile/DeleteController.php new file mode 100644 index 00000000..a5e77e7a --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/DeleteController.php @@ -0,0 +1,98 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + + +use Exception; +use SP\Core\Acl\ActionsInterface; +use SP\Core\Events\Event; +use SP\Core\Events\EventMessage; +use SP\Http\JsonResponse; +use SP\Modules\Web\Controllers\Traits\JsonTrait; +use SP\Mvc\Controller\ItemTrait; + +/** + * Class DeleteController + */ +final class DeleteController extends UserProfileSaveBase +{ + use JsonTrait, ItemTrait; + + /** + * Delete action + * + * @param int|null $id + * + * @return bool + * @throws \JsonException + */ + public function deleteAction(?int $id = null): bool + { + try { + if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_DELETE)) { + return $this->returnJsonResponse( + JsonResponse::JSON_ERROR, + __u('You don\'t have permission to do this operation') + ); + } + + if ($id === null) { + $this->userProfileService->deleteByIdBatch($this->getItemsIdFromRequest($this->request)); + + $this->eventDispatcher->notifyEvent( + 'delete.userProfile.selection', + new Event($this, EventMessage::factory()->addDescription(__u('Profiles deleted'))) + ); + + $this->deleteCustomFieldsForItem(ActionsInterface::PROFILE, $id, $this->customFieldService); + + return $this->returnJsonResponse(JsonResponse::JSON_SUCCESS, __u('Profiles deleted')); + } + + $this->userProfileService->delete($id); + + $this->eventDispatcher->notifyEvent( + 'delete.userProfile', + new Event( + $this, + EventMessage::factory() + ->addDescription(__u('Profile deleted')) + ->addDetail(__u('Profile'), $id) + ->addExtra('userProfileId', $id) + ) + ); + + $this->deleteCustomFieldsForItem(ActionsInterface::PROFILE, $id, $this->customFieldService); + + return $this->returnJsonResponse(JsonResponse::JSON_SUCCESS, __u('Profile deleted')); + } catch (Exception $e) { + processException($e); + + $this->eventDispatcher->notifyEvent('exception', new Event($e)); + + return $this->returnJsonResponseException($e); + } + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfile/EditController.php b/app/modules/web/Controllers/UserProfile/EditController.php new file mode 100644 index 00000000..281202aa --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/EditController.php @@ -0,0 +1,76 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + + +use Exception; +use SP\Core\Acl\ActionsInterface; +use SP\Core\Events\Event; +use SP\Http\JsonResponse; +use SP\Modules\Web\Controllers\Traits\JsonTrait; + +/** + * Class EditController + */ +final class EditController extends UserProfileViewBase +{ + use JsonTrait; + + /** + * Edit action + * + * @param int $id + * + * @return bool + * @throws \JsonException + */ + public function editAction(int $id): bool + { + try { + if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_EDIT)) { + return $this->returnJsonResponse( + JsonResponse::JSON_ERROR, + __u('You don\'t have permission to do this operation') + ); + } + + $this->view->assign('header', __('Edit Profile')); + $this->view->assign('isView', false); + $this->view->assign('route', 'userProfile/saveEdit/'.$id); + + $this->setViewData($id); + + $this->eventDispatcher->notifyEvent('show.userProfile.edit', new Event($this)); + + return $this->returnJsonResponseData(['html' => $this->render()]); + } catch (Exception $e) { + processException($e); + + $this->eventDispatcher->notifyEvent('exception', new Event($e)); + + return $this->returnJsonResponseException($e); + } + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfile/SaveCreateController.php b/app/modules/web/Controllers/UserProfile/SaveCreateController.php new file mode 100644 index 00000000..72b62ac7 --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/SaveCreateController.php @@ -0,0 +1,87 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + + +use Exception; +use SP\Core\Acl\ActionsInterface; +use SP\Core\Events\Event; +use SP\Core\Events\EventMessage; +use SP\Core\Exceptions\ValidationException; +use SP\Http\JsonResponse; +use SP\Modules\Web\Controllers\Traits\JsonTrait; +use SP\Mvc\Controller\ItemTrait; + +/** + * Class SaveCreateController + */ +final class SaveCreateController extends UserProfileSaveBase +{ + use JsonTrait, ItemTrait; + + /** + * @return bool + * @throws \JsonException + */ + public function saveCreateAction(): bool + { + try { + if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_CREATE)) { + return $this->returnJsonResponse( + JsonResponse::JSON_ERROR, + __u('You don\'t have permission to do this operation') + ); + } + + $this->form->validateFor(ActionsInterface::PROFILE_CREATE); + + $profileData = $this->form->getItemData(); + + $id = $this->userProfileService->create($profileData); + + $this->eventDispatcher->notifyEvent( + 'create.userProfile', + new Event( + $this, + EventMessage::factory() + ->addDescription(__u('Profile added')) + ->addDetail(__u('Name'), $profileData->getName()) + ) + ); + + $this->addCustomFieldsForItem(ActionsInterface::PROFILE, $id, $this->request, $this->customFieldService); + + return $this->returnJsonResponse(JsonResponse::JSON_SUCCESS, __u('Profile added')); + } catch (ValidationException $e) { + return $this->returnJsonResponseException($e); + } catch (Exception $e) { + processException($e); + + $this->eventDispatcher->notifyEvent('exception', new Event($e)); + + return $this->returnJsonResponseException($e); + } + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfile/SaveEditController.php b/app/modules/web/Controllers/UserProfile/SaveEditController.php new file mode 100644 index 00000000..151ecea2 --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/SaveEditController.php @@ -0,0 +1,92 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + + +use Exception; +use SP\Core\Acl\ActionsInterface; +use SP\Core\Events\Event; +use SP\Core\Events\EventMessage; +use SP\Core\Exceptions\ValidationException; +use SP\Http\JsonResponse; +use SP\Modules\Web\Controllers\Traits\JsonTrait; +use SP\Mvc\Controller\ItemTrait; + +/** + * Class SaveEditController + */ +final class SaveEditController extends UserProfileSaveBase +{ + use JsonTrait, ItemTrait; + + /** + * Saves edit action + * + * @param int $id + * + * @return bool + * @throws \JsonException + */ + public function saveEditAction(int $id): bool + { + try { + if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_EDIT)) { + return $this->returnJsonResponse( + JsonResponse::JSON_ERROR, + __u('You don\'t have permission to do this operation') + ); + } + + $this->form->validateFor(ActionsInterface::PROFILE_EDIT, $id); + + $profileData = $this->form->getItemData(); + + $this->userProfileService->update($profileData); + + $this->eventDispatcher->notifyEvent( + 'edit.userProfile', + new Event( + $this, + EventMessage::factory() + ->addDescription(__u('Profile updated')) + ->addDetail(__u('Name'), $profileData->getName()) + ->addExtra('userProfileId', $id) + ) + ); + + $this->updateCustomFieldsForItem(ActionsInterface::PROFILE, $id, $this->request, $this->customFieldService); + + return $this->returnJsonResponse(JsonResponse::JSON_SUCCESS, __u('Profile updated')); + } catch (ValidationException $e) { + return $this->returnJsonResponseException($e); + } catch (Exception $e) { + processException($e); + + $this->eventDispatcher->notifyEvent('exception', new Event($e)); + + return $this->returnJsonResponseException($e); + } + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfile/SearchController.php b/app/modules/web/Controllers/UserProfile/SearchController.php new file mode 100644 index 00000000..0b51cb7d --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/SearchController.php @@ -0,0 +1,106 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + + +use SP\Core\Acl\ActionsInterface; +use SP\Core\Application; +use SP\Domain\User\UserProfileServiceInterface; +use SP\Html\DataGrid\DataGridInterface; +use SP\Http\JsonResponse; +use SP\Modules\Web\Controllers\ControllerBase; +use SP\Modules\Web\Controllers\Helpers\Grid\UserProfileGrid; +use SP\Modules\Web\Controllers\Traits\JsonTrait; +use SP\Mvc\Controller\ItemTrait; +use SP\Mvc\Controller\WebControllerHelper; + +/** + * Class SearchController + */ +final class SearchController extends ControllerBase +{ + use JsonTrait, ItemTrait; + + private UserProfileServiceInterface $userProfileService; + private UserProfileGrid $userProfileGrid; + + public function __construct( + Application $application, + WebControllerHelper $webControllerHelper, + UserProfileServiceInterface $userProfileService, + UserProfileGrid $userProfileGrid + ) { + parent::__construct($application, $webControllerHelper); + + $this->checkLoggedIn(); + + $this->userProfileService = $userProfileService; + $this->userProfileGrid = $userProfileGrid; + } + + /** + * Search action + * + * @return bool + * @throws \JsonException + * @throws \SP\Core\Exceptions\ConstraintException + * @throws \SP\Core\Exceptions\QueryException + */ + public function searchAction(): bool + { + if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_SEARCH)) { + return $this->returnJsonResponse( + JsonResponse::JSON_ERROR, + __u('You don\'t have permission to do this operation') + ); + } + + $this->view->addTemplate('datagrid-table', 'grid'); + $this->view->assign('index', $this->request->analyzeInt('activetab', 0)); + $this->view->assign('data', $this->getSearchGrid()); + + return $this->returnJsonResponseData(['html' => $this->render()]); + } + + /** + * getSearchGrid + * + * @return \SP\Html\DataGrid\DataGridInterface + * @throws \SP\Core\Exceptions\ConstraintException + * @throws \SP\Core\Exceptions\QueryException + */ + protected function getSearchGrid(): DataGridInterface + { + $itemSearchData = $this->getSearchData( + $this->configData->getAccountCount(), + $this->request + ); + + return $this->userProfileGrid->updatePager( + $this->userProfileGrid->getGrid($this->userProfileService->search($itemSearchData)), + $itemSearchData + ); + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfile/UserProfileSaveBase.php b/app/modules/web/Controllers/UserProfile/UserProfileSaveBase.php new file mode 100644 index 00000000..377bd7fd --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/UserProfileSaveBase.php @@ -0,0 +1,58 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + + +use SP\Core\Application; +use SP\Domain\CustomField\CustomFieldServiceInterface; +use SP\Domain\User\UserProfileServiceInterface; +use SP\Modules\Web\Controllers\ControllerBase; +use SP\Modules\Web\Forms\UserProfileForm; +use SP\Mvc\Controller\WebControllerHelper; + +/** + * Class UserProfileSaveBase + */ +abstract class UserProfileSaveBase extends ControllerBase +{ + protected UserProfileServiceInterface $userProfileService; + protected CustomFieldServiceInterface $customFieldService; + protected UserProfileForm $form; + + public function __construct( + Application $application, + WebControllerHelper $webControllerHelper, + UserProfileServiceInterface $userProfileService, + CustomFieldServiceInterface $customFieldService + ) { + parent::__construct($application, $webControllerHelper); + + $this->checkLoggedIn(); + + $this->userProfileService = $userProfileService; + $this->customFieldService = $customFieldService; + $this->form = new UserProfileForm($application, $this->request); + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfile/UserProfileViewBase.php b/app/modules/web/Controllers/UserProfile/UserProfileViewBase.php new file mode 100644 index 00000000..5235c367 --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/UserProfileViewBase.php @@ -0,0 +1,108 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + + +use SP\Core\Acl\Acl; +use SP\Core\Acl\ActionsInterface; +use SP\Core\Application; +use SP\DataModel\ProfileData; +use SP\DataModel\UserProfileData; +use SP\Domain\CustomField\CustomFieldServiceInterface; +use SP\Domain\User\UserProfileServiceInterface; +use SP\Modules\Web\Controllers\ControllerBase; +use SP\Mvc\Controller\ItemTrait; +use SP\Mvc\Controller\WebControllerHelper; + +/** + * Class UserProfileViewBase + */ +abstract class UserProfileViewBase extends ControllerBase +{ + use ItemTrait; + + private UserProfileServiceInterface $userProfileService; + private CustomFieldServiceInterface $customFieldService; + + public function __construct( + Application $application, + WebControllerHelper $webControllerHelper, + UserProfileServiceInterface $userProfileService, + CustomFieldServiceInterface $customFieldService + ) { + parent::__construct($application, $webControllerHelper); + + $this->checkLoggedIn(); + + $this->userProfileService = $userProfileService; + $this->customFieldService = $customFieldService; + } + + /** + * Sets view data for displaying user profile's data + * + * @param int|null $profileId + * + * @throws \SP\Core\Exceptions\ConstraintException + * @throws \SP\Core\Exceptions\QueryException + * @throws \SP\Core\Exceptions\SPException + * @throws \SP\Domain\Common\Services\ServiceException + * @throws \SP\Infrastructure\Common\Repositories\NoSuchItemException + */ + protected function setViewData(?int $profileId = null): void + { + $this->view->addTemplate('user_profile', 'itemshow'); + + $profile = $profileId + ? $this->userProfileService->getById($profileId) + : new UserProfileData(); + + $this->view->assign('profile', $profile); + $this->view->assign('profileData', $profile->getProfile() ?: new ProfileData()); + + $this->view->assign('nextAction', Acl::getActionRoute(ActionsInterface::ACCESS_MANAGE)); + + if ($this->view->isView === true) { + $this->view->assign( + 'usedBy', + $profileId + ? $this->userProfileService->getUsersForProfile($profileId) + : [] + ); + + $this->view->assign('disabled', 'disabled'); + $this->view->assign('readonly', 'readonly'); + } else { + $this->view->assign('disabled', false); + $this->view->assign('readonly', false); + } + + $this->view->assign('showViewCustomPass', $this->acl->checkUserAccess(ActionsInterface::CUSTOMFIELD_VIEW_PASS)); + $this->view->assign( + 'customFields', + $this->getCustomFieldsForItem(ActionsInterface::PROFILE, $profileId, $this->customFieldService) + ); + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfile/ViewController.php b/app/modules/web/Controllers/UserProfile/ViewController.php new file mode 100644 index 00000000..620e8b06 --- /dev/null +++ b/app/modules/web/Controllers/UserProfile/ViewController.php @@ -0,0 +1,76 @@ +. + */ + +namespace SP\Modules\Web\Controllers\UserProfile; + +use Exception; +use SP\Core\Acl\ActionsInterface; +use SP\Core\Events\Event; +use SP\Http\JsonResponse; +use SP\Modules\Web\Controllers\Traits\JsonTrait; + +/** + * Class UserProfileController + * + * @package SP\Modules\Web\Controllers + */ +final class ViewController extends UserProfileViewBase +{ + use JsonTrait; + + /** + * View action + * + * @param int $id + * + * @return bool + * @throws \JsonException + */ + public function viewAction(int $id): bool + { + try { + if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_VIEW)) { + return $this->returnJsonResponse( + JsonResponse::JSON_ERROR, + __u('You don\'t have permission to do this operation') + ); + } + + $this->view->assign('header', __('View Profile')); + $this->view->assign('isView', true); + + $this->setViewData($id); + + $this->eventDispatcher->notifyEvent('show.userProfile', new Event($this)); + + return $this->returnJsonResponseData(['html' => $this->render()]); + } catch (Exception $e) { + processException($e); + + $this->eventDispatcher->notifyEvent('exception', new Event($e)); + + return $this->returnJsonResponseException($e); + } + } +} \ No newline at end of file diff --git a/app/modules/web/Controllers/UserProfileController.php b/app/modules/web/Controllers/UserProfileController.php deleted file mode 100644 index 3c0ef893..00000000 --- a/app/modules/web/Controllers/UserProfileController.php +++ /dev/null @@ -1,512 +0,0 @@ -. - */ - -namespace SP\Modules\Web\Controllers; - -use DI\DependencyException; -use DI\NotFoundException; -use Exception; -use SP\Core\Acl\Acl; -use SP\Core\Acl\ActionsInterface; -use SP\Core\Events\Event; -use SP\Core\Events\EventMessage; -use SP\Core\Exceptions\ConstraintException; -use SP\Core\Exceptions\QueryException; -use SP\Core\Exceptions\SessionTimeout; -use SP\Core\Exceptions\SPException; -use SP\Core\Exceptions\ValidationException; -use SP\DataModel\ProfileData; -use SP\DataModel\UserProfileData; -use SP\Domain\Auth\Services\AuthException; -use SP\Domain\Common\Services\ServiceException; -use SP\Domain\User\Services\UserProfileService; -use SP\Html\DataGrid\DataGridInterface; -use SP\Http\JsonResponse; -use SP\Infrastructure\Common\Repositories\NoSuchItemException; -use SP\Modules\Web\Controllers\Helpers\Grid\UserProfileGrid; -use SP\Modules\Web\Controllers\Traits\JsonTrait; -use SP\Modules\Web\Forms\UserProfileForm; -use SP\Mvc\Controller\CrudControllerInterface; -use SP\Mvc\Controller\ItemTrait; - -/** - * Class UserProfileController - * - * @package SP\Modules\Web\Controllers - */ -final class UserProfileController extends ControllerBase implements CrudControllerInterface -{ - use JsonTrait, ItemTrait; - - protected ?UserProfileService $userProfileService = null; - - /** - * Search action - * - * @return bool - * @throws \DI\DependencyException - * @throws \DI\NotFoundException - * @throws \JsonException - * @throws \SP\Core\Exceptions\ConstraintException - * @throws \SP\Core\Exceptions\QueryException - */ - public function searchAction(): bool - { - if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_SEARCH)) { - return $this->returnJsonResponse( - JsonResponse::JSON_ERROR, - __u('You don\'t have permission to do this operation') - ); - } - - $this->view->addTemplate('datagrid-table', 'grid'); - $this->view->assign( - 'index', - $this->request->analyzeInt('activetab', 0) - ); - $this->view->assign('data', $this->getSearchGrid()); - - return $this->returnJsonResponseData(['html' => $this->render()]); - } - - /** - * getSearchGrid - * - * @throws DependencyException - * @throws NotFoundException - * @throws ConstraintException - * @throws QueryException - */ - protected function getSearchGrid(): DataGridInterface - { - $itemSearchData = $this->getSearchData( - $this->configData->getAccountCount(), - $this->request - ); - - $userProfileGrid = $this->dic->get(UserProfileGrid::class); - - return $userProfileGrid->updatePager( - $userProfileGrid->getGrid($this->userProfileService->search($itemSearchData)), - $itemSearchData - ); - } - - /** - * @return bool - * @throws \DI\DependencyException - * @throws \DI\NotFoundException - * @throws \JsonException - */ - public function createAction(): bool - { - try { - if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_CREATE)) { - return $this->returnJsonResponse( - JsonResponse::JSON_ERROR, - __u('You don\'t have permission to do this operation') - ); - } - - $this->view->assign('header', __('New Profile')); - $this->view->assign('isView', false); - $this->view->assign('route', 'userProfile/saveCreate'); - - $this->setViewData(); - - $this->eventDispatcher->notifyEvent( - 'show.userProfile.create', - new Event($this) - ); - - return $this->returnJsonResponseData(['html' => $this->render()]); - } catch (Exception $e) { - processException($e); - - $this->eventDispatcher->notifyEvent( - 'exception', - new Event($e) - ); - - return $this->returnJsonResponseException($e); - } - } - - /** - * Sets view data for displaying user profile's data - * - * @param int|null $profileId - * - * @throws ConstraintException - * @throws DependencyException - * @throws NoSuchItemException - * @throws NotFoundException - * @throws QueryException - * @throws SPException - * @throws ServiceException - */ - protected function setViewData(?int $profileId = null): void - { - $this->view->addTemplate('user_profile', 'itemshow'); - - $profile = $profileId - ? $this->userProfileService->getById($profileId) - : new UserProfileData(); - - $this->view->assign('profile', $profile); - $this->view->assign( - 'profileData', - $profile->getProfile() ?: new ProfileData() - ); - - $this->view->assign( - 'nextAction', - Acl::getActionRoute(ActionsInterface::ACCESS_MANAGE) - ); - - if ($this->view->isView === true) { - $this->view->assign( - 'usedBy', - $profileId - ? $this->userProfileService->getUsersForProfile($profileId) - : [] - ); - - $this->view->assign('disabled', 'disabled'); - $this->view->assign('readonly', 'readonly'); - } else { - $this->view->assign('disabled', false); - $this->view->assign('readonly', false); - } - - $this->view->assign( - 'showViewCustomPass', - $this->acl->checkUserAccess(ActionsInterface::CUSTOMFIELD_VIEW_PASS) - ); - $this->view->assign( - 'customFields', - $this->getCustomFieldsForItem(ActionsInterface::PROFILE, $profileId) - ); - } - - /** - * Edit action - * - * @param int $id - * - * @return bool - * @throws \DI\DependencyException - * @throws \DI\NotFoundException - * @throws \JsonException - */ - public function editAction(int $id): bool - { - try { - if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_EDIT)) { - return $this->returnJsonResponse( - JsonResponse::JSON_ERROR, - __u('You don\'t have permission to do this operation') - ); - } - - $this->view->assign('header', __('Edit Profile')); - $this->view->assign('isView', false); - $this->view->assign('route', 'userProfile/saveEdit/' . $id); - - $this->setViewData($id); - - $this->eventDispatcher->notifyEvent( - 'show.userProfile.edit', - new Event($this) - ); - - return $this->returnJsonResponseData(['html' => $this->render()]); - } catch (Exception $e) { - processException($e); - - $this->eventDispatcher->notifyEvent( - 'exception', - new Event($e) - ); - - return $this->returnJsonResponseException($e); - } - } - - /** - * Delete action - * - * @param int|null $id - * - * @return bool - * @throws \DI\DependencyException - * @throws \DI\NotFoundException - * @throws \JsonException - */ - public function deleteAction(?int $id = null): bool - { - try { - if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_DELETE)) { - return $this->returnJsonResponse( - JsonResponse::JSON_ERROR, - __u('You don\'t have permission to do this operation') - ); - } - - if ($id === null) { - $this->userProfileService - ->deleteByIdBatch($this->getItemsIdFromRequest($this->request)); - - $this->eventDispatcher->notifyEvent( - 'delete.userProfile.selection', - new Event( - $this, - EventMessage::factory() - ->addDescription(__u('Profiles deleted')) - ) - ); - - $this->deleteCustomFieldsForItem( - ActionsInterface::PROFILE, - $id - ); - - return $this->returnJsonResponse( - JsonResponse::JSON_SUCCESS, - __u('Profiles deleted') - ); - } - - $this->userProfileService->delete($id); - - - $this->eventDispatcher->notifyEvent( - 'delete.userProfile', - new Event( - $this, - EventMessage::factory() - ->addDescription(__u('Profile deleted')) - ->addDetail(__u('Profile'), $id) - ->addExtra('userProfileId', $id) - ) - ); - - $this->deleteCustomFieldsForItem( - ActionsInterface::PROFILE, - $id - ); - - return $this->returnJsonResponse( - JsonResponse::JSON_SUCCESS, - __u('Profile deleted') - ); - } catch (Exception $e) { - processException($e); - - $this->eventDispatcher->notifyEvent( - 'exception', - new Event($e) - ); - - return $this->returnJsonResponseException($e); - } - } - - /** - * @return bool - * @throws \DI\DependencyException - * @throws \DI\NotFoundException - * @throws \JsonException - */ - public function saveCreateAction(): bool - { - try { - if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_CREATE)) { - return $this->returnJsonResponse( - JsonResponse::JSON_ERROR, - __u('You don\'t have permission to do this operation') - ); - } - - $form = new UserProfileForm($this->dic); - $form->validateFor(ActionsInterface::PROFILE_CREATE, null); - - $profileData = $form->getItemData(); - - $id = $this->userProfileService->create($profileData); - - $this->eventDispatcher->notifyEvent( - 'create.userProfile', - new Event( - $this, - EventMessage::factory() - ->addDescription(__u('Profile added')) - ->addDetail(__u('Name'), $profileData->getName()) - ) - ); - - $this->addCustomFieldsForItem( - ActionsInterface::PROFILE, - $id, - $this->request - ); - - return $this->returnJsonResponse( - JsonResponse::JSON_SUCCESS, - __u('Profile added') - ); - } catch (ValidationException $e) { - return $this->returnJsonResponseException($e); - } catch (Exception $e) { - processException($e); - - $this->eventDispatcher->notifyEvent( - 'exception', - new Event($e) - ); - - return $this->returnJsonResponseException($e); - } - } - - /** - * Saves edit action - * - * @param int $id - * - * @return bool - * @throws \DI\DependencyException - * @throws \DI\NotFoundException - * @throws \JsonException - */ - public function saveEditAction(int $id): bool - { - try { - if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_EDIT)) { - return $this->returnJsonResponse( - JsonResponse::JSON_ERROR, - __u('You don\'t have permission to do this operation') - ); - } - - $form = new UserProfileForm($this->dic, $id); - $form->validateFor(ActionsInterface::PROFILE_EDIT, null); - - $profileData = $form->getItemData(); - - $this->userProfileService->update($profileData); - - $this->eventDispatcher->notifyEvent( - 'edit.userProfile', - new Event( - $this, - EventMessage::factory() - ->addDescription(__u('Profile updated')) - ->addDetail(__u('Name'), $profileData->getName()) - ->addExtra('userProfileId', $id) - ) - ); - - $this->updateCustomFieldsForItem( - ActionsInterface::PROFILE, - $id, - $this->request - ); - - return $this->returnJsonResponse( - JsonResponse::JSON_SUCCESS, - __u('Profile updated') - ); - } catch (ValidationException $e) { - return $this->returnJsonResponseException($e); - } catch (Exception $e) { - processException($e); - - $this->eventDispatcher->notifyEvent( - 'exception', - new Event($e) - ); - - return $this->returnJsonResponseException($e); - } - } - - /** - * View action - * - * @param int $id - * - * @return bool - * @throws \DI\DependencyException - * @throws \DI\NotFoundException - * @throws \JsonException - */ - public function viewAction(int $id): bool - { - try { - if (!$this->acl->checkUserAccess(ActionsInterface::PROFILE_VIEW)) { - return $this->returnJsonResponse( - JsonResponse::JSON_ERROR, - __u('You don\'t have permission to do this operation') - ); - } - - $this->view->assign('header', __('View Profile')); - $this->view->assign('isView', true); - - $this->setViewData($id); - - $this->eventDispatcher->notifyEvent( - 'show.userProfile', - new Event($this) - ); - - return $this->returnJsonResponseData(['html' => $this->render()]); - } catch (Exception $e) { - processException($e); - - $this->eventDispatcher->notifyEvent( - 'exception', - new Event($e) - ); - - return $this->returnJsonResponseException($e); - } - } - - /** - * Initialize class - * - * @throws AuthException - * @throws DependencyException - * @throws NotFoundException - * @throws SessionTimeout - */ - protected function initialize(): void - { - $this->checkLoggedIn(); - - $this->userProfileService = $this->dic->get(UserProfileService::class); - } -} \ No newline at end of file diff --git a/app/modules/web/Forms/UserProfileForm.php b/app/modules/web/Forms/UserProfileForm.php index ec96d2a4..40afeedc 100644 --- a/app/modules/web/Forms/UserProfileForm.php +++ b/app/modules/web/Forms/UserProfileForm.php @@ -25,6 +25,7 @@ namespace SP\Modules\Web\Forms; use SP\Core\Acl\ActionsInterface; +use SP\Core\Exceptions\SPException; use SP\Core\Exceptions\ValidationException; use SP\DataModel\ProfileData; use SP\DataModel\UserProfileData; @@ -129,8 +130,15 @@ final class UserProfileForm extends FormBase implements FormInterface } } - public function getItemData(): ?UserProfileData + /** + * @throws \SP\Core\Exceptions\SPException + */ + public function getItemData(): UserProfileData { + if (null === $this->userProfileData) { + throw new SPException(__u('Profile data not set')); + } + return $this->userProfileData; } } \ No newline at end of file