123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-only
- */
- namespace OC\Setup;
- use OC\DB\Connection;
- use OC\DB\ConnectionFactory;
- use OC\DB\MigrationService;
- use OC\SystemConfig;
- use OCP\IL10N;
- use OCP\Migration\IOutput;
- use OCP\Security\ISecureRandom;
- use Psr\Log\LoggerInterface;
- abstract class AbstractDatabase {
- /** @var IL10N */
- protected $trans;
- /** @var string */
- protected $dbUser;
- /** @var string */
- protected $dbPassword;
- /** @var string */
- protected $dbName;
- /** @var string */
- protected $dbHost;
- /** @var string */
- protected $dbPort;
- /** @var string */
- protected $tablePrefix;
- /** @var SystemConfig */
- protected $config;
- /** @var LoggerInterface */
- protected $logger;
- /** @var ISecureRandom */
- protected $random;
- /** @var bool */
- protected $tryCreateDbUser;
- public function __construct(IL10N $trans, SystemConfig $config, LoggerInterface $logger, ISecureRandom $random) {
- $this->trans = $trans;
- $this->config = $config;
- $this->logger = $logger;
- $this->random = $random;
- }
- public function validate($config) {
- $errors = [];
- if (empty($config['dbuser']) && empty($config['dbname'])) {
- $errors[] = $this->trans->t('Enter the database Login and name for %s', [$this->dbprettyname]);
- } elseif (empty($config['dbuser'])) {
- $errors[] = $this->trans->t('Enter the database Login for %s', [$this->dbprettyname]);
- } elseif (empty($config['dbname'])) {
- $errors[] = $this->trans->t('Enter the database name for %s', [$this->dbprettyname]);
- }
- if (substr_count($config['dbname'], '.') >= 1) {
- $errors[] = $this->trans->t('You cannot use dots in the database name %s', [$this->dbprettyname]);
- }
- return $errors;
- }
- public function initialize($config) {
- $dbUser = $config['dbuser'];
- $dbPass = $config['dbpass'];
- $dbName = $config['dbname'];
- $dbHost = !empty($config['dbhost']) ? $config['dbhost'] : 'localhost';
- $dbPort = !empty($config['dbport']) ? $config['dbport'] : '';
- $dbTablePrefix = $config['dbtableprefix'] ?? 'oc_';
- $createUserConfig = $this->config->getValue('setup_create_db_user', true);
- // accept `false` both as bool and string, since setting config values from env will result in a string
- $this->tryCreateDbUser = $createUserConfig !== false && $createUserConfig !== 'false';
- $this->config->setValues([
- 'dbname' => $dbName,
- 'dbhost' => $dbHost,
- 'dbport' => $dbPort,
- 'dbtableprefix' => $dbTablePrefix,
- ]);
- $this->dbUser = $dbUser;
- $this->dbPassword = $dbPass;
- $this->dbName = $dbName;
- $this->dbHost = $dbHost;
- $this->dbPort = $dbPort;
- $this->tablePrefix = $dbTablePrefix;
- }
- /**
- * @param array $configOverwrite
- * @return \OC\DB\Connection
- */
- protected function connect(array $configOverwrite = []): Connection {
- $connectionParams = [
- 'host' => $this->dbHost,
- 'user' => $this->dbUser,
- 'password' => $this->dbPassword,
- 'tablePrefix' => $this->tablePrefix,
- 'dbname' => $this->dbName
- ];
- // adding port support through installer
- if (!empty($this->dbPort)) {
- if (ctype_digit($this->dbPort)) {
- $connectionParams['port'] = $this->dbPort;
- } else {
- $connectionParams['unix_socket'] = $this->dbPort;
- }
- } elseif (strpos($this->dbHost, ':')) {
- // Host variable may carry a port or socket.
- [$host, $portOrSocket] = explode(':', $this->dbHost, 2);
- if (ctype_digit($portOrSocket)) {
- $connectionParams['port'] = $portOrSocket;
- } else {
- $connectionParams['unix_socket'] = $portOrSocket;
- }
- $connectionParams['host'] = $host;
- }
- $connectionParams = array_merge($connectionParams, $configOverwrite);
- $connectionParams = array_merge($connectionParams, ['primary' => $connectionParams, 'replica' => [$connectionParams]]);
- $cf = new ConnectionFactory($this->config);
- $connection = $cf->getConnection($this->config->getValue('dbtype', 'sqlite'), $connectionParams);
- $connection->ensureConnectedToPrimary();
- return $connection;
- }
- /**
- * @param string $username
- */
- abstract public function setupDatabase($username);
- public function runMigrations(?IOutput $output = null) {
- if (!is_dir(\OC::$SERVERROOT.'/core/Migrations')) {
- return;
- }
- $ms = new MigrationService('core', \OC::$server->get(Connection::class), $output);
- $ms->migrate('latest', true);
- }
- }
|