. */ namespace SP\Controller; defined('APP_ROOT') || die(); use SP\Account\AccountSearchFilter; use SP\Account\AccountSearchItem; use SP\Core\Acl\ActionsInterface; use SP\Core\Exceptions\SPException; use SP\Core\SessionFactory; use SP\Core\SessionUtil; use SP\Html\DataGrid\DataGrid; use SP\Html\DataGrid\DataGridAction; use SP\Html\DataGrid\DataGridActionSearch; use SP\Html\DataGrid\DataGridActionType; use SP\Html\DataGrid\DataGridData; use SP\Html\DataGrid\DataGridHeaderSort; use SP\Html\DataGrid\DataGridPager; use SP\Html\DataGrid\DataGridSort; use SP\Http\Request; use SP\Mgmt\Categories\Category; use SP\Mgmt\Customers\Customer; use SP\Mgmt\Tags\Tag; use SP\Modules\Web\Controllers\ControllerBase; use SP\Mvc\View\Template; use SP\Services\Account\AccountSearchService; /** * Clase encargada de obtener los datos para presentar la búsqueda * * @package Controller */ class AccountSearchController extends ControllerBase implements ActionsInterface { /** * Indica si el filtrado de cuentas está activo * * @var bool */ private $filterOn = false; /** @var string */ private $sk; /** @var int */ private $sortKey = 0; /** @var string */ private $sortOrder = 0; /** @var bool */ private $searchGlobal = false; /** @var int */ private $limitStart = 0; /** @var int */ private $limitCount = 0; /** @var int */ private $queryTimeStart = 0; /** @var bool */ private $isAjax = false; /** * Constructor * * @param $template \SP\Mvc\View\Template con instancia de plantilla */ public function __construct(Template $template = null) { parent::__construct($template); $this->queryTimeStart = microtime(); $this->sk = SessionUtil::getSessionKey(true); $this->view->assign('sk', $this->sk); $this->setVars(); } /** * Establecer las variables necesarias para las plantillas */ private function setVars() { $this->view->assign('isAdmin', $this->userData->isIsAdminApp() || $this->userData->isIsAdminAcc()); $this->view->assign('showGlobalSearch', $this->configData->isGlobalSearch() && $this->userProfileData->isAccGlobalSearch()); // Obtener el filtro de búsqueda desde la sesión $filters = SessionFactory::getSearchFilters(); // Comprobar si la búsqueda es realizada desde el formulario // de lo contrario, se recupera la información de filtros de la sesión $isSearch = (!isset($this->view->actionId)); $this->sortKey = $isSearch ? Request::analyze('skey', 0) : $filters->getSortKey(); $this->sortOrder = $isSearch ? Request::analyze('sorder', 0) : $filters->getSortOrder(); $this->searchGlobal = $isSearch ? Request::analyze('gsearch', 0) : $filters->getGlobalSearch(); $this->limitStart = $isSearch ? Request::analyze('start', 0) : $filters->getLimitStart(); $this->limitCount = $isSearch ? Request::analyze('rpp', 0) : $filters->getLimitCount(); // Valores POST $this->view->assign('searchCustomer', $isSearch ? Request::analyze('customer', 0) : $filters->getCustomerId()); $this->view->assign('searchCategory', $isSearch ? Request::analyze('category', 0) : $filters->getCategoryId()); $this->view->assign('searchTags', $isSearch ? Request::analyze('tags') : $filters->getTagsId()); $this->view->assign('searchTxt', $isSearch ? Request::analyze('search') : $filters->getTxtSearch()); $this->view->assign('searchGlobal', Request::analyze('gsearch', $filters->getGlobalSearch())); $this->view->assign('searchFavorites', Request::analyze('searchfav', $filters->isSearchFavorites())); } /** * @param boolean $isAjax */ public function setIsAjax($isAjax) { $this->isAjax = $isAjax; } /** * Obtener los datos para la caja de búsqueda */ public function getSearchBox() { $this->view->addTemplate('searchbox'); $this->view->assign('customers', Customer::getItem()->getItemsForSelectByUser()); $this->view->assign('categories', Category::getItem()->getItemsForSelect()); $this->view->assign('tags', Tag::getItem()->getItemsForSelect()); } /** * Obtener los resultados de una búsqueda * * @throws \InvalidArgumentException */ public function getSearch() { $this->view->addTemplate('index'); $this->view->assign('isAjax', $this->isAjax); $Search = new AccountSearchService(); $Search->setGlobalSearch($this->searchGlobal) ->setSortKey($this->sortKey) ->setSortOrder($this->sortOrder) ->setLimitStart($this->limitStart) ->setLimitCount($this->limitCount) ->setTxtSearch($this->view->searchTxt) ->setCategoryId($this->view->searchCategory) ->setClientId($this->view->searchCustomer) ->setTagsId($this->view->searchTags) ->setSearchFavorites($this->view->searchFavorites); $this->filterOn = ($this->sortKey > 1 || $this->view->searchCustomer || $this->view->searchCategory || $this->view->searchTags || $this->view->searchTxt || $this->view->searchFavorites || $Search->isSortViews()); $UserPreferences = SessionFactory::getUserPreferences(); AccountSearchItem::$accountLink = $UserPreferences->isAccountLink(); AccountSearchItem::$topNavbar = $UserPreferences->isTopNavbar(); AccountSearchItem::$optionalActions = $UserPreferences->isOptionalActions(); AccountSearchItem::$wikiEnabled = $this->configData->isWikiEnabled(); AccountSearchItem::$dokuWikiEnabled = $this->configData->isDokuwikiEnabled(); AccountSearchItem::$isDemoMode = $this->configData->isDemoEnabled(); if (AccountSearchItem::$wikiEnabled) { $wikiFilter = array_map(function ($value) { return preg_quote($value, '/'); }, $this->configData->getWikiFilter()); $this->view->assign('wikiFilter', implode('|', $wikiFilter)); $this->view->assign('wikiPageUrl', $this->configData->getWikiPageurl()); } $Grid = $this->getGrid(); $Grid->getData()->setData($Search->processSearchResults()); $Grid->updatePager(); $Grid->setTime(round(microtime() - $this->queryTimeStart, 5)); // Establecer el filtro de búsqueda en la sesión como un objeto SessionFactory::setSearchFilters($Search->save()); $this->view->assign('data', $Grid); } /** * Devuelve la matriz a utilizar en la vista * * @return DataGrid * @throws \ReflectionException */ private function getGrid() { $GridActionView = new DataGridAction(); $GridActionView->setId(self::ACCOUNT_VIEW); $GridActionView->setType(DataGridActionType::VIEW_ITEM); $GridActionView->setName(__('Detalles de Cuenta')); $GridActionView->setTitle(__('Detalles de Cuenta')); $GridActionView->setIcon($this->icons->getIconView()); $GridActionView->setReflectionFilter(AccountSearchItem::class, 'isShowView'); $GridActionView->addData('action-id', self::ACCOUNT_VIEW); $GridActionView->addData('action-sk', $this->sk); $GridActionView->addData('onclick', 'account/show'); $GridActionViewPass = new DataGridAction(); $GridActionViewPass->setId(self::ACCOUNT_VIEW_PASS); $GridActionViewPass->setType(DataGridActionType::VIEW_ITEM); $GridActionViewPass->setName(__('Ver Clave')); $GridActionViewPass->setTitle(__('Ver Clave')); $GridActionViewPass->setIcon($this->icons->getIconViewPass()); $GridActionViewPass->setReflectionFilter(AccountSearchItem::class, 'isShowViewPass'); $GridActionViewPass->addData('action-id', self::ACCOUNT_VIEW_PASS); $GridActionViewPass->addData('action-full', 1); $GridActionViewPass->addData('action-sk', $this->sk); $GridActionViewPass->addData('onclick', 'account/showpass'); // Añadir la clase para usar el portapapeles $ClipboardIcon = $this->icons->getIconClipboard()->setClass('clip-pass-button'); $GridActionCopyPass = new DataGridAction(); $GridActionCopyPass->setId(self::ACCOUNT_VIEW_PASS); $GridActionCopyPass->setType(DataGridActionType::VIEW_ITEM); $GridActionCopyPass->setName(__('Copiar Clave en Portapapeles')); $GridActionCopyPass->setTitle(__('Copiar Clave en Portapapeles')); $GridActionCopyPass->setIcon($ClipboardIcon); $GridActionCopyPass->setReflectionFilter(AccountSearchItem::class, 'isShowCopyPass'); $GridActionCopyPass->addData('action-id', self::ACCOUNT_VIEW_PASS); $GridActionCopyPass->addData('action-full', 0); $GridActionCopyPass->addData('action-sk', $this->sk); $GridActionCopyPass->addData('useclipboard', '1'); $GridActionEdit = new DataGridAction(); $GridActionEdit->setId(self::ACCOUNT_EDIT); $GridActionEdit->setType(DataGridActionType::EDIT_ITEM); $GridActionEdit->setName(__('Editar Cuenta')); $GridActionEdit->setTitle(__('Editar Cuenta')); $GridActionEdit->setIcon($this->icons->getIconEdit()); $GridActionEdit->setReflectionFilter(AccountSearchItem::class, 'isShowEdit'); $GridActionEdit->addData('action-id', self::ACCOUNT_EDIT); $GridActionEdit->addData('action-sk', $this->sk); $GridActionEdit->addData('onclick', 'account/edit'); $GridActionCopy = new DataGridAction(); $GridActionCopy->setId(self::ACCOUNT_COPY); $GridActionCopy->setType(DataGridActionType::MENUBAR_ITEM); $GridActionCopy->setName(__('Copiar Cuenta')); $GridActionCopy->setTitle(__('Copiar Cuenta')); $GridActionCopy->setIcon($this->icons->getIconCopy()); $GridActionCopy->setReflectionFilter(AccountSearchItem::class, 'isShowCopy'); $GridActionCopy->addData('action-id', self::ACCOUNT_COPY); $GridActionCopy->addData('action-sk', $this->sk); $GridActionCopy->addData('onclick', 'account/copy'); $GridActionDel = new DataGridAction(); $GridActionDel->setId(self::ACCOUNT_DELETE); $GridActionDel->setType(DataGridActionType::DELETE_ITEM); $GridActionDel->setName(__('Eliminar Cuenta')); $GridActionDel->setTitle(__('Eliminar Cuenta')); $GridActionDel->setIcon($this->icons->getIconDelete()); $GridActionDel->setReflectionFilter(AccountSearchItem::class, 'isShowDelete'); $GridActionDel->addData('action-id', self::ACCOUNT_DELETE); $GridActionDel->addData('action-sk', $this->sk); $GridActionDel->addData('onclick', 'account/delete'); $GridActionRequest = new DataGridAction(); $GridActionRequest->setId(self::ACCOUNT_REQUEST); $GridActionRequest->setName(__('Solicitar Modificación')); $GridActionRequest->setTitle(__('Solicitar Modificación')); $GridActionRequest->setIcon($this->icons->getIconEmail()); $GridActionRequest->setReflectionFilter(AccountSearchItem::class, 'isShowRequest'); $GridActionRequest->addData('action-id', self::ACCOUNT_REQUEST); $GridActionRequest->addData('action-sk', $this->sk); $GridActionRequest->addData('onclick', 'account/show'); $GridActionOptional = new DataGridAction(); $GridActionOptional->setId(0); $GridActionOptional->setName(__('Más Acciones')); $GridActionOptional->setTitle(__('Más Acciones')); $GridActionOptional->setIcon($this->icons->getIconOptional()); $GridActionOptional->setReflectionFilter(AccountSearchItem::class, 'isShowOptional'); $GridActionOptional->addData('onclick', 'account/menu'); $GridPager = new DataGridPager(); $GridPager->setIconPrev($this->icons->getIconNavPrev()); $GridPager->setIconNext($this->icons->getIconNavNext()); $GridPager->setIconFirst($this->icons->getIconNavFirst()); $GridPager->setIconLast($this->icons->getIconNavLast()); $GridPager->setSortKey($this->sortKey); $GridPager->setSortOrder($this->sortOrder); $GridPager->setLimitStart($this->limitStart); $GridPager->setLimitCount($this->limitCount); $GridPager->setOnClickFunction('account/sort'); $GridPager->setFilterOn($this->filterOn); $GridPager->setSourceAction(new DataGridActionSearch(self::ACCOUNT_SEARCH)); $UserPreferences = SessionFactory::getUserPreferences(); $showOptionalActions = $UserPreferences->isOptionalActions() || $UserPreferences->isResultsAsCards() || ($UserPreferences->getUserId() === 0 && $this->configData->isResultsAsCards()); $Grid = new DataGrid(); $Grid->setId('gridSearch'); $Grid->setDataHeaderTemplate('header', $this->view->getBase()); $Grid->setDataRowTemplate('rows', $this->view->getBase()); $Grid->setDataPagerTemplate('datagrid-nav-full', 'grid'); $Grid->setHeader($this->getHeaderSort()); $Grid->setDataActions($GridActionView); $Grid->setDataActions($GridActionViewPass); $Grid->setDataActions($GridActionCopyPass); $Grid->setDataActions($GridActionEdit, !$showOptionalActions); $Grid->setDataActions($GridActionCopy, !$showOptionalActions); $Grid->setDataActions($GridActionDel, !$showOptionalActions); $Grid->setDataActions($GridActionRequest); $Grid->setPager($GridPager); $Grid->setData(new DataGridData()); return $Grid; } /** * Devolver la cabecera con los campos de ordenación * * @return DataGridHeaderSort */ private function getHeaderSort() { $GridSortCustomer = new DataGridSort(); $GridSortCustomer->setName(__('Cliente')) ->setTitle(__('Ordenar por Cliente')) ->setSortKey(AccountSearchFilter::SORT_CLIENT) ->setIconUp($this->icons->getIconUp()) ->setIconDown($this->icons->getIconDown()); $GridSortName = new DataGridSort(); $GridSortName->setName(__('Nombre')) ->setTitle(__('Ordenar por Nombre')) ->setSortKey(AccountSearchFilter::SORT_NAME) ->setIconUp($this->icons->getIconUp()) ->setIconDown($this->icons->getIconDown()); $GridSortCategory = new DataGridSort(); $GridSortCategory->setName(__('Categoría')) ->setTitle(__('Ordenar por Categoría')) ->setSortKey(AccountSearchFilter::SORT_CATEGORY) ->setIconUp($this->icons->getIconUp()) ->setIconDown($this->icons->getIconDown()); $GridSortLogin = new DataGridSort(); $GridSortLogin->setName(__('Usuario')) ->setTitle(__('Ordenar por Usuario')) ->setSortKey(AccountSearchFilter::SORT_LOGIN) ->setIconUp($this->icons->getIconUp()) ->setIconDown($this->icons->getIconDown()); $GridSortUrl = new DataGridSort(); $GridSortUrl->setName(__('URL / IP')) ->setTitle(__('Ordenar por URL / IP')) ->setSortKey(AccountSearchFilter::SORT_URL) ->setIconUp($this->icons->getIconUp()) ->setIconDown($this->icons->getIconDown()); $GridHeaderSort = new DataGridHeaderSort(); $GridHeaderSort->addSortField($GridSortCustomer) ->addSortField($GridSortName) ->addSortField($GridSortCategory) ->addSortField($GridSortLogin) ->addSortField($GridSortUrl); return $GridHeaderSort; } /** * Realizar las accione del controlador * * @param mixed $type Tipo de acción * @throws \InvalidArgumentException */ public function doAction($type = null) { try { $this->getSearchBox(); $this->getSearch(); $this->eventDispatcher->notifyEvent('show.account.search', $this); } catch (SPException $e) { $this->showError(self::ERR_EXCEPTION); } } }