protected function setupForm($formDataSample) { $form = new UsersRolesForm(); $inputFilter = new UsersRolesFormInputFilter(); $form->setInputFilter($inputFilter->getInputFilter()); $form->setData($formDataSample); return $form; }
public function indexAction() { $mainLayout = $this->initializeAdminArea(); $lang = $this->params()->fromRoute('lang'); $id = $this->params()->fromRoute('id'); $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default'); try { $helper = new UsersRolesControllerHelper(); $roleRecord = $helper->recoverWrapperRecordsById(new UsersRolesGetterWrapper(new UsersRolesGetter($em)), array('id' => $id, 'limit' => 1), $id); $permissionsWrapper = $helper->recoverWrapper(new UsersRolesPermissionsGetterWrapper(new UsersRolesPermissionsGetter($em)), array()); $allPermissionsRecords = $permissionsWrapper->getRecords(); $helper->checkRecords($allPermissionsRecords, 'Permessi utente non presenti in archivio'); $acl = new Acl(); $form = new UsersRolesForm(); if (!empty($roleRecord)) { $acl->addRole($roleRecord[0]['name']); $currentRolesPermissionsRecords = $helper->recoverWrapperRecords(new UsersRolesPermissionsRelationsGetterWrapper(new UsersRolesPermissionsRelationsGetter($em)), array('roleId' => $roleRecord[0]['id'], 'orderBy' => 'permission.position')); if (!empty($currentRolesPermissionsRecords)) { $permissions = array(); foreach ($currentRolesPermissionsRecords as $permission) { $permissions[$permission['flag']] = $permission['permissionId']; $acl->addResource($permission['flag']); $acl->allow($roleRecord[0]['name'], $permission['flag']); } $roleRecord[0]['permissions'] = $permissions; } $formAction = $this->url()->fromRoute('admin/users-roles-update', array('lang' => $lang)); $formTitle = 'Modifica ruolo utente'; $formDescription = 'Modifica dati relativi al ruolo'; $form->setData($roleRecord[0]); } else { $formTitle = 'Nuovo ruolo utente'; $formDescription = 'Creazione nuovo ruolo utente'; $formAction = $this->url()->fromRoute('admin/users-roles-insert', array('lang' => $lang)); } $this->layout()->setVariables(array('form' => $form, 'formAction' => $formAction, 'formTitle' => $formTitle, 'formDescription' => $formDescription, 'roleName' => isset($roleRecord[0]['name']) ? $roleRecord[0]['name'] : null, 'roleId' => isset($roleRecord[0]['id']) ? $roleRecord[0]['id'] : null, 'permissions' => $permissionsWrapper->sortPerGroup($allPermissionsRecords), 'acl' => $acl, 'formDataCommonPath' => 'backend/templates/common/', 'adminAccess' => isset($roleRecord[0]['adminAccess']) ? $roleRecord[0]['adminAccess'] : null, 'formBreadCrumbTitle' => 'Modifica', 'formBreadCrumbCategory' => array(array('label' => 'Utenti', 'href' => $this->url()->fromRoute('admin/users-summary', array('lang' => $lang)), 'title' => 'Elenco utenti'), array('label' => 'Ruoli', 'href' => $this->url()->fromRoute('admin/users-roles-summary', array('lang' => $lang)), 'title' => 'Elenco ruoli')), 'showRolePermissionsTemplate' => 1, 'templatePartial' => self::formTemplate)); } catch (\Exception $e) { } $this->layout()->setTemplate($mainLayout); }
public function indexAction() { /** * @var \Doctrine\ORM\EntityManager $em */ $em = $this->getServiceLocator()->get('doctrine.entitymanager.orm_default'); /** * @var \Doctrine\DBAL\Connection $connection */ $connection = $em->getConnection(); $request = $this->getRequest(); $post = array_merge_recursive($request->getPost()->toArray(), $request->getFiles()->toArray()); if (!($request->isXmlHttpRequest() or $request->isPost())) { return $this->redirect()->toRoute('main'); } $inputFilter = new UsersRolesFormInputFilter(); $form = new UsersRolesForm(); $form->setBindOnValidate(false); $form->setInputFilter($inputFilter->getInputFilter()); $form->setData($post); $this->initializeAdminArea(); $userDetails = $this->recoverUserDetails(); $helper = new UsersRolesControllerHelper(); $helper->setConnection($connection); $helper->getConnection()->beginTransaction(); try { if (!$form->isValid()) { throw new NullException("The form is not valid"); } $inputFilter->exchangeArray($form->getData()); $helper->setLoggedUser($userDetails); $userRoleRecord = $helper->recoverWrapperRecords(new UsersRolesGetterWrapper(new UsersRolesGetter($em)), array('name' => $inputFilter->name)); if (!empty($userRoleRecord)) { throw new NullException("Il nome ruolo inserito è già presente in archivio"); } $lastInsertId = $helper->insert($inputFilter); if ($inputFilter->adminAccess == 1 and empty($inputFilter->permissions)) { throw new NullException("Aggiungere almeno un permesso al ruolo"); } if (!empty($inputFilter->permissions)) { foreach ($inputFilter->permissions as $key => $value) { $helper->insertPermissionRelation($lastInsertId, $value); } } $logWriter = new LogWriter($connection); $logWriter->writeLog(array('user_id' => $userDetails->id, 'module_id' => ModulesContainer::contenuti_id, 'message' => "Inserito nuovo ruolo utente " . $inputFilter->name, 'type' => 'info', 'reference_id' => $lastInsertId, 'backend' => 1)); $this->layout()->setVariables(array('messageType' => 'success', 'messageTitle' => 'Ruolo utente inserito correttamente', 'messageText' => 'I dati sono stati processati correttamente dal sistema', 'showLinkResetFormAndShowIt' => 1, 'backToSummaryLink' => $this->url()->fromRoute('admin/users-roles-summary', array('lang' => $this->params()->fromRoute('lang'))), 'backToSummaryText' => "Elenco ruoli")); $helper->getConnection()->commit(); } catch (\Exception $e) { try { $helper->getConnection()->rollBack(); } catch (\Doctrine\DBAL\ConnectionException $e) { } $logWriter = new LogWriter($connection); $logWriter->writeLog(array('user_id' => $userDetails->id, 'module_id' => ModulesContainer::contenuti_id, 'message' => "Errore inserimento nuovo ruolo utente: " . $inputFilter->name, 'type' => 'error', 'description' => $e->getMessage(), 'backend' => 1)); $this->layout()->setVariables(array('messageType' => 'danger', 'messageTitle' => 'Errore inserimento nuovo ruolo utente', 'messageText' => $e->getMessage(), 'form' => $form, 'formInputFilter' => $inputFilter->getInputFilter(), 'messageShowFormLink' => 1, 'messageShowForm' => 'Torna al form di inserimento dati')); } $this->layout()->setTemplate($this->layout()->getVariable('templateDir') . 'message.phtml'); }