* * This program 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 2 * of the License, or (at your option) any later version. * * This program 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. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301, USA. */ use Codappix\SearchCore\Configuration\ConfigurationContainerInterface; use Codappix\SearchCore\Connection\ConnectionInterface; use Codappix\SearchCore\Domain\Index\TcaIndexer\TcaTableService; use TYPO3\CMS\Core\Database\ConnectionPool; use TYPO3\CMS\Core\Database\Query\QueryBuilder; use TYPO3\CMS\Core\Utility\GeneralUtility; /** * Will index the given table using configuration from TCA. */ class TcaIndexer extends AbstractIndexer { /** * @var TcaIndexer\TcaTableService */ protected $tcaTableService; /** * @param TcaIndexer\TcaTableService $tcaTableService * @param ConnectionInterface $connection * @param ConfigurationContainerInterface $configuration */ public function __construct( TcaIndexer\TcaTableService $tcaTableService, ConnectionInterface $connection, ConfigurationContainerInterface $configuration ) { parent::__construct($connection, $configuration); $this->tcaTableService = $tcaTableService; } /** * @return array|null */ protected function getRecords(int $offset, int $limit) { $records = $this->getQuery() ->setFirstResult($offset) ->setMaxResults($limit) ->execute() ->fetchAll(); if ($records === null) { return null; } $this->tcaTableService->filterRecordsByRootLineBlacklist($records); foreach ($records as &$record) { $this->tcaTableService->prepareRecord($record); } return $records; } /** * @throws NoRecordFoundException If record could not be found. */ protected function getRecord(int $identifier) : array { $query = $this->getQuery(); $query = $query->andWhere($this->tcaTableService->getTableName() . '.uid = ' . $identifier); $record = $query->execute()->fetch(); if ($record === false || $record === null) { throw new NoRecordFoundException( 'Record could not be fetched from database: "' . $identifier . '". Perhaps record is not active.', 1484225364 ); } $this->tcaTableService->prepareRecord($record); return $record; } protected function getDocumentName() : string { return $this->tcaTableService->getTableName(); } protected function getQuery(TcaTableService $tcaTableService = null) : QueryBuilder { if ($tcaTableService === null) { $tcaTableService = $this->tcaTableService; } $queryBuilder = $this->getDatabaseConnection()->getQueryBuilderForTable($tcaTableService->getTableName()); $where = $tcaTableService->getWhereClause(); $query = $queryBuilder->select(... $tcaTableService->getFields()) ->from($tcaTableService->getTableClause()) ->where($where->getStatement()) ->setParameters($where->getParameters()); foreach ($tcaTableService->getJoins() as $join) { $query->from($join->getTable()); $query->andWhere($join->getCondition()); } return $query; } protected function getDatabaseConnection() : ConnectionPool { return GeneralUtility::makeInstance(ConnectionPool::class); } }