aboutsummaryrefslogtreecommitdiffstats
path: root/lib/private/Setup/AbstractDatabase.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/private/Setup/AbstractDatabase.php')
-rw-r--r--lib/private/Setup/AbstractDatabase.php138
1 files changed, 138 insertions, 0 deletions
diff --git a/lib/private/Setup/AbstractDatabase.php b/lib/private/Setup/AbstractDatabase.php
new file mode 100644
index 00000000000..8f6294faa66
--- /dev/null
+++ b/lib/private/Setup/AbstractDatabase.php
@@ -0,0 +1,138 @@
+<?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,
+ '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;
+ }
+
+ abstract public function setupDatabase();
+
+ 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);
+ }
+}