mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-27 21:58:52 +00:00
[ticket/14257] Use migrations instead of cron job for some reparsers
PHPBB3-14257
This commit is contained in:
parent
8b0f8d7b3c
commit
33500fd372
2 changed files with 87 additions and 52 deletions
|
@ -147,58 +147,6 @@ services:
|
|||
tags:
|
||||
- { name: cron.task }
|
||||
|
||||
cron.task.text_reparser.contact_admin_info:
|
||||
class: phpbb\cron\task\text_reparser\reparser
|
||||
arguments:
|
||||
- @config
|
||||
- @config_text
|
||||
- @text_reparser.lock
|
||||
- @text_reparser_collection
|
||||
calls:
|
||||
- [set_name, [cron.task.text_reparser.contact_admin_info]]
|
||||
- [set_reparser, [text_reparser.contact_admin_info]]
|
||||
tags:
|
||||
- { name: cron.task }
|
||||
|
||||
cron.task.text_reparser.forum_description:
|
||||
class: phpbb\cron\task\text_reparser\reparser
|
||||
arguments:
|
||||
- @config
|
||||
- @config_text
|
||||
- @text_reparser.lock
|
||||
- @text_reparser_collection
|
||||
calls:
|
||||
- [set_name, [cron.task.text_reparser.forum_description]]
|
||||
- [set_reparser, [text_reparser.forum_description]]
|
||||
tags:
|
||||
- { name: cron.task }
|
||||
|
||||
cron.task.text_reparser.forum_rules:
|
||||
class: phpbb\cron\task\text_reparser\reparser
|
||||
arguments:
|
||||
- @config
|
||||
- @config_text
|
||||
- @text_reparser.lock
|
||||
- @text_reparser_collection
|
||||
calls:
|
||||
- [set_name, [cron.task.text_reparser.forum_rules]]
|
||||
- [set_reparser, [text_reparser.forum_rules]]
|
||||
tags:
|
||||
- { name: cron.task }
|
||||
|
||||
cron.task.text_reparser.group_description:
|
||||
class: phpbb\cron\task\text_reparser\reparser
|
||||
arguments:
|
||||
- @config
|
||||
- @config_text
|
||||
- @text_reparser.lock
|
||||
- @text_reparser_collection
|
||||
calls:
|
||||
- [set_name, [cron.task.text_reparser.group_description]]
|
||||
- [set_reparser, [text_reparser.group_description]]
|
||||
tags:
|
||||
- { name: cron.task }
|
||||
|
||||
cron.task.text_reparser.pm_text:
|
||||
class: phpbb\cron\task\text_reparser\reparser
|
||||
arguments:
|
||||
|
|
87
phpBB/phpbb/db/migration/data/v320/reparse_fast.php
Normal file
87
phpBB/phpbb/db/migration/data/v320/reparse_fast.php
Normal file
|
@ -0,0 +1,87 @@
|
|||
<?php
|
||||
/**
|
||||
*
|
||||
* This file is part of the phpBB Forum Software package.
|
||||
*
|
||||
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
||||
* @license GNU General Public License, version 2 (GPL-2.0)
|
||||
*
|
||||
* For full copyright and license information, please see
|
||||
* the docs/CREDITS.txt file.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace phpbb\db\migration\data\v320;
|
||||
|
||||
class reparse_fast extends \phpbb\db\migration\container_aware_migration
|
||||
{
|
||||
static public function depends_on()
|
||||
{
|
||||
return array('\phpbb\db\migration\data\v310\contact_admin_form');
|
||||
}
|
||||
|
||||
public function effectively_installed()
|
||||
{
|
||||
return isset($this->config['reparse_lock']);
|
||||
}
|
||||
|
||||
public function update_data()
|
||||
{
|
||||
return array(
|
||||
array('config.add', array('reparse_lock', 0, true)),
|
||||
array('custom', array(array($this, 'reparse'))),
|
||||
);
|
||||
}
|
||||
|
||||
public function reparse($resume_data)
|
||||
{
|
||||
// Somtimes a cron job is too much
|
||||
$limit = 200;
|
||||
$fast_reparsers = array(
|
||||
'text_reparser.contact_admin_info',
|
||||
'text_reparser.forum_description',
|
||||
'text_reparser.forum_rules',
|
||||
'text_reparser.group_description',
|
||||
);
|
||||
|
||||
if (!is_array($resume_data))
|
||||
{
|
||||
$resume_data = array(
|
||||
'reparser' => 0,
|
||||
'current' => $this->container->get($fast_reparsers[0])->get_max_id(),
|
||||
);
|
||||
}
|
||||
|
||||
$fast_reparsers_size = sizeof($fast_reparsers);
|
||||
$processed_records = 0;
|
||||
while ($processed_records < $limit && $resume_data['reparser'] < $fast_reparsers_size)
|
||||
{
|
||||
$reparser = $this->container->get($fast_reparsers[$resume_data['reparser']]);
|
||||
|
||||
// New reparser
|
||||
if ($resume_data['current'] === 0)
|
||||
{
|
||||
$resume_data['current'] = $reparser->get_max_id();
|
||||
}
|
||||
|
||||
$start = max(1, $resume_data['current'] + 1 - ($limit - $processed_records));
|
||||
$end = max(1, $resume_data['current']);
|
||||
$reparser->reparse_range($start, $end);
|
||||
|
||||
$processed_records = $end - $start + 1;
|
||||
$resume_data['current'] = $start - 1;
|
||||
|
||||
if ($start === 1)
|
||||
{
|
||||
$resume_data['reparser']++;
|
||||
}
|
||||
}
|
||||
|
||||
if ($resume_data['reparser'] === $fast_reparsers_size)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
return $resume_data;
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue