<?php /*************************************************************** * Copyright notice * * (c) sgalinski Internet Services (https://www.sgalinski.de) * * All rights reserved * * This script is part of the TYPO3 project. The TYPO3 project is * free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * The GNU General Public License can be found at * http://www.gnu.org/copyleft/gpl.html. * * This script is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * This copyright notice MUST APPEAR in all copies of the script! ***************************************************************/ namespace SGalinski\SgJobs\Service; use Doctrine\DBAL\Exception; use TYPO3\CMS\Backend\Template\Components\ButtonBar; use TYPO3\CMS\Backend\Template\Components\DocHeaderComponent; use TYPO3\CMS\Backend\Utility\BackendUtility; use TYPO3\CMS\Core\Database\ConnectionPool; use TYPO3\CMS\Core\Database\Query\Restriction\DeletedRestriction; use TYPO3\CMS\Core\Imaging\Icon; use TYPO3\CMS\Core\Imaging\IconFactory; use TYPO3\CMS\Core\Utility\GeneralUtility; use TYPO3\CMS\Extbase\Mvc\Request; use TYPO3\CMS\Extbase\Utility\LocalizationUtility; /** * Backend Service class */ class BackendService { /** * Get all pages the be user has access to * * @return array * @throws Exception */ public static function getPages(): array { $out = []; $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class) ->getQueryBuilderForTable('pages'); $queryBuilder->getRestrictions()->removeAll() ->add(GeneralUtility::makeInstance(DeletedRestriction::class)); $rows = $queryBuilder->select('*') ->from('pages') ->where( $queryBuilder->expr()->eq( 'is_siteroot', $queryBuilder->createNamedParameter(1, \PDO::PARAM_INT) ) )->executeQuery()->fetchAllAssociative(); foreach ($rows as $row) { $pageInfo = BackendUtility::readPageAccess($row['uid'], $GLOBALS['BE_USER']->getPagePermsClause(1)); if ($pageInfo) { $rootline = BackendUtility::BEgetRootLine($pageInfo['uid'], '', TRUE); ksort($rootline); $path = '/root'; foreach ($rootline as $page) { $path .= '/p' . dechex($page['uid']); } $pageInfo['path'] = $path; $out[] = $pageInfo; } } return $out; } /** * create buttons for the backend module header * * @param DocHeaderComponent $docHeaderComponent * @param Request $request * @throws \InvalidArgumentException * @throws \UnexpectedValueException */ public static function makeButtons($docHeaderComponent, $request): void { $buttonBar = $docHeaderComponent->getButtonBar(); /** @var IconFactory $iconFactory */ $iconFactory = GeneralUtility::makeInstance(IconFactory::class); $locallangPath = 'LLL:EXT:core/Resources/Private/Language/locallang_core.xlf:'; // Refresh $refreshButton = $buttonBar->makeLinkButton() ->setHref(GeneralUtility::getIndpEnv('REQUEST_URI')) ->setTitle( LocalizationUtility::translate( $locallangPath . 'labels.reload', '' ) ) ->setIcon($iconFactory->getIcon('actions-refresh', Icon::SIZE_SMALL)); $buttonBar->addButton($refreshButton, ButtonBar::BUTTON_POSITION_RIGHT); // shortcut button $shortcutButton = $buttonBar->makeShortcutButton() ->setDisplayName('Shortcut') ->setRouteIdentifier($request->getPluginName()) ->setArguments( [ 'id' => [], 'M' => [] ] ); $buttonBar->addButton($shortcutButton, ButtonBar::BUTTON_POSITION_RIGHT); } /** * Returns the uids of the pages with job records * * @return array * @throws Exception */ public static function getPagesWithJobRecords(): array { $out = []; $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable( 'tx_sgjobs_domain_model_job' ); $queryBuilder->getRestrictions()->removeAll()->add(GeneralUtility::makeInstance(DeletedRestriction::class)); $rows = $queryBuilder->select('pid') ->from('tx_sgjobs_domain_model_job') ->groupBy('pid') ->executeQuery()->fetchAllAssociative(); foreach ($rows as $row) { $pageInfo = BackendUtility::readPageAccess($row['pid'], $GLOBALS['BE_USER']->getPagePermsClause(1)); if ($pageInfo) { $rootline = BackendUtility::BEgetRootLine($pageInfo['uid'], '', TRUE); ksort($rootline); $path = '/root'; foreach ($rootline as $page) { $path .= '/p' . dechex($page['uid']); } $pageInfo['path'] = $path; $out[] = $pageInfo; } } return $out; } }