config = $config; } protected function configure() { $this ->setName('maintenance:install') ->setDescription('install ownCloud') ->addOption('database', null, InputOption::VALUE_REQUIRED, 'Supported database type', 'sqlite') ->addOption('database-name', null, InputOption::VALUE_REQUIRED, 'Name of the database') ->addOption('database-host', null, InputOption::VALUE_REQUIRED, 'Hostname of the database', 'localhost') ->addOption('database-user', null, InputOption::VALUE_REQUIRED, 'User name to connect to the database') ->addOption('database-pass', null, InputOption::VALUE_REQUIRED, 'Password of the database user') ->addOption('database-table-prefix', null, InputOption::VALUE_REQUIRED, 'Prefix for all tables', 'oc_') ->addOption('admin-user', null, InputOption::VALUE_REQUIRED, 'User name of the admin account', 'admin') ->addOption('admin-pass', null, InputOption::VALUE_REQUIRED, 'Password of the admin account') ->addOption('data-dir', null, InputOption::VALUE_REQUIRED, 'Path to data directory', \OC::$SERVERROOT."/data"); } protected function execute(InputInterface $input, OutputInterface $output) { $options = $this->validateInput($input, $output); $errors = \OC\Setup::install($options); if (count($errors) === 0) { $output->writeln("ownCloud was successfully installed"); return 0; } foreach($errors as $error) { if (is_array($error)) { $output->writeln('' . (string)$error['error'] . ''); $output->writeln(' -> ' . (string)$error['hint'] . ''); } else { $output->writeln('' . (string)$error . ''); } } return 1; } /** * @param InputInterface $input * @param OutputInterface $output * @return array */ protected function validateInput(InputInterface $input, OutputInterface $output) { $db = strtolower($input->getOption('database')); $supportedDatabases = $this->config->getSystemValue('supportedDatabases', [ 'sqlite', 'mysql', 'pgsql', 'oci', 'mssql' ]); if (!in_array($db, $supportedDatabases)) { throw new InvalidArgumentException("Database <$db> is not supported."); } $dbUser = $input->getOption('database-user'); $dbPass = $input->getOption('database-pass'); $dbName = $input->getOption('database-name'); $dbHost = $input->getOption('database-host'); $dbTablePrefix = $input->getOption('database-table-prefix'); $adminLogin = $input->getOption('admin-user'); $adminPassword = $input->getOption('admin-pass'); $dataDir = $input->getOption('data-dir'); if ($db !== 'sqlite') { if (is_null($dbUser)) { throw new InvalidArgumentException("Database user not provided."); } if (is_null($dbName)) { throw new InvalidArgumentException("Database name not provided."); } if (is_null($dbPass)) { /** @var $dialog \Symfony\Component\Console\Helper\DialogHelper */ $dialog = $this->getHelperSet()->get('dialog'); $dbPass = $dialog->askHiddenResponse( $output, "What is the password to access the database with user <$dbUser>?", false ); } } if (is_null($adminPassword)) { /** @var $dialog \Symfony\Component\Console\Helper\DialogHelper */ $dialog = $this->getHelperSet()->get('dialog'); $adminPassword = $dialog->askHiddenResponse( $output, "What is the password you like to use for the admin account <$adminLogin>?", false ); } $options = [ 'dbtype' => $db, 'dbuser' => $dbUser, 'dbpass' => $dbPass, 'dbname' => $dbName, 'dbhost' => $dbHost, 'dbtableprefix' => $dbTablePrefix, 'adminlogin' => $adminLogin, 'adminpass' => $adminPassword, 'directory' => $dataDir ]; return $options; } }