Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
57.14% |
4 / 7 |
CRAP | |
87.76% |
43 / 49 |
| config | |
0.00% |
0 / 1 |
|
57.14% |
4 / 7 |
17.53 | |
87.76% |
43 / 49 |
| __construct | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
| get_name | |
100.00% |
1 / 1 |
1 | |
100.00% |
1 / 1 |
|||
| add | |
100.00% |
1 / 1 |
2 | |
100.00% |
5 / 5 |
|||
| update | |
100.00% |
1 / 1 |
2 | |
100.00% |
5 / 5 |
|||
| update_if_equals | |
0.00% |
0 / 1 |
2.03 | |
80.00% |
4 / 5 |
|||
| remove | |
0.00% |
0 / 1 |
2.03 | |
80.00% |
4 / 5 |
|||
| reverse | |
0.00% |
0 / 1 |
7.18 | |
84.62% |
22 / 26 |
|||
| <?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\tool; | |
| /** | |
| * Migration config tool | |
| */ | |
| class config implements \phpbb\db\migration\tool\tool_interface | |
| { | |
| /** @var \phpbb\config\config */ | |
| protected $config; | |
| /** | |
| * Constructor | |
| * | |
| * @param \phpbb\config\config $config | |
| */ | |
| public function __construct(\phpbb\config\config $config) | |
| { | |
| $this->config = $config; | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function get_name() | |
| { | |
| return 'config'; | |
| } | |
| /** | |
| * Add a config setting. | |
| * | |
| * @param string $config_name The name of the config setting | |
| * you would like to add | |
| * @param mixed $config_value The value of the config setting | |
| * @param bool $is_dynamic True if it is dynamic (changes very often) | |
| * and should not be stored in the cache, false if not. | |
| * @return null | |
| */ | |
| public function add($config_name, $config_value, $is_dynamic = false) | |
| { | |
| if (isset($this->config[$config_name])) | |
| { | |
| return; | |
| } | |
| $this->config->set($config_name, $config_value, !$is_dynamic); | |
| } | |
| /** | |
| * Update an existing config setting. | |
| * | |
| * @param string $config_name The name of the config setting you would | |
| * like to update | |
| * @param mixed $config_value The value of the config setting | |
| * @return null | |
| * @throws \phpbb\db\migration\exception | |
| */ | |
| public function update($config_name, $config_value) | |
| { | |
| if (!isset($this->config[$config_name])) | |
| { | |
| throw new \phpbb\db\migration\exception('CONFIG_NOT_EXIST', $config_name); | |
| } | |
| $this->config->set($config_name, $config_value); | |
| } | |
| /** | |
| * Update a config setting if the first argument equal to the | |
| * current config value | |
| * | |
| * @param string $compare If equal to the current config value, will be | |
| * updated to the new config value, otherwise not | |
| * @param string $config_name The name of the config setting you would | |
| * like to update | |
| * @param mixed $config_value The value of the config setting | |
| * @return null | |
| * @throws \phpbb\db\migration\exception | |
| */ | |
| public function update_if_equals($compare, $config_name, $config_value) | |
| { | |
| if (!isset($this->config[$config_name])) | |
| { | |
| throw new \phpbb\db\migration\exception('CONFIG_NOT_EXIST', $config_name); | |
| } | |
| $this->config->set_atomic($config_name, $compare, $config_value); | |
| } | |
| /** | |
| * Remove an existing config setting. | |
| * | |
| * @param string $config_name The name of the config setting you would | |
| * like to remove | |
| * @return null | |
| */ | |
| public function remove($config_name) | |
| { | |
| if (!isset($this->config[$config_name])) | |
| { | |
| return; | |
| } | |
| $this->config->delete($config_name); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function reverse() | |
| { | |
| $arguments = func_get_args(); | |
| $original_call = array_shift($arguments); | |
| $call = false; | |
| switch ($original_call) | |
| { | |
| case 'add': | |
| $call = 'remove'; | |
| break; | |
| case 'remove': | |
| $call = 'add'; | |
| if (count($arguments) == 1) | |
| { | |
| $arguments[] = ''; | |
| } | |
| break; | |
| case 'update_if_equals': | |
| $call = 'update_if_equals'; | |
| // Set to the original value if the current value is what we compared to originally | |
| $arguments = array( | |
| $arguments[2], | |
| $arguments[1], | |
| $arguments[0], | |
| ); | |
| break; | |
| case 'reverse': | |
| // Reversing a reverse is just the call itself | |
| $call = array_shift($arguments); | |
| break; | |
| } | |
| if ($call) | |
| { | |
| return call_user_func_array(array(&$this, $call), $arguments); | |
| } | |
| } | |
| } |