Compare commits

...

30 commits

Author SHA1 Message Date
Christian Hesse
e40a5575c4 Merge branch 'CommitBrief' into next 2026-01-21 08:57:17 +01:00
Christian Hesse
082f6e4812 Merge branch 'ExitOnError' into next 2026-01-21 08:57:17 +01:00
Christian Hesse
3b98e676c5 README: update screenshots 2026-01-21 08:57:17 +01:00
Christian Hesse
0db4306795 global-functions: enable scheduler if disabled 2026-01-21 08:57:17 +01:00
Christian Hesse
3baf0bd060 mode-button: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
c76c9591d5 global-functions: $ScriptInstallUpdate: drop output on commit...
... now that we have it on loading global functions.
2026-01-21 08:57:17 +01:00
Christian Hesse
86bf200bb5 global-functions: simplify the scheduler fix 2026-01-21 08:57:17 +01:00
Christian Hesse
80746d4dad mod/ssh-keys-import: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
4fe77ef238 global-functions: give commit info when laoding 2026-01-21 08:57:17 +01:00
Christian Hesse
ad8299824c global-functions: make the scheduler fix a block 2026-01-21 08:57:17 +01:00
Christian Hesse
b7df0d393a mod/scriptrunonce: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
03010ad9d9 global-functions: $ScriptInstallUpdate: use $CommitBrief 2026-01-21 08:57:17 +01:00
Christian Hesse
8b3fae745d global-functions: $NetMask6: drop unused variable 2026-01-21 08:57:17 +01:00
Christian Hesse
5f8f5e22a7 mod/notification-telegram: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
7f888b197e global-functions: $FetchUserAgentStr: user $CommitBrief 2026-01-21 08:57:17 +01:00
Christian Hesse
969658da16 mod/notification-ntfy: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
c81967f63a global-functions: $DeviceInfo: use $CommitBrief 2026-01-21 08:57:17 +01:00
Christian Hesse
6dd37e45d6 mod/notification-matrix: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
005b80b4c5 global-functions: introduce $CommitBrief 2026-01-21 08:57:17 +01:00
Christian Hesse
ddf7a015c5 mod/notification-gotify: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
d4624689ae mod/notification-email: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
2366122a36 mod/ipcalc: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
c0e802eab9 mod/inspectvar: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
345c8ef6b2 mod/bridge-port-vlan: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
920785c25b mod/bridge-port-to: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
87b80e05cb accesslist-duplicates: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
d0f2ae0033 global-functions: $SendNotification: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
f3d81f7e0d global-functions: $ScriptInstallUpdate: use $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
5443034897 global-functions: make $ExitError a wrapper for $ExitOnError 2026-01-21 08:57:17 +01:00
Christian Hesse
a8e091dde7 global-functions: introduce $ExitOnError
This is just like $ExitError, but first parameter is dropped. We will
not need it now that we can exit a script with :exit.
2026-01-21 08:57:17 +01:00
19 changed files with 70 additions and 55 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.3 KiB

After

Width:  |  Height:  |  Size: 2.5 KiB

Before After
Before After

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.6 KiB

After

Width:  |  Height:  |  Size: 2.8 KiB

Before After
Before After

View file

@ -32,5 +32,5 @@
:set ($Seen->$Mac) 1;
}
} do={
:global ExitError; $ExitError false [ :jobname ] $Err;
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
}

View file

@ -32,5 +32,5 @@
:set ($Seen->$Mac) 1;
}
} do={
:global ExitError; $ExitError false [ :jobname ] $Err;
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
}

View file

@ -41,5 +41,5 @@
:set ($Seen->$Mac) 1;
}
} do={
:global ExitError; $ExitError false [ :jobname ] $Err;
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
}

View file

@ -32,5 +32,5 @@
:set ($Seen->$Mac) 1;
}
} do={
:global ExitError; $ExitError false [ :jobname ] $Err;
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
}

View file

@ -30,12 +30,14 @@
:global CharacterReplace;
:global CleanFilePath;
:global CleanName;
:global CommitBrief;
:global DeviceInfo;
:global Dos2Unix;
:global DownloadPackage;
:global EitherOr;
:global EscapeForRegEx;
:global ExitError;
:global ExitOnError;
:global FetchHuge;
:global FetchUserAgentStr;
:global FileExists;
@ -319,13 +321,24 @@
:return $Return;
}
# get readable device info
:set DeviceInfo do={
# return a brief commit description
:set CommitBrief do={
:global CommitId;
:global CommitInfo;
:if ($CommitId = "unknown") do={
:return "unknown";
}
:return ($CommitInfo . "/" . [ :pick $CommitId 0 8 ]);
}
# get readable device info
:set DeviceInfo do={
:global ExpectedConfigVersion;
:global Identity;
:global CommitBrief;
:global IfThenElse;
:global FormatLine;
@ -366,8 +379,7 @@
$RouterBoard->"current-firmware" != $RouterBoard->"upgrade-firmware") \
([ $FormatLine " Firmware" ($RouterBoard->"current-firmware") ] . "\n") ] . \
"RouterOS-Scripts:\n" . \
[ $IfThenElse ($CommitId != "unknown") \
([ $FormatLine " Commit" ($CommitInfo . "/" . [ :pick $CommitId 0 8 ]) ] . "\n") ] . \
[ $FormatLine " Commit" [ $CommitBrief ] ] . "\n" . \
[ $FormatLine " Version" $ExpectedConfigVersion ]);
}
@ -473,20 +485,30 @@
:return $Return;
}
# simple macro to print error message on unintentional error
# wrapper for $ExitOnError with additional parameter
:set ExitError do={
:local ExitOK [ :tostr $1 ];
:local Name [ :tostr $2 ];
:local Error [ :tostr $3 ];
:global ExitOnError;
:if ($ExitOK = "false") do={
$ExitOnError $Name $Error;
}
}
# simple macro to print error message on unintentional error
:set ExitOnError do={
:local Name [ :tostr $1 ];
:local Error [ :tostr $2 ];
:global IfThenElse;
:global LogPrint;
:if ($ExitOK = "false") do={
$LogPrint error $Name ([ $IfThenElse ([ :pick $Name 0 1 ] = "\$") \
"Function" "Script" ] . " '" . $Name . "' exited with error" . \
[ $IfThenElse (!($Error ~ "^(|true|false)\$")) (": " . $Error) "." ]);
}
$LogPrint error $Name ([ $IfThenElse ([ :pick $Name 0 1 ] = "\$") \
"Function" "Script" ] . " '" . $Name . "' exited with error" . \
[ $IfThenElse (!($Error ~ "^(|true|false)\$")) (": " . $Error) "." ]);
}
# fetch huge data to file, read in chunks
@ -550,16 +572,13 @@
:set FetchUserAgentStr do={
:local Caller [ :tostr $1 ];
:global CommitId;
:global CommitInfo;
:global CommitBrief;
:global IfThenElse;
:local Resource [ /system/resource/get ];
:return ("User-Agent: Mikrotik/" . $Resource->"version" . " " . $Resource->"architecture-name" . \
" " . $Caller . "/Fetch (https://rsc.eworm.de/" . [ $IfThenElse ($CommitId != "unknown") \
("; " . $CommitInfo . "/" . [ :pick $CommitId 0 8 ]) ] . ")");
" " . $Caller . "/Fetch (https://rsc.eworm.de/; " . [ $CommitBrief ] . ")");
}
# check for existence of file, optionally with type
@ -1024,7 +1043,6 @@
# return an IPv6 netmask for CIDR
:set NetMask6 do={
:local FuncName $0;
:local CIDR [ :tostr $1 ];
:global IfThenElse;
@ -1241,7 +1259,6 @@
:local NewComment [ :tostr $2 ];
:global CommitId;
:global CommitInfo;
:global ExpectedConfigVersion;
:global GlobalConfigReady;
:global GlobalFunctionsReady;
@ -1417,10 +1434,6 @@
}
}
:if ($CommitId != "unknown" && $CommitIdBefore != $CommitId) do={
$LogPrint info $0 ("Updated to commit: " . $CommitInfo . "/" . [ :pick $CommitId 0 8 ]);
}
:if ($ExpectedConfigVersionBefore > $ExpectedConfigVersion) do={
$LogPrint warning $0 ("The configuration version decreased from " . \
$ExpectedConfigVersionBefore . " to " . $ExpectedConfigVersion . \
@ -1517,7 +1530,7 @@
:set GlobalConfigMigration;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# lock script against multiple invocation
@ -1663,7 +1676,7 @@
$SendNotification2 ({ origin=$0; subject=$1; message=$2; link=$3; silent=$4 });
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via NotificationFunctions - expects one array argument
@ -1921,18 +1934,20 @@
}
# add (and fix) global scripts scheduler
:local OnEvent "/system/script { run global-config; run global-functions; }";
:if ([ :len [ /system/scheduler/find where name="global-scripts" ] ] = 0) do={
/system/scheduler/add name="global-scripts" start-time=startup;
}
:if ([ /system/scheduler/get "global-scripts" on-event ] != $OnEvent) do={
/system/scheduler/set "global-scripts" on-event=$OnEvent;
/system/scheduler {
:local OnEvent "/system/script { run global-config; run global-functions; }";
:if ([ :len [ find where name="global-scripts" ] ] = 0) do={
add name="global-scripts" start-time=startup;
}
set on-event=$OnEvent [ find where name="global-scripts" on-event!=$OnEvent ];
enable [ find where name="global-scripts" disabled ];
}
# Log success
:local Resource [ /system/resource/get ];
$LogPrintOnce info $ScriptName ("Loaded on " . $Resource->"board-name" . \
" with RouterOS " . $Resource->"version" . ".");
$LogPrintOnce info $ScriptName ("Loaded " . \
[ $IfThenElse ($CommitId != "unknown") ([ $CommitBrief ] . " ") ] . \
"on " . $Resource->"board-name" . " with RouterOS " . $Resource->"version" . ".");
# signal we are ready
:set GlobalFunctionsReady true;

View file

@ -66,5 +66,5 @@
/interface/ethernet/enable $InterfaceReEnable;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }

View file

@ -75,5 +75,5 @@
/interface/ethernet/enable $InterfaceReEnable;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }

View file

@ -17,7 +17,7 @@
:put [ :tocrlf [ $InspectVarReturn $1 ] ];
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# inspect variable and return formatted string

View file

@ -28,7 +28,7 @@
[ $FormatLine "HostMax" ($Values->"hostmax") ] . "\n" . \
[ $FormatLine "Broadcast" ($Values->"broadcast") ]) ];
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# calculate and return netmask, network, min host, max host and broadcast

View file

@ -146,7 +146,7 @@
/system/scheduler/set interval=(($SchedVal->"run-count") . "m") \
comment="Waiting for retry..." $Scheduler;
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# generate filter for log-forward
@ -274,7 +274,7 @@
$SendEMail2 ({ origin=$0; subject=$1; message=$2; link=$3 });
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via e-mail - expects one array argument

View file

@ -54,7 +54,7 @@
:set GotifyQueue;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via Gotify - expects one array argument
@ -126,7 +126,7 @@
$SendGotify2 ({ origin=$0; subject=$1; message=$2; link=$3; silent=$4 });
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via Gotify - expects one array argument

View file

@ -59,7 +59,7 @@
:set MatrixQueue;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via Matrix - expects one array argument
@ -172,7 +172,7 @@
$SendMatrix2 ({ origin=$0; subject=$1; message=$2; link=$3 });
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via Matrix - expects one array argument

View file

@ -53,7 +53,7 @@
:set NtfyQueue;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via ntfy - expects one array argument
@ -148,7 +148,7 @@
$SendNtfy2 ({ origin=$0; subject=$1; message=$2; link=$3; silent=$4 });
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via ntfy - expects one array argument

View file

@ -62,7 +62,7 @@
:set TelegramQueue;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# get the chat id
@ -101,7 +101,7 @@
$LogPrint info $0 ("The thread id is: " . ($Message->"message_thread_id"));
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via telegram - expects one array argument
@ -237,7 +237,7 @@
$SendTelegram2 ({ origin=$0; subject=$1; message=$2; link=$3; silent=$4 });
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# send notification via telegram - expects one array argument

View file

@ -52,5 +52,5 @@
:return true;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }

View file

@ -68,7 +68,7 @@
:return false;
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
# import keys from a file
@ -110,5 +110,5 @@
}
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }

View file

@ -82,7 +82,7 @@
$LogPrint info $FuncName ("No action defined for " . $Count . " mode-button presses.");
}
} do={
:global ExitError; $ExitError false $0 $Err;
:global ExitOnError; $ExitOnError $0 $Err;
} }
/system/scheduler/add name="_ModeButtonScheduler" \
on-event=":global ModeButtonScheduler; \$ModeButtonScheduler;" interval=3s;
@ -91,5 +91,5 @@
/system/scheduler/set $Scheduler start-time=[ /system/clock/get time ];
}
} do={
:global ExitError; $ExitError false [ :jobname ] $Err;
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
}