Rev 16798 | AutorÃa | Comparar con el anterior | Ultima modificación | Ver Log |
<?phpdeclare(strict_types=1);namespace LeadersLinked\Controller;use Laminas\Db\Adapter\AdapterInterface;use Laminas\Mvc\Controller\AbstractActionController;use Laminas\Log\LoggerInterface;use Laminas\View\Model\ViewModel;use Laminas\View\Model\JsonModel;use LeadersLinked\Library\Functions;use LeadersLinked\Model\Company;use LeadersLinked\Hydrator\ObjectPropertyHydrator;use LeadersLinked\Mapper\MyCoachCategoryMapper;use LeadersLinked\Model\MyCoachCategory;use LeadersLinked\Form\MyCoach\MyCoachCategoryForm;use LeadersLinked\Mapper\UserMapper;use LeadersLinked\Mapper\MyCoachCategoryUserMapper;use LeadersLinked\Form\MyCoach\MyCoachCategoryUserDataForm;use LeadersLinked\Form\MyCoach\MyCoachCategoryUserForm;use LeadersLinked\Mapper\QueryMapper;use Laminas\Paginator\Adapter\DbSelect;use Laminas\Paginator\Paginator;use LeadersLinked\Model\MyCoachCategoryUser;use LeadersLinked\Mapper\JobDescriptionMapper;use LeadersLinked\Mapper\MyCoachCategoryJobDescriptionMapper;use LeadersLinked\Model\User;use LeadersLinked\Model\MyCoachCategoryJobDescription;class MyCoachCategoryUserController extends AbstractActionController {/**** @var \Laminas\Db\Adapter\AdapterInterface*/private $adapter;/**** @var \LeadersLinked\Cache\CacheInterface*/private $cache;/**** @var \Laminas\Log\LoggerInterface*/private $logger;/**** @var array*/private $config;/**** @var \Laminas\Mvc\I18n\Translator*/private $translator;/**** @param \Laminas\Db\Adapter\AdapterInterface $adapter* @param \LeadersLinked\Cache\CacheInterface $cache* @param \Laminas\Log\LoggerInterface LoggerInterface $logger* @param array $config* @param \Laminas\Mvc\I18n\Translator $translator*/public function __construct($adapter, $cache, $logger, $config, $translator){$this->adapter = $adapter;$this->cache = $cache;$this->logger = $logger;$this->config = $config;$this->translator = $translator;}public function indexAction(){$request = $this->getRequest();$currentUserPlugin = $this->plugin('currentUserPlugin');$currentCompany = $currentUserPlugin->getCompany();$currentUser = $currentUserPlugin->getUser();$request = $this->getRequest();if ($request->isGet()) {$headers = $request->getHeaders();$isJson = false;if ($headers->has('Accept')) {$accept = $headers->get('Accept');$prioritized = $accept->getPrioritized();foreach ($prioritized as $key => $value) {$raw = trim($value->getRaw());if (!$isJson) {$isJson = strpos($raw, 'json');}}}//$isJson = true;if ($isJson) {$category_uuid = Functions::sanitizeFilterString($this->params()->fromQuery('category_id'));if(!$category_uuid) {return new JsonModel(['success' => true,'data' => ['total' => 0,'items' => [],'link_add' => '','link_upload' => '','link_jobs_description' => '','roles' => [],'jobs_description' => [],]]);}$myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);$myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_uuid);if(!$myCoachCategory) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND']);}if($myCoachCategory->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY']);}$search = $this->params()->fromQuery('search', []);$search = empty($search['value']) ? '' : Functions::sanitizeFilterString($search['value']);$start = intval($this->params()->fromQuery('start', 0), 10);$records_x_page = intval($this->params()->fromQuery('length', 10), 10);$page = intval($start / $records_x_page);$page++;$order = $this->params()->fromQuery('order', []);$order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);$order_direction = empty($order[0]['dir']) ? 'ASC' : Functions::sanitizeFilterString(filter_var($order[0]['dir']));$fields = ['first_name', 'last_name', 'email'];$order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'first_name';if (!in_array($order_direction, ['ASC', 'DESC'])) {$order_direction = 'ASC';}$acl = $this->getEvent()->getViewModel()->getVariable('acl');$allowAdd = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/add');$allowEdit = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/edit');$allowDelete = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/delete');$allowUpload = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/upload');$allowJobsDescription = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/jobs-description');$items = [];$queryMapper = QueryMapper::getInstance($this->adapter);$select = $queryMapper->getSql()->select();$select->columns(['role']);$select->from(['cu' => MyCoachCategoryUserMapper::_TABLE]);$select->join(['u' => UserMapper::_TABLE], 'cu.user_id = u.id', ['uuid', 'first_name', 'last_name', 'email']);$select->where->equalTo('cu.category_id', $myCoachCategory->id);if($search) {$select->where->nest()->like('first_name', '%' . $search . '%')->or->like('last_name', '%' . $search . '%')->or->like('email', '%' . $search . '%')->unnest();}$select->order($order_field . ' ' . $order_direction);//echo $select->getSqlString($this->adapter->platform); exit;$paginatorAdapter = new DbSelect($select, $this->adapter);$paginator = new Paginator($paginatorAdapter);$paginator->setItemCountPerPage($records_x_page);$paginator->setCurrentPageNumber($page);$records = $paginator->getCurrentItems();foreach ($records as $record) {switch($record['role']){case MyCoachCategoryUser::ROLE_ADMINISTRATOR :$role = 'LABEL_ADMINISTRATOR';break;case MyCoachCategoryUser::ROLE_EDITOR :$role = 'LABEL_EDITOR';break;case MyCoachCategoryUser::ROLE_USER :$role = 'LABEL_USER';break;default :$role = 'LABEL_UNKNOWN';break;}$item = ['first_name' => $record['first_name'],'last_name' => $record['first_name'],'email' => $record['email'],'role' => $role,'actions' => ['link_edit' => $allowEdit ? $this->url()->fromRoute('my-coach/categories/users/edit', ['id' => $myCoachCategory->uuid, 'user_id' => $record['uuid'] ]) : '','link_delete' => $allowDelete ? $this->url()->fromRoute('my-coach/categories/users/delete', ['id' => $myCoachCategory->uuid, 'user_id' => $record['uuid'] ]) : '',]];array_push($items, $item);}if($myCoachCategory->privacy == MyCoachCategory::PRIVACY_COMPANY) {$roles = [MyCoachCategoryUser::ROLE_USER => 'LABEL_USER',MyCoachCategoryUser::ROLE_EDITOR => 'LABEL_EDITOR',MyCoachCategoryUser::ROLE_ADMINISTRATOR => 'LABEL_ADMINISTRATOR',];} else {$roles = [MyCoachCategoryUser::ROLE_EDITOR => 'LABEL_EDITOR',MyCoachCategoryUser::ROLE_ADMINISTRATOR => 'LABEL_ADMINISTRATOR',];}$jobs_description = [];$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$myCoachCategoryJobDescriptionMapper = MyCoachCategoryJobDescriptionMapper::getInstance($this->adapter);$records = $myCoachCategoryJobDescriptionMapper->fetchAllByCategoryId($myCoachCategory->id);foreach($records as $record){$jobDescription = $jobDescriptionMapper->fetchOne($record->job_description_id);array_push($jobs_description, $jobDescription->uuid);}return new JsonModel(['success' => true,'data' => ['total' => $paginator->getTotalItemCount(),'items' => $items,'link_add' => $allowAdd ? $this->url()->fromRoute('my-coach/categories/users/add', ['id' => $myCoachCategory->uuid ] ) : '','link_upload' => $allowUpload ? $this->url()->fromRoute('my-coach/categories/users/upload', ['id' => $myCoachCategory->uuid ] ) : '','roles' => $roles,'link_jobs_description' => $allowJobsDescription ? $this->url()->fromRoute('my-coach/categories/users/jobs-description', ['id' => $myCoachCategory->uuid ] ) : '','jobs_description' => $jobs_description,]]);} else {$jobDescriptionIdBoss = 0;$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$jobsDescription = $this->recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $jobDescriptionIdBoss);$form = new MyCoachCategoryUserForm($this->adapter, $currentCompany->id, MyCoachCategory::PRIVACY_COMPANY);$formFilter = new MyCoachCategoryUserDataForm($this->adapter, $currentCompany->id);$this->layout()->setTemplate('layout/layout-backend');$viewModel = new ViewModel();$viewModel->setTemplate('leaders-linked/my-coach-category-users/index.phtml');$viewModel->setVariables(['form' => $form,'formFilter' => $formFilter,'jobsDescription' => $jobsDescription,'companyName' => $currentCompany->name,]);return $viewModel;}} else {return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}}/**** @param User $currentUser* @param Company $currentCompany* @param JobDescriptionMapper $jobDescriptionMapper* @param int $jobDescriptionIdBoss* @return array*/private function recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $jobDescriptionIdBoss){$items = [];$records = $jobDescriptionMapper->fetchAllByCompanyIdAndJobDescriptionIdBoss($currentCompany->id, $jobDescriptionIdBoss);foreach($records as $record){array_push($items, ['uuid' => $record->uuid,'name' => $record->name,'children' => $this->recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $record->id),]);}return $items;}public function addAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentCompany = $currentUserPlugin->getCompany();$currentUser = $currentUserPlugin->getUser();$request = $this->getRequest();if($request->isPost()) {$category_uuid = Functions::sanitizeFilterString($this->params()->fromRoute('id'));$myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);$myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_uuid);if(!$myCoachCategory) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND']);}if($myCoachCategory->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY']);}$dataPost = $request->getPost()->toArray();$form = new MyCoachCategoryUserForm($this->adapter, $currentCompany->id, $myCoachCategory->privacy);$form->setData($dataPost);if($form->isValid()) {$dataPost = (array) $form->getData();$userMapper = UserMapper::getInstance($this->adapter);$user = $userMapper->fetchOneByUuid($dataPost['user_id']);$myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);$myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);if($myCoachCategoryUser) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_USER_ALREADY_FOUND']);}$myCoachCategoryUser = new MyCoachCategoryUser();$myCoachCategoryUser->category_id = $myCoachCategory->id;$myCoachCategoryUser->user_id = $user->id;$myCoachCategoryUser->role = $dataPost['role'];$myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);if($myCoachCategoryUserMapper->insert($myCoachCategoryUser)) {$this->logger->info('Se agrego el usuario ' . $user->first_name . ' ' . $user->last_name . ' (' . $user->email . ') la categoria ' . $myCoachCategory->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_ADDED'];} else {$data = ['success' => false,'data' => $myCoachCategoryUserMapper->getError()];}return new JsonModel($data);} else {$messages = [];$form_messages = (array) $form->getMessages();foreach ($form_messages as $fieldname => $field_messages) {$messages[$fieldname] = array_values($field_messages);}return new JsonModel(['success' => false,'data' => $messages]);}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}public function editAction(){$request = $this->getRequest();$currentUserPlugin = $this->plugin('currentUserPlugin');$currentCompany = $currentUserPlugin->getCompany();$currentUser = $currentUserPlugin->getUser();$request = $this->getRequest();$uuid = $this->params()->fromRoute('id');$user_uuid = $this->params()->fromRoute('user_id');$myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);$myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);if(!$myCoachCategory) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND']);}if($myCoachCategory->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY']);}$userMapper = UserMapper::getInstance($this->adapter);$user = $userMapper->fetchOneByUuid($user_uuid);if(!$user) {return new JsonModel(['success' => false,'data' => 'ERROR_USER_NOT_FOUND']);}$myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);$myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);if(!$myCoachCategoryUser) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_USER_NOT_FOUND']);}if ($request->isPost()) {$dataPost = $request->getPost()->toArray();$form = new MyCoachCategoryUserForm($this->adapter, $currentCompany->id, $myCoachCategory->privacy);$form->setData($dataPost);if ($form->isValid()) {$dataPost = (array) $form->getData();$myCoachCategoryUser->role = $dataPost['role'];if($myCoachCategoryUserMapper->update($myCoachCategoryUser)) {$this->logger->info('Se actualizo el usuario ' . $user->first_name . ' ' . $user->last_name . ' (' . $user->email . ') la categoria ' . $myCoachCategory->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_UPDATED'];} else {$data = ['success' => false,'data' => $myCoachCategoryUserMapper->getError()];}return new JsonModel($data);} else {$messages = [];$form_messages = (array) $form->getMessages();foreach ($form_messages as $fieldname => $field_messages) {$messages[$fieldname] = array_values($field_messages);}return new JsonModel(['success' => false,'data' => $messages]);}} else if ($request->isGet()) {$data = ['success' => true,'data' => ['user_id' => $user->uuid,'role' => $myCoachCategoryUser->role,]];return new JsonModel($data);}$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}public function deleteAction(){$request = $this->getRequest();$currentUserPlugin = $this->plugin('currentUserPlugin');$currentCompany = $currentUserPlugin->getCompany();$currentUser = $currentUserPlugin->getUser();$request = $this->getRequest();$uuid = $this->params()->fromRoute('id');$user_id = $this->params()->fromRoute('user_id');$myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);$myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);if(!$myCoachCategory) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND']);}if($myCoachCategory->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY']);}$userMapper = UserMapper::getInstance($this->adapter);$user = $userMapper->fetchOneByUuid($user_id);if(!$user) {return new JsonModel(['success' => false,'data' => 'ERROR_USER_NOT_FOUND']);}$myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);$myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);if(!$myCoachCategoryUser) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_USER_NOT_FOUND']);}if ($request->isPost()) {if ($myCoachCategoryUserMapper->deleteOneByCategoryIdAndUserId($myCoachCategory->id, $user->id)) {$this->logger->info('Se borro el usuario ' . $user->first_name . ' ' . $user->last_name . ' (' . $user->email . ') la categoria ' . $myCoachCategory->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_DELETED'];} else {$data = ['success' => false,'data' => $myCoachCategoryUserMapper->getError()];}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];}return new JsonModel($data);}public function jobsDescriptionAction(){$request = $this->getRequest();$currentUserPlugin = $this->plugin('currentUserPlugin');$currentCompany = $currentUserPlugin->getCompany();$currentUser = $currentUserPlugin->getUser();$request = $this->getRequest();$uuid = $this->params()->fromRoute('id');$myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);$myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);if(!$myCoachCategory) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND']);}if($myCoachCategory->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY']);}if ($request->isPost()) {$myCoachCategoryJobDescriptionMapper = MyCoachCategoryJobDescriptionMapper::getInstance($this->adapter);$myCoachCategoryJobDescriptionMapper->deleteAllByCategoryId($myCoachCategory->id);$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$jobs_description_uuid = $this->params()->fromPost('job_description_id');if(!empty($jobs_description_uuid)) {foreach($jobs_description_uuid as $job_description_uuid){$jobDescription = $jobDescriptionMapper->fetchOneByUuid($job_description_uuid);if($jobDescription && $jobDescription->company_id == $currentCompany->id) {$myCoachCategoryJobDescription = new MyCoachCategoryJobDescription();$myCoachCategoryJobDescription->category_id = $myCoachCategory->id;$myCoachCategoryJobDescription->job_description_id = $jobDescription->id;$myCoachCategoryJobDescriptionMapper->insert($myCoachCategoryJobDescription);}}}$data = ['success' => true,'data' => 'LABEL_RECORD_UPDATED'];} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];}return new JsonModel($data);}}