[9.3.00] sauvegarde auto et manuelle
This commit is contained in:
parent
9b5ed2eb0d
commit
b1c04577c1
|
@ -1022,7 +1022,10 @@ class core extends common {
|
||||||
if($lastClearTmp > $this->getData(['core', 'lastClearTmp']) + 86400) {
|
if($lastClearTmp > $this->getData(['core', 'lastClearTmp']) + 86400) {
|
||||||
$iterator = new DirectoryIterator(self::TEMP_DIR);
|
$iterator = new DirectoryIterator(self::TEMP_DIR);
|
||||||
foreach($iterator as $fileInfos) {
|
foreach($iterator as $fileInfos) {
|
||||||
if($fileInfos->isFile() AND $fileInfos->getBasename() !== '.gitkeep') {
|
if( $fileInfos->isFile() &&
|
||||||
|
$fileInfos->getBasename() !== '.htaccess' &&
|
||||||
|
$fileInfos->getBasename() !== '.gitkeep'
|
||||||
|
) {
|
||||||
@unlink($fileInfos->getPathname());
|
@unlink($fileInfos->getPathname());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1039,7 +1042,18 @@ class core extends common {
|
||||||
AND $this->getData(['user']) // Pas de backup pendant l'installation
|
AND $this->getData(['user']) // Pas de backup pendant l'installation
|
||||||
) {
|
) {
|
||||||
// Copie du fichier de données
|
// Copie du fichier de données
|
||||||
copy(self::DATA_DIR.'core.json', self::BACKUP_DIR . date('Y-m-d', $lastBackup) . '.json');
|
// Creation du ZIP
|
||||||
|
$fileName = date('Y-m-d-h-i-s', time()) . '.zip';
|
||||||
|
$zip = new ZipArchive();
|
||||||
|
if($zip->open(self::TEMP_DIR . $fileName, ZipArchive::CREATE) === TRUE){
|
||||||
|
foreach(core::scanDir('site/') as $file) {
|
||||||
|
$zip->addFile($file);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$zip->close();
|
||||||
|
copy(self::TEMP_DIR . $fileName, self::BACKUP_DIR . $fileName );
|
||||||
|
unlink (self::TEMP_DIR . $fileName);
|
||||||
// Date du dernier backup
|
// Date du dernier backup
|
||||||
$this->setData(['core', 'lastBackup', $lastBackup]);
|
$this->setData(['core', 'lastBackup', $lastBackup]);
|
||||||
// Enregistre les données
|
// Enregistre les données
|
||||||
|
@ -1536,6 +1550,30 @@ class core extends common {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Scan le contenu d'un dossier et de ses sous-dossiers
|
||||||
|
* @param string $dir Dossier à scanner
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public static function scanDir($dir) {
|
||||||
|
$dirContent = [];
|
||||||
|
$iterator = new DirectoryIterator($dir);
|
||||||
|
foreach($iterator as $fileInfos) {
|
||||||
|
if(in_array($fileInfos->getFilename(), ['.', '..', 'backup'])) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
elseif($fileInfos->isDir()) {
|
||||||
|
$dirContent = array_merge($dirContent, self::scanDir($fileInfos->getPathname()));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$dirContent[] = $fileInfos->getPathname();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $dirContent;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class helper {
|
class helper {
|
||||||
|
|
|
@ -204,7 +204,7 @@ class config extends common {
|
||||||
$fileName = date('Y-m-d-h-i-s', time()) . '.zip';
|
$fileName = date('Y-m-d-h-i-s', time()) . '.zip';
|
||||||
$zip = new ZipArchive();
|
$zip = new ZipArchive();
|
||||||
if($zip->open(self::TEMP_DIR . $fileName, ZipArchive::CREATE) === TRUE){
|
if($zip->open(self::TEMP_DIR . $fileName, ZipArchive::CREATE) === TRUE){
|
||||||
foreach(configHelper::scanDir('site/') as $file) {
|
foreach(core::scanDir('site/') as $file) {
|
||||||
$zip->addFile($file);
|
$zip->addFile($file);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -352,29 +352,3 @@ class config extends common {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class configHelper extends helper {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Scan le contenu d'un dossier et de ses sous-dossiers
|
|
||||||
* @param string $dir Dossier à scanner
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public static function scanDir($dir) {
|
|
||||||
$dirContent = [];
|
|
||||||
$iterator = new DirectoryIterator($dir);
|
|
||||||
foreach($iterator as $fileInfos) {
|
|
||||||
if(in_array($fileInfos->getFilename(), ['.', '..', 'backup'])) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
elseif($fileInfos->isDir()) {
|
|
||||||
$dirContent = array_merge($dirContent, self::scanDir($fileInfos->getPathname()));
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$dirContent[] = $fileInfos->getPathname();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return $dirContent;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue