2023-03-07 10:57:42 +01:00
|
|
|
#!rsc by RouterOS
|
|
|
|
# RouterOS script: mod/scriptrunonece
|
2025-01-02 00:04:06 +01:00
|
|
|
# Copyright (c) 2020-2025 Christian Hesse <mail@eworm.de>
|
2025-01-24 20:46:12 +01:00
|
|
|
# https://rsc.eworm.de/COPYING.md
|
2023-04-04 19:24:00 +02:00
|
|
|
#
|
2025-02-07 17:39:48 +01:00
|
|
|
# requires RouterOS, version=7.15
|
2024-04-04 21:45:02 +02:00
|
|
|
#
|
2023-04-04 19:24:00 +02:00
|
|
|
# download script and run it once
|
2025-01-24 20:46:12 +01:00
|
|
|
# https://rsc.eworm.de/doc/mod/scriptrunonce.md
|
2023-03-07 10:57:42 +01:00
|
|
|
|
|
|
|
:global ScriptRunOnce;
|
|
|
|
|
|
|
|
# fetch and run script(s) once
|
2025-05-06 09:45:14 +02:00
|
|
|
:set ScriptRunOnce do={ :onerror Err {
|
2023-03-07 10:57:42 +01:00
|
|
|
:local Scripts [ :toarray $1 ];
|
|
|
|
|
|
|
|
:global ScriptRunOnceBaseUrl;
|
|
|
|
:global ScriptRunOnceUrlSuffix;
|
|
|
|
|
2025-02-12 13:59:31 +01:00
|
|
|
:global FetchHuge;
|
2024-03-08 12:45:38 +01:00
|
|
|
:global LogPrint;
|
2023-03-07 10:57:42 +01:00
|
|
|
:global ValidateSyntax;
|
|
|
|
|
|
|
|
:foreach Script in=$Scripts do={
|
2023-06-26 11:17:24 +02:00
|
|
|
:if (!($Script ~ "^(ftp|https?|sftp)://")) do={
|
2023-03-07 10:57:42 +01:00
|
|
|
:if ([ :len $ScriptRunOnceBaseUrl ] = 0) do={
|
2024-03-08 12:45:38 +01:00
|
|
|
$LogPrint warning $0 ("Script '" . $Script . "' is not an url and base url is not available.");
|
2024-03-08 17:52:07 +01:00
|
|
|
:return false;
|
2023-03-07 10:57:42 +01:00
|
|
|
}
|
|
|
|
:set Script ($ScriptRunOnceBaseUrl . $Script . ".rsc" . $ScriptRunOnceUrlSuffix);
|
|
|
|
}
|
|
|
|
|
2025-02-12 13:59:31 +01:00
|
|
|
:local Source [ $FetchHuge $0 $Script true ];
|
|
|
|
:if ($Source = false) do={
|
2024-03-08 12:45:38 +01:00
|
|
|
$LogPrint warning $0 ("Failed fetching script '" . $Script . "'!");
|
2025-02-12 13:59:31 +01:00
|
|
|
:return false;
|
2023-03-07 10:57:42 +01:00
|
|
|
}
|
|
|
|
|
2025-02-12 14:01:10 +01:00
|
|
|
:if ([ $ValidateSyntax $Source ] = false) do={
|
|
|
|
$LogPrint warning $0 ("The script '" . $Script . "' failed syntax validation!");
|
|
|
|
:return false;
|
|
|
|
}
|
|
|
|
|
2025-05-08 10:02:15 +02:00
|
|
|
:onerror Err {
|
2025-02-12 14:01:10 +01:00
|
|
|
$LogPrint info $0 ("Running script '" . $Script . "' now.");
|
|
|
|
[ :parse $Source ];
|
2025-05-08 10:02:15 +02:00
|
|
|
} do={
|
|
|
|
$LogPrint warning $0 ("The script '" . $Script . "' failed to run: " . $Err);
|
2025-02-12 14:02:33 +01:00
|
|
|
:return false;
|
2023-03-07 10:57:42 +01:00
|
|
|
}
|
2025-02-12 14:02:33 +01:00
|
|
|
|
|
|
|
:return true;
|
2023-03-07 10:57:42 +01:00
|
|
|
}
|
2025-05-06 09:45:14 +02:00
|
|
|
} do={
|
|
|
|
:global ExitError; $ExitError false $0 $Err;
|
2024-12-09 09:10:44 +01:00
|
|
|
} }
|