forked from ZwiiCMS-Team/ZwiiCMS
Merge branch '10600' into 11000
This commit is contained in:
commit
108e285704
@ -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] = [
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user