* * 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 TYPO3\CMS\Extbase\Object\ObjectManagerInterface; use Leonmrni\SearchCore\Connection\ConnectionInterface; /** * Will index the given table using configuration from TCA. */ class TcaIndexer implements IndexerInterface { /** * @var ConnectionInterface */ protected $connection; /** * @var TcaIndexer\TcaTableService */ protected $tcaTableService; /** * @var \TYPO3\CMS\Core\Log\Logger */ protected $logger; /** * Inject log manager to get concrete logger from it. * * @param \TYPO3\CMS\Core\Log\LogManager $logManager */ public function injectLogger(\TYPO3\CMS\Core\Log\LogManager $logManager) { $this->logger = $logManager->getLogger(__CLASS__); } /** * @param TcaIndexer\TcaTableService $tcaTableService * @param ConnectionInterface $connection */ public function __construct( TcaIndexer\TcaTableService $tcaTableService, ConnectionInterface $connection ) { $this->tcaTableService = $tcaTableService; $this->connection = $connection; } public function indexAllDocuments() { $this->logger->info('Start indexing'); foreach ($this->getRecordGenerator() as $records) { $this->logger->debug('Index records.', [$records]); if ($records === null) { break; } $this->connection->addDocuments($this->tcaTableService->getTableName(), $records); } $this->logger->info('Finish indexing'); } public function indexDocument($identifier) { $this->logger->info('Start indexing single record.', [$identifier]); try { $this->connection->addDocument($this->tcaTableService->getTableName(), $this->getRecord($identifier)); } catch (NoRecordFoundException $e) { $this->logger->info('Could not index document.', [$e->getMessage()]); } $this->logger->info('Finish indexing'); } /** * @return \Generator */ protected function getRecordGenerator() { $offset = 0; // TODO: Make configurable. $limit = 50; while (($records = $this->getRecords($offset, $limit)) !== []) { yield $records; $offset += $limit; } } /** * @param int $offset * @param int $limit * @return array|null */ protected function getRecords($offset, $limit) { $records = $GLOBALS['TYPO3_DB']->exec_SELECTgetRows( $this->tcaTableService->getFields(), $this->tcaTableService->getTableClause(), $this->tcaTableService->getWhereClause(), '', '', (int) $offset . ',' . (int) $limit ); if ($records === null) { return null; } $this->tcaTableService->filterRecordsByRootLineBlacklist($records); foreach ($records as &$record) { $this->tcaTableService->prepareRecord($record); } return $records; } /** * @param int $identifier * @return array * @throws NoRecordFoundException If record could not be found. */ protected function getRecord($identifier) { $record = $GLOBALS['TYPO3_DB']->exec_SELECTgetSingleRow( $this->tcaTableService->getFields(), $this->tcaTableService->getTableClause(), $this->tcaTableService->getWhereClause() . ' AND ' . $this->tcaTableService->getTableName() . '.uid = ' . (int) $identifier ); if ($record === false) { throw new NoRecordFoundException( 'Record could not be fetched from database: "' . $identifier . '". Perhaps record is not active.', 1484225364 ); } $this->tcaTableService->prepareRecord($record); return $record; } }