mirror of
https://github.com/eworm-de/routeros-scripts.git
synced 2026-03-01 03:29:35 +00:00
Compare commits
31 commits
72660f21a5
...
9eae2fafe2
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9eae2fafe2 | ||
|
|
fbe7b8e4bc | ||
|
|
b667ce8bed | ||
|
|
fe9d0a0bb4 | ||
|
|
7054238b8c | ||
|
|
5ed1c3db66 | ||
|
|
c5ef71eb4a | ||
|
|
87f82d736f | ||
|
|
542a018a15 | ||
|
|
d1c02fe19b | ||
|
|
f7cd7d7729 | ||
|
|
d00c500609 | ||
|
|
edd184db8f | ||
|
|
98178d1562 | ||
|
|
8bc9e23bd7 | ||
|
|
faad9c5b2a | ||
|
|
4841c2c58d | ||
|
|
da516a5102 | ||
|
|
9ae01995d7 | ||
|
|
5d0760e422 | ||
|
|
5cc9b8c775 | ||
|
|
19dcddf406 | ||
|
|
5dcd63eed0 | ||
|
|
7bb6a3f843 | ||
|
|
843ec3030c | ||
|
|
bbf2f5abbf | ||
|
|
9347063647 | ||
|
|
16976b1d78 | ||
|
|
74be3eae5d | ||
|
|
b7a5402be6 | ||
|
|
28b1297a43 |
20 changed files with 80 additions and 55 deletions
Binary file not shown.
|
Before Width: | Height: | Size: 2.3 KiB After Width: | Height: | Size: 2.5 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 2.6 KiB After Width: | Height: | Size: 2.8 KiB |
|
|
@ -32,5 +32,5 @@
|
|||
:set ($Seen->$Mac) 1;
|
||||
}
|
||||
} do={
|
||||
:global ExitError; $ExitError false [ :jobname ] $Err;
|
||||
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -32,5 +32,5 @@
|
|||
:set ($Seen->$Mac) 1;
|
||||
}
|
||||
} do={
|
||||
:global ExitError; $ExitError false [ :jobname ] $Err;
|
||||
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -41,5 +41,5 @@
|
|||
:set ($Seen->$Mac) 1;
|
||||
}
|
||||
} do={
|
||||
:global ExitError; $ExitError false [ :jobname ] $Err;
|
||||
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -32,5 +32,5 @@
|
|||
:set ($Seen->$Mac) 1;
|
||||
}
|
||||
} do={
|
||||
:global ExitError; $ExitError false [ :jobname ] $Err;
|
||||
:global ExitOnError; $ExitOnError [ :jobname ] $Err;
|
||||
}
|
||||
|
|
|
|||
9
global-functions.d/deprecated.rsc
Normal file
9
global-functions.d/deprecated.rsc
Normal file
|
|
@ -0,0 +1,9 @@
|
|||
#!rsc by RouterOS
|
||||
# RouterOS script: global-functions.d/deprecated
|
||||
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||
# https://rsc.eworm.de/COPYING.md
|
||||
#
|
||||
# requires RouterOS, version=7.17
|
||||
#
|
||||
# deprecated global functions
|
||||
# https://rsc.eworm.de/
|
||||
|
|
@ -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
|
||||
|
|
@ -1241,7 +1260,6 @@
|
|||
:local NewComment [ :tostr $2 ];
|
||||
|
||||
:global CommitId;
|
||||
:global CommitInfo;
|
||||
:global ExpectedConfigVersion;
|
||||
:global GlobalConfigReady;
|
||||
:global GlobalFunctionsReady;
|
||||
|
|
@ -1397,7 +1415,7 @@
|
|||
source=[ $IfThenElse ($ScriptUpdatesCRLF = true) $SourceCRLF $SourceNew ] $Script;
|
||||
:if ($ScriptVal->"name" = "global-config" || \
|
||||
$ScriptVal->"name" = "global-functions" || \
|
||||
$ScriptVal->"name" ~ ("^mod/.")) do={
|
||||
$ScriptVal->"name" ~ ("^(global-functions\\.d|mod)/.")) do={
|
||||
:set ReloadGlobal true;
|
||||
}
|
||||
} on-error={ }
|
||||
|
|
@ -1417,10 +1435,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 +1531,7 @@
|
|||
:set GlobalConfigMigration;
|
||||
}
|
||||
} do={
|
||||
:global ExitError; $ExitError false $0 $Err;
|
||||
:global ExitOnError; $ExitOnError $0 $Err;
|
||||
} }
|
||||
|
||||
# lock script against multiple invocation
|
||||
|
|
@ -1663,7 +1677,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 +1935,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;
|
||||
|
|
|
|||
|
|
@ -66,5 +66,5 @@
|
|||
/interface/ethernet/enable $InterfaceReEnable;
|
||||
}
|
||||
} do={
|
||||
:global ExitError; $ExitError false $0 $Err;
|
||||
:global ExitOnError; $ExitOnError $0 $Err;
|
||||
} }
|
||||
|
|
|
|||
|
|
@ -75,5 +75,5 @@
|
|||
/interface/ethernet/enable $InterfaceReEnable;
|
||||
}
|
||||
} do={
|
||||
:global ExitError; $ExitError false $0 $Err;
|
||||
:global ExitOnError; $ExitOnError $0 $Err;
|
||||
} }
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -52,5 +52,5 @@
|
|||
:return true;
|
||||
}
|
||||
} do={
|
||||
:global ExitError; $ExitError false $0 $Err;
|
||||
:global ExitOnError; $ExitOnError $0 $Err;
|
||||
} }
|
||||
|
|
|
|||
|
|
@ -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;
|
||||
} }
|
||||
|
|
|
|||
|
|
@ -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;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue