aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--console.php36
-rw-r--r--lib/private/console/application.php76
2 files changed, 80 insertions, 32 deletions
diff --git a/console.php b/console.php
index 7536908a5c1..3da87b75c8e 100644
--- a/console.php
+++ b/console.php
@@ -23,8 +23,8 @@
*
*/
-use Symfony\Component\Console\Application;
-use Symfony\Component\Console\Input\ArgvInput;
+use OC\Console\Application;
+use Symfony\Component\Console\Output\ConsoleOutput;
define('OC_CONSOLE', 1);
@@ -54,36 +54,8 @@ try {
}
}
- $defaults = new OC_Defaults;
- $application = new Application($defaults->getName(), \OC_Util::getVersionString());
- require_once 'core/register_command.php';
- if (\OC::$server->getConfig()->getSystemValue('installed', false)) {
- if (!\OCP\Util::needUpgrade()) {
- OC_App::loadApps();
- foreach (OC_App::getAllApps() as $app) {
- $file = OC_App::getAppPath($app) . '/appinfo/register_command.php';
- if (file_exists($file)) {
- require $file;
- }
- }
- } else {
- echo "ownCloud or one of the apps require upgrade - only a limited number of commands are available" . PHP_EOL;
- }
- } else {
- echo "ownCloud is not installed - only a limited number of commands are available" . PHP_EOL;
- }
- $input = new ArgvInput();
- if ($input->getFirstArgument() !== 'check') {
- $errors = \OC_Util::checkServer(\OC::$server->getConfig());
- if (!empty($errors)) {
- foreach ($errors as $error) {
- echo $error['error'] . "\n";
- echo $error['hint'] . "\n\n";
- }
- exit(1);
- }
- }
-
+ $application = new Application(\OC::$server->getConfig());
+ $application->loadCommands(new ConsoleOutput());
$application->run();
} catch (Exception $ex) {
echo "An unhandled exception has been thrown:" . PHP_EOL;
diff --git a/lib/private/console/application.php b/lib/private/console/application.php
new file mode 100644
index 00000000000..d7f8ac53f91
--- /dev/null
+++ b/lib/private/console/application.php
@@ -0,0 +1,76 @@
+<?php
+
+namespace OC\Console;
+
+use OC_App;
+use OC_Defaults;
+use OCP\IConfig;
+use Symfony\Component\Console\Application as SymfonyApplication;
+use Symfony\Component\Console\Input\ArgvInput;
+use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Output\OutputInterface;
+
+class Application {
+ /**
+ * @var IConfig
+ */
+ private $config;
+
+ /**
+ * @param IConfig $config
+ */
+ public function __construct(IConfig $config) {
+ $defaults = new OC_Defaults;
+ $this->config = $config;
+ $this->application = new SymfonyApplication($defaults->getName(), \OC_Util::getVersionString());
+ }
+
+ /**
+ * @param OutputInterface $output
+ */
+ public function loadCommands(OutputInterface $output) {
+ // $application is required to be defined in the register_command scripts
+ $application = $this->application;
+ require_once \OC::$SERVERROOT . '/core/register_command.php';
+ if ($this->config->getSystemValue('installed', false)) {
+ if (!\OCP\Util::needUpgrade()) {
+ OC_App::loadApps();
+ foreach (OC_App::getAllApps() as $app) {
+ $file = OC_App::getAppPath($app) . '/appinfo/register_command.php';
+ if (file_exists($file)) {
+ require $file;
+ }
+ }
+ } else {
+ $output->writeln("ownCloud or one of the apps require upgrade - only a limited number of commands are available");
+ }
+ } else {
+ $output->writeln("ownCloud is not installed - only a limited number of commands are available");
+ }
+ $input = new ArgvInput();
+ if ($input->getFirstArgument() !== 'check') {
+ $errors = \OC_Util::checkServer(\OC::$server->getConfig());
+ if (!empty($errors)) {
+ foreach ($errors as $error) {
+ $output->writeln($error['error']);
+ $output->writeln($error['hint']);
+ $output->writeln('');
+ }
+ }
+ }
+ }
+
+ public function setAutoExit($boolean) {
+ $this->application->setAutoExit($boolean);
+ }
+
+ /**
+ * @param InputInterface $input
+ * @param OutputInterface $output
+ * @return int
+ * @throws \Exception
+ */
+ public function run(InputInterface $input = null, OutputInterface $output = null) {
+ return $this->application->run($input, $output);
+ }
+}