Rev 16768 | Ir a la última revisión | 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\Cache\Storage\Adapter\AbstractAdapter;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\Mapper\UserMapper;use LeadersLinked\Mapper\UserPasswordMapper;use LeadersLinked\Model\User;use LeadersLinked\Form\ChangePasswordForm;use LeadersLinked\Model\CompanyUser;use LeadersLinked\Mapper\CompanyUserMapper;use LeadersLinked\Mapper\CompanyUserRoleMapper;use LeadersLinked\Mapper\RoleMapper;use LeadersLinked\Model\UserType;use LeadersLinked\Model\UserPassword;use PhpOffice\PhpSpreadsheet\IOFactory;use LeadersLinked\Form\UserUploadForm;use LeadersLinked\Mapper\CompanyServiceMapper;use LeadersLinked\Model\CompanyService;use LeadersLinked\Model\Role;use LeadersLinked\Mapper\CompanyRoleMapper;use LeadersLinked\Model\CompanyUserRole;use LeadersLinked\Model\Notification;use LeadersLinked\Model\EmailTemplate;use LeadersLinked\Mapper\NotificationMapper;use LeadersLinked\Mapper\UserNotificationSettingMapper;use LeadersLinked\Mapper\EmailTemplateMapper;use LeadersLinked\Library\QueueEmail;use LeadersLinked\Mapper\NetworkMapper;use LeadersLinked\Model\Network;class UserRequestAccessController 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();$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) {{$search = $this->params()->fromQuery('search', []);$search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);//$page = intval($this->params()->fromQuery('start', 1), 10);//$records_x_page = intval($this->params()->fromQuery('length', 10), 10);$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 = ['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');$allowApprove = $acl->isAllowed($currentUser->usertype_id, 'users/request-access/approve');$allowReject = $acl->isAllowed($currentUser->usertype_id, 'users/request-access/reject');$userMapper = UserMapper::getInstance($this->adapter);$paginator = $userMapper->fetchAllDataTableRequestAccessPendingByNetworkId($network->id, $search, $page, $records_x_page, $order_field, $order_direction);$items = [];$records = $paginator->getCurrentItems();foreach($records as $record){$actions = [];$actions['link_approve'] = $allowApprove ? $this->url()->fromRoute('users/request-access/approve', ['id' => $record->uuid ]) : '';$actions['link_reject'] = $allowReject ? $this->url()->fromRoute('users/request-access/reject', ['id' => $record->uuid ]) : '';$item = ['first_name' => $record->first_name,'last_name' => $record->last_name,'email' => $record->email,'actions' => $actions];array_push($items, $item);}}return new JsonModel(['success' => true,'data' => ['items' => $items,'total' => $paginator->getTotalItemCount(),]]);}else if($request->isGet()) {$this->layout()->setTemplate('layout/layout-backend');$viewModel = new ViewModel();$viewModel->setTemplate('leaders-linked/users-request-access/index.phtml');return $viewModel ;} else {return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);;}}public function approveAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();//$currentCompany = $currentUserPlugin->getCompany();$currentNetworkPlugin = $this->plugin('currentNetworkPlugin');$currentNetwork = $currentNetworkPlugin->getNetwork();$request = $this->getRequest();if($request->isPost()) {$uuid = $this->params()->fromRoute('id');if(!$uuid) {return new JsonModel(['success' => false,'data' => 'ERROR_INVALID_PARAMETER']);}$userMapper = UserMapper::getInstance($this->adapter);$user = $userMapper->fetchOneByUuid($uuid);if(!$user) {return new JsonModel(['success' => false,'data' => 'ERROR_USER_NOT_FOUND']);}if($user->network_id != $currentNetwork->id) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}if($user->request_access != User::REQUEST_ACCESS_PENDING) {return new JsonModel(['success' => false,'data' => 'ERROR_REQUEST_ACCESS_IS_NOT_PENDING']);}$user->request_access = User::REQUEST_ACCESS_APPROVED;$result = $userMapper->update($user);if($result) {$emailTemplateMapper = EmailTemplateMapper::getInstance($this->adapter);$emailTemplate = $emailTemplateMapper->fetchOneByCodeAndNetworkId(EmailTemplate::CODE_REQUEST_ACCESS_APPROVED, $currentNetwork->id);if($emailTemplate) {$arrayCont = ['firstname' => $user->first_name,'lastname' => $user->last_name,'other_user_firstname' => '','other_user_lastname' => '','company_name' => '','group_name' => '','content' => '','code' => '','link' => $this->url()->fromRoute('home', [], ['force_canonical' => true])];$email = new QueueEmail($this->adapter);$email->processEmailTemplate($emailTemplate, $arrayCont, $user->email, trim($user->first_name . ' ' . $user->last_name));}$this->logger->info('Usted autorizo el acceso al usuario : ' . trim($user->first_name . ' ' . $user->last_name) . '(' . $user->email . ') ha sido autorizado ', ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);return new JsonModel(['success' => true,'data' => 'LABEL_USER_REQUEST_ACCESS_HAS_BEEN_APPROVED']);} else {return new JsonModel(['success' => false,'data' => $userMapper->getError()]);}}return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}public function rejectAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();//$currentCompany = $currentUserPlugin->getCompany();$currentNetworkPlugin = $this->plugin('currentNetworkPlugin');$currentNetwork = $currentNetworkPlugin->getNetwork();$request = $this->getRequest();if($request->isPost()) {$uuid = $this->params()->fromRoute('id');if(!$uuid) {return new JsonModel(['success' => false,'data' => 'ERROR_INVALID_PARAMETER']);}$userMapper = UserMapper::getInstance($this->adapter);$user = $userMapper->fetchOneByUuid($uuid);if(!$user) {return new JsonModel(['success' => false,'data' => 'ERROR_USER_NOT_FOUND']);}if($user->network_id != $currentNetwork->id) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}if($user->request_access != User::REQUEST_ACCESS_PENDING) {return new JsonModel(['success' => false,'data' => 'ERROR_REQUEST_ACCESS_IS_NOT_PENDING']);}$user->request_access = User::REQUEST_ACCESS_REJECTED;$result = $userMapper->update($user);if($result) {$emailTemplateMapper = EmailTemplateMapper::getInstance($this->adapter);$emailTemplate = $emailTemplateMapper->fetchOneByCodeAndNetworkId(EmailTemplate::CODE_REQUEST_ACCESS_REJECT, $currentNetwork->id);if($emailTemplate) {$arrayCont = ['firstname' => $user->first_name,'lastname' => $user->last_name,'other_user_firstname' => '','other_user_lastname' => '','company_name' => '','group_name' => '','content' => '','code' => '','link' => $this->url()->fromRoute('home', [], ['force_canonical' => true])];$email = new QueueEmail($this->adapter);$email->processEmailTemplate($emailTemplate, $arrayCont, $user->email, trim($user->first_name . ' ' . $user->last_name));}$this->logger->info('Usted rechazo el acceso al usuario : ' . trim($user->first_name . ' ' . $user->last_name) . '(' . $user->email . ') ha sido autorizado ', ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);return new JsonModel(['success' => true,'data' => 'LABEL_USER_REQUEST_ACCESS_HAS_BEEN_REJECTED']);} else {return new JsonModel(['success' => false,'data' => $userMapper->getError()]);}}return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}}