Rev 12327 | 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\CreateFeedForm;use LeadersLinked\Library\Functions;use LeadersLinked\Mapper\UserMapper;use LeadersLinked\Mapper\HighPerformanceTeamsGroupsMapper;use LeadersLinked\Mapper\CompanyMapper;use LeadersLinked\Mapper\TopicMapper;use LeadersLinked\Model\Feed;use LeadersLinked\Mapper\FeedMapper;use LeadersLinked\Model\HighPerformanceTeamsGroupsMembers;use LeadersLinked\Form\HighPerformanceTeamsGroupsMembersForm;use LeadersLinked\Mapper\HighPerformanceTeamsGroupsMembersMapper;class HighPerformanceTeamsGroupsViewForoArticlesController 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();$currentNetworkPlugin = $this->plugin('currentNetworkPlugin');$network = $currentNetworkPlugin->getNetwork();$group_uuid = $this->params()->fromRoute('group_id');$category_uuid = $this->params()->fromRoute('category_id');$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(!$group_uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}if(!$category_uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$highPerformanceTeamsGroups = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($group_uuid);$this->layout()->setTemplate('layout/layout-backend');$viewModel = new ViewModel();if (!$highPerformanceTeamsGroups) {$viewModel->setTemplate('leaders-linked/no-access/index.phtml');return $viewModel;}if($highPerformanceTeamsGroups->status != HighPerformanceTeamsGroups::STATUS_ACTIVE) {$viewModel->setTemplate('leaders-linked/no-access/index.phtml');return $viewModel;}$highPerformanceTeamsGroupsMembersMapper = HighPerformanceTeamsGroupsMembersMapper::getInstance($this->adapter);$highPerformanceTeamsGroupsMember = $highPerformanceTeamsGroupsMembersMapper->fetchOneByGroupIdAndUserId($highPerformanceTeamsGroups->id, $currentUser->id);if(!$highPerformanceTeamsGroupsMember) {$viewModel->setTemplate('leaders-linked/no-access/index.phtml');return $viewModel;}if(!($highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ACCEPTED || $highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ADDED_BY_ADMIN) ){$viewModel->setTemplate('leaders-linked/no-access/index.phtml');return $viewModel;}$topicMapper = TopicMapper::getInstance($this->adapter);$topic = $topicMapper->fetchOneByUuidAndGroupId($category_uuid,$highPerformanceTeamsGroups->id);if(!$topic){$viewModel->setTemplate('leaders-linked/no-access/index.phtml');return $viewModel;}if($isJson) {$acl = $this->getEvent()->getViewModel()->getVariable('acl');$allowEdit = $acl->isAllowed($currentUser->usertype_id, 'high-performance-teams/groups/view/foro/categories/articles/edit');$allowDelete = $acl->isAllowed($currentUser->usertype_id,'high-performance-teams/groups/view/foro/categories/articles/delete');$allowView = $acl->isAllowed($currentUser->usertype_id,'high-performance-teams/groups/view/foro/categories/articles/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', 'added_on'];$order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'added_on';if(!in_array($order_direction, ['ASC', 'DESC'])) {$order_direction = 'DESC';}$feedMapper = FeedMapper::getInstance($this->adapter);$paginator = $feedMapper->fetchAllDataTableForo($search, $page, $records_x_page, $order_field, $order_direction, $topic->id);$items = [];$records = $paginator->getCurrentItems();foreach($records as $record){$userMapper = UserMapper::getInstance($this->adapter);$user = $userMapper->fetchOne($record->user_id);if($record->user_id!=$currentUser->id){$contentAllowDelete=$allowDelete;$contentAllowEdit=$allowEdit;$allowDelete=false;$allowEdit=false;}if($highPerformanceTeamsGroupsMember->type!=HighPerformanceTeamsGroupsMembers::TYPE_USER){$allowDelete=true;}$dt = \DateTime::createFromFormat('Y-m-d H:i:s', $record->added_on);$item = ['title' => $record->title,'author' => ['user_name' => $user->first_name . ' ' . $user->last_name,'user_url' => 'https://'. $network->main_hostname . '/profile/view/' . $user->uuid,'user_image' => $this->url()->fromRoute('storage', ['code' => $user->uuid, 'type' => 'user', 'filename' => $user->image]),],'added_on'=> $dt->format('d/m/Y'),'actions' => ['link_edit' => $allowEdit ? $this->url()->fromRoute('high-performance-teams/groups/view/foro/categories/articles/edit', ['group_id' => $group_uuid,'category_id' => $category_uuid, 'article_id' => $record->uuid]) : '','link_delete' => $allowDelete ? $this->url()->fromRoute('high-performance-teams/groups/view/foro/categories/articles/delete', ['group_id' => $group_uuid,'category_id' => $category_uuid, 'article_id' => $record->uuid]) : '','link_view' => $allowView ? $this->url()->fromRoute('high-performance-teams/groups/view/foro/categories/articles/view', ['group_id' => $group_uuid,'category_id' => $category_uuid, 'article_id' => $record->uuid]) : '',]];if($record->user_id!=$currentUser->id){$allowDelete=$contentAllowDelete;$allowEdit=$contentAllowEdit;}array_push($items, $item);}return new JsonModel(['success' => true,'data' => ['items' => $items,'total' => $paginator->getTotalItemCount(),]]);} else {$formAdd = new CreateFeedForm($this->adapter);$viewModel->setTemplate('leaders-linked/high-performance-teams-groups-view-foro-articles/index.phtml');$viewModel->setVariables(['formAdd' => $formAdd,'group_uuid'=>$group_uuid,'group_title'=>$highPerformanceTeamsGroups->title,'category_uuid'=>$category_uuid,'topic_title'=>$topic->title]);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();$group_uuid = $this->params()->fromRoute('group_id');$category_uuid = $this->params()->fromRoute('category_id');$request = $this->getRequest();if($request->isPost()) {$dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());$form = new CreateFeedForm($this->adapter);$form->setData($dataPost);if($form->isValid()) {$hydrator = new ObjectPropertyHydrator();$feed = new Feed();$hydrator->hydrate($dataPost, $feed);$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$highPerformanceTeamsGroups = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($group_uuid);if (!$highPerformanceTeamsGroups) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if($highPerformanceTeamsGroups->status != HighPerformanceTeamsGroups::STATUS_ACTIVE) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}$highPerformanceTeamsGroupsMembersMapper = HighPerformanceTeamsGroupsMembersMapper::getInstance($this->adapter);$highPerformanceTeamsGroupsMember = $highPerformanceTeamsGroupsMembersMapper->fetchOneByGroupIdAndUserId($highPerformanceTeamsGroups->id, $currentUser->id);if(!$highPerformanceTeamsGroupsMember) {return new JsonModel(['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND']);}$highPerformanceTeamsGroupsMemberMapper = HighPerformanceTeamsGroupsMembersMapper::getInstance($this->adapter);$highPerformanceTeamsGroupsMember = $highPerformanceTeamsGroupsMemberMapper->fetchOneByGroupIdAndUserId($highPerformanceTeamsGroups->id, $currentUser->id);if($highPerformanceTeamsGroupsMember) {if($highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ACCEPTED || $highPerformanceTeamsGroupsMember->status == HighPerformanceTeamsGroupsMembers::STATUS_ADDED_BY_ADMIN ){$id = $highPerformanceTeamsGroups->id;}else{return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}} else {return new JsonModel(['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND']);}$topicMapper = TopicMapper::getInstance($this->adapter);$topic = $topicMapper->fetchOneByUuidAndGroupId($category_uuid,$highPerformanceTeamsGroups->id);if($topic){$feed->topic_id = $topic->id;}else{return new JsonModel(['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND']);}$feed->company_id = $currentCompany->id;$feed->group_id = null;$feed->high_performance_group_id = $id;$feed->user_id = $currentUser->id;$feed->type = Feed::TYPE_HPTG;$feed->posted_or_shared = Feed::POSTED;$feed->shared_with = Feed::SHARE_WITH_CONNECTIONS;$feed->total_comments = 0;$feed->total_shared = 0;$feedMapper = FeedMapper::getInstance($this->adapter);$result = $feedMapper->insert($feed);if($result) {$this->logger->info('Se agrego el articulo del foro con el titulo ' . $feed->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$response = ['success' => true,'data' => 'LABEL_RECORD_ADDED'];} else {$response = ['success' => false,'data' => $feedMapper->getError()];}} else {$messages = [];$form_messages = (array) $form->getMessages();foreach($form_messages as $fieldname => $field_messages){$messages[$fieldname] = array_values($field_messages);}$response = ['success' => false,'data' => $messages];}} else {$response = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];}return new JsonModel($response);}public function editAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();$group_uuid = $this->params()->fromRoute('group_id');$category_uuid = $this->params()->fromRoute('category_id');$article_uuid = $this->params()->fromRoute('article_id');if(!$group_uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}if(!$category_uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}if(!$article_uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$highPerformanceTeamsGroups = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($group_uuid);if (!$highPerformanceTeamsGroups) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if($highPerformanceTeamsGroups->status != HighPerformanceTeamsGroups::STATUS_ACTIVE) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}$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->user_id!=$currentUser->id){return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}$feedMapper = FeedMapper::getInstance($this->adapter);$feed = $feedMapper->fetchOneByUuid($article_uuid);if($request->isPost()) {$form = new CreateFeedForm($this->adapter);$dataPost = $request->getPost()->toArray();$form->setData($dataPost);if($form->isValid()) {$dataPost = (array) $form->getData();$hydrator = new ObjectPropertyHydrator();$hydrator->hydrate($dataPost, $feed);$result = $feedMapper->update($feed);if($result) {$this->logger->info('Se actualizo el articulo del foro con el titulo ' . $feed->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_UPDATED'];} else {$data = ['success' => false,'data' => $feedMapper->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($feed)];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');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$group_uuid = $this->params()->fromRoute('group_id');$request = $this->getRequest();$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$highPerformanceTeamsGroups = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($group_uuid);if (!$highPerformanceTeamsGroups) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if($highPerformanceTeamsGroups->status != HighPerformanceTeamsGroups::STATUS_ACTIVE) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}$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->user_id!=$currentUser->id){if($highPerformanceTeamsGroupsMember->type==HighPerformanceTeamsGroupsMembers::TYPE_USER){return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}}if($request->isPost()) {$article_uuid = $this->params()->fromRoute('article_id');$feedMapper = FeedMapper::getInstance($this->adapter);$feed = $feedMapper->fetchOneByUuid($article_uuid);if(!$feed) {$response = ['success' => false,'data' => 'ERROR_POST_NOT_FOUND'];return new JsonModel($response);}$feedMapper = FeedMapper::getInstance($this->adapter);$feed->status = Feed::STATUS_DELETED;if($feedMapper->update($feed)) {$response = ['success' => true,'data' => 'LABEL_FEED_WAS_DELETED'];} else {$response = ['success' => false,'data' => $feedMapper->getError()];}return new JsonModel($response);} else {$response = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];}return new JsonModel($response);}}