mirror of
https://github.com/werkraum-media/events.git
synced 2025-01-13 09:06:09 +01:00
129 lines
4 KiB
PHP
129 lines
4 KiB
PHP
|
<?php
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
|
||
|
/*
|
||
|
* Copyright (C) 2022 Daniel Siepmann <coding@daniel-siepmann.de>
|
||
|
*
|
||
|
* 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.
|
||
|
*/
|
||
|
|
||
|
namespace Wrm\Events\Service\DestinationDataImportService;
|
||
|
|
||
|
use TYPO3\CMS\Core\Database\ConnectionPool;
|
||
|
use TYPO3\CMS\Core\Database\Query\QueryBuilder;
|
||
|
use TYPO3\CMS\Core\DataHandling\SlugHelper;
|
||
|
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||
|
use Wrm\Events\Service\DestinationDataImportService\Slugger\Registry;
|
||
|
use Wrm\Events\Service\DestinationDataImportService\Slugger\SluggerType;
|
||
|
|
||
|
class Slugger
|
||
|
{
|
||
|
/**
|
||
|
* @var Registry
|
||
|
*/
|
||
|
private $registry;
|
||
|
|
||
|
/**
|
||
|
* @var ConnectionPool
|
||
|
*/
|
||
|
private $connectionPool;
|
||
|
|
||
|
public function __construct(
|
||
|
Registry $registry,
|
||
|
ConnectionPool $connectionPool
|
||
|
) {
|
||
|
$this->registry = $registry;
|
||
|
$this->connectionPool = $connectionPool;
|
||
|
}
|
||
|
|
||
|
public function update(string $tableName): void
|
||
|
{
|
||
|
$sluggerType = $this->registry->get($tableName);
|
||
|
foreach ($this->getRecords($sluggerType) as $record) {
|
||
|
$this->updateRecord($sluggerType, $record);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return \Generator<array>
|
||
|
*/
|
||
|
private function getRecords(SluggerType $sluggerType): \Generator
|
||
|
{
|
||
|
$tableName = $sluggerType->getSupportedTableName();
|
||
|
$slugColumn = $sluggerType->getSlugColumn();
|
||
|
$queryBuilder = $this->getQueryBuilder($tableName);
|
||
|
|
||
|
$statement = $queryBuilder->select('*')
|
||
|
->from($tableName)
|
||
|
->where(
|
||
|
$queryBuilder->expr()->orX(
|
||
|
$queryBuilder->expr()->eq($slugColumn, $queryBuilder->createNamedParameter('', \PDO::PARAM_STR)),
|
||
|
$queryBuilder->expr()->isNull($slugColumn)
|
||
|
)
|
||
|
)
|
||
|
->execute();
|
||
|
|
||
|
while ($record = $statement->fetch()) {
|
||
|
if (is_array($record) === false) {
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
yield $record;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private function updateRecord(SluggerType $sluggerType, array $record): void
|
||
|
{
|
||
|
$tableName = $sluggerType->getSupportedTableName();
|
||
|
$record = $sluggerType->prepareRecordForSlugGeneration($record);
|
||
|
$slug = $this->getSlugHelper($sluggerType)->generate($record, (int) $record['pid']);
|
||
|
|
||
|
$queryBuilder = $this->getQueryBuilder($tableName);
|
||
|
$queryBuilder->update($tableName)
|
||
|
->where(
|
||
|
$queryBuilder->expr()->eq(
|
||
|
'uid',
|
||
|
$queryBuilder->createNamedParameter($record['uid'], \PDO::PARAM_INT)
|
||
|
)
|
||
|
)
|
||
|
->set($sluggerType->getSlugColumn(), $slug);
|
||
|
$queryBuilder->execute();
|
||
|
}
|
||
|
|
||
|
private function getSlugHelper(
|
||
|
SluggerType $sluggerType
|
||
|
): SlugHelper {
|
||
|
$tableName = $sluggerType->getSupportedTableName();
|
||
|
$column = $sluggerType->getSlugColumn();
|
||
|
|
||
|
return GeneralUtility::makeInstance(
|
||
|
SlugHelper::class,
|
||
|
$tableName,
|
||
|
$column,
|
||
|
$GLOBALS['TCA'][$tableName]['columns'][$column]['config']
|
||
|
);
|
||
|
}
|
||
|
|
||
|
private function getQueryBuilder(
|
||
|
string $tableName
|
||
|
): QueryBuilder {
|
||
|
$queryBuilder = $this->connectionPool->getQueryBuilderForTable($tableName);
|
||
|
$queryBuilder->getRestrictions()->removeAll();
|
||
|
return $queryBuilder;
|
||
|
}
|
||
|
}
|