aboutsummaryrefslogtreecommitdiffstats
path: root/backup-upload.rsc
diff options
context:
space:
mode:
Diffstat (limited to 'backup-upload.rsc')
-rw-r--r--backup-upload.rsc35
1 files changed, 26 insertions, 9 deletions
diff --git a/backup-upload.rsc b/backup-upload.rsc
index 8d96eba..14c3914 100644
--- a/backup-upload.rsc
+++ b/backup-upload.rsc
@@ -1,17 +1,19 @@
#!rsc by RouterOS
# RouterOS script: backup-upload
-# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
-# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
+# Copyright (c) 2013-2025 Christian Hesse <mail@eworm.de>
+# https://rsc.eworm.de/COPYING.md
#
# provides: backup-script, order=50
-# requires RouterOS, version=7.14
+# requires RouterOS, version=7.15
+# requires device-mode, fetch
#
# create and upload backup and config file
-# https://git.eworm.de/cgit/routeros-scripts/about/doc/backup-upload.md
+# https://rsc.eworm.de/doc/backup-upload.md
:global GlobalFunctionsReady;
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
+:local ExitOK false;
:do {
:local ScriptName [ :jobname ];
@@ -33,6 +35,8 @@
:global LogPrint;
:global MkDir;
:global RandomDelay;
+ :global RmDir;
+ :global RmFile;
:global ScriptFromTerminal;
:global ScriptLock;
:global SendNotification2;
@@ -43,13 +47,23 @@
:if ($BackupSendBinary != true && \
$BackupSendExport != true) do={
$LogPrint error $ScriptName ("Configured to send neither backup nor config export.");
+ :set ExitOK true;
:error false;
}
:if ([ $ScriptLock $ScriptName ] = false) do={
:set PackagesUpdateBackupFailure true;
+ :set ExitOK true;
:error false;
}
+
+ :if ([ :len [ /system/scheduler/find where name="running-from-backup-partition" ] ] > 0) do={
+ $LogPrint warning $ScriptName ("Running from backup partition, refusing to act.");
+ :set PackagesUpdateBackupFailure true;
+ :set ExitOK true;
+ :error false;
+ }
+
$WaitFullyConnected;
:if ([ $ScriptFromTerminal $ScriptName ] = false && $BackupRandomDelay > 0) do={
@@ -67,6 +81,7 @@
:if ([ $MkDir $DirName ] = false) do={
$LogPrint error $ScriptName ("Failed creating directory!");
+ :set ExitOK true;
:error false;
}
@@ -86,7 +101,7 @@
:set Failed 1;
}
- /file/remove ($FilePath . ".backup");
+ $RmFile ($FilePath . ".backup");
}
# create configuration export
@@ -105,7 +120,7 @@
:set Failed 1;
}
- /file/remove ($FilePath . ".rsc");
+ $RmFile ($FilePath . ".rsc");
}
# global-config-overlay
@@ -126,7 +141,7 @@
:set Failed 1;
}
- /file/remove ($FilePath . ".conf");
+ $RmFile ($FilePath . ".conf");
}
:local FileInfo do={
@@ -157,5 +172,7 @@
:if ($Failed = 1) do={
:set PackagesUpdateBackupFailure true;
}
- /file/remove $DirName;
-} on-error={ }
+ $RmDir $DirName;
+} on-error={
+ :global ExitError; $ExitError $ExitOK [ :jobname ];
+}