aboutsummaryrefslogtreecommitdiffstats
path: root/check-lte-firmware-upgrade
blob: d861784d17525ad081dc658bc406d71f8c4cd5dc (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#!rsc by RouterOS
# RouterOS script: check-lte-firmware-upgrade
# Copyright (c) 2018-2022 Christian Hesse <mail@eworm.de>
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
#
# check for LTE firmware upgrade, send notification
# https://git.eworm.de/cgit/routeros-scripts/about/doc/check-lte-firmware-upgrade.md

:local 0 "check-lte-firmware-upgrade";
:global GlobalFunctionsReady;
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }

:global Identity;
:global SentLteFirmwareUpgradeNotification;

:global CharacterReplace;
:global LogPrintExit2;
:global ScriptFromTerminal;
:global SendNotification2;
:global SymbolForNotification;

:foreach Interface in=[ / interface lte find ] do={
  :local IntName [ / interface lte get $Interface name ];
  :do {
    :local Firmware [ / interface lte firmware-upgrade $Interface once as-value ];
    :local Info [ / interface lte info $Interface once as-value ];

    :if ($SentLteFirmwareUpgradeNotification = ($Firmware->"latest")) do={
      $LogPrintExit2 debug $0 ("Already sent the LTE firmware upgrade notification for version " . \
        ($Firmware->"latest") . ".") false;
    } else={
      :if (($Firmware->"installed") != ($Firmware->"latest")) do={
        $LogPrintExit2 info $0 ("A new firmware version " . ($Firmware->"latest") . " is available for " . \
          "LTE interface " . $IntName . ".") false;

        :if ([ $ScriptFromTerminal $0 ] = true && \
            [ :len [ / system script find where name="unattended-lte-firmware-upgrade" ] ] > 0) do={
          :put ("Do you want to start unattended lte firmware upgrade for interface " . $IntName . "? [y/N]");
          :if (([ / terminal inkey timeout=60 ] % 32) = 25) do={
             / system script run unattended-lte-firmware-upgrade;
             $LogPrintExit2 info $0 ("Scheduled lte firmware upgrade for interface " . $IntName . "...") true;
          } else={
            :put "Canceled...";
          }
        }

        $SendNotification2 ({ origin=$0; \
          subject=([ $SymbolForNotification "sparkles" ] . "LTE firmware upgrade"); \
          message=("A new firmware version " . ($Firmware->"latest") . " is available for " . \
            "LTE interface " . $IntName . " on " . $Identity . ".\n\n" . \
            "Interface: " . [ $CharacterReplace ($Info->"manufacturer" . " " . $Info->"model") ("\"") "" ] . "\n" . \
            "Installed: " . ($Firmware->"installed") . "\n" . \
            "Available: " . ($Firmware->"latest")); silent=true });
        :set SentLteFirmwareUpgradeNotification ($Firmware->"latest");
      } else={
        :if ([ $ScriptFromTerminal $0 ] = true) do={
          $LogPrintExit2 info $0 ("No firmware upgrade available for LTE interface " . $IntName . ".") false;
        }
      }
    }
  } on-error={
    $LogPrintExit2 debug $0 ("Could not get latest LTE firmware version for interface " . \
      $IntName . ".") false;
  }
}