From 0e002df2af1da836d489a0f377fe6d3affd0884b Mon Sep 17 00:00:00 2001 From: SylvainLelievre Date: Fri, 19 Feb 2021 07:14:42 +0100 Subject: [PATCH 1/3] =?UTF-8?q?Correction=20dans=20addon=20du=20contr?= =?UTF-8?q?=C3=B4le=20d'update?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- core/module/addon/addon.php | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/core/module/addon/addon.php b/core/module/addon/addon.php index e442f178..d2a84268 100644 --- a/core/module/addon/addon.php +++ b/core/module/addon/addon.php @@ -11,7 +11,7 @@ * @author Frédéric Tempez * @copyright Copyright (C) 2018-2021, Frédéric Tempez * @author Sylvain Lelièvre -* @copyright Copyright (C) 2020-2021, Sylvain Lelièvre + * @copyright Copyright (C) 2020-2021, Sylvain Lelièvre * @license GNU General Public License, version 3 * @link http://zwiicms.fr/ */ @@ -142,9 +142,10 @@ class addon extends common { // Module normalisé ? if( is_file( $moduleDir.'/'.$moduleName.'/'.$moduleName.'.php' ) AND is_file( $moduleDir.'/'.$moduleName.'/view/index/index.php' ) ){ - // Lecture de la version du module pour validation de la mise à jour + // Lecture de la version et de la validation d'update du module pour validation de la mise à jour // Pour une version <= version installée l'utilisateur doit cocher 'Mise à jour forcée' $version = '0.0'; + $update = false; $file = file_get_contents( $moduleDir.'/'.$moduleName.'/'.$moduleName.'.php'); $file = str_replace(' ','',$file); $file = str_replace("\t",'',$file); @@ -154,6 +155,15 @@ class addon extends common { $posend = strpos($file, "'", $posdeb + 1); $version = substr($file, $posdeb + 1, $posend - $posdeb - 1); } + $pos1 = strpos($file, 'constUPDATE'); + if( $pos1 !== false){ + $posdeb = strpos($file, "=", $pos1); + $posend = strpos($file, ";", $posdeb + 1); + $strUpdate = substr($file, $posdeb + 1, $posend - $posdeb - 1); + if( strpos( $strUpdate,"true",0) !== false){ + $update = true; + } + } // Module déjà installé ? $moduleInstal = false; @@ -169,7 +179,7 @@ class addon extends common { $valInstalVersion = floatval( $infoModules[$moduleName]['version'] ); $newVersion = false; if( $valNewVersion > $valInstalVersion ) $newVersion = true; - $validMaj = $infoModules[$moduleName]['update'] && ( $newVersion || $checkValidMaj); + $validMaj = $update && ( $newVersion || $checkValidMaj); // Nouvelle installation ou mise à jour du module if( ! $moduleInstal || $validMaj ){ @@ -191,7 +201,7 @@ class addon extends common { else{ $notification = ' Version détectée '.$version.' < à celle installée '.$infoModules[$moduleName]['version']; } - if( $infoModules[$moduleName]['update'] === false){ + if( $update === false){ $notification = ' Mise à jour par ce procédé interdite par le concepteur du module'; } } @@ -358,4 +368,4 @@ class addon extends common { 'view' => 'import' ]); } -} \ No newline at end of file +} From f95d8a79611e2b7a7595cdf3f4a059a34a44c485 Mon Sep 17 00:00:00 2001 From: SylvainLelievre Date: Fri, 19 Feb 2021 07:49:04 +0100 Subject: [PATCH 2/3] addon messages en cas de delete --- core/module/addon/addon.php | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/core/module/addon/addon.php b/core/module/addon/addon.php index d2a84268..b8d5f379 100644 --- a/core/module/addon/addon.php +++ b/core/module/addon/addon.php @@ -47,9 +47,23 @@ class addon extends common { } else{ // Suppression des dossiers - if( $this->removeDir('./module/'.$this->getUrl(2) ) === true){ + $infoModules = helper::getModules(); + $module = $this->getUrl(2); + //Liste des dossiers associés au module non effacés + $list = ''; + foreach( $infoModules[$module]['dataDirectory'] as $moduleId){ + if (strpos($moduleId,'module.json') === false && strpos($moduleId,'page.json') === false) { + $list === '' ? $list = self::DATA_DIR.$moduleId : $list .= ', '.self::DATA_DIR. $moduleId; + } + } + if( $this->removeDir('./module/'.$module ) === true){ $success = true; - $notification = 'Module '.$this->getUrl(2) .' effacé du dossier /module/, il peut rester des données dans d\'autres dossiers'; + if( $list === ''){ + $notification = 'Module '.$module .' désinstallé'; + } + else{ + $notification = 'Module '.$module .' désinstallé, il reste des données dans '.$list; + } } else{ $success = false; From 887ce73f027f53130ed2e1a3ed9d3bef1f9da0fa Mon Sep 17 00:00:00 2001 From: SylvainLelievre Date: Fri, 19 Feb 2021 07:53:34 +0100 Subject: [PATCH 3/3] correction colonnes tableau addon --- core/module/addon/view/index/index.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/module/addon/view/index/index.php b/core/module/addon/view/index/index.php index 6da3c716..5248fdc9 100644 --- a/core/module/addon/view/index/index.php +++ b/core/module/addon/view/index/index.php @@ -40,7 +40,7 @@ - +