index construction du tableau

This commit is contained in:
fredtempez 2021-02-15 20:38:38 +01:00
parent 3b1f6a874a
commit 9d7810ebf2

View File

@ -118,10 +118,10 @@ class addon extends common {
// Validation de la maj si autorisation du concepteur du module ET // Validation de la maj si autorisation du concepteur du module ET
// ( Version plus récente OU Check de forçage ) // ( Version plus récente OU Check de forçage )
$valNewVersion = floatval($version); $valNewVersion = floatval($version);
$valInstalVersion = floatval( $infomodule[$moduleName]['version'] ); $valInstalVersion = floatval( $infoModules[$moduleName]['version'] );
$newVersion = false; $newVersion = false;
if( $valNewVersion > $valInstalVersion ) $newVersion = true; if( $valNewVersion > $valInstalVersion ) $newVersion = true;
$validMaj = $infomodule[$moduleName]['update'] && ( $newVersion || $checkValidMaj); $validMaj = $infoModules[$moduleName]['update'] && ( $newVersion || $checkValidMaj);
// Nouvelle installation ou mise à jour du module // Nouvelle installation ou mise à jour du module
if( ! $moduleInstal || $validMaj ){ if( ! $moduleInstal || $validMaj ){
@ -137,8 +137,8 @@ class addon extends common {
} }
else{ else{
$success = false; $success = false;
$notification = ' Version détectée '.$version.' <= à celle installée '.$infomodule[$moduleName]['version']; $notification = ' Version détectée '.$version.' <= à celle installée '.$infoModules[$moduleName]['version'];
if( $infomodule[$moduleName]['update'] === false){ if( $infoModules[$moduleName]['update'] === false){
$notification = ' Mise à jour par ce procédé interdite par le concepteur du module'; $notification = ' Mise à jour par ce procédé interdite par le concepteur du module';
} }
} }
@ -160,57 +160,39 @@ class addon extends common {
'state' => $success 'state' => $success
]); ]);
} }
$infomodule = helper::getModules();
// $infomodule[nom_module]['realName'], ['version'], ['update'], ['delete'], ['dataDirectory'] // Lister les modules
// Préparation du tableau des modules installés // $infoModules[nom_module]['realName'], ['version'], ['update'], ['delete'], ['dataDirectory']
// Liste des modules installés (répertoire de module/) $infoModules = helper::getModules();
if ($dh = opendir( 'module/' )) {
$i=0; // Clés moduleIds dans les pages
while (($dirmodule = readdir($dh)) !== false) { $inPages = helper::arrayCollumn($this->getData(['page']),'moduleId', 'SORT_DESC');
if( $dirmodule !== '.' && $dirmodule !== '..'){
self::$modInstal[$i][0] = $dirmodule; // nom du module // Parcourir les données des modules
self::$modInstal[$i][1] = $infomodule[$dirmodule]['realName']; foreach ($infoModules as $key=>$value) {
self::$modInstal[$i][2] = $infomodule[$dirmodule]['version']; // Construire le tableau de sortie
// Initialisations self::$modInstal[] = [
self::$modInstal[$i][3] = ''; // page(s) $key,
self::$modInstal[$i][4] = ''; // pour button effacement $infoModules[$key]['realName'],
self::$modInstal[$i][5] = ''; // pour button download $infoModules[$key]['version'],
$i++; array_search($key,$inPages),// devrait retourner toutes les valeurs et pas la première
} array_key_exists('delete',$infoModules[$key]) && $infoModules[$key]['delete'] === true
} ? template::button('moduleDelete' . $key, [
closedir($dh);
}
foreach( self::$modInstal as $i=>$value){
// Page(s)
foreach( $this->getData(['page']) as $keyPage=>$valuePage){
if( $valuePage['moduleId'] === self::$modInstal[$i][0]){
if(self::$modInstal[$i][3] !==''){
self::$modInstal[$i][3] = self::$modInstal[$i][3].'<br>'.$valuePage['title'];
}
else{
self::$modInstal[$i][3] = $valuePage['title'];
}
}
}
// Non utilisé et autorisation de suppression ?
if( self::$modInstal[$i][3] == '' && $infomodule[ self::$modInstal[$i][0] ]['delete'] === true ){
self::$modInstal[$i][4] = template::button('moduleDelete' . self::$modInstal[$i][0], [
'class' => 'moduleDelete buttonRed', 'class' => 'moduleDelete buttonRed',
'href' => helper::baseUrl() . $this->getUrl(0) . '/moduleDelete/' . self::$modInstal[$i][0] . '/' . $_SESSION['csrf'], 'href' => helper::baseUrl() . $this->getUrl(0) . '/moduleDelete/' . $key . '/' . $_SESSION['csrf'],
'value' => template::ico('cancel') 'value' => template::ico('cancel')
]); ])
} : '',
// Présence de données externes à module.json ? array_key_exists('update',$infoModules[$key]) && $infoModules[$key]['update'] === true
if( $infomodule[ self::$modInstal[$i][0] ]['dataDirectory'] !== '' ){ ? template::button('moduleDelete' . $key, [
self::$modInstal[$i][5] = template::button('moduleExport' . self::$modInstal[$i][0], [ 'class' => 'moduleDelete buttonRed',
'class' => 'buttonBlue', 'href' => helper::baseUrl() . $this->getUrl(0) . '/moduleDelete/' . $key . '/' . $_SESSION['csrf'],
//'href' => helper::baseUrl() . $this->getUrl(0) . '/exportData/' . self::$modInstal[$i][0] . '/' . $_SESSION['csrf'], 'value' => template::ico('cancel')
'href' => helper::baseUrl(false).$this->exportZip( self::$modInstal[$i][0] ), ])
'value' => template::ico('upload') : ''
]); ];
} }
}
// Valeurs en sortie // Valeurs en sortie
$this->addOutput([ $this->addOutput([
'title' => 'Gestion des modules', 'title' => 'Gestion des modules',
@ -313,13 +295,13 @@ class addon extends common {
* Export des données d'un module externes à module.json * Export des données d'un module externes à module.json
*/ */
private function exportZip( $exportModule ){ private function exportZip( $exportModule ){
$infomodule = helper::getModules(); $infoModules = helper::getModules();
// création du zip // création du zip
$zip = new ZipArchive(); $zip = new ZipArchive();
if( ! is_dir('tmp/exportDataModules')) mkdir('tmp/exportDataModules',0777, true); if( ! is_dir('tmp/exportDataModules')) mkdir('tmp/exportDataModules',0777, true);
$filename = 'tmp/exportDataModules/'.$exportModule.'dataExport.zip'; $filename = 'tmp/exportDataModules/'.$exportModule.'dataExport.zip';
if( is_file( $filename )) unlink( $filename); if( is_file( $filename )) unlink( $filename);
$directory = $infomodule[$exportModule]['dataDirectory'].'/'; $directory = $infoModules[$exportModule]['dataDirectory'].'/';
if($zip->open( $filename, ZipArchive::CREATE) !== TRUE){ if($zip->open( $filename, ZipArchive::CREATE) !== TRUE){
exit; exit;
} }