diff options
author | John Molakvoæ <skjnldsv@users.noreply.github.com> | 2024-08-16 12:58:58 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-08-16 12:58:58 +0200 |
commit | 13a72d0f0e8f9ba12df2a7f2e0f28a02f4b9ce4a (patch) | |
tree | d3414f72df295ad92d2ad11b2e653875bbe12da9 | |
parent | 74b8de5665c31fab86f4ed3d64d9bd7669c5dc5f (diff) | |
parent | 67c52d202c3e8b8ccd00684d0c76e7ac5eab4e96 (diff) | |
download | nextcloud-server-13a72d0f0e8f9ba12df2a7f2e0f28a02f4b9ce4a.tar.gz nextcloud-server-13a72d0f0e8f9ba12df2a7f2e0f28a02f4b9ce4a.zip |
Merge pull request #38750 from whlsxl/postgres-install-error
-rw-r--r-- | lib/private/Setup/PostgreSQL.php | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/lib/private/Setup/PostgreSQL.php b/lib/private/Setup/PostgreSQL.php index 4ece8957ce6..7d204bb6d16 100644 --- a/lib/private/Setup/PostgreSQL.php +++ b/lib/private/Setup/PostgreSQL.php @@ -51,16 +51,6 @@ class PostgreSQL extends AbstractDatabase { $this->dbPassword = \OC::$server->get(ISecureRandom::class)->generate(30, ISecureRandom::CHAR_ALPHANUMERIC); $this->createDBUser($connection); - - // Go to the main database and grant create on the public schema - // The code below is implemented to make installing possible with PostgreSQL version 15: - // https://www.postgresql.org/docs/release/15.0/ - // From the release notes: For new databases having no need to defend against insider threats, granting CREATE permission will yield the behavior of prior releases - // Therefore we assume that the database is only used by one user/service which is Nextcloud - // Additional services should get installed in a separate database in order to stay secure - // Also see https://www.postgresql.org/docs/15/ddl-schemas.html#DDL-SCHEMAS-PATTERNS - $connectionMainDatabase->executeQuery('GRANT CREATE ON SCHEMA public TO "' . addslashes($this->dbUser) . '"'); - $connectionMainDatabase->close(); } } @@ -73,6 +63,20 @@ class PostgreSQL extends AbstractDatabase { $this->createDatabase($connection); // the connection to dbname=postgres is not needed anymore $connection->close(); + + if ($this->tryCreateDbUser) { + if ($canCreateRoles) { + // Go to the main database and grant create on the public schema + // The code below is implemented to make installing possible with PostgreSQL version 15: + // https://www.postgresql.org/docs/release/15.0/ + // From the release notes: For new databases having no need to defend against insider threats, granting CREATE permission will yield the behavior of prior releases + // Therefore we assume that the database is only used by one user/service which is Nextcloud + // Additional services should get installed in a separate database in order to stay secure + // Also see https://www.postgresql.org/docs/15/ddl-schemas.html#DDL-SCHEMAS-PATTERNS + $connectionMainDatabase->executeQuery('GRANT CREATE ON SCHEMA public TO "' . addslashes($this->dbUser) . '"'); + $connectionMainDatabase->close(); + } + } } catch (\Exception $e) { $this->logger->warning('Error trying to connect as "postgres", assuming database is setup and tables need to be created', [ 'exception' => $e, |