2023-03-07 10:57:42 +01:00
|
|
|
#!rsc by RouterOS
|
|
|
|
# RouterOS script: firmware-upgrade-reboot
|
2025-01-02 00:04:06 +01:00
|
|
|
# Copyright (c) 2022-2025 Christian Hesse <mail@eworm.de>
|
2025-01-24 20:46:11 +01:00
|
|
|
# https://rsc.eworm.de/COPYING.md
|
2023-03-07 10:57:42 +01:00
|
|
|
#
|
2025-02-07 17:39:48 +01:00
|
|
|
# requires RouterOS, version=7.15
|
2023-11-15 21:31:18 +01:00
|
|
|
#
|
2023-03-07 10:57:42 +01:00
|
|
|
# install firmware upgrade, and reboot
|
2025-01-24 20:46:11 +01:00
|
|
|
# https://rsc.eworm.de/doc/firmware-upgrade-reboot.md
|
2023-03-07 10:57:42 +01:00
|
|
|
|
2024-12-06 10:31:52 +01:00
|
|
|
:local ExitOK false;
|
2025-05-06 09:44:23 +02:00
|
|
|
:onerror Err {
|
2025-05-06 14:08:37 +02:00
|
|
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
|
|
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
|
|
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
2024-03-06 15:28:55 +01:00
|
|
|
:local ScriptName [ :jobname ];
|
2024-03-04 13:48:01 +01:00
|
|
|
|
2024-03-08 12:45:38 +01:00
|
|
|
:global LogPrint;
|
2024-03-04 13:48:01 +01:00
|
|
|
:global ScriptLock;
|
|
|
|
:global VersionToNum;
|
|
|
|
|
2024-03-05 16:12:36 +01:00
|
|
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
2024-12-06 10:31:52 +01:00
|
|
|
:set ExitOK true;
|
2024-03-06 15:28:55 +01:00
|
|
|
:error false;
|
2024-03-05 16:12:36 +01:00
|
|
|
}
|
2024-03-04 13:48:01 +01:00
|
|
|
|
|
|
|
:local RouterBoard [ /system/routerboard/get ];
|
|
|
|
:if ($RouterBoard->"current-firmware" = $RouterBoard->"upgrade-firmware") do={
|
2024-03-08 12:45:38 +01:00
|
|
|
$LogPrint info $ScriptName ("Current and upgrade firmware match with version " . \
|
|
|
|
$RouterBoard->"current-firmware" . ".");
|
2024-12-06 10:31:52 +01:00
|
|
|
:set ExitOK true;
|
2024-03-06 15:28:55 +01:00
|
|
|
:error true;
|
2024-03-04 13:48:01 +01:00
|
|
|
}
|
|
|
|
:if ([ $VersionToNum ($RouterBoard->"current-firmware") ] > [ $VersionToNum ($RouterBoard->"upgrade-firmware") ]) do={
|
2024-03-08 12:45:38 +01:00
|
|
|
$LogPrint info $ScriptName ("Different firmware version is available, but it is a downgrade. Ignoring.");
|
2024-12-06 10:31:52 +01:00
|
|
|
:set ExitOK true;
|
2024-03-06 15:28:55 +01:00
|
|
|
:error true;
|
2024-03-04 13:48:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
:if ([ /system/routerboard/settings/get auto-upgrade ] = false) do={
|
2024-03-08 12:45:38 +01:00
|
|
|
$LogPrint info $ScriptName ("Firmware version " . $RouterBoard->"upgrade-firmware" . \
|
|
|
|
" is available, upgrading.");
|
2024-03-04 13:48:01 +01:00
|
|
|
/system/routerboard/upgrade;
|
|
|
|
}
|
|
|
|
|
|
|
|
:while ([ :len [ /log/find where topics=({"system";"info";"critical"}) \
|
|
|
|
message="Firmware upgraded successfully, please reboot for changes to take effect!" ] ] = 0) do={
|
|
|
|
:delay 1s;
|
|
|
|
}
|
|
|
|
|
|
|
|
:local Uptime [ /system/resource/get uptime ];
|
|
|
|
:if ($Uptime < 1m) do={
|
|
|
|
:delay $Uptime;
|
|
|
|
}
|
|
|
|
|
2024-03-08 12:45:38 +01:00
|
|
|
$LogPrint info $ScriptName ("Firmware upgrade successful, rebooting.");
|
2024-03-04 13:48:01 +01:00
|
|
|
/system/reboot;
|
2025-05-06 09:44:23 +02:00
|
|
|
} do={
|
|
|
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
2024-12-06 10:31:52 +01:00
|
|
|
}
|