Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 4 |
CRAP | |
0.00% |
0 / 104 |
| update | |
0.00% |
0 / 1 |
|
0.00% |
0 / 4 |
342 | |
0.00% |
0 / 104 |
| __construct | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 14 |
|||
| run | |
0.00% |
0 / 1 |
240 | |
0.00% |
0 / 84 |
|||
| get_step_count | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 3 |
|||
| get_task_lang_name | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 3 |
|||
| <?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\install\module\update_database\task; | |
| use phpbb\db\migration\exception; | |
| use phpbb\db\output_handler\installer_migrator_output_handler; | |
| use phpbb\db\output_handler\log_wrapper_migrator_output_handler; | |
| use phpbb\install\exception\resource_limit_reached_exception; | |
| use phpbb\install\exception\user_interaction_required_exception; | |
| use phpbb\install\task_base; | |
| /** | |
| * Database updater task | |
| */ | |
| class update extends task_base | |
| { | |
| /** | |
| * @var \phpbb\cache\driver\driver_interface | |
| */ | |
| protected $cache; | |
| /** | |
| * @var \phpbb\config\config | |
| */ | |
| protected $config; | |
| /** | |
| * @var \phpbb\extension\manager | |
| */ | |
| protected $extension_manager; | |
| /** | |
| * @var \phpbb\filesystem\filesystem | |
| */ | |
| protected $filesystem; | |
| /** | |
| * @var \phpbb\install\helper\config | |
| */ | |
| protected $installer_config; | |
| /** | |
| * @var \phpbb\install\helper\iohandler\iohandler_interface | |
| */ | |
| protected $iohandler; | |
| /** | |
| * @var \phpbb\language\language | |
| */ | |
| protected $language; | |
| /** | |
| * @var \phpbb\log\log | |
| */ | |
| protected $log; | |
| /** | |
| * @var \phpbb\db\migrator | |
| */ | |
| protected $migrator; | |
| /** | |
| * @var \phpbb\user | |
| */ | |
| protected $user; | |
| /** | |
| * @var string | |
| */ | |
| protected $phpbb_root_path; | |
| /** | |
| * Constructor | |
| * | |
| * @param \phpbb\install\helper\container_factory $container | |
| * @param \phpbb\filesystem\filesystem $filesystem | |
| * @param \phpbb\install\helper\config $installer_config | |
| * @param \phpbb\install\helper\iohandler\iohandler_interface $iohandler | |
| * @param \phpbb\language\language $language | |
| * @param string $phpbb_root_path | |
| */ | |
| public function __construct(\phpbb\install\helper\container_factory $container, \phpbb\filesystem\filesystem $filesystem, \phpbb\install\helper\config $installer_config, \phpbb\install\helper\iohandler\iohandler_interface $iohandler, \phpbb\language\language $language, $phpbb_root_path) | |
| { | |
| $this->filesystem = $filesystem; | |
| $this->installer_config = $installer_config; | |
| $this->iohandler = $iohandler; | |
| $this->language = $language; | |
| $this->phpbb_root_path = $phpbb_root_path; | |
| $this->cache = $container->get('cache.driver'); | |
| $this->config = $container->get('config'); | |
| $this->extension_manager = $container->get('ext.manager'); | |
| $this->log = $container->get('log'); | |
| $this->migrator = $container->get('migrator'); | |
| $this->user = $container->get('user'); | |
| parent::__construct(true); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function run() | |
| { | |
| $this->language->add_lang('migrator'); | |
| if (!isset($this->config['version_update_from'])) | |
| { | |
| $this->config->set('version_update_from', $this->config['version']); | |
| } | |
| $original_version = $this->config['version_update_from']; | |
| $this->migrator->set_output_handler( | |
| new log_wrapper_migrator_output_handler( | |
| $this->language, | |
| new installer_migrator_output_handler($this->iohandler), | |
| $this->phpbb_root_path . 'store/migrations_' . time() . '.log', | |
| $this->filesystem | |
| ) | |
| ); | |
| $this->migrator->create_migrations_table(); | |
| $migrations = $this->extension_manager | |
| ->get_finder() | |
| ->core_path('phpbb/db/migration/data/') | |
| ->extension_directory('/migrations') | |
| ->get_classes(); | |
| $this->migrator->set_migrations($migrations); | |
| $migration_step_count = $this->installer_config->get('database_update_migration_steps', -1); | |
| if ($migration_step_count < 0) | |
| { | |
| $migration_step_count = count($this->migrator->get_installable_migrations()) * 2; | |
| $this->installer_config->set('database_update_migration_steps', $migration_step_count); | |
| } | |
| $progress_count = $this->installer_config->get('database_update_count', 0); | |
| $restart_progress_bar = ($progress_count === 0); // Only "restart" when the update runs for the first time | |
| $this->iohandler->set_task_count($migration_step_count, $restart_progress_bar); | |
| $this->installer_config->set_task_progress_count($migration_step_count); | |
| while (!$this->migrator->finished()) | |
| { | |
| try | |
| { | |
| $this->migrator->update(); | |
| $progress_count++; | |
| $last_run_migration = $this->migrator->get_last_run_migration(); | |
| if (isset($last_run_migration['effectively_installed']) && $last_run_migration['effectively_installed']) | |
| { | |
| // We skipped two step, so increment $progress_count by another one | |
| $progress_count++; | |
| } | |
| else if (($last_run_migration['task'] === 'process_schema_step' && !$last_run_migration['state']['migration_schema_done']) || | |
| ($last_run_migration['task'] === 'process_data_step' && !$last_run_migration['state']['migration_data_done'])) | |
| { | |
| // We just run a step that wasn't counted yet so make it count | |
| $migration_step_count++; | |
| } | |
| $this->iohandler->set_task_count($migration_step_count); | |
| $this->installer_config->set_task_progress_count($migration_step_count); | |
| $this->iohandler->set_progress('STAGE_UPDATE_DATABASE', $progress_count); | |
| } | |
| catch (exception $e) | |
| { | |
| $msg = $e->getParameters(); | |
| array_unshift($msg, $e->getMessage()); | |
| $this->iohandler->add_error_message($msg); | |
| throw new user_interaction_required_exception(); | |
| } | |
| if ($this->installer_config->get_time_remaining() <= 0 || $this->installer_config->get_memory_remaining() <= 0) | |
| { | |
| $this->installer_config->set('database_update_count', $progress_count); | |
| $this->installer_config->set('database_update_migration_steps', $migration_step_count); | |
| throw new resource_limit_reached_exception(); | |
| } | |
| } | |
| if ($original_version !== $this->config['version']) | |
| { | |
| $this->log->add( | |
| 'admin', | |
| (isset($this->user->data['user_id'])) ? $this->user->data['user_id'] : ANONYMOUS, | |
| $this->user->ip, | |
| 'LOG_UPDATE_DATABASE', | |
| false, | |
| array( | |
| $original_version, | |
| $this->config['version'] | |
| ) | |
| ); | |
| } | |
| $this->iohandler->add_success_message('INLINE_UPDATE_SUCCESSFUL'); | |
| $this->cache->purge(); | |
| $this->config->increment('assets_version', 1); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| static public function get_step_count() | |
| { | |
| return 0; | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function get_task_lang_name() | |
| { | |
| return ''; | |
| } | |
| } |