v9.0.0 creation de l'export en cours

This commit is contained in:
fredtempez 2018-12-26 12:00:30 +01:00
parent dc60b4929d
commit 6ec892e7a4

View File

@ -459,15 +459,79 @@ class theme extends common {
* Export du thème * Export du thème
*/ */
public function export() { public function export() {
// Creation du ZIP // Creation du dossier
$fileName = date('Theme Y-m-d-h-i-s', time()) . '.zip'; $genRandom = date('dmYhms').'-'.rand(100,999);
$zip = new ZipArchive(); $zipFilename = $genRandom . '.zip';
if($zip->open('site/tmp/' . $fileName, ZipArchive::CREATE) === TRUE){ $folderTemp = 'site/tmp/theme-' . $genRandom . '/';
foreach('data/theme.json' as $file) { $folderSource = $folderTemp . 'site/file/source/';
$zip->addFile($file); $folderData = $folderTemp . 'site/data/';
if (mkdir($folderTemp,0755,TRUE) and mkdir($folderData,0755,TRUE) AND mkdir($folderSource,0755,TRUE) ) {
// Dossier créé avec succès, copie du thème
if (copy( 'site/data/theme.json' , $folderData . 'theme.json')){
// Copie réalisée avec succès copie des images du thème
// Copie image de body
if ($this->getData(['theme','body','image']) !== '') {
if ( !mkdir ($folderSource . dirname($this->getData(['theme','body','image'])),0755,TRUE) OR
!copy('site/file/source/'.$this->getData(['theme','body','image']), $folderSource . $this->getData(['theme','body','image']))) {
// Erreur de copie des images
// Valeurs en sortie
$this->addOutput([
'notification' => 'Erreur lors de la création de l\'export',
'redirect' => helper::baseUrl() . 'theme/manage',
'state' => true
]);
}
}
// Copie image du header
if ($this->getData(['theme','header','image']) !== '') {
// Le dossier est-il créé ?
if (!file_exists($folderSource . dirname($this->getData(['theme','header','image'])))) {
if ( !mkdir ($folderSource . dirname($this->getData(['theme','header','image'])),0755,TRUE)) {
// Erreur création dossier
// Valeurs en sortie
$this->addOutput([
'notification' => 'Erreur lors de la création de l\'export',
'redirect' => helper::baseUrl() . 'theme/manage',
'state' => true
]);
}
}
if (!copy('site/file/source/'.$this->getData(['theme','header','image']), $folderSource . $this->getData(['theme','header','image']))) {
// Erreur de copie des images
// Valeurs en sortie
$this->addOutput([
'notification' => 'Erreur lors de la création de l\'export',
'redirect' => helper::baseUrl() . 'theme/manage',
'state' => true
]);
}
}
} }
else {
// Erreur de copy du thème
// Valeurs en sortie
$this->addOutput([
'notification' => 'Erreur lors de la création de l\'export',
'redirect' => helper::baseUrl() . 'theme/manage',
'state' => true
]);
}
} else {
// Erreur création du dossier temporaire
// Valeurs en sortie
$this->addOutput([
'notification' => 'Erreur lors de la création de l\'export',
'redirect' => helper::baseUrl() . 'theme/manage',
'state' => true
]);
} }
$zip->close();
echo 'site/file/source'.$zipFilename;
echo "<p>";
echo $folderTemp;
// Création du ZIP
$this->create_zip($folderTemp, 'site/file/source'.$zipFilename);
die();
// Téléchargement du ZIP // Téléchargement du ZIP
header('Content-Transfer-Encoding: binary'); header('Content-Transfer-Encoding: binary');
header('Content-Disposition: attachment; filename="' . $fileName . '"'); header('Content-Disposition: attachment; filename="' . $fileName . '"');
@ -485,4 +549,31 @@ class theme extends common {
public function import() { public function import() {
} }
}
// compress all files in the source directory to destination directory
public function create_zip($files = array(), $dest = '', $overwrite = false) {
if (file_exists($dest) && !$overwrite) {
return false;
}
if (($files)) {
$zip = new ZipArchive();
if ($zip->open($dest, $overwrite ? ZIPARCHIVE::OVERWRITE : ZIPARCHIVE::CREATE) !== true) {
return false;
}
foreach ($files as $file) {
$zip->addFile($file, $file);
}
$zip->close();
return file_exists($dest);
} else {
return false;
}
}
public function addzip($source, $destination) {
$files_to_zip = glob($source . '/*');
create_zip($files_to_zip, $destination);
}
}