forked from ZwiiCMS-Team/ZwiiCMS
Merge branch '10500' of https://forge.chapril.org/ZwiiCMS-Team/ZwiiCMS into 10500
This commit is contained in:
commit
d8d0d68f47
@ -11,7 +11,7 @@
|
||||
* @author Frédéric Tempez <frederic.tempez@outlook.com>
|
||||
* @copyright Copyright (C) 2018-2021, Frédéric Tempez
|
||||
* @author Sylvain Lelièvre <lelievresylvain@free.fr>
|
||||
* @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/
|
||||
*/
|
||||
@ -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;
|
||||
@ -142,9 +156,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 +169,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 +193,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 +215,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 +382,4 @@ class addon extends common {
|
||||
'view' => 'import'
|
||||
]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -40,7 +40,7 @@
|
||||
</div>
|
||||
<?php echo template::formClose(); ?>
|
||||
<?php if($module::$modInstal): ?>
|
||||
<?php echo template::table([2, 3, 2, 2, 1, 1, 1], $module::$modInstal, ['Module installé', 'Alias', 'Version', 'Page(s)', 'Supprimer', 'Exporter', 'Importer']); ?>
|
||||
<?php echo template::table([2, 2, 2, 2, 1, 1, 1, 1], $module::$modInstal, ['Module installé', 'Alias', 'Version', 'Page(s)', 'Supprimer', 'Exporter', 'Importer']); ?>
|
||||
<?php else: ?>
|
||||
<?php echo template::speech('Aucun module installé.'); ?>
|
||||
<?php endif; ?>
|
||||
|
Loading…
Reference in New Issue
Block a user