meilisearch/Classes/Migrations/RemoveSiteFromScheduler.php
2021-04-17 21:20:54 +02:00

107 lines
3.7 KiB
PHP

<?php
namespace WapplerSystems\Meilisearch\Migrations;
/***************************************************************
* Copyright notice
*
* (c) 2017 Timo Hund <timo.hund@dkd.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!
***************************************************************/
use TYPO3\CMS\Core\Database\ConnectionPool;
use TYPO3\CMS\Core\Messaging\FlashMessage;
use TYPO3\CMS\Core\Utility\GeneralUtility;
/**
* Removes the Site property from the SchedulerTask and set the rootPageId property.
*/
class RemoveSiteFromScheduler implements Migration {
/**
* Called by the extension manager to determine if the update menu entry
* should by showed.
*
* @return bool
*/
public function isNeeded()
{
$taskRows = $this->getTasksWithAssignedSite();
$legacySchedulerTaskCount = $taskRows->rowCount();
return $legacySchedulerTaskCount > 0;
}
/**
* Main update function called by the extension manager.
*
* @return string
*/
public function process()
{
$taskRows = $this->getTasksWithAssignedSite();
$legacySchedulerTasks = $taskRows->fetchAll();
$queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable("tx_scheduler_task");
$status = FlashMessage::OK;
$title = 'Remove site from scheduler task';
$failedTaskCount = 0;
$migratedTaskCount = 0;
foreach ($legacySchedulerTasks as $legacySchedulerTask) {
try {
$uid = $legacySchedulerTask['uid'];
$task = unserialize($legacySchedulerTask['serialized_task_object']);
$task->setRootPageId($task->getSite()->getRootPageId());
$updatedTask = serialize($task);
$updatedRows = $queryBuilder->update('tx_scheduler_task')
->where($queryBuilder->expr()->eq('uid', $uid))
->set('serialized_task_object', $updatedTask)
->execute();
$migratedTaskCount += $updatedRows;
} catch (\Exception $e) {
$failedTaskCount++;
$status = FlashMessage::ERROR;
}
}
$message = 'Migrated ' . (int)$migratedTaskCount . ' scheduler tasks! Update of ' . (int)$failedTaskCount . ' failed!';
return [$status, $title, $message];
}
/**
* @return \Doctrine\DBAL\Driver\Statement|int
*/
protected function getTasksWithAssignedSite()
{
$queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable("tx_scheduler_task");
$taskRows = $queryBuilder
->select('uid', 'serialized_task_object')
->from("tx_scheduler_task")
->where(
$queryBuilder->expr()->andX(
$queryBuilder->expr()->like('serialized_task_object', "'%WapplerSystems%'"),
$queryBuilder->expr()->like('serialized_task_object', "'%site\";O:28:\"%'")
)
)->execute();
return $taskRows;
}
}