Merge branch '10600' into 11000

This commit is contained in:
F Tempez 2021-04-06 17:37:17 +02:00
commit 108e285704
2 changed files with 122 additions and 114 deletions

View File

@ -177,13 +177,10 @@ class helper {
$delete = true; $delete = true;
} }
// Constante DATADIRECTORY // Constante DATADIRECTORY
if ( array_key_exists('DATADIRECTORY', $class_constants) if ( array_key_exists('DATADIRECTORY', $class_constants)) {
&& $class_constants['DATADIRECTORY'] !== []
&& is_array($class_constants['DATADIRECTORY'])
) {
$dataDirectory = $value::DATADIRECTORY; $dataDirectory = $value::DATADIRECTORY;
} else { } else {
$dataDirectory = []; $dataDirectory = '';
} }
// Affection // Affection
$modules [$value] = [ $modules [$value] = [

View File

@ -62,19 +62,13 @@ class addon extends common {
$infoModules = helper::getModules(); $infoModules = helper::getModules();
$module = $this->getUrl(2); $module = $this->getUrl(2);
//Liste des dossiers associés au module non effacés //Liste des dossiers associés au module non effacés
$list = ''; if( $this->removeDir('./module/'.$module ) === true ){
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; $success = true;
if( $list === ''){ $notification = 'Module '. $module .' désinstallé';
$notification = 'Module '.$module .' désinstallé'; if(($infoModules[$this->getUrl(2)]['dataDirectory']) ) {
if (!$this->removeDir($infoModules[$this->getUrl(2)]['dataDirectory'])){
$notification = 'Module '.$module .' désinstallé, il reste des données dans ' . $infoModules[$this->getUrl(2)]['dataDirectory'];
} }
else{
$notification = 'Module '.$module .' désinstallé, il reste des données dans '.$list;
} }
} }
else{ else{
@ -386,15 +380,16 @@ class addon extends common {
'value' => template::ico('cancel') 'value' => template::ico('cancel')
]) ])
: '', : '',
is_array($infoModules[$key]['dataDirectory']) && implode(', ',array_keys($inPages,$key)) !== '' implode(', ',array_keys($inPages,$key)) !== ''
? template::button('moduleExport' . $key, [ ? template::button('moduleExport' . $key, [
'href' => helper::baseUrl(). $this->getUrl(0) . '/export/' . $key,// appel de fonction vaut exécution, utiliser un paramètre 'href' => helper::baseUrl(). $this->getUrl(0) . '/export/' . $key . '/' . $_SESSION['csrf'],// appel de fonction vaut exécution, utiliser un paramètre
'value' => template::ico('download') 'value' => template::ico('download')
]) ])
: '', : '',
is_array($infoModules[$key]['dataDirectory']) && implode(', ',array_keys($inPages,$key)) === '' '',
implode(', ',array_keys($inPages,$key)) === ''
? template::button('moduleExport' . $key, [ ? template::button('moduleExport' . $key, [
'href' => helper::baseUrl(). $this->getUrl(0) . '/import/' . $key.'/' . $_SESSION['csrf'],// appel de fonction vaut exécution, utiliser un paramètre 'href' => helper::baseUrl(). $this->getUrl(0) . '/import/' . $key . '/' . $_SESSION['csrf'],// appel de fonction vaut exécution, utiliser un paramètre
'value' => template::ico('upload') 'value' => template::ico('upload')
]) ])
: '' : ''
@ -408,38 +403,20 @@ class addon extends common {
]); ]);
} }
/*
* Copie récursive de dossiers
*
*/
private function custom_copy($src, $dst) {
// open the source directory
$dir = opendir($src);
// Make the destination directory if not exist
if (!is_dir($dst)) {
mkdir($dst);
}
// Loop through the files in source directory
while( $file = readdir($dir) ) {
if (( $file != '.' ) && ( $file != '..' )) {
if ( is_dir($src . '/' . $file) ){
// Recursively calling custom copy function
// for sub directory
$this -> custom_copy($src . '/' . $file, $dst . '/' . $file);
}
else {
copy($src . '/' . $file, $dst . '/' . $file);
}
}
}
closedir($dir);
}
/* /*
* Export des données d'un module externes ou interne à module.json * Export des données d'un module externes ou interne à module.json
*/ */
public function export(){ public function export(){
// Jeton incorrect
if ($this->getUrl(3) !== $_SESSION['csrf']) {
// Valeurs en sortie
$this->addOutput([
'redirect' => helper::baseUrl() . 'addon',
'state' => false,
'notification' => 'Action non autorisée'
]);
}
else {
// Lire les données du module // Lire les données du module
$infoModules = helper::getModules(); $infoModules = helper::getModules();
// Créer un dossier par défaut // Créer un dossier par défaut
@ -456,6 +433,7 @@ class addon extends common {
$pageContent[$pageId] = $this->getData(['page',$pageId]); $pageContent[$pageId] = $this->getData(['page',$pageId]);
// Export de fr/module.json // Export de fr/module.json
$moduleId = 'fr/module.json'; $moduleId = 'fr/module.json';
$moduleDir = str_replace('site/data/','',$infoModules[$this->getUrl(2)]['dataDirectory']);
// Création de l'arborescence des langues // Création de l'arborescence des langues
// Pas de nom dossier de langue - dossier par défaut // Pas de nom dossier de langue - dossier par défaut
$t = explode ('/',$moduleId); $t = explode ('/',$moduleId);
@ -464,29 +442,33 @@ class addon extends common {
} else { } else {
$lang = $t[0]; $lang = $t[0];
} }
// Créer le dossier si inexistant // Créer le dossier temporaire si inexistant sinon le nettoie et le créer
if (!is_dir($tmpFolder . '/' . $lang)) { if (!is_dir($tmpFolder . '/' . $lang)) {
mkdir ($tmpFolder . '/' . $lang); mkdir ($tmpFolder . '/' . $lang, 0777, true);
} else {
$this->removeDir($tmpFolder . '/' . $lang);
mkdir ($tmpFolder . '/' . $lang, 0777, true);
}
// Créer le dossier temporaire des données du module
if ($infoModules[$this->getUrl(2)]['dataDirectory']) {
if (!is_dir($tmpFolder . '/' . $moduleDir)) {
mkdir ($tmpFolder . '/' . $moduleDir, 0777, true) ;
}
} }
// Sauvegarde si données non vides // Sauvegarde si données non vides
$tmpData [$pageId] = $this->getData(['module',$pageId ]); $tmpData [$pageId] = $this->getData(['module',$pageId ]);
if ($tmpData [$pageId] !== null) { if ($tmpData [$pageId] !== null) {
file_put_contents($tmpFolder . '/' . $moduleId, json_encode($tmpData)); file_put_contents($tmpFolder . '/' . $moduleId, json_encode($tmpData));
} }
// Export des données localisées dans des dossiers // Export des données localisées dans le dossier de données du module
foreach ($infoModules[$this->getUrl(2)]['dataDirectory'] as $dirId) { if ($infoModules[$this->getUrl(2)]['dataDirectory'] ) {
if ( file_exists(self::DATA_DIR . '/' . $dirId) $this->custom_copy ($infoModules[$this->getUrl(2)]['dataDirectory'], $tmpFolder . '/' . $moduleDir);
&& !file_exists($tmpFolder . '/' . $dirId ) ) {
$this->custom_copy ( self::DATA_DIR . '/' . $dirId, $tmpFolder . '/' . $dirId );
}
} }
} }
// Enregistrement des pages dans le dossier de langue identique à module // Enregistrement des pages dans le dossier de langue identique à module
if (!file_exists($tmpFolder . '/' . $lang . '/page.json')) { if (!file_exists($tmpFolder . '/' . $lang . '/page.json')) {
file_put_contents($tmpFolder . '/' . $lang . '/page.json', json_encode($pageContent)); file_put_contents($tmpFolder . '/' . $lang . '/page.json', json_encode($pageContent));
} }
// création du zip // création du zip
$fileName = $this->getUrl(2) . '.zip'; $fileName = $this->getUrl(2) . '.zip';
$this->makeZip ($fileName, $tmpFolder, []); $this->makeZip ($fileName, $tmpFolder, []);
@ -511,6 +493,7 @@ class addon extends common {
]); ]);
} }
} }
}
/* /*
* Importer des données d'un module externes ou interne à module.json * Importer des données d'un module externes ou interne à module.json
@ -598,4 +581,32 @@ class addon extends common {
]); ]);
} }
} }
/*
* Copie récursive de dossiers
*
*/
private function custom_copy($src, $dst) {
// open the source directory
$dir = opendir($src);
// Make the destination directory if not exist
if (!is_dir($dst)) {
mkdir($dst);
}
// Loop through the files in source directory
while( $file = readdir($dir) ) {
if (( $file != '.' ) && ( $file != '..' )) {
if ( is_dir($src . '/' . $file) ){
// Recursively calling custom copy function
// for sub directory
$this -> custom_copy($src . '/' . $file, $dst . '/' . $file);
}
else {
copy($src . '/' . $file, $dst . '/' . $file);
}
}
}
closedir($dir);
}
} }