* a one-time job gets scheduled after each update via a repair job * the job remove all directories inside data/updater-INSTANCEID/backups except the 3 most recent ones (determined by mtime of the folder) Signed-off-by: Morris Jobke <hey@morrisjobke.de>pull/9855/head
parent
cd87a40eb3
commit
dc4c158ea7
@ -0,0 +1,90 @@ |
||||
<?php |
||||
/** |
||||
* @copyright 2018 Morris Jobke <hey@morrisjobke.de> |
||||
* |
||||
* @author Morris Jobke <hey@morrisjobke.de> |
||||
* |
||||
* @license GNU AGPL version 3 or any later version |
||||
* |
||||
* This program is free software: you can redistribute it and/or modify |
||||
* it under the terms of the GNU Affero General Public License as |
||||
* published by the Free Software Foundation, either version 3 of the |
||||
* License, or (at your option) any later version. |
||||
* |
||||
* This program is distributed in the hope that it will be useful, |
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
* GNU Affero General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Affero General Public License |
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
||||
* |
||||
*/ |
||||
namespace OC\Core\BackgroundJobs; |
||||
|
||||
use OC\BackgroundJob\QueuedJob; |
||||
use OCP\IConfig; |
||||
use OCP\ILogger; |
||||
|
||||
class BackgroundCleanupUpdaterBackupsJob extends QueuedJob { |
||||
|
||||
/** @var IConfig */ |
||||
protected $config; |
||||
/** @var ILogger */ |
||||
protected $log; |
||||
|
||||
public function __construct(IConfig $config, ILogger $log) { |
||||
$this->config = $config; |
||||
$this->log = $log; |
||||
} |
||||
|
||||
/** |
||||
* This job cleans up all backups except the latest 3 from the updaters backup directory |
||||
* |
||||
*/ |
||||
public function run($arguments) { |
||||
$dataDir = $this->config->getSystemValue('datadirectory', \OC::$SERVERROOT . '/data'); |
||||
$instanceId = $this->config->getSystemValue('instanceid', null); |
||||
|
||||
if(!is_string($instanceId) || empty($instanceId)) { |
||||
return; |
||||
} |
||||
|
||||
$updaterFolderPath = $dataDir . '/updater-' . $instanceId; |
||||
$backupFolderPath = $updaterFolderPath . '/backups'; |
||||
if(file_exists($backupFolderPath)) { |
||||
$this->log->info("$backupFolderPath exists - start to clean it up"); |
||||
|
||||
$dirList = []; |
||||
$dirs = new \DirectoryIterator($backupFolderPath); |
||||
foreach($dirs as $dir) { |
||||
// skip files and dot dirs |
||||
if ($dir->isFile() || $dir->isDot()) { |
||||
continue; |
||||
} |
||||
|
||||
$mtime = $dir->getMTime(); |
||||
$realPath = $dir->getRealPath(); |
||||
|
||||
if ($realPath === false) { |
||||
continue; |
||||
} |
||||
|
||||
$dirList[$mtime] = $realPath; |
||||
} |
||||
|
||||
ksort($dirList); |
||||
// drop the newest 3 directories |
||||
$dirList = array_slice($dirList, 0, -3); |
||||
$this->log->info("List of all directories that will be deleted: " . json_encode($dirList)); |
||||
|
||||
foreach($dirList as $dir) { |
||||
$this->log->info("Removing $dir ..."); |
||||
\OC_Helper::rmdirr($dir); |
||||
} |
||||
$this->log->info("Cleanup finished"); |
||||
} else { |
||||
$this->log->info("Could not find updater directory $backupFolderPath - cleanup step not needed"); |
||||
} |
||||
} |
||||
} |
||||
@ -0,0 +1,48 @@ |
||||
<?php |
||||
/** |
||||
* @copyright Copyright (c) 2018 Morris Jobke <hey@morrisjobke.de> |
||||
* |
||||
* @author Morris Jobke <hey@morrisjobke.de> |
||||
* |
||||
* @license GNU AGPL version 3 or any later version |
||||
* |
||||
* This program is free software: you can redistribute it and/or modify |
||||
* it under the terms of the GNU Affero General Public License as |
||||
* published by the Free Software Foundation, either version 3 of the |
||||
* License, or (at your option) any later version. |
||||
* |
||||
* This program is distributed in the hope that it will be useful, |
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||||
* GNU Affero General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Affero General Public License |
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
||||
* |
||||
*/ |
||||
|
||||
namespace OC\Repair; |
||||
|
||||
use OC\Core\BackgroundJobs\BackgroundCleanupUpdaterBackupsJob; |
||||
use OCP\BackgroundJob\IJobList; |
||||
use OCP\Migration\IOutput; |
||||
use OCP\Migration\IRepairStep; |
||||
|
||||
class AddCleanupUpdaterBackupsJob implements IRepairStep { |
||||
|
||||
/** @var IJobList */ |
||||
protected $jobList; |
||||
|
||||
public function __construct(IJobList $jobList) { |
||||
$this->jobList = $jobList; |
||||
} |
||||
|
||||
public function getName() { |
||||
return 'Queue a one-time job to cleanup old backups of the updater'; |
||||
} |
||||
|
||||
public function run(IOutput $output) { |
||||
$this->jobList->add(BackgroundCleanupUpdaterBackupsJob::class); |
||||
} |
||||
} |
||||
|
||||
Loading…
Reference in new issue