fix mysql & mariadb requirement checks on installation

This commit is contained in:
Mohit Panjwani
2021-06-25 16:24:18 +05:30
parent 18a2e83348
commit 2ec87baa6f
3 changed files with 24 additions and 13 deletions

View File

@ -6,7 +6,6 @@ use Crater\Http\Requests\DatabaseEnvironmentRequest;
use Crater\Http\Requests\DiskEnvironmentRequest; use Crater\Http\Requests\DiskEnvironmentRequest;
use Crater\Http\Requests\DomainEnvironmentRequest; use Crater\Http\Requests\DomainEnvironmentRequest;
use Crater\Http\Requests\MailEnvironmentRequest; use Crater\Http\Requests\MailEnvironmentRequest;
use Crater\Http\Requests\PaymentSettingsRequest;
use Exception; use Exception;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
@ -195,10 +194,7 @@ class EnvironmentManager
switch ($connection) { switch ($connection) {
case 'mysql': case 'mysql':
$dbSupportInfo = $checker->checkMysqlVersion( $dbSupportInfo = $checker->checkMysqlVersion($conn);
$conn,
config('crater.min_mysql_version')
);
break; break;

View File

@ -2,6 +2,7 @@
namespace Crater\Space; namespace Crater\Space;
use Illuminate\Support\Str;
use PDO; use PDO;
use SQLite3; use SQLite3;
@ -122,10 +123,16 @@ class RequirementsChecker
* *
* @return array * @return array
*/ */
public function checkMysqlVersion($conn, string $minMysqlVersion = null) public function checkMysqlVersion($conn)
{ {
$minVersionMysql = $minMysqlVersion; $version_info = $conn->getAttribute(PDO::ATTR_SERVER_VERSION);
$isMariaDb = Str::contains($version_info, 'MariaDB');
$minVersionMysql = $isMariaDb ? config('crater.min_mariadb_version') : config('crater.min_mysql_version');
$currentMysqlVersion = $this->getMysqlVersionInfo($conn); $currentMysqlVersion = $this->getMysqlVersionInfo($conn);
$supported = false; $supported = false;
if (version_compare($currentMysqlVersion, $minVersionMysql) >= 0) { if (version_compare($currentMysqlVersion, $minVersionMysql) >= 0) {
@ -148,9 +155,11 @@ class RequirementsChecker
*/ */
private static function getMysqlVersionInfo($pdo) private static function getMysqlVersionInfo($pdo)
{ {
$currentVersion = $pdo->getAttribute(PDO::ATTR_SERVER_VERSION); $version = $pdo->query('select version()')->fetchColumn();
return $currentVersion; preg_match("/^[0-9\.]+/", $version, $match);
return $match[0];
} }
/** /**

View File

@ -3,24 +3,30 @@
return [ return [
/* /*
* Minimum php version of the application. * Minimum php version.
*/ */
'min_php_version' => '7.4.0', 'min_php_version' => '7.4.0',
/* /*
* Minimum mysql version of the application. * Minimum mysql version.
*/ */
'min_mysql_version' => '5.7.7', 'min_mysql_version' => '5.7.7',
/* /*
* Minimum pgsql version of the application. * Minimum mariadb version.
*/
'min_mariadb_version' => '10.2.7',
/*
* Minimum pgsql version.
*/ */
'min_pgsql_version' => '9.2.0', 'min_pgsql_version' => '9.2.0',
/* /*
* Minimum sqlite version of the application. * Minimum sqlite version.
*/ */
'min_sqlite_version' => '3.24.0', 'min_sqlite_version' => '3.24.0',