Commit 17aabc1e authored by Ad Schellevis's avatar Ad Schellevis

rewrite backup cleanup

parent 0c92c582
...@@ -241,6 +241,9 @@ function write_config($desc = 'Unknown', $backup = true) ...@@ -241,6 +241,9 @@ function write_config($desc = 'Unknown', $backup = true)
/* sync carp entries to other firewalls */ /* sync carp entries to other firewalls */
carp_sync_client(); carp_sync_client();
/* cleanup backups */
cleanup_backups();
return $config; return $config;
} }
...@@ -388,94 +391,24 @@ function config_validate($conffile) { ...@@ -388,94 +391,24 @@ function config_validate($conffile) {
return true; return true;
} }
function cleanup_backupcache($lock = false) { /**
* remove old backups
*/
function cleanup_backups() {
global $g; global $g;
$i = false; $i = false;
$revisions = get_config_backup_count(); $revisions = get_config_backup_count();
if (!$lock) $cnf = OPNsense\Core\Config::getInstance();
$lockkey = lock('config');
$cnt=1;
foreach ($cnf->getBackups() as $filename) {
$backups = get_backups(); if ($cnt > $revisions ) {
if ($backups) { unlink($filename);
$baktimes = $backups['versions'];
unset($backups['versions']);
} else {
$backups = array();
$baktimes = array();
}
$newbaks = array();
$bakfiles = glob('/conf/backup/config-*');
$tocache = array();
foreach($bakfiles as $backup) { // Check for backups in the directory not represented in the cache.
$backupsize = filesize($backup);
if($backupsize == 0) {
unlink($backup);
continue;
}
$tocheck = array_shift(explode('.', array_pop(explode('-', $backup))));
if(!in_array($tocheck, $baktimes)) {
$i = true;
$newxml = parse_xml_config($backup, array($g['xml_rootobj'], 'pfsense'));
if($newxml == "-1") {
log_error(sprintf(gettext("The backup cache file %s is corrupted. Unlinking."), $backup));
unlink($backup);
log_error(sprintf(gettext("The backup cache file %s is corrupted. Unlinking."), $backup));
continue;
}
if($newxml['revision']['description'] == "")
$newxml['revision']['description'] = "Unknown";
if($newxml['version'] == "")
$newxml['version'] = "?";
$tocache[$tocheck] = array('description' => $newxml['revision']['description'], 'version' => $newxml['version'], 'filesize' => $backupsize);
}
}
foreach($backups as $checkbak) {
if(count(preg_grep('/' . $checkbak['time'] . '/i', $bakfiles)) != 0) {
$newbaks[] = $checkbak;
} else {
$i = true;
if(file_exists("/var/run/booting")) print " " . $tocheck . "r";
}
}
foreach($newbaks as $todo) $tocache[$todo['time']] = array('description' => $todo['description'], 'version' => $todo['version'], 'filesize' => $todo['filesize']);
if(is_int($revisions) and (count($tocache) > $revisions)) {
$toslice = array_slice(array_keys($tocache), 0, $revisions);
foreach($toslice as $sliced)
$newcache[$sliced] = $tocache[$sliced];
foreach($tocache as $version => $versioninfo) {
if(!in_array($version, array_keys($newcache))) {
unlink_if_exists('/conf/backup/config-' . $version . '.xml');
}
} }
$tocache = $newcache; ++$cnt ;
}
$bakout = fopen('/conf/backup/backup.cache', 'w');
fwrite($bakout, serialize($tocache));
fclose($bakout);
if (!$lock)
unlock($lockkey);
}
function get_backups()
{
if (file_exists('/conf/backup/backup.cache')) {
$confvers = unserialize(file_get_contents('/conf/backup/backup.cache'));
$bakvers = array_keys($confvers);
$toreturn = array();
sort($bakvers);
// $bakvers = array_reverse($bakvers);
foreach(array_reverse($bakvers) as $bakver)
$toreturn[] = array('time' => $bakver, 'description' => $confvers[$bakver]['description'], 'version' => $confvers[$bakver]['version'], 'filesize' => $confvers[$bakver]['filesize']);
} else {
return false;
} }
$toreturn['versions'] = $bakvers;
return $toreturn;
} }
...@@ -534,8 +467,6 @@ function get_config_backup_count() { ...@@ -534,8 +467,6 @@ function get_config_backup_count() {
global $config, $g; global $config, $g;
if (isset($config['system']['backupcount']) && is_numeric($config['system']['backupcount']) && ($config['system']['backupcount'] >= 0)) { if (isset($config['system']['backupcount']) && is_numeric($config['system']['backupcount']) && ($config['system']['backupcount'] >= 0)) {
return intval($config['system']['backupcount']); return intval($config['system']['backupcount']);
} elseif ($g['platform'] == "nanobsd") {
return 5;
} else { } else {
return 30; return 30;
} }
......
...@@ -176,10 +176,6 @@ echo "Updating configuration..."; ...@@ -176,10 +176,6 @@ echo "Updating configuration...";
convert_config(); convert_config();
echo "done.\n"; echo "done.\n";
echo "Cleaning backup cache...";
cleanup_backupcache(true);
echo "done.\n";
/* read in /etc/sysctl.conf and set values if needed */ /* read in /etc/sysctl.conf and set values if needed */
echo "Setting up extended sysctls..."; echo "Setting up extended sysctls...";
system_setup_sysctl(); system_setup_sysctl();
......
...@@ -218,7 +218,7 @@ include("head.inc"); ...@@ -218,7 +218,7 @@ include("head.inc");
<tr> <tr>
<td><?=gettext("Backup Count");?></td> <td><?=gettext("Backup Count");?></td>
<td><input name="backupcount" type="text" class="formfld unknown" size="5" value="<?=htmlspecialchars($config['system']['backupcount']);?>"/></td> <td><input name="backupcount" type="text" class="formfld unknown" size="5" value="<?=htmlspecialchars($config['system']['backupcount']);?>"/></td>
<td><?= gettext("Enter the number of older configurations to keep in the local backup cache. By default this is 30 for a full install or 5 on NanoBSD."); ?></td> <td><?= gettext("Enter the number of older configurations to keep in the local backup cache. By default this is 30."); ?></td>
<td><input name="save" type="submit" class="btn btn-primary" value="<?=gettext("Save"); ?>" /></td> <td><input name="save" type="submit" class="btn btn-primary" value="<?=gettext("Save"); ?>" /></td>
</tr> </tr>
</tbody> </tbody>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment