From 276950b1178c9269be156688493c28c9f7b3e0b6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Tempez?= Date: Thu, 5 Dec 2024 18:09:18 +0100 Subject: [PATCH] =?UTF-8?q?1.14.09=20Corrige=20la=20m=C3=A9thode=20de=20ba?= =?UTF-8?q?ckup?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- core/class/helper.class.php | 29 ++++++++++++++++++++--------- 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/core/class/helper.class.php b/core/class/helper.class.php index 0da4102..3bfbed9 100644 --- a/core/class/helper.class.php +++ b/core/class/helper.class.php @@ -197,14 +197,20 @@ class helper public static function autoBackup($folder, $filter = ['backup', 'tmp']) { - // Creation du ZIP + // Création du nom de fichier ZIP $baseName = str_replace('/', '', helper::baseUrl(false, false)); $baseName = empty($baseName) ? 'ZwiiCMS' : $baseName; - $fileName = $baseName . '-backup-' . date('Y-m-d-H-i-s', time()) . '.zip'; + $fileName = $baseName . '-backup-' . date('Y-m-d-H-i-s') . '.zip'; + + // Initialisation de l'archive ZIP $zip = new ZipArchive(); - $zip->open($folder . $fileName, ZipArchive::CREATE | ZipArchive::OVERWRITE); + if ($zip->open($folder . $fileName, ZipArchive::CREATE | ZipArchive::OVERWRITE) !== true) { + return false; // Retourne false si l'ouverture échoue + } + $directory = 'site/'; - //$filter = array('backup','tmp','file'); + + // Récupération des fichiers et des dossiers $files = new RecursiveIteratorIterator( new RecursiveCallbackFilterIterator( new RecursiveDirectoryIterator( @@ -212,23 +218,28 @@ class helper RecursiveDirectoryIterator::SKIP_DOTS ), function ($fileInfo, $key, $iterator) use ($filter) { - return $fileInfo->isFile() || !in_array($fileInfo->getBaseName(), $filter); + // Inclure les fichiers ou les répertoires non filtrés + return $fileInfo->isFile() || ($fileInfo->isDir() && !in_array($fileInfo->getBaseName(), $filter)); } ) ); - foreach ($files as $name => $file) { + + // Ajout des fichiers à l'archive + foreach ($files as $file) { if (!$file->isDir()) { $filePath = $file->getRealPath(); - $relativePath = substr($filePath, strlen(realpath($directory)) + 1); + $relativePath = str_replace(DIRECTORY_SEPARATOR, '/', substr($filePath, strlen(realpath($directory)) + 1)); $zip->addFile($filePath, $relativePath); } } + + // Fermeture de l'archive ZIP $zip->close(); - return ($fileName); + + return $fileName; } - /** * Retourne la liste des modules installés dans un tableau composé * du nom réel