1
0
mirror of https://github.com/phpbb/phpbb.git synced 2025-05-05 23:25:30 +02:00

[ticket/12039] Use an abstract class and some more minor adjustments

PHPBB3-12039
This commit is contained in:
Joas Schilling 2013-11-27 14:16:34 +01:00
parent d5743f008d
commit e6749261f1
7 changed files with 126 additions and 99 deletions

View File

@ -13,6 +13,13 @@ services:
tags: tags:
- { name: console.command } - { name: console.command }
console.command.config.get:
class: phpbb\console\command\config\get
arguments:
- @config
tags:
- { name: console.command }
console.command.config.set: console.command.config.set:
class: phpbb\console\command\config\set class: phpbb\console\command\config\set
arguments: arguments:

View File

@ -0,0 +1,22 @@
<?php
/**
*
* @package phpBB3
* @copyright (c) 2013 phpBB Group
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
*
*/
namespace phpbb\console\command\config;
abstract class command extends \phpbb\console\command\command
{
/** @var \phpbb\config\config */
protected $config;
function __construct(\phpbb\config\config $config)
{
$this->config = $config;
parent::__construct();
}
}

View File

@ -10,46 +10,29 @@ namespace phpbb\console\command\config;
use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface; use Symfony\Component\Console\Output\OutputInterface;
class delete extends \phpbb\console\command\command class delete extends command
{ {
/** @var \phpbb\config\config */
protected $config;
function __construct(\phpbb\config\config $config)
{
$this->config = $config;
parent::__construct();
}
protected function configure() protected function configure()
{ {
$this $this
->setName('config:delete') ->setName('config:delete')
->setDescription('Sets a configuration option\'s value') ->setDescription("Sets a configuration option's value")
->addArgument( ->addArgument(
'config-key', 'key',
InputArgument::REQUIRED, InputArgument::REQUIRED,
'The configuration option\'s name' "The configuration option's name"
)
->addArgument(
'use-cache',
InputArgument::OPTIONAL,
'Whether this variable should be cached or if it changes too frequently to be efficiently cached.',
true
) )
; ;
} }
protected function execute(InputInterface $input, OutputInterface $output) protected function execute(InputInterface $input, OutputInterface $output)
{ {
$key = $input->getArgument('config-key'); $key = $input->getArgument('key');
$use_cache = $input->getArgument('use-cache');
$use_cache = (strtolower($use_cache) !== 'false' && $use_cache);
$this->config->delete($key, $use_cache); $this->config->delete($key);
$output->writeln("<info>Successfully deleted config $key</info>"); $output->writeln("<info>Successfully deleted config $key</info>");
} }

View File

@ -0,0 +1,44 @@
<?php
/**
*
* @package phpBB3
* @copyright (c) 2013 phpBB Group
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
*
*/
namespace phpbb\console\command\config;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
class get extends command
{
protected function configure()
{
$this
->setName('config:get')
->setDescription("Gets a configuration option's value")
->addArgument(
'key',
InputArgument::REQUIRED,
"The configuration option's name"
)
;
}
protected function execute(InputInterface $input, OutputInterface $output)
{
$key = $input->getArgument('key');
if (isset($this->config[$key]))
{
$output->writeln("<info>{$this->config[$key]}</info>");
}
else
{
$output->writeln("<error>Could not get config $key</error>");
}
}
}

View File

@ -10,50 +10,40 @@ namespace phpbb\console\command\config;
use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface; use Symfony\Component\Console\Output\OutputInterface;
class increment extends \phpbb\console\command\command class increment extends command
{ {
/** @var \phpbb\config\config */
protected $config;
function __construct(\phpbb\config\config $config)
{
$this->config = $config;
parent::__construct();
}
protected function configure() protected function configure()
{ {
$this $this
->setName('config:increment') ->setName('config:increment')
->setDescription('Sets a configuration option\'s value') ->setDescription("Sets a configuration option's value")
->addArgument( ->addArgument(
'config-key', 'key',
InputArgument::REQUIRED, InputArgument::REQUIRED,
'The configuration option\'s name' "The configuration option's name"
) )
->addArgument( ->addArgument(
'increment', 'increment',
InputArgument::REQUIRED, InputArgument::REQUIRED,
'Amount to increment by' 'Amount to increment by'
) )
->addArgument( ->addOption(
'use-cache', 'dynamic',
InputArgument::OPTIONAL, 'd',
'Whether this variable should be cached or if it changes too frequently to be efficiently cached.', InputOption::VALUE_NONE,
true 'Set this option if the configuration option changes too frequently to be efficiently cached.'
) )
; ;
} }
protected function execute(InputInterface $input, OutputInterface $output) protected function execute(InputInterface $input, OutputInterface $output)
{ {
$key = $input->getArgument('config-key'); $key = $input->getArgument('key');
$increment = $input->getArgument('increment'); $increment = $input->getArgument('increment');
$use_cache = $input->getArgument('use-cache'); $use_cache = !$input->getOption('dynamic');
$use_cache = (strtolower($use_cache) !== 'false' && $use_cache);
$this->config->increment($key, $increment, $use_cache); $this->config->increment($key, $increment, $use_cache);

View File

@ -10,51 +10,42 @@ namespace phpbb\console\command\config;
use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface; use Symfony\Component\Console\Output\OutputInterface;
class set extends \phpbb\console\command\command class set extends command
{ {
/** @var \phpbb\config\config */
protected $config;
function __construct(\phpbb\config\config $config)
{
$this->config = $config;
parent::__construct();
}
protected function configure() protected function configure()
{ {
$this $this
->setName('config:set') ->setName('config:set')
->setDescription('Sets a configuration option\'s value') ->setDescription("Sets a configuration option's value")
->addArgument( ->addArgument(
'config-key', 'key',
InputArgument::REQUIRED, InputArgument::REQUIRED,
'The configuration option\'s name' "The configuration option's name"
) )
->addArgument( ->addArgument(
'config-value', 'value',
InputArgument::REQUIRED, InputArgument::REQUIRED,
'New configuration value' 'New configuration value, use 0 and 1 to specify boolean values'
) )
->addArgument( ->addOption(
'use-cache', 'dynamic',
InputArgument::OPTIONAL, 'd',
'Whether this variable should be cached or if it changes too frequently to be efficiently cached.', InputOption::VALUE_NONE,
true 'Set this option if the configuration option changes too frequently to be efficiently cached.'
) )
; ;
} }
protected function execute(InputInterface $input, OutputInterface $output) protected function execute(InputInterface $input, OutputInterface $output)
{ {
$key = $input->getArgument('config-key'); $key = $input->getArgument('key');
$value = $input->getArgument('config-value'); $value = $input->getArgument('value');
$use_cache = $input->getArgument('use-cache'); $use_cache = !$input->getOption('dynamic');
$use_cache = (strtolower($use_cache) !== 'false' && $use_cache);
var_dump($key, $value, $use_cache);
$this->config->set($key, $value, $use_cache); $this->config->set($key, $value, $use_cache);
$output->writeln("<info>Successfully set config $key</info>"); $output->writeln("<info>Successfully set config $key</info>");

View File

@ -10,56 +10,46 @@ namespace phpbb\console\command\config;
use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface; use Symfony\Component\Console\Output\OutputInterface;
class set_atomic extends \phpbb\console\command\command class set_atomic extends command
{ {
/** @var \phpbb\config\config */
protected $config;
function __construct(\phpbb\config\config $config)
{
$this->config = $config;
parent::__construct();
}
protected function configure() protected function configure()
{ {
$this $this
->setName('config:set-atomic') ->setName('config:set-atomic')
->setDescription('Sets a configuration option\'s value') ->setDescription("Sets a configuration option's value")
->addArgument( ->addArgument(
'config-key', 'key',
InputArgument::REQUIRED, InputArgument::REQUIRED,
'The configuration option\'s name' "The configuration option's name"
) )
->addArgument( ->addArgument(
'old-value', 'old',
InputArgument::REQUIRED, InputArgument::REQUIRED,
'Current configuration value' 'Current configuration value, use 0 and 1 to specify boolean values'
) )
->addArgument( ->addArgument(
'new-value', 'new',
InputArgument::REQUIRED, InputArgument::REQUIRED,
'New configuration value' 'New configuration value, use 0 and 1 to specify boolean values'
) )
->addArgument( ->addOption(
'use-cache', 'dynamic',
InputArgument::OPTIONAL, 'd',
'Whether this variable should be cached or if it changes too frequently to be efficiently cached.', InputOption::VALUE_NONE,
true 'Set this option if the configuration option changes too frequently to be efficiently cached.'
) )
; ;
} }
protected function execute(InputInterface $input, OutputInterface $output) protected function execute(InputInterface $input, OutputInterface $output)
{ {
$key = $input->getArgument('config-key'); $key = $input->getArgument('key');
$old_value = $input->getArgument('old-value'); $old_value = $input->getArgument('old');
$new_value = $input->getArgument('new-value'); $new_value = $input->getArgument('new');
$use_cache = $input->getArgument('use-cache'); $use_cache = !$input->getOption('dynamic');
$use_cache = (strtolower($use_cache) !== 'false' && $use_cache);
if ($this->config->set_atomic($key, $old_value, $new_value, $use_cache)) if ($this->config->set_atomic($key, $old_value, $new_value, $use_cache))
{ {