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_OPTIONAL, 'Prefix for all tables (default: oc_)', null) ->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) { // validate the environment $setupHelper = new Setup($this->config, \OC::$server->getIniWrapper(), \OC::$server->getL10N('lib'), new \OC_Defaults()); $sysInfo = $setupHelper->getSystemInfo(true); $errors = $sysInfo['errors']; if (count($errors) > 0) { $this->printErrors($output, $errors); return 1; } // validate user input $options = $this->validateInput($input, $output, array_keys($sysInfo['databases'])); // perform installation $errors = $setupHelper->install($options); if (count($errors) > 0) { $this->printErrors($output, $errors); return 1; } $output->writeln("ownCloud was successfully installed"); return 0; } /** * @param InputInterface $input * @param OutputInterface $output * @param string[] $supportedDatabases * @return array */ protected function validateInput(InputInterface $input, OutputInterface $output, $supportedDatabases) { $db = strtolower($input->getOption('database')); 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 = 'oc_'; if ($input->hasParameterOption('--database-table-prefix')) { $dbTablePrefix = (string) $input->getOption('database-table-prefix'); $dbTablePrefix = trim($dbTablePrefix); } $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; } /** * @param OutputInterface $output * @param $errors */ protected function printErrors(OutputInterface $output, $errors) { foreach ($errors as $error) { if (is_array($error)) { $output->writeln('' . (string)$error['error'] . ''); $output->writeln(' -> ' . (string)$error['hint'] . ''); } else { $output->writeln('' . (string)$error . ''); } } } }