aboutsummaryrefslogtreecommitdiffstats
path: root/apps/settings/lib/SetupChecks/SupportedDatabase.php
diff options
context:
space:
mode:
Diffstat (limited to 'apps/settings/lib/SetupChecks/SupportedDatabase.php')
-rw-r--r--apps/settings/lib/SetupChecks/SupportedDatabase.php64
1 files changed, 54 insertions, 10 deletions
diff --git a/apps/settings/lib/SetupChecks/SupportedDatabase.php b/apps/settings/lib/SetupChecks/SupportedDatabase.php
index 43807a90251..d083958d16e 100644
--- a/apps/settings/lib/SetupChecks/SupportedDatabase.php
+++ b/apps/settings/lib/SetupChecks/SupportedDatabase.php
@@ -19,6 +19,14 @@ use OCP\SetupCheck\ISetupCheck;
use OCP\SetupCheck\SetupResult;
class SupportedDatabase implements ISetupCheck {
+
+ private const MIN_MARIADB = '10.6';
+ private const MAX_MARIADB = '11.8';
+ private const MIN_MYSQL = '8.0';
+ private const MAX_MYSQL = '8.4';
+ private const MIN_POSTGRES = '13';
+ private const MAX_POSTGRES = '17';
+
public function __construct(
private IL10N $l10n,
private IURLGenerator $urlGenerator,
@@ -38,8 +46,8 @@ class SupportedDatabase implements ISetupCheck {
$version = null;
$databasePlatform = $this->connection->getDatabasePlatform();
if ($databasePlatform instanceof MySQLPlatform) {
- $result = $this->connection->prepare("SHOW VARIABLES LIKE 'version';");
- $result->execute();
+ $statement = $this->connection->prepare("SHOW VARIABLES LIKE 'version';");
+ $result = $statement->execute();
$row = $result->fetch();
$version = $row['Value'];
$versionlc = strtolower($version);
@@ -47,25 +55,61 @@ class SupportedDatabase implements ISetupCheck {
[$major, $minor, ] = explode('.', $versionlc);
$versionConcern = $major . '.' . $minor;
if (str_contains($versionlc, 'mariadb')) {
- if (version_compare($versionConcern, '10.3', '<') || version_compare($versionConcern, '10.11', '>')) {
- return SetupResult::warning($this->l10n->t('MariaDB version "%s" detected. MariaDB >=10.3 and <=10.11 is suggested for best performance, stability and functionality with this version of Nextcloud.', $version));
+ if (version_compare($versionConcern, '10.3', '=')) {
+ return SetupResult::info(
+ $this->l10n->t(
+ 'MariaDB version 10.3 detected, this version is end-of-life and only supported as part of Ubuntu 20.04. MariaDB >=%1$s and <=%2$s is suggested for best performance, stability and functionality with this version of Nextcloud.',
+ [
+ self::MIN_MARIADB,
+ self::MAX_MARIADB,
+ ]
+ ),
+ );
+ } elseif (version_compare($versionConcern, self::MIN_MARIADB, '<') || version_compare($versionConcern, self::MAX_MARIADB, '>')) {
+ return SetupResult::warning(
+ $this->l10n->t(
+ 'MariaDB version "%1$s" detected. MariaDB >=%2$s and <=%3$s is suggested for best performance, stability and functionality with this version of Nextcloud.',
+ [
+ $version,
+ self::MIN_MARIADB,
+ self::MAX_MARIADB,
+ ],
+ ),
+ );
}
} else {
- if (version_compare($versionConcern, '8.0', '<') || version_compare($versionConcern, '8.3', '>')) {
- return SetupResult::warning($this->l10n->t('MySQL version "%s" detected. MySQL >=8.0 and <=8.3 is suggested for best performance, stability and functionality with this version of Nextcloud.', $version));
+ if (version_compare($versionConcern, self::MIN_MYSQL, '<') || version_compare($versionConcern, self::MAX_MYSQL, '>')) {
+ return SetupResult::warning(
+ $this->l10n->t(
+ 'MySQL version "%1$s" detected. MySQL >=%2$s and <=%3$s is suggested for best performance, stability and functionality with this version of Nextcloud.',
+ [
+ $version,
+ self::MIN_MYSQL,
+ self::MAX_MYSQL,
+ ],
+ ),
+ );
}
}
} elseif ($databasePlatform instanceof PostgreSQLPlatform) {
- $result = $this->connection->prepare('SHOW server_version;');
- $result->execute();
+ $statement = $this->connection->prepare('SHOW server_version;');
+ $result = $statement->execute();
$row = $result->fetch();
$version = $row['server_version'];
$versionlc = strtolower($version);
// we only care about X not X.Y or X.Y.Z differences
[$major, ] = explode('.', $versionlc);
$versionConcern = $major;
- if (version_compare($versionConcern, '12', '<') || version_compare($versionConcern, '16', '>')) {
- return SetupResult::warning($this->l10n->t('PostgreSQL version "%s" detected. PostgreSQL >=12 and <=16 is suggested for best performance, stability and functionality with this version of Nextcloud.', $version));
+ if (version_compare($versionConcern, self::MIN_POSTGRES, '<') || version_compare($versionConcern, self::MAX_POSTGRES, '>')) {
+ return SetupResult::warning(
+ $this->l10n->t(
+ 'PostgreSQL version "%1$s" detected. PostgreSQL >=%2$s and <=%3$s is suggested for best performance, stability and functionality with this version of Nextcloud.',
+ [
+ $version,
+ self::MIN_POSTGRES,
+ self::MAX_POSTGRES,
+ ])
+ );
}
} elseif ($databasePlatform instanceof OraclePlatform) {
$version = 'Oracle';