blob: 5a6bd2912a8b6c26cada56a863201f3203575e4c (
about) (
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
|
#!rsc
# RouterOS script: capsman-download-packages
# Copyright (c) 2018 Christian Hesse <mail@eworm.de>
# Michael Gisbers <michael@gisbers.de>
#
# requires: dont-require-permissions=yes
#
# download and cleanup packages for CAP installation from CAPsMAN
:global CertificateAvailable;
:local "package-path" [ / caps-man manager get package-path ];
:local "installed-version" [ / system package update get installed-version ];
:local updated false;
:foreach package in=[ / file find where type=package ] do={
:if ([ / file get $package package-version ] != $"installed-version") do={
:local "package-name" [ / file get $package package-name ];
:local "package-architecture" [ / file get $package package-architecture ];
:if ($"package-architecture" = "mips") do={
:set "package-architecture" "mipsbe";
}
:if ($"package-name" = "wireless@") do={
:set "package-name" "wireless";
}
:local "package-file" ($"package-name" . "-" . $"installed-version" . "-" . $"package-architecture" . ".npk");
$CertificateAvailable "Let's Encrypt Authority X3" "letsencrypt";
/ tool fetch mode=https check-certificate=yes-without-crl \
("https://upgrade.mikrotik.com/routeros/" . $"installed-version" . "/" . $"package-file") \
dst-path=($"package-path" . "/" . $"package-file");
:set updated true;
/ file remove $package;
}
}
:if ($updated = true && [ / caps-man manager get enabled ] = true) do={
/ caps-man manager set enabled=yes;
}
|