Rev 16822 | Rev 16979 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |
<?php/**** Controlador: Mis Perfiles**/declare(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\Mapper\CompanyMapper;use LeadersLinked\Mapper\CompanyUserMapper;use LeadersLinked\Form\CreateFeedForm;use LeadersLinked\Form\CommentForm;use LeadersLinked\Form\CommentAnswerForm;use LeadersLinked\Model\Comment;use LeadersLinked\Mapper\CommentMapper;use LeadersLinked\Mapper\FeedMapper;use LeadersLinked\Mapper\GroupMapper;use LeadersLinked\Model\Feed;use LeadersLinked\Mapper\QueryMapper;use LeadersLinked\Hydrator\ObjectPropertyHydrator;use LeadersLinked\Library\Image;use LeadersLinked\Model\VideoConvert;use LeadersLinked\Mapper\VideoConvertMapper;use LeadersLinked\Mapper\LikeMapper;use Laminas\Paginator\Adapter\DbSelect;use Laminas\Paginator\Paginator;use LeadersLinked\Mapper\UserMapper;use LeadersLinked\Library\Functions;use LeadersLinked\Model\Company;use LeadersLinked\Mapper\TopicMapper;use LeadersLinked\Model\HighPerformanceTeamsGroupsMembers;use LeadersLinked\Model\HighPerformanceTeamsGroups;use LeadersLinked\Mapper\HighPerformanceTeamsGroupsMembersMapper;use LeadersLinked\Mapper\HighPerformanceTeamsGroupsMapper;use LeadersLinked\Mapper\FastSurveyMapper;use LeadersLinked\Model\FastSurvey;use LeadersLinked\Form\FastSurvey\FastSurveyForm;class FeedController 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;}/**** Generación del listado de perfiles* {@inheritDoc}* @see \Laminas\Mvc\Controller\AbstractActionController::indexAction()*/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');}}}$formFeed = new CreateFeedForm($this->adapter);$this->layout()->setTemplate('layout/layout-backend');$viewModel = new ViewModel();$viewModel->setTemplate('leaders-linked/feeds/index.phtml');$viewModel->setVariables(['formFeed' => $formFeed,]);return $viewModel;} else {return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}}public function commentAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$id = $this->params()->fromRoute('id');$request = $this->getRequest();if ($request->isPost()) {$feedMapper = FeedMapper::getInstance($this->adapter);$feed = $feedMapper->fetchOneByUuidAndNetworkId($id, $currentUser->network_id);if (!$feed) {$response = ['success' => false,'data' => 'ERROR_POST_NOT_FOUND'];return new JsonModel($response);}if ($feed->company_id != $currentCompany->id) {$response = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($response);}$dataPost = $request->getPost()->toArray();$form = new CommentForm();$form->setData($dataPost);if ($form->isValid()) {$now = $feedMapper->getDatebaseNow();$companyUserMapper = CompanyUserMapper::getInstance($this->adapter);$owner = $companyUserMapper->fetchOwnerByCompanyId($currentCompany->id);$dataPost = (array) $form->getData();$comment = new Comment();$comment->comment = $dataPost['comment'];$comment->feed_id = $feed->id;$comment->network_id = $currentUser->network_id;if ($feed->type == 'hptg') {$comment->user_id = $currentUser->id;} else if ($feed->type == 'mytq') {$comment->user_id = $currentCompany->id;} else {$comment->user_id = $owner->user_id;}$commentMapper = CommentMapper::getInstance($this->adapter);if ($commentMapper->insert($comment)) {$total_comments = $commentMapper->fetchCountCommentByFeedId($comment->feed_id);$feed->total_comments = $total_comments;$feedMapper->update($feed);$response = ['success' => true,'data' => $this->renderComment($comment->id, $now),'total_comments' => $total_comments];return new JsonModel($response);} else {$response = ['success' => false,'data' => $commentMapper->getError()];return new JsonModel($response);}} else {$message = '';;$form_messages = (array) $form->getMessages();foreach ($form_messages as $fieldname => $field_messages) {foreach ($field_messages as $key => $value) {$message = $value;}}$response = ['success' => false,'data' => $message];return new JsonModel($response);}} else {$response = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($response);}}public function answerAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$id = $this->params()->fromRoute('id');$comment_uuid = $this->params()->fromRoute('comment');$request = $this->getRequest();if ($request->isPost()) {$feedMapper = FeedMapper::getInstance($this->adapter);$feed = $feedMapper->fetchOneByUuid($id);if (!$feed) {$response = ['success' => false,'data' => 'ERROR_POST_NOT_FOUND'];return new JsonModel($response);}if ($feed->company_id != $currentCompany->id) {$response = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($response);}$dataPost = $request->getPost()->toArray();$form = new CommentAnswerForm();$form->setData($dataPost);if ($form->isValid()) {$now = $feedMapper->getDatebaseNow();$companyUserMapper = CompanyUserMapper::getInstance($this->adapter);$owner = $companyUserMapper->fetchOwnerByCompanyId($currentCompany->id);$dataPost = (array) $form->getData();$answer = new Comment();$answer->comment = $dataPost['answer'];$answer->feed_id = $feed->id;if ($feed->type == 'hptg') {$answer->user_id = $currentUser->id;} else {$answer->user_id = $owner->user_id;}$commentMapper = CommentMapper::getInstance($this->adapter);$comment = $commentMapper->fetchOneByUuid($comment_uuid);$answer->parent_id = $comment->id;if ($commentMapper->insert($answer)) {$total_comments = $commentMapper->fetchCountCommentByFeedId($comment->feed_id);$feed->total_comments = $total_comments;$feedMapper->update($feed);$response = ['success' => true,'data' => $this->renderComment($answer->id, $now),'total_comments' => $total_comments];return new JsonModel($response);} else {$response = ['success' => false,'data' => $commentMapper->getError()];return new JsonModel($response);}} else {$message = '';;$form_messages = (array) $form->getMessages();foreach ($form_messages as $fieldname => $field_messages) {foreach ($field_messages as $key => $value) {$message = $value;}}$response = ['success' => false,'data' => $message];return new JsonModel($response);}} else {$response = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($response);}}public function commentDeleteAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();if ($request->isPost()) {$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$id = $this->params()->fromRoute('id');$comment = $this->params()->fromRoute('comment');$feedMapper = FeedMapper::getInstance($this->adapter);$feed = $feedMapper->fetchOneByUuidAndNetworkId($id, $currentUser->network_id);if (!$feed) {$response = ['success' => false,'data' => 'ERROR_POST_NOT_FOUND'];return new JsonModel($response);}if ($feed->company_id != $currentCompany->id) {$response = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($response);}$commentMapper = CommentMapper::getInstance($this->adapter);$comment = $commentMapper->fetchOneByUuid($comment);if ($comment && $comment->feed_id == $feed->id) {$comment->status = Comment::STATUS_DELETED;if ($commentMapper->update($comment)) {$total_comments = $commentMapper->fetchCountCommentByFeedId($comment->feed_id);$feed = $feedMapper->fetchOne($comment->feed_id);$feed->total_comments = $total_comments;$feedMapper->update($feed);$response = ['success' => true,'data' => ['message' => 'LABEL_COMMENT_WAS_DELETED','total_comments' => $total_comments]];} else {$response = ['success' => false,'data' => $commentMapper->getError()];}} else {$response = ['success' => false,'data' => 'ERROR_COMMENT_NOT_FOUND'];}} else {$response = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];}return new JsonModel($response);}public function deleteAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();if ($request->isPost()) {$id = $this->params()->fromRoute('id');$feedMapper = FeedMapper::getInstance($this->adapter);$feed = $feedMapper->fetchOneByUuidAndNetworkId($id, $currentUser->network_id);if (!$feed) {$response = ['success' => false,'data' => 'ERROR_POST_NOT_FOUND'];return new JsonModel($response);}if ($feed->company_id != $currentCompany->id) {$response = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];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);}public function addAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentNetworkPlugin = $this->plugin('currentNetworkPlugin');$currentNetwork = $currentNetworkPlugin->getNetwork();$currentCompany = $currentUserPlugin->getCompany();$myt_id = $this->params()->fromRoute('myt_id');$hptg_uuid = $this->params()->fromRoute('hptg_id');$request = $this->getRequest();if ($request->isPost()) {$dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());$feed_content_type = empty($dataPost['feed_content_type']) ? '' : $dataPost['feed_content_type'];if( $feed_content_type == Feed::FILE_TYPE_FAST_SURVEY) {$form = new FastSurveyForm();$form->setData($dataPost);if ($form->isValid()) {$dataPost = (array) $form->getData();$companyUserMapper = CompanyUserMapper::getInstance($this->adapter);$companyUser = $companyUserMapper->fetchOwnerByCompanyId($currentCompany->id);$now = $companyUserMapper->getDatebaseNow();$hydrator = new ObjectPropertyHydrator();$fastSurvey = new FastSurvey();$hydrator->hydrate($dataPost, $fastSurvey);$fastSurvey->network_id = $currentNetwork->id;$fastSurvey->company_id = $currentCompany->id;$fastSurvey->user_id = $companyUser->id;$fastSurvey->status = FastSurvey::STATUS_ACTIVE;$fastSurveyMapper = FastSurveyMapper::getInstance($this->adapter);$result = $fastSurveyMapper->insert($fastSurvey);if ($result) {$feed = new Feed();$feed->company_id = $currentCompany->id;$feed->network_id = $currentNetwork->id;$feed->user_id = $companyUser->id;$feed->fast_survey_id = $fastSurvey->id;$feed->type = Feed::TYPE_COMPANY;$feed->file_type = Feed::FILE_TYPE_FAST_SURVEY;$feed->posted_or_shared = Feed::POSTED;$feed->status = Feed::STATUS_PUBLISHED;$feed->title = '-';$feed->description = '-';$feed->total_comments = 0;$feed->total_shared = 0;$feed->shared_with = Feed::SHARE_WITH_CONNECTIONS;$feedMapper = FeedMapper::getInstance($this->adapter);$feedMapper->insert($feed);$this->logger->info('Se agrego la encuesta rápida : ' . $fastSurvey->question, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$response = ['success' => true,'data' => $this->renderFeed($feed->id, $now)];} else {$response = ['success' => false,'data' => $fastSurveyMapper->getError()];}return new JsonModel($response);} 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 {$form = new CreateFeedForm($this->adapter);$form->setData($dataPost);if ($form->isValid()) {$companyMapper = CompanyMapper::getInstance($this->adapter);$now = $companyMapper->getDatebaseNow();$company = $companyMapper->fetchOne($currentCompany->id);$companyUserMapper = CompanyUserMapper::getInstance($this->adapter);$owner = $companyUserMapper->fetchOwnerByCompanyId($company->id);$dataPost['priority'] = isset($dataPost['priority']) ? Feed::PRIORITY_URGENT : '';$hydrator = new ObjectPropertyHydrator();$feed = new Feed();$hydrator->hydrate($dataPost, $feed);if ($hptg_uuid) {$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$highPerformanceTeamsGroups = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($hptg_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']);}$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']);}$topic_uuid = $this->params()->fromRoute('topic_id');if ($topic_uuid) {$topicMapper = TopicMapper::getInstance($this->adapter);$topic = $topicMapper->fetchOneByUuid($topic_uuid);if ($topic) {$feed->topic_id = $topic->id;} else {return new JsonModel(['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND']);}}$feed->network_id = $currentUser->network_id;$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;} else if ($myt_id) {$feedMapper = FeedMapper::getInstance($this->adapter);$myt = $feedMapper->fetchOneByUuid($myt_id);$feed->network_id = $currentUser->network_id;$feed->company_id = $currentCompany->id;$feed->group_id = null;$feed->user_id = $owner->user_id;$feed->myt_id = $myt->id;$feed->related_feed = $myt->id;$feed->type = Feed::TYPE_MYT_ANSWER;$feed->posted_or_shared = Feed::POSTED;$feed->shared_with = Feed::SHARE_WITH_PUBLIC;} else {$feed->network_id = $currentUser->network_id;$feed->company_id = $currentCompany->id;$feed->group_id = null;$feed->user_id = $owner->user_id;$feed->type = Feed::TYPE_COMPANY;$feed->posted_or_shared = Feed::POSTED;$feed->shared_with = Feed::SHARE_WITH_CONNECTIONS;}$feed->total_comments = 0;$feed->total_shared = 0;$files = $this->getRequest()->getFiles()->toArray();$file_type = '';if (isset($files['file']) && empty($files['file']['error'])) {$feed_tmp_filename = $files['file']['tmp_name'];$feed_filename = $this->normalizeString($files['file']['name']);$mime_type = mime_content_type($feed_tmp_filename);if ($mime_type == 'image/jpg' || $mime_type == 'image/jpeg' || $mime_type == 'image/png') {$file_type = Feed::FILE_TYPE_IMAGE;} else if ($mime_type == 'video/quicktime' || $mime_type == 'video/webm' || $mime_type == 'video/mpeg' || $mime_type == 'video/mpg' || $mime_type == 'video/mp4') {$file_type = Feed::FILE_TYPE_VIDEO;} else if ($mime_type == 'application/pdf') {$file_type = Feed::FILE_TYPE_DOCUMENT;}}$feedMapper = FeedMapper::getInstance($this->adapter);$result = $feedMapper->insert($feed);if ($result) {$feed = $feedMapper->fetchOne($feed->id);if ($file_type == Feed::FILE_TYPE_DOCUMENT) {try {$target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;if (!file_exists($target_path)) {mkdir($target_path, 0755);}$full_filename = $target_path . DIRECTORY_SEPARATOR . $feed_filename;$result = move_uploaded_file($feed_tmp_filename, $full_filename);if ($result) {$feed->file_type = $file_type;$feed->file_name = basename($feed_filename);$feedMapper->update($feed);} else {error_log('no se pudo mover o renombrar el documento : ' . $feed_tmp_filename . ' al directorio : ' . $full_filename);}} catch (\Throwable $e) {error_log($e->getTraceAsString());}}if ($file_type == Feed::FILE_TYPE_IMAGE) {try {$target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;if (!file_exists($target_path)) {mkdir($target_path, 0755);}list($target_width, $target_height) = explode('x', $this->config['leaderslinked.image_sizes.feed_image_size']);$feed_filename = substr($feed_filename, 0, strrpos($feed_filename, '.')) . '.png';$crop_to_dimensions = false;if (Image::uploadImage($feed_tmp_filename, $target_path, $feed_filename, $target_width, $target_height, $crop_to_dimensions)) {$feed->file_type = $file_type;$feed->file_name = basename($feed_filename);$feedMapper->update($feed);}} catch (\Throwable $e) {error_log($e->getTraceAsString());}}if ($file_type == Feed::FILE_TYPE_VIDEO) {try {$target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;if (!file_exists($target_path)) {mkdir($target_path, 0755);}$full_filename = $target_path . DIRECTORY_SEPARATOR . $feed_filename;$result = move_uploaded_file($feed_tmp_filename, $full_filename);if ($result) {$size = $this->config['leaderslinked.image_sizes.feed_image_size'];$getFromSecound = 2;//extracción del cover$generateFileName = substr($feed_filename, 0, strrpos($feed_filename, '.'));$generateFile = $target_path . DIRECTORY_SEPARATOR . $generateFileName . '.png';$cmd = "/usr/bin/ffmpeg -i $full_filename -an -ss $getFromSecound -s $size $generateFile";exec($cmd);$feed->file_type = $file_type;$feed->file_name = basename($feed_filename);$feed->file_image_preview = basename($generateFile);$feedMapper->update($feed);$videoConvert = new VideoConvert();$videoConvert->filename = $full_filename;$videoConvert->type = VideoConvert::TYPE_FEED;$videoConvertMapper = VideoConvertMapper::getInstance($this->adapter);$videoConvertMapper->insert($videoConvert);} else {error_log('no se pudo mover o renombrar el documento : ' . $feed_tmp_filename . ' al directorio : ' . $full_filename);}} catch (\Throwable $e) {error_log($e->getTraceAsString());}}$response = ['success' => true,'data' => $this->renderFeed($feed->id, $now)];} 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 timelineAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();if ($request->isGet()) {$page = (int) $this->params()->fromQuery('page');$type = $this->params()->fromRoute('type');$topic_uuid = $this->params()->fromRoute('topic_id');$urgent = $this->params()->fromRoute('urgent');$myt_id = $this->params()->fromRoute('myt_id');$hptg_uuid = $this->params()->fromRoute('hptg_id');if ($hptg_uuid) {$highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);$now = $highPerformanceTeamsGroupsMapper->getDatebaseNow();$highPerformanceTeamsGroups = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($hptg_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']);}$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) {$queryMapper = QueryMapper::getInstance($this->adapter);$select = $queryMapper->getSql()->select(FeedMapper::_TABLE);$select->columns(['id']);$select->where->equalTo('status', Feed::STATUS_PUBLISHED);$select->where->equalTo('company_id', $currentCompany->id);$select->where->equalTo('high_performance_group_id', $highPerformanceTeamsGroups->id);if (isset($topic_uuid)) {$topicMapper = TopicMapper::getInstance($this->adapter);$topic = $topicMapper->fetchOneByUuid($topic_uuid);if ($topic) {if ($topic->status != 'a') {return new JsonModel(['success' => false,'data' => 'ERROR_YOU_DO_NOT_HAVE_ACCESS']);}$select->where->equalTo('topic_id', $topic->id);} else {return new JsonModel(['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND']);}} else {if (isset($urgent)) {$select->where->equalTo('priority', Feed::PRIORITY_URGENT);} else {$select->where->IsNull('topic_id');}}$select->where->and->equalTo('type', Feed::TYPE_HPTG);$select->order('added_on desc');} else {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}} else {return new JsonModel(['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND']);}} else if ($myt_id) {$feedMapper = FeedMapper::getInstance($this->adapter);$now = $feedMapper->getDatebaseNow();$myt = $feedMapper->fetchOneByUuid($myt_id);$queryMapper = QueryMapper::getInstance($this->adapter);$select = $queryMapper->getSql()->select(FeedMapper::_TABLE);$select->columns(['id']);$select->where->equalTo('status', Feed::STATUS_PUBLISHED);$select->where->equalTo('company_id', $currentCompany->id);$select->where->equalTo('myt_id', $myt->id);$select->where->and->equalTo('type', Feed::TYPE_MYT_ANSWER);$select->order('added_on desc');} else {$queryMapper = QueryMapper::getInstance($this->adapter);$now = $queryMapper->getDatebaseNow();$select = $queryMapper->getSql()->select(FeedMapper::_TABLE);$select->columns(['id']);$select->where->equalTo('status', Feed::STATUS_PUBLISHED);$select->where->equalTo('company_id', $currentCompany->id);$select->where->and->equalTo('type', Feed::TYPE_COMPANY);$select->order('added_on desc');//echo $select->getSqlString($this->adapter->platform); exit;}$dbSelect = new DbSelect($select, $this->adapter);$paginator = new Paginator($dbSelect);$paginator->setCurrentPageNumber($page ? $page : 1);$paginator->setItemCountPerPage(10);$items = [];$feeds = $paginator->getCurrentItems();foreach ($feeds as $feed) {$items[] = $this->renderFeed($feed->id, $now);}$response = ['success' => true,'data' => ['total' => ['count' => $paginator->getTotalItemCount(),'pages' => $paginator->getPages()->pageCount,],'current' => ['items' => $items,'page' => $paginator->getCurrentPageNumber(),'count' => $paginator->getCurrentItemCount(),]]];return new JsonModel($response);}$response = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($response);}public function oneFeedAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();if ($request->isGet()) {$feed_uuid = $this->params()->fromRoute('id');$myt_id = $this->params()->fromRoute('id');if (!isset($feed_uuid)) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}$items = [];$feedMapper = FeedMapper::getInstance($this->adapter);$now = $feedMapper->getDatebaseNow();$feed = $feedMapper->fetchOneByUuid($feed_uuid);if (!$feed) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($feed->type == 'mytq') {$items = $this->renderFeed($feed->id, $now, $myt_id);$response = ['success' => true,'data' => ['item' => $items,'feed_title' => $feed->title,'topic_title' => $feed->description]];} else if ($feed->type == 'myta') {$items = $this->renderFeed($feed->id, $now, $myt_id);$response = ['success' => true,'data' => ['item' => $items,'feed_title' => $feed->title,'topic_title' => $feed->description]];} else if ($feed->type == 'hptg') {$group_uuid = $this->params()->fromRoute('group_id');$topic_uuid = $this->params()->fromRoute('topic_id');if (!isset($topic_uuid)) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}if (!isset($group_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']);}if ($feed->high_performance_group_id != $highPerformanceTeamsGroups->id) {return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}$topicMapper = TopicMapper::getInstance($this->adapter);$topic = $topicMapper->fetchOneByUuid($topic_uuid);if (!$topic) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($feed->topic_id != $topic->id) {return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}$items = $this->renderFeed($feed->id, $now, $group_uuid);$response = ['success' => true,'data' => ['item' => $items,'topic_title' => $topic->title,'feed_title' => $feed->title]];}return new JsonModel($response);}}/**** @param string $str* @return string*/private function normalizeString($str = ''){$basename = substr($str, 0, strrpos($str, '.'));$basename = str_replace('.', '-', $basename);$extension = substr($str, strrpos($str, '.'));$str = $basename . $extension;$str = strip_tags($str);$str = preg_replace('/[\r\n\t ]+/', ' ', $str);$str = preg_replace('/[\"\*\/\:\<\>\?\'\|\,]+/', ' ', $str);$str = strtolower($str);$str = html_entity_decode($str, ENT_QUOTES, "utf-8");$str = htmlentities($str, ENT_QUOTES, "utf-8");$str = preg_replace("/(&)([a-z])([a-z]+;)/i", '$2', $str);$str = str_replace(' ', '-', $str);$str = rawurlencode($str);$str = str_replace('%', '-', $str);return trim(strtolower($str));}/**** @param int $feed_id* @param Company $company* @return array*/private function renderFeed($feed_id, $now, $group_uuid = '', $myt_id = ''){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$companyMapper = CompanyMapper::getInstance($this->adapter);$company = $companyMapper->fetchOne($currentCompany->id);$companyUserMapper = CompanyUserMapper::getInstance($this->adapter);$owner = $companyUserMapper->fetchOwnerByCompanyId($currentCompany->id);$currentNetworkPlugin = $this->plugin('currentNetworkPlugin');$network = $currentNetworkPlugin->getNetwork();$acl = $this->getEvent()->getViewModel()->getVariable('acl');$feedMapper = FeedMapper::getInstance($this->adapter);$feed = $feedMapper->fetchOne($feed_id);$params = ['id' => $feed->uuid];$item = ['feed_unique' => uniqid(),'feed_uuid' => $feed->uuid,'feed_content_type' => $feed->file_type ? $feed->file_type : '','owner_url' => 'https://' . $network->main_hostname . '/company/view/' . $company->uuid,'owner_image' => $this->url()->fromRoute('storage', ['code' => $company->uuid, 'type' => 'company', 'filename' => $company->image]),'owner_name' => $company->name,];$userMapper = UserMapper::getInstance($this->adapter);$user = $userMapper->fetchOne($feed->user_id);$item['owner_shared'] = $feed->total_shared;$item['owner_comments'] = $feed->total_comments;if($feed->file_type == Feed::FILE_TYPE_FAST_SURVEY) {$fastSurveyMapper = FastSurveyMapper::getInstance($this->adapter);$fastSurvey = $fastSurveyMapper->fetchOne($feed->fast_survey_id);$owner_description = ['question' => $fastSurvey->question,'number_of_answers' => $fastSurvey->number_of_answers,'answer1' => $fastSurvey->answer1,'answer2' => $fastSurvey->answer2,'answer3' => $fastSurvey->answer3,'answer4' => $fastSurvey->answer4,'answer5' => $fastSurvey->answer5,'result_type' => $fastSurvey->result_type,];if($fastSurvey->expire_on > $now) {$owner_description['active'] = 1;$owner_description['time_remaining'] = Functions::getDateDiff($now, $fastSurvey->expire_on);} else {if($fastSurvey->result_type == FastSurvey::RESULT_TYPE_PUBLIC) {$owner_description['votes1'] = $fastSurvey->votes1;$owner_description['votes2'] = $fastSurvey->votes2;$owner_description['votes3'] = $fastSurvey->votes3;$owner_description['votes4'] = $fastSurvey->votes4;$owner_description['votes5'] = $fastSurvey->votes5;}$owner_description['active'] = 0;$owner_description['time_remaining'] = 0;}$item['owner_description'] = $owner_description;$item['feed_delete_url'] = '';} else {$item['owner_description'] = strip_tags($feed->description, 'p');$item['feed_delete_url'] = $this->url()->fromRoute('feeds/delete', $params);}$item['owner_time_elapse'] = Functions::timeAgo($feed->added_on, $now);if ($feed->file_type == Feed::FILE_TYPE_IMAGE) {$item['owner_file_image'] = $this->url()->fromRoute('storage', ['code' => $feed->uuid, 'type' => 'feed', 'filename' => $feed->file_name]);}if ($feed->file_type == Feed::FILE_TYPE_DOCUMENT) {$item['owner_file_document'] = $this->url()->fromRoute('storage', ['code' => $feed->uuid, 'type' => 'feed', 'filename' => $feed->file_name]);}if ($feed->file_type == Feed::FILE_TYPE_VIDEO) {$item['owner_file_image_preview'] = $this->url()->fromRoute('storage', ['code' => $feed->uuid, 'type' => 'feed', 'filename' => $feed->file_image_preview]);$item['owner_file_video'] = $this->url()->fromRoute('storage', ['code' => $feed->uuid, 'type' => 'feed', 'filename' => $feed->file_name]);}if($feed->file_type == Feed::FILE_TYPE_FAST_SURVEY) {$item['comment_add_url'] = '';$item['comments'] = [];} else {$commentMapper = CommentMapper::getInstance($this->adapter);$records = $commentMapper->fetchAllPublishedByFeedId($feed->id);$comments = [];$comment_count = 0;foreach ($records as $record) {$user = $userMapper->fetchOne($record->user_id);$comment = [];$comment['unique'] = uniqid();$comment_count++;$comment['comment_index'] = $comment_count;$user = $userMapper->fetchOne($record->user_id);if ($user->id == $owner->user_id) {$comment['user_image'] = $this->url()->fromRoute('storage', ['type' => 'company', 'code' => $company->uuid, 'filename' => $company->image]);$comment['user_url'] = 'https://' . $network->main_hostname . '/company/view/' . $company->uuid;$comment['user_name'] = $company->name;} else {$comment['user_image'] = $this->url()->fromRoute('storage', ['type' => 'user', 'code' => $user->uuid, 'filename' => $user->image]);$comment['user_url'] = 'https://' . $network->main_hostname . '/profile/view/' . $user->uuid;$comment['user_name'] = $user->first_name . ' ' . $user->last_name;}$comment['link_delete'] = $this->url()->fromRoute('feeds/comments/delete', ['id' => $feed->uuid, 'comment' => $record->uuid]);$comment['link_answer_add'] = $this->url()->fromRoute('feeds/comments/answer', ['id' => $feed->uuid, 'comment' => $record->uuid]);$comment['time_elapsed'] = Functions::timeAgo($record->added_on, $now);$comment['comment'] = $record->comment;$records2 = $commentMapper->fetchAllPublishedByCommentId($record->id);$answers = [];$contador = 0;foreach ($records2 as $record2) {$user = $userMapper->fetchOne($record2->user_id);$answer = [];$answer['unique'] = uniqid();$user = $userMapper->fetchOne($record2->user_id);if ($user->id == $owner->user_id) {$answer['user_image'] = $this->url()->fromRoute('storage', ['type' => 'company', 'code' => $company->uuid, 'filename' => $company->image]);$answer['user_url'] = 'https://' . $network->main_hostname . '/company/view/' . $company->uuid;$answer['user_name'] = $company->name;} else {$answer['user_image'] = $this->url()->fromRoute('storage', ['type' => 'user', 'code' => $user->uuid, 'filename' => $user->image]);$answer['user_url'] = 'https://' . $network->main_hostname . '/profile/view/' . $user->uuid;$answer['user_name'] = $user->first_name . ' ' . $user->last_name;}$answer['link_delete'] = $this->url()->fromRoute('feeds/comments/delete', ['id' => $feed->uuid, 'comment' => $record2->uuid]);$answer['time_elapsed'] = Functions::timeAgo($record2->added_on, $now);$answer['comment'] = $record2->comment;$records2 = $commentMapper->fetchAllPublishedByCommentId($record2->id);$contador++;array_push($answers, $answer);}$comment['number_answers'] = $contador;$comment['answers'] = $answers;array_push($comments, $comment);}$item['comment_add_url'] = $this->url()->fromRoute('feeds/comments', ['id' => $feed->uuid]);$item['comments'] = $comments;}//echo '<pre>';// print_r($item);//echo '</pre>';//exit;return $item;}/**** @param int $comment_id* @return array*/private function renderComment($comment_id, $now){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentNetworkPlugin = $this->plugin('currentNetworkPlugin');$network = $currentNetworkPlugin->getNetwork();$currentCompany = $currentUserPlugin->getCompany();$companyMapper = CompanyMapper::getInstance($this->adapter);$company = $companyMapper->fetchOne($currentCompany->id);$companyUserMapper = CompanyUserMapper::getInstance($this->adapter);$owner = $companyUserMapper->fetchOwnerByCompanyId($currentCompany->id);$item = [];$commentMapper = CommentMapper::getInstance($this->adapter);$record = $commentMapper->fetchOne($comment_id);$feedMapper = FeedMapper::getInstance($this->adapter);$feed = $feedMapper->fetchOne($record->feed_id);if ($record) {$userMapper = UserMapper::getInstance($this->adapter);$item = [];$item['unique'] = uniqid();$user = $userMapper->fetchOne($record->user_id);if ($user->id == $owner->user_id) {$item['user_image'] = $this->url()->fromRoute('storage', ['type' => 'company', 'code' => $company->uuid, 'filename' => $company->image]);$item['user_url'] = 'https://' . $network->main_hostname . '/company/view/' . $company->uuid;$item['user_name'] = $company->name;} else {$item['user_image'] = $this->url()->fromRoute('storage', ['type' => 'user', 'code' => $user->uuid, 'filename' => $user->image]);$item['user_url'] = 'https://' . $network->main_hostname . '/profile/view/' . $user->uuid;$item['user_name'] = $user->first_name . ' ' . $user->last_name;}$item['link_answer_add'] = $this->url()->fromRoute('feeds/comments/answer', ['id' => $feed->uuid, 'comment' => $record->uuid]);$item['link_delete'] = $this->url()->fromRoute('feeds/comments/delete', ['id' => $feed->uuid, 'comment' => $record->uuid]);$item['time_elapsed'] = Functions::timeAgo($record->added_on, $now);$item['comment'] = $record->comment;}return $item;}/**** @param string $path* @return boolean*/private function deletePath($path){try {if (is_dir($path)) {if ($dh = opendir($path)) {while (($file = readdir($dh)) !== false) {if ($file == '.' || $file == '..') {continue;}unlink($path . DIRECTORY_SEPARATOR . $file);}closedir($dh);}rmdir($path);}return true;} catch (\Throwable $e) {error_log($e->getTraceAsString());return false;}}}