From 4e31b968a2fb5297e0594f22a1a8cf1fc9510979 Mon Sep 17 00:00:00 2001 From: "alejandro.campos@artica.es" Date: Tue, 24 Oct 2023 11:56:35 +0200 Subject: [PATCH 1/4] oum update checks --- .../lib/UpdateManager/Client.php | 58 +++++++++++++++++++ .../required_um_versions.php | 5 ++ 2 files changed, 63 insertions(+) create mode 100644 pandora_console/update_manager_client/required_um_versions.php diff --git a/pandora_console/update_manager_client/lib/UpdateManager/Client.php b/pandora_console/update_manager_client/lib/UpdateManager/Client.php index 42d9e6367a..678c0e7320 100644 --- a/pandora_console/update_manager_client/lib/UpdateManager/Client.php +++ b/pandora_console/update_manager_client/lib/UpdateManager/Client.php @@ -1246,6 +1246,40 @@ class Client } + /** + * Compare version strings. + * + * @param string $version1 Version1. + * @param string $version2 Version2. + * + * @return array + * @throws \Exception On error. + */ + private function compareVersions(string $version1, string $version2):int + { + $v1_components = explode('.', $version1); + $v2_components = explode('.', $version2); + + $maxLength = max(count($v1_components), count($v2_components)); + + for ($i = 0; $i < $maxLength; $i++) { + $v1_part = isset($v1_components[$i]) === true ? intval($v1_components[$i]) : 0; + $v2_part = isset($v2_components[$i]) === true ? intval($v2_components[$i]) : 0; + + if ($v1_part < $v2_part) { + // $version1 is older. + return -1; + } else if ($v1_part > $v2_part) { + // $version1 is newer. + return 1; + } + } + + // Versions are identical. + return 0; + } + + /** * Update files. * @@ -1284,6 +1318,30 @@ class Client throw new \Exception('Files are not readable'); } + // External path to required versions file. + $filepath = $this->tmpDir.'/downloads/'.$version.'/required_um_versions.php'; + + if (file_exists($filepath) === true) { + include $filepath; + + $curr_php_version = phpversion(); + $curr_mysql_version = db_get_value_sql('SELECT VERSION() AS version'); + + if (isset($php_version) === true + && is_string($php_version) === true + && $this->compareVersions($curr_php_version, $php_version) < 0 + ) { + throw new \Exception('PHP version >= '.$php_version.' is required'); + } + + if (isset($mysql_version) === true + && is_string($mysql_version) === true + && $this->compareVersions($curr_mysql_version, $mysql_version) < 0 + ) { + throw new \Exception('MySQL version >= '.$mysql_version.' is required'); + } + } + $created_directories = []; while (($pf = readdir($pd)) !== false) { diff --git a/pandora_console/update_manager_client/required_um_versions.php b/pandora_console/update_manager_client/required_um_versions.php new file mode 100644 index 0000000000..52345d521b --- /dev/null +++ b/pandora_console/update_manager_client/required_um_versions.php @@ -0,0 +1,5 @@ + Date: Tue, 24 Oct 2023 12:00:57 +0200 Subject: [PATCH 2/4] oum update checks --- pandora_console/update_manager_client/required_um_versions.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pandora_console/update_manager_client/required_um_versions.php b/pandora_console/update_manager_client/required_um_versions.php index 52345d521b..ba8e16a5d1 100644 --- a/pandora_console/update_manager_client/required_um_versions.php +++ b/pandora_console/update_manager_client/required_um_versions.php @@ -1,5 +1,5 @@ Date: Fri, 27 Oct 2023 08:42:07 +0200 Subject: [PATCH 3/4] change location of file --- .../{update_manager_client => }/required_um_versions.php | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename pandora_console/{update_manager_client => }/required_um_versions.php (100%) diff --git a/pandora_console/update_manager_client/required_um_versions.php b/pandora_console/required_um_versions.php similarity index 100% rename from pandora_console/update_manager_client/required_um_versions.php rename to pandora_console/required_um_versions.php From 7e4016579aea0965d4c4abf41915caf28420342e Mon Sep 17 00:00:00 2001 From: "alejandro.campos@artica.es" Date: Mon, 18 Dec 2023 12:47:54 +0100 Subject: [PATCH 4/4] minor change --- .../lib/UpdateManager/Client.php | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/pandora_console/update_manager_client/lib/UpdateManager/Client.php b/pandora_console/update_manager_client/lib/UpdateManager/Client.php index 5bfcedfb64..7a40deea5b 100644 --- a/pandora_console/update_manager_client/lib/UpdateManager/Client.php +++ b/pandora_console/update_manager_client/lib/UpdateManager/Client.php @@ -1460,6 +1460,8 @@ class Client bool $classic=false, bool $called_recursively=false ) :void { + global $config; + if (is_dir($from) !== true || is_readable($from) !== true) { throw new \Exception('Cannot access patch files '.$from); } @@ -1480,9 +1482,20 @@ class Client } // External path to required versions file. - $filepath = $this->tmpDir.'/downloads/'.$version.'/required_um_versions.php'; + $download_filepath = $this->tmpDir.'/downloads/'.$version.'/required_um_versions.php'; - if (file_exists($filepath) === true) { + // Fallback file path in console root. + $local_filepath = $config['homedir'].'/required_um_versions.php'; + + $filepath = null; + + if (file_exists($download_filepath) === true) { + $filepath = $download_filepath; + } else if (file_exists($local_filepath) === true) { + $filepath = $local_filepath; + } + + if ($filepath !== null) { include $filepath; $curr_php_version = phpversion();