diff options
Diffstat (limited to 'phpBB/phpbb/console/command/db')
| -rw-r--r-- | phpBB/phpbb/console/command/db/console_migrator_output_handler.php | 2 | ||||
| -rw-r--r-- | phpBB/phpbb/console/command/db/list_command.php | 73 | ||||
| -rw-r--r-- | phpBB/phpbb/console/command/db/migrate.php | 50 | ||||
| -rw-r--r-- | phpBB/phpbb/console/command/db/migration_command.php | 56 | ||||
| -rw-r--r-- | phpBB/phpbb/console/command/db/revert.php | 88 | 
5 files changed, 231 insertions, 38 deletions
| diff --git a/phpBB/phpbb/console/command/db/console_migrator_output_handler.php b/phpBB/phpbb/console/command/db/console_migrator_output_handler.php index b9741a3838..568b2646d4 100644 --- a/phpBB/phpbb/console/command/db/console_migrator_output_handler.php +++ b/phpBB/phpbb/console/command/db/console_migrator_output_handler.php @@ -13,8 +13,8 @@  namespace phpbb\console\command\db; +use phpbb\db\output_handler\migrator_output_handler_interface;  use phpbb\user; -use phpbb\db\migrator_output_handler_interface;  use Symfony\Component\Console\Output\OutputInterface;  class console_migrator_output_handler implements migrator_output_handler_interface diff --git a/phpBB/phpbb/console/command/db/list_command.php b/phpBB/phpbb/console/command/db/list_command.php new file mode 100644 index 0000000000..708107b592 --- /dev/null +++ b/phpBB/phpbb/console/command/db/list_command.php @@ -0,0 +1,73 @@ +<?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\console\command\db; + +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Input\InputOption; +use Symfony\Component\Console\Output\OutputInterface; + +class list_command extends \phpbb\console\command\db\migration_command +{ +	protected function configure() +	{ +		$this +			->setName('db:list') +			->setDescription($this->user->lang('CLI_DESCRIPTION_DB_LIST')) +			->addOption( +				'available', +				'u', +				InputOption::VALUE_NONE, +				$this->user->lang('CLI_MIGRATIONS_ONLY_AVAILABLE') +			) +		; +	} + +	protected function execute(InputInterface $input, OutputInterface $output) +	{ +		$show_installed = !$input->getOption('available'); +		$installed = $available = array(); + +		foreach ($this->load_migrations() as $name) +		{ +			if ($this->migrator->migration_state($name) !== false) +			{ +				$installed[] = $name; +			} +			else +			{ +				$available[] = $name; +			} +		} + +		if ($show_installed) +		{ +			$output->writeln('<info>' . $this->user->lang('CLI_MIGRATIONS_INSTALLED') . $this->user->lang('COLON') . '</info>'); +			$output->writeln($installed); + +			if (empty($installed)) +			{ +				$output->writeln($this->user->lang('CLI_MIGRATIONS_EMPTY')); +			} + +			$output->writeln(''); +		} + +		$output->writeln('<info>' . $this->user->lang('CLI_MIGRATIONS_AVAILABLE') . $this->user->lang('COLON') . '</info>'); +		$output->writeln($available); + +		if (empty($available)) +		{ +			$output->writeln($this->user->lang('CLI_MIGRATIONS_EMPTY')); +		} +	} +} diff --git a/phpBB/phpbb/console/command/db/migrate.php b/phpBB/phpbb/console/command/db/migrate.php index 87c2a057d1..ae4211f7be 100644 --- a/phpBB/phpbb/console/command/db/migrate.php +++ b/phpBB/phpbb/console/command/db/migrate.php @@ -12,38 +12,31 @@  */  namespace phpbb\console\command\db; +use phpbb\db\output_handler\log_wrapper_migrator_output_handler;  use Symfony\Component\Console\Input\InputInterface;  use Symfony\Component\Console\Output\OutputInterface; -class migrate extends \phpbb\console\command\command +class migrate extends \phpbb\console\command\db\migration_command  { -	/** @var \phpbb\db\migrator */ -	protected $migrator; - -	/** @var \phpbb\extension\manager */ -	protected $extension_manager; - -	/** @var \phpbb\config\config */ -	protected $config; - -	/** @var \phpbb\cache\service */ -	protected $cache; -  	/** @var \phpbb\log\log */  	protected $log;  	/** @var string phpBB root path */  	protected $phpbb_root_path; -	function __construct(\phpbb\user $user, \phpbb\db\migrator $migrator, \phpbb\extension\manager $extension_manager, \phpbb\config\config $config, \phpbb\cache\service $cache, \phpbb\log\log $log, $phpbb_root_path) +	/** @var  \phpbb\filesystem\filesystem_interface */ +	protected $filesystem; + +	/** @var \phpbb\language\language */ +	protected $language; + +	function __construct(\phpbb\user $user, \phpbb\language\language $language, \phpbb\db\migrator $migrator, \phpbb\extension\manager $extension_manager, \phpbb\config\config $config, \phpbb\cache\service $cache, \phpbb\log\log $log, \phpbb\filesystem\filesystem_interface $filesystem, $phpbb_root_path)  	{ -		$this->migrator = $migrator; -		$this->extension_manager = $extension_manager; -		$this->config = $config; -		$this->cache = $cache; +		$this->language = $language;  		$this->log = $log; +		$this->filesystem = $filesystem;  		$this->phpbb_root_path = $phpbb_root_path; -		parent::__construct($user); +		parent::__construct($user, $migrator, $extension_manager, $config, $cache);  		$this->user->add_lang(array('common', 'install', 'migrator'));  	} @@ -57,7 +50,7 @@ class migrate extends \phpbb\console\command\command  	protected function execute(InputInterface $input, OutputInterface $output)  	{ -		$this->migrator->set_output_handler(new \phpbb\db\log_wrapper_migrator_output_handler($this->user, new console_migrator_output_handler($this->user, $output), $this->phpbb_root_path . 'store/migrations_' . time() . '.log')); +		$this->migrator->set_output_handler(new log_wrapper_migrator_output_handler($this->language, new console_migrator_output_handler($this->user, $output), $this->phpbb_root_path . 'store/migrations_' . time() . '.log', $this->filesystem));  		$this->migrator->create_migrations_table(); @@ -87,21 +80,4 @@ class migrate extends \phpbb\console\command\command  		$this->finalise_update();  		$output->writeln($this->user->lang['DATABASE_UPDATE_COMPLETE']);  	} - -	protected function load_migrations() -	{ -		$migrations = $this->extension_manager -			->get_finder() -			->core_path('phpbb/db/migration/data/') -			->extension_directory('/migrations') -			->get_classes(); - -		$this->migrator->set_migrations($migrations); -	} - -	protected function finalise_update() -	{ -		$this->cache->purge(); -		$this->config->increment('assets_version', 1); -	}  } diff --git a/phpBB/phpbb/console/command/db/migration_command.php b/phpBB/phpbb/console/command/db/migration_command.php new file mode 100644 index 0000000000..b951560588 --- /dev/null +++ b/phpBB/phpbb/console/command/db/migration_command.php @@ -0,0 +1,56 @@ +<?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\console\command\db; + +abstract class migration_command extends \phpbb\console\command\command +{ +	/** @var \phpbb\db\migrator */ +	protected $migrator; + +	/** @var \phpbb\extension\manager */ +	protected $extension_manager; + +	/** @var \phpbb\config\config */ +	protected $config; + +	/** @var \phpbb\cache\service */ +	protected $cache; + +	function __construct(\phpbb\user $user, \phpbb\db\migrator $migrator, \phpbb\extension\manager $extension_manager, \phpbb\config\config $config, \phpbb\cache\service $cache) +	{ +		$this->migrator = $migrator; +		$this->extension_manager = $extension_manager; +		$this->config = $config; +		$this->cache = $cache; +		parent::__construct($user); +	} + +	protected function load_migrations() +	{ +		$migrations = $this->extension_manager +			->get_finder() +			->core_path('phpbb/db/migration/data/') +			->extension_directory('/migrations') +			->get_classes(); + +		$this->migrator->set_migrations($migrations); + +		return $this->migrator->get_migrations(); +	} + +	protected function finalise_update() +	{ +		$this->cache->purge(); +		$this->config->increment('assets_version', 1); +	} +} diff --git a/phpBB/phpbb/console/command/db/revert.php b/phpBB/phpbb/console/command/db/revert.php new file mode 100644 index 0000000000..3fa2e17515 --- /dev/null +++ b/phpBB/phpbb/console/command/db/revert.php @@ -0,0 +1,88 @@ +<?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\console\command\db; + +use phpbb\db\output_handler\log_wrapper_migrator_output_handler; +use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Output\OutputInterface; + +class revert extends \phpbb\console\command\db\migration_command +{ +	/** @var string phpBB root path */ +	protected $phpbb_root_path; + +	/** @var  \phpbb\filesystem\filesystem_interface */ +	protected $filesystem; + +	/** @var \phpbb\language\language */ +	protected $language; + +	function __construct(\phpbb\user $user, \phpbb\language\language $language, \phpbb\db\migrator $migrator, \phpbb\extension\manager $extension_manager, \phpbb\config\config $config, \phpbb\cache\service $cache, \phpbb\filesystem\filesystem_interface $filesystem, $phpbb_root_path) +	{ +		$this->filesystem = $filesystem; +		$this->language = $language; +		$this->phpbb_root_path = $phpbb_root_path; +		parent::__construct($user, $migrator, $extension_manager, $config, $cache); +		$this->user->add_lang(array('common', 'migrator')); +	} + +	protected function configure() +	{ +		$this +			->setName('db:revert') +			->setDescription($this->user->lang('CLI_DESCRIPTION_DB_REVERT')) +			->addArgument( +				'name', +				InputArgument::REQUIRED, +				$this->user->lang('CLI_MIGRATION_NAME') +			) +		; +	} + +	protected function execute(InputInterface $input, OutputInterface $output) +	{ +		$name = str_replace('/', '\\', $input->getArgument('name')); + +		$this->migrator->set_output_handler(new log_wrapper_migrator_output_handler($this->language, new console_migrator_output_handler($this->user, $output), $this->phpbb_root_path . 'store/migrations_' . time() . '.log', $this->filesystem)); + +		$this->cache->purge(); + +		if (!in_array($name, $this->load_migrations())) +		{ +			$output->writeln('<error>' . $this->user->lang('MIGRATION_NOT_VALID', $name) . '</error>'); +			return 1; +		} +		else if ($this->migrator->migration_state($name) === false) +		{ +			$output->writeln('<error>' . $this->user->lang('MIGRATION_NOT_INSTALLED', $name) . '</error>'); +			return 1; +		} + +		try +		{ +			while ($this->migrator->migration_state($name) !== false) +			{ +				$this->migrator->revert($name); +			} +		} +		catch (\phpbb\db\migration\exception $e) +		{ +			$output->writeln('<error>' . $e->getLocalisedMessage($this->user) . '</error>'); +			$this->finalise_update(); +			return 1; +		} + +		$this->finalise_update(); +	} +} | 
