Rev 11682 | AutorÃa | Ultima modificación | Ver Log |
<?phpdeclare(strict_types=1);namespace LeadersLinked\Controller;use Laminas\Authentication\AuthenticationService;use Laminas\Authentication\Result as AuthResult;use Laminas\Db\Adapter\AdapterInterface;use Laminas\Cache\Storage\Adapter\AbstractAdapter;use Laminas\Mvc\Controller\AbstractActionController;use Laminas\Mvc\I18n\Translator;use Laminas\Log\LoggerInterface;use Laminas\View\Model\ViewModel;use Laminas\View\Model\JsonModel;use LeadersLinked\Model\HighPerformanceTeamsGroups;use LeadersLinked\Hydrator\ObjectPropertyHydrator;use LeadersLinked\Form\HighPerformanceTeamsGroupsForm;use LeadersLinked\Library\Functions;use LeadersLinked\Mapper\UserMapper;use LeadersLinked\Mapper\HighPerformanceTeamsGroupsMapper;use LeadersLinked\Mapper\CompanyMapper;use LeadersLinked\Mapper\CompanyUserMapper;use LeadersLinked\Model\ChatGroupUser;use LeadersLinked\Model\ChatGroup;use LeadersLinked\Model\HighPerformanceTeamsGroupsMembers;use LeadersLinked\Form\HighPerformanceTeamsGroupsMembersForm;use LeadersLinked\Mapper\ChatGroupMapper;use LeadersLinked\Mapper\HighPerformanceTeamsGroupsMembersMapper;use LeadersLinked\Mapper\ChatGroupUserMapper;use LeadersLinked\Mapper\ChatGroupUserMessageMapper;use LeadersLinked\Mapper\ChatGroupMessageMapper;class HighPerformanceTeamsGroupsController extends AbstractActionController{/**** @var AdapterInterface*/private $adapter;/**** @var AbstractAdapter*/private $cache;/**** @var LoggerInterface*/private $logger;/**** @var array*/private $config;/**** @param AdapterInterface $adapter* @param AbstractAdapter $cache* @param LoggerInterface $logger* @param array $config*/public function __construct($adapter, $cache , $logger, $config){$this->adapter = $adapter;$this->cache = $cache;$this->logger = $logger;$this->config = $config;}public function indexAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$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');}}}if($isJson) {$acl = $this->getEvent()->getViewModel()->getVariable('acl');$allowEdit = $acl->isAllowed($currentUser->usertype_id, 'high-performance-teams/groups/edit');$allowDelete = $acl->isAllowed($currentUser->usertype_id,'high-performance-teams/groups/delete');$allowView = $acl->isAllowed($currentUser->usertype_id,'high-performance-teams/groups/view');$search = $this->params()->fromQuery('search', []);$search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);$records_x_page = intval($this->params()->fromQuery('length', 10), 10);$page = (intval($this->params()->fromQuery('start', 1), 10)/$records_x_page)+1;$order = $this->params()->fromQuery('order', []);$order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);$order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var( $order[0]['dir'], FILTER_SANITIZE_STRING));$fields = ['title', 'date'];$order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'title';if(!in_array($order_direction, ['ASC', 'DESC'])) {$order_direction = 'ASC';}$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$paginator = $highPerformanceTeamsGroupsMapper->fetchAllDataTableInnerJoinMember($search, $page, $records_x_page, $order_field, $order_direction, $currentUser->id);$items = [];$records = $paginator->getCurrentItems();$highPerformanceTeamsGroupsMembersMapper = HighPerformanceTeamsGroupsMembersMapper::getInstance($this->adapter);foreach($records as $record){$highPerformanceTeamsGroupsMember = $highPerformanceTeamsGroupsMembersMapper->fetchOneByGroupIdAndUserId($record->id, $currentUser->id);if($highPerformanceTeamsGroupsMember) {if(($highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ACCEPTED || $highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ADDED_BY_ADMIN) ){$contentAllowDelete=$allowDelete;$contentAllowEdit=$allowEdit;if($highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_MODERATOR||$highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_USER){$allowDelete=false;$allowEdit=false;}if($highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_ADMINISTRATOR){$allowDelete=false;}$item = ['title' => $record->title,'description' => $record->description,'status'=> $record->status,'actions' => ['link_edit' => $allowEdit ? $this->url()->fromRoute('high-performance-teams/groups/edit', ['group_id' => $record->uuid]) : '','link_delete' => $allowDelete ? $this->url()->fromRoute('high-performance-teams/groups/delete', ['group_id' => $record->uuid]) : '','link_view' => $allowView ? $this->url()->fromRoute('high-performance-teams/groups/view', ['group_id' => $record->uuid]) : '',]];array_push($items, $item);$allowDelete=$contentAllowDelete;$allowEdit=$contentAllowEdit;}}}return new JsonModel(['success' => true,'data' => ['items' => $items,'total' => $paginator->getTotalItemCount(),]]);} else {$formAdd = new HighPerformanceTeamsGroupsForm($this->adapter, $currentCompany->id);$this->layout()->setTemplate('layout/layout-backend');$viewModel = new ViewModel();$viewModel->setTemplate('leaders-linked/high-performance-teams-groups/index.phtml');$viewModel->setVariables(['formAdd' => $formAdd,]);return $viewModel ;}} else {return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}}public function addAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();if($request->isPost()) {$form = new HighPerformanceTeamsGroupsForm($this->adapter, $currentCompany->id);$dataPost = $request->getPost()->toArray();$form->setData($dataPost);if($form->isValid()) {$dataPost = (array) $form->getData();$dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : HighPerformanceTeamsGroups::STATUS_INACTIVE;$dataPost['company_id']=$currentCompany->id;$hydrator = new ObjectPropertyHydrator();$highPerformanceTeamsGroups = new HighPerformanceTeamsGroups();$hydrator->hydrate($dataPost, $highPerformanceTeamsGroups);$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$result = $highPerformanceTeamsGroupsMapper->insert($highPerformanceTeamsGroups);if($result) {$highPerformanceTeamsGroupsMember = new HighPerformanceTeamsGroupsMembers();$highPerformanceTeamsGroupsMember->group_id = $highPerformanceTeamsGroups->id;$highPerformanceTeamsGroupsMember->user_id = $currentUser->id;$highPerformanceTeamsGroupsMember->status = HighPerformanceTeamsGroupsMembers::STATUS_ADDED_BY_ADMIN;$highPerformanceTeamsGroupsMember->type = HighPerformanceTeamsGroupsMembers::TYPE_CREATOR;$highPerformanceTeamsGroupsMemberMapper = HighPerformanceTeamsGroupsMembersMapper::getInstance($this->adapter);$highPerformanceTeamsGroupsMemberMapper->insert($highPerformanceTeamsGroupsMember);$chatGroup = new ChatGroup();$chatGroup->name = $highPerformanceTeamsGroups->title;$chatGroup->high_performance_team_group_id =$highPerformanceTeamsGroups->id;$chatGroupMapper = ChatGroupMapper::getInstance($this->adapter);$result = $chatGroupMapper->insert($chatGroup);if ($result) {$chatGroup = $chatGroupMapper->fetchOne($chatGroup->id);$chatGroupUser = new ChatGroupUser();$chatGroupUser->group_id = $chatGroup->id;$chatGroupUser->user_id = $currentUser->id;$chatGroupUser->owner = ChatGroupUser::OWNER_YES;$chatGroupUserMapper = ChatGroupUserMapper::getInstance($this->adapter);$result = $chatGroupUserMapper->insert($chatGroupUser);if($result) {$fullpath_chat = $this->config['leaderslinked.fullpath.chat'];$dirpath = $fullpath_chat . $chatGroup->uuid;if (! file_exists($dirpath)) {mkdir($dirpath, 0777, true);chmod($dirpath, 0777);}} else {$response = ['success' => false,'data' => $chatGroupUserMapper->getError(),];return new JsonModel($response);}} else {$response = ['success' => false,'data' => $chatGroupMapper->getError(),];return new JsonModel($response);}$this->logger->info('Se agrego el grupo de alto rendimiento ' . $highPerformanceTeamsGroups->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_ADDED'];} else {$data = ['success' => false,'data' => $highPerformanceTeamsGroupsMapper->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()) {$companyUserMapper = CompanyUserMapper::getInstance($this->adapter);$userMapper = UserMapper::getInstance($this->adapter);$datosCompanyUser = $companyUserMapper->fetchAllByCompanyId($currentCompany->id);$users=[];foreach($datosCompanyUser as $record){$datosUser = $userMapper->fetchOne($record->user_id);$user=['uuid'=>$datosUser->uuid,'email'=>$datosUser->email,'first_name'=>$datosUser->first_name,'last_name'=>$datosUser->last_name,];array_push($users, $user);}return new JsonModel(['success' => true,'data' => $users]);} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}public function editAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();$uuid = $this->params()->fromRoute('group_id');if(!$uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$highPerformanceTeamsGroups = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($uuid);if (!$highPerformanceTeamsGroups) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}$highPerformanceTeamsGroupsMembersMapper = HighPerformanceTeamsGroupsMembersMapper::getInstance($this->adapter);$highPerformanceTeamsGroupsMember = $highPerformanceTeamsGroupsMembersMapper->fetchOneByGroupIdAndUserId($highPerformanceTeamsGroups->id, $currentUser->id);if(!$highPerformanceTeamsGroupsMember) {return new JsonModel(['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND']);}if(!($highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ACCEPTED || $highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ADDED_BY_ADMIN) ){return new JsonModel(['success' => false,'data' => 'ERROR_YOU_DO_NOT_HAVE_ACCESS']);}if($highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_MODERATOR||$highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_USER){return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}if($request->isPost()) {$form = new HighPerformanceTeamsGroupsForm($this->adapter, $currentCompany->id);$dataPost = $request->getPost()->toArray();$dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : HighPerformanceTeamsGroups::STATUS_INACTIVE;$form->setData($dataPost);if($form->isValid()) {$dataPost = (array) $form->getData();$hydrator = new ObjectPropertyHydrator();$hydrator->hydrate($dataPost, $highPerformanceTeamsGroups);$result = $highPerformanceTeamsGroupsMapper->update($highPerformanceTeamsGroups);if($result) {$chatGroup = new ChatGroup();$chatGroup->name = $highPerformanceTeamsGroups->title;$chatGroup->high_performance_team_group_id=$highPerformanceTeamsGroups->id;$chatGroupMapper = ChatGroupMapper::getInstance($this->adapter);$result = $chatGroupMapper->update($chatGroup);$this->logger->info('Se actualizo el grupo de alto rendimiento ' . $highPerformanceTeamsGroups->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_UPDATED'];} else {$data = ['success' => false,'data' => $highPerformanceTeamsGroupsMapper->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()) {$hydrator = new ObjectPropertyHydrator();$data = ['success' => true,'data' => $hydrator->extract($highPerformanceTeamsGroups)];return new JsonModel($data);} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}public function deleteAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentCompany = $currentUserPlugin->getCompany();$currentUser = $currentUserPlugin->getUser();$request = $this->getRequest();$uuid = $this->params()->fromRoute('group_id');if (!$uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$highPerformanceTeamsGroups = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($uuid);if (!$highPerformanceTeamsGroups) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}$highPerformanceTeamsGroupsMembersMapper = HighPerformanceTeamsGroupsMembersMapper::getInstance($this->adapter);$highPerformanceTeamsGroupsMember = $highPerformanceTeamsGroupsMembersMapper->fetchOneByGroupIdAndUserId($highPerformanceTeamsGroups->id, $currentUser->id);if(!$highPerformanceTeamsGroupsMember) {return new JsonModel(['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND']);}if(!($highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ACCEPTED || $highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ADDED_BY_ADMIN) ){return new JsonModel(['success' => false,'data' => 'ERROR_YOU_DO_NOT_HAVE_ACCESS']);}if($highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_ADMINISTRATOR||$highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_MODERATOR||$highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_USER){return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}if ($request->isPost()) {$chatGroupMapper = ChatGroupMapper::getInstance($this->adapter);$chatGroup = $chatGroupMapper->fetchOneHptg($highPerformanceTeamsGroups->id);if(!$chatGroup) {return new JsonModel(['success' => false,'data' => 'ERROR_GROUP_NOT_FOUND']);}$chatGroupUserMapper = ChatGroupUserMapper::getInstance($this->adapter);$chatGroupOwner = $chatGroupUserMapper->fetchOwnerByGroupId($chatGroup->id);if($chatGroupOwner->user_id != $currentUser->id) {return new JsonModel(['success' => false,'data' => 'ERROR_CHAT_GROUP_YOU_ARE_NOT_OWNER']);}$chatGroupUserMessageMapper = ChatGroupUserMessageMapper::getInstance($this->adapter);$result = $chatGroupUserMessageMapper->deleteAllByGroupId($chatGroup->id);if(!$result) {return new JsonModel(['success' => false,'data' => $chatGroupUserMessageMapper->getError()]);}$chatGroupMessageMapper = ChatGroupMessageMapper::getInstance($this->adapter);$result = $chatGroupMessageMapper->deleteAllByGroupId($chatGroup->id);if(!$result) {return new JsonModel(['success' => false,'data' => $chatGroupMessageMapper->getError()]);}$result = $chatGroupUserMapper->deleteAllByGroupId($chatGroup->id);if(!$result) {return new JsonModel(['success' => false,'data' => $chatGroupUserMapper->getError()]);}$chatGroupMapper->deleteByGroupId($chatGroup->id);if(!$result) {return new JsonModel(['success' => false,'data' => $chatGroupMapper->getError()]);}$fullpath_chat = $this->config['leaderslinked.fullpath.chat'];$dirpath = $fullpath_chat . $chatGroup->uuid;Functions::rmDirRecursive($dirpath);$result = $highPerformanceTeamsGroupsMapper->delete($highPerformanceTeamsGroups->id);if ($result) {$this->logger->info('Se borro el grupo de alto rendimiento ' . $highPerformanceTeamsGroups->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_DELETED'];} else {$data = ['success' => false,'data' => $highPerformanceTeamsGroupsMapper->getError()];return new JsonModel($data);}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}}