From 7151369e5fe41a35b364f583ee2883b83193cfe1 Mon Sep 17 00:00:00 2001 From: scolebrook Date: Tue, 27 May 2014 13:03:53 -0400 Subject: Add ability to enable/disable maintenance mode from cli. --- core/command/maintenance/mmode.php | 52 ++++++++++++++++++++++++++++++++++++++ core/register_command.php | 1 + 2 files changed, 53 insertions(+) create mode 100644 core/command/maintenance/mmode.php diff --git a/core/command/maintenance/mmode.php b/core/command/maintenance/mmode.php new file mode 100644 index 00000000000..be007c5f4d3 --- /dev/null +++ b/core/command/maintenance/mmode.php @@ -0,0 +1,52 @@ + + * and Stephen Colebrook + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +namespace OC\Core\Command\Maintenance; + +use Symfony\Component\Console\Command\Command; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Input\InputOption; +use Symfony\Component\Console\Output\OutputInterface; + +class MMode extends Command { + + protected function configure() { + $this + ->setName('maintenance:mmode') + ->setDescription('set maintenance mode') + ->addOption( + 'on', + null, + InputOption::VALUE_NONE, + 'enable maintenance mode' + ) + ->addOption( + 'off', + null, + InputOption::VALUE_NONE, + 'disable maintenance mode' + ); + } + + protected function execute(InputInterface $input, OutputInterface $output) { + if ($input->getOption('on')) { + \OC_Config::setValue('maintenance', true); + $output->writeln('Maintenance mode enabled'); + } elseif ($input->getOption('off')) { + \OC_Config::setValue('maintenance', false); + $output->writeln('Maintenance mode disabled'); + } else { + if (\OC_Config::getValue('maintenance', false)) { + $output->writeln('Maintenance mode is currently enabled'); + } else { + $output->writeln('Maintenance mode is currently disabled'); + } + } + } +} diff --git a/core/register_command.php b/core/register_command.php index f1361c859fc..cad5606b2e1 100644 --- a/core/register_command.php +++ b/core/register_command.php @@ -12,6 +12,7 @@ $application->add(new OC\Core\Command\Db\GenerateChangeScript()); $application->add(new OC\Core\Command\Db\ConvertType(OC_Config::getObject(), new \OC\DB\ConnectionFactory())); $application->add(new OC\Core\Command\Upgrade()); $application->add(new OC\Core\Command\Maintenance\SingleUser()); +$application->add(new OC\Core\Command\Maintenance\MMode()); $application->add(new OC\Core\Command\App\Disable()); $application->add(new OC\Core\Command\App\Enable()); $application->add(new OC\Core\Command\App\ListApps()); -- cgit v1.2.3 From 00f811f09c3c717c59bd1994d583d8ebfdefd380 Mon Sep 17 00:00:00 2001 From: scolebrook Date: Wed, 28 May 2014 09:41:34 -0400 Subject: Changed class name to mode --- core/command/maintenance/mmode.php | 52 -------------------------------------- core/command/maintenance/mode.php | 52 ++++++++++++++++++++++++++++++++++++++ core/register_command.php | 2 +- 3 files changed, 53 insertions(+), 53 deletions(-) delete mode 100644 core/command/maintenance/mmode.php create mode 100644 core/command/maintenance/mode.php diff --git a/core/command/maintenance/mmode.php b/core/command/maintenance/mmode.php deleted file mode 100644 index be007c5f4d3..00000000000 --- a/core/command/maintenance/mmode.php +++ /dev/null @@ -1,52 +0,0 @@ - - * and Stephen Colebrook - * This file is licensed under the Affero General Public License version 3 or - * later. - * See the COPYING-README file. - */ - -namespace OC\Core\Command\Maintenance; - -use Symfony\Component\Console\Command\Command; -use Symfony\Component\Console\Input\InputInterface; -use Symfony\Component\Console\Input\InputOption; -use Symfony\Component\Console\Output\OutputInterface; - -class MMode extends Command { - - protected function configure() { - $this - ->setName('maintenance:mmode') - ->setDescription('set maintenance mode') - ->addOption( - 'on', - null, - InputOption::VALUE_NONE, - 'enable maintenance mode' - ) - ->addOption( - 'off', - null, - InputOption::VALUE_NONE, - 'disable maintenance mode' - ); - } - - protected function execute(InputInterface $input, OutputInterface $output) { - if ($input->getOption('on')) { - \OC_Config::setValue('maintenance', true); - $output->writeln('Maintenance mode enabled'); - } elseif ($input->getOption('off')) { - \OC_Config::setValue('maintenance', false); - $output->writeln('Maintenance mode disabled'); - } else { - if (\OC_Config::getValue('maintenance', false)) { - $output->writeln('Maintenance mode is currently enabled'); - } else { - $output->writeln('Maintenance mode is currently disabled'); - } - } - } -} diff --git a/core/command/maintenance/mode.php b/core/command/maintenance/mode.php new file mode 100644 index 00000000000..b4a7408d015 --- /dev/null +++ b/core/command/maintenance/mode.php @@ -0,0 +1,52 @@ + + * and Stephen Colebrook + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + +namespace OC\Core\Command\Maintenance; + +use Symfony\Component\Console\Command\Command; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Input\InputOption; +use Symfony\Component\Console\Output\OutputInterface; + +class Mode extends Command { + + protected function configure() { + $this + ->setName('maintenance:mode') + ->setDescription('set maintenance mode') + ->addOption( + 'on', + null, + InputOption::VALUE_NONE, + 'enable maintenance mode' + ) + ->addOption( + 'off', + null, + InputOption::VALUE_NONE, + 'disable maintenance mode' + ); + } + + protected function execute(InputInterface $input, OutputInterface $output) { + if ($input->getOption('on')) { + \OC_Config::setValue('maintenance', true); + $output->writeln('Maintenance mode enabled'); + } elseif ($input->getOption('off')) { + \OC_Config::setValue('maintenance', false); + $output->writeln('Maintenance mode disabled'); + } else { + if (\OC_Config::getValue('maintenance', false)) { + $output->writeln('Maintenance mode is currently enabled'); + } else { + $output->writeln('Maintenance mode is currently disabled'); + } + } + } +} diff --git a/core/register_command.php b/core/register_command.php index cad5606b2e1..801fd987912 100644 --- a/core/register_command.php +++ b/core/register_command.php @@ -12,7 +12,7 @@ $application->add(new OC\Core\Command\Db\GenerateChangeScript()); $application->add(new OC\Core\Command\Db\ConvertType(OC_Config::getObject(), new \OC\DB\ConnectionFactory())); $application->add(new OC\Core\Command\Upgrade()); $application->add(new OC\Core\Command\Maintenance\SingleUser()); -$application->add(new OC\Core\Command\Maintenance\MMode()); +$application->add(new OC\Core\Command\Maintenance\Mode()); $application->add(new OC\Core\Command\App\Disable()); $application->add(new OC\Core\Command\App\Enable()); $application->add(new OC\Core\Command\App\ListApps()); -- cgit v1.2.3 From 43759f1f468fac8de4a8db0b8d94d004f6fb3745 Mon Sep 17 00:00:00 2001 From: scolebrook Date: Wed, 28 May 2014 16:26:13 -0400 Subject: Use OC\Config instead of OC_Config --- core/command/maintenance/mode.php | 19 ++++++++++++++----- core/register_command.php | 2 +- 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/core/command/maintenance/mode.php b/core/command/maintenance/mode.php index b4a7408d015..f26a11384a8 100644 --- a/core/command/maintenance/mode.php +++ b/core/command/maintenance/mode.php @@ -1,7 +1,7 @@ - * and Stephen Colebrook + * Copyright (c) 2013 Robin Appelman and + * Copyright (c) 2014 Stephen Colebrook * This file is licensed under the Affero General Public License version 3 or * later. * See the COPYING-README file. @@ -9,6 +9,8 @@ namespace OC\Core\Command\Maintenance; +use OC\Config; + use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputOption; @@ -16,6 +18,13 @@ use Symfony\Component\Console\Output\OutputInterface; class Mode extends Command { + protected $config; + + public function __construct(Config $config) { + $this->config = $config; + parent::__construct(); + } + protected function configure() { $this ->setName('maintenance:mode') @@ -36,13 +45,13 @@ class Mode extends Command { protected function execute(InputInterface $input, OutputInterface $output) { if ($input->getOption('on')) { - \OC_Config::setValue('maintenance', true); + $this->config->setValue('maintenance', true); $output->writeln('Maintenance mode enabled'); } elseif ($input->getOption('off')) { - \OC_Config::setValue('maintenance', false); + $this->config->setValue('maintenance', false); $output->writeln('Maintenance mode disabled'); } else { - if (\OC_Config::getValue('maintenance', false)) { + if ($this->config->getValue('maintenance', false)) { $output->writeln('Maintenance mode is currently enabled'); } else { $output->writeln('Maintenance mode is currently disabled'); diff --git a/core/register_command.php b/core/register_command.php index 801fd987912..8b1491a2cb7 100644 --- a/core/register_command.php +++ b/core/register_command.php @@ -12,7 +12,7 @@ $application->add(new OC\Core\Command\Db\GenerateChangeScript()); $application->add(new OC\Core\Command\Db\ConvertType(OC_Config::getObject(), new \OC\DB\ConnectionFactory())); $application->add(new OC\Core\Command\Upgrade()); $application->add(new OC\Core\Command\Maintenance\SingleUser()); -$application->add(new OC\Core\Command\Maintenance\Mode()); +$application->add(new OC\Core\Command\Maintenance\Mode(OC_Config::getObject())); $application->add(new OC\Core\Command\App\Disable()); $application->add(new OC\Core\Command\App\Enable()); $application->add(new OC\Core\Command\App\ListApps()); -- cgit v1.2.3