Compare commits
1107 commits
change-121
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
623f96d94a | ||
|
|
aa0b5a9ca2 | ||
|
|
ee9618014c | ||
|
|
0745f09a8a | ||
|
|
222404535b | ||
|
|
c697c321e6 | ||
|
|
96896c37e5 | ||
|
|
6e37bab481 | ||
|
|
28b00e23a1 | ||
|
|
830693df79 | ||
|
|
240decf419 | ||
|
|
c0678f0501 | ||
|
|
73350ff3f4 | ||
|
|
7caaa62321 | ||
|
|
1f11f72d18 | ||
|
|
daeb173dbc | ||
|
|
4acbd6449e | ||
|
|
9db7f4494c | ||
|
|
2d0c79160d | ||
|
|
b6e72f9a9f | ||
|
|
1b53b52ac6 | ||
|
|
f77cc07338 | ||
|
|
094215aec7 | ||
|
|
d60ee59e77 | ||
|
|
3926d12070 | ||
|
|
5dbd419d1a | ||
|
|
ac6aefd34c | ||
|
|
518a4c329f | ||
|
|
9ef3ba5479 | ||
|
|
84c49c0f7e | ||
|
|
bc174d7f1f | ||
|
|
678fc3307e | ||
|
|
1ac0147fce | ||
|
|
1f6c43d5ce | ||
|
|
544e8094de | ||
|
|
d4979146f9 | ||
|
|
ca487376d6 | ||
|
|
ea9e843ae9 | ||
|
|
94514a7c75 | ||
|
|
699be25b64 | ||
|
|
79c98a4b3a | ||
|
|
e49f68c1f2 | ||
|
|
2f4e83990a | ||
|
|
77dc0565a9 | ||
|
|
564c7f6bbc | ||
|
|
6718b90780 | ||
|
|
e6faf346c2 | ||
|
|
295fa3144a | ||
|
|
b65f3512d0 | ||
|
|
8a904dadf4 | ||
|
|
fa64e8906b | ||
|
|
2feaaf36b2 | ||
|
|
30743c0e87 | ||
|
|
725eb834f4 | ||
|
|
b97a434a9c | ||
|
|
70675a9fee | ||
|
|
e0b12a9050 | ||
|
|
a64e9bed80 | ||
|
|
e10455fb18 | ||
|
|
ed9dee3c5f | ||
|
|
4f778cb1c6 | ||
|
|
a61fbfb75c | ||
|
|
903a3f44a0 | ||
|
|
638258000b | ||
|
|
b285f2c5d2 | ||
|
|
93eb218589 | ||
|
|
45e2f7b0a8 | ||
|
|
b29f3535b6 | ||
|
|
fa9c4be576 | ||
|
|
ce37544bae | ||
|
|
aeca778284 | ||
|
|
af5f01a973 | ||
|
|
0b7528db99 | ||
|
|
54612e333f | ||
|
|
05f0838119 | ||
|
|
c6451c87f1 | ||
|
|
4935c81bd9 | ||
|
|
d12be8f1ac | ||
|
|
c4a060c3d4 | ||
|
|
f3afee3e4b | ||
|
|
82587ec589 | ||
|
|
edd51ca719 | ||
|
|
d1fa3facfd | ||
|
|
b4e6cc5b59 | ||
|
|
9287996b74 | ||
|
|
75692abf47 | ||
|
|
7b45bb5b46 | ||
|
|
165d7c60d4 | ||
|
|
b16c2f5b90 | ||
|
|
cbb0aba1b1 | ||
|
|
1ce3160933 | ||
|
|
607a608502 | ||
|
|
148d40e18d | ||
|
|
036c6ef682 | ||
|
|
5986894749 | ||
|
|
8d68f24095 | ||
|
|
eb89f8359b | ||
|
|
8faf4ab7cf | ||
|
|
ceb6f2353e | ||
|
|
719b662b76 | ||
|
|
cbb282746f | ||
|
|
2e0787afd1 | ||
|
|
a0399216fc | ||
|
|
2d6fdc355e | ||
|
|
fae8dbd8ea | ||
|
|
a2d6671cf0 | ||
|
|
d610bf3582 | ||
|
|
97b4a41f23 | ||
|
|
a2250a00e6 | ||
|
|
c6cc8b9a51 | ||
|
|
5075701958 | ||
|
|
8f6a38f299 | ||
|
|
cc5aea22b3 | ||
|
|
d002d1c0c0 | ||
|
|
737a872a5f | ||
|
|
298a43a871 | ||
|
|
335bfc0a88 | ||
|
|
20885c4620 | ||
|
|
5ccb0d07b1 | ||
|
|
7d701483d3 | ||
|
|
7772fbb22d | ||
|
|
83b164d511 | ||
|
|
f0910a4472 | ||
|
|
090f25a82d | ||
|
|
8ff34a2408 | ||
|
|
affb9b3baf | ||
|
|
87787eefe3 | ||
|
|
677b5b8069 | ||
|
|
876505c36d | ||
|
|
b5a0269667 | ||
|
|
f3e6e152bc | ||
|
|
8eb397f79f | ||
|
|
db0a5bf33c | ||
|
|
fbfeea3042 | ||
|
|
1a1399d302 | ||
|
|
335266f247 | ||
|
|
d100cac9ed | ||
|
|
c88953e44d | ||
|
|
20987221d9 | ||
|
|
ea4b5553c2 | ||
|
|
b80b872e55 | ||
|
|
ea05b69f7c | ||
|
|
d7a6eb1d00 | ||
|
|
6ad6f9aa08 | ||
|
|
c62f236251 | ||
|
|
47309e5c03 | ||
|
|
9fa11cb79a | ||
|
|
def540c965 | ||
|
|
025b492783 | ||
|
|
6630d35eea | ||
|
|
c81618b571 | ||
|
|
35b556f0b2 | ||
|
|
9ceed0926a | ||
|
|
5ffa85f8bf | ||
|
|
48d0f1f0b9 | ||
|
|
a931cb61a0 | ||
|
|
14b51d96b0 | ||
|
|
2c715096b9 | ||
|
|
2773fef9d8 | ||
|
|
6b0c9ab17d | ||
|
|
59dc7e6d0c | ||
|
|
22e6383e86 | ||
|
|
62ca30b5d3 | ||
|
|
907358cb85 | ||
|
|
2fed8f967b | ||
|
|
386ea2419f | ||
|
|
fe080c0d3d | ||
|
|
a856d309df | ||
|
|
721e786f68 | ||
|
|
4c2c7e817a | ||
|
|
89175e511f | ||
|
|
b068f86995 | ||
|
|
d46574b4fe | ||
|
|
c3010af4ed | ||
|
|
1307b8587e | ||
|
|
6415849850 | ||
|
|
95f8af6234 | ||
|
|
de2a90d841 | ||
|
|
e2d3f0f073 | ||
|
|
595b4aea9d | ||
|
|
0de6d006ae | ||
|
|
1f4bf9ee63 | ||
|
|
c3d3d61f92 | ||
|
|
6130c94cc1 | ||
|
|
15fd522d3d | ||
|
|
5b15c82bb1 | ||
|
|
30b80e903d | ||
|
|
80aed200fd | ||
|
|
2d81984aed | ||
|
|
e3284ca770 | ||
|
|
daee05dbd7 | ||
|
|
43bac7c33c | ||
|
|
a2f837be59 | ||
|
|
8353a8547f | ||
|
|
cb984a5e52 | ||
|
|
0e00a228d6 | ||
|
|
e08bb2192d | ||
|
|
fb8e616846 | ||
|
|
d993495e44 | ||
|
|
1e4f168735 | ||
|
|
b70e6e7984 | ||
|
|
4bc3bf40e6 | ||
|
|
d69b399572 | ||
|
|
bf684a7197 | ||
|
|
d59c4aee26 | ||
|
|
3d3b270748 | ||
|
|
6a49c483b6 | ||
|
|
c50acd697a | ||
|
|
4bd7d44cd2 | ||
|
|
86ad41f6b6 | ||
|
|
64fe923c5a | ||
|
|
f1396b83aa | ||
|
|
1b5dd1e1d3 | ||
|
|
e78c71948d | ||
|
|
ce129ee441 | ||
|
|
2a95687477 | ||
|
|
74dc809b98 | ||
|
|
ff218e4ce5 | ||
|
|
bd3cc3bbd4 | ||
|
|
36f155ce62 | ||
|
|
187735f35f | ||
|
|
3521995dbc | ||
|
|
1f4290f4be | ||
|
|
205bcce6f9 | ||
|
|
10ac816348 | ||
|
|
f22d46da96 | ||
|
|
d0adf9974e | ||
|
|
fefe59751f | ||
|
|
a523f97938 | ||
|
|
c757064eb9 | ||
|
|
9cd4ed08a4 | ||
|
|
9ae21c00bd | ||
|
|
314e68e4cd | ||
|
|
e01873301f | ||
|
|
3f092d3477 | ||
|
|
2a7fd7ea53 | ||
|
|
5badafe109 | ||
|
|
c1e6348bb9 | ||
|
|
d5f9ecebfb | ||
|
|
5c599beae1 | ||
|
|
8b1b73c936 | ||
|
|
f5c4378676 | ||
|
|
12926b7c42 | ||
|
|
2317013121 | ||
|
|
86a8919ed2 | ||
|
|
09f9826760 | ||
|
|
7a1fef78a2 | ||
|
|
a6b36dde7b | ||
|
|
5b89f3e425 | ||
|
|
a9e7bb0a05 | ||
|
|
b807fc9e90 | ||
|
|
142b0760b0 | ||
|
|
79f681b801 | ||
|
|
1925d2847c | ||
|
|
187aeba78b | ||
|
|
dc2296d500 | ||
|
|
c3fce37066 | ||
|
|
6691e2e765 | ||
|
|
01f3cb91e7 | ||
|
|
9085780562 | ||
|
|
f095b581e7 | ||
|
|
661aad522b | ||
|
|
4561b17dbf | ||
|
|
39295b4954 | ||
|
|
0f58cecc0f | ||
|
|
f2dbb9eff3 | ||
|
|
b4d80d3b17 | ||
|
|
9b5419b939 | ||
|
|
15248ffd39 | ||
|
|
6270ac45d8 | ||
|
|
194698f53f | ||
|
|
38ec392a5f | ||
|
|
aaecd1b457 | ||
|
|
5b40380cd2 | ||
|
|
2d39dbdf7c | ||
|
|
bc1c238158 | ||
|
|
160effd91b | ||
|
|
10bd9a1cb5 | ||
|
|
59f9a1187f | ||
|
|
ce29fcf49e | ||
|
|
6a9fced721 | ||
|
|
713e63da87 | ||
|
|
148892694f | ||
|
|
9e70bca30b | ||
|
|
a68763c4dd | ||
|
|
857993cf90 | ||
|
|
ad6ad5bfcc | ||
|
|
be0e9be1ba | ||
|
|
b19c448f78 | ||
|
|
2afe734bc3 | ||
|
|
6040f70b19 | ||
|
|
286ed96cc3 | ||
|
|
af40ae82ed | ||
|
|
87edd0bd29 | ||
|
|
59c66de690 | ||
|
|
5958851bd7 | ||
|
|
35bce7c5eb | ||
|
|
78463f469b | ||
|
|
f7ba78702f | ||
|
|
24ea16cf91 | ||
|
|
506acb748b | ||
|
|
e3a15cc6b8 | ||
|
|
0ef8888412 | ||
|
|
1936dcb563 | ||
|
|
d865deb8a8 | ||
|
|
7b624faaa1 | ||
|
|
4954a88695 | ||
|
|
9d845d40f0 | ||
|
|
4358dabb19 | ||
|
|
ef1a402c4e | ||
|
|
862830b341 | ||
|
|
ff812dd192 | ||
|
|
40b19a179d | ||
|
|
8cddc63767 | ||
|
|
446aa3d7ff | ||
|
|
12037ff6e6 | ||
|
|
9b558ff8a1 | ||
|
|
2374be9a21 | ||
|
|
27fc07e940 | ||
|
|
d5141f43e5 | ||
|
|
63606ad25c | ||
|
|
200167fa38 | ||
|
|
02986eb77a | ||
|
|
a6ab95ccef | ||
|
|
37a6d4cc43 | ||
|
|
d2af793683 | ||
|
|
829fce789b | ||
|
|
d57916fc26 | ||
|
|
fe3d9f8418 | ||
|
|
41b705aa5a | ||
|
|
60c5e84401 | ||
|
|
3ad8cafc7a | ||
|
|
83cf003f62 | ||
|
|
bcdb74f31d | ||
|
|
aae9b4d4e3 | ||
|
|
057bbb8481 | ||
|
|
3eec13b8b5 | ||
|
|
76778f0431 | ||
|
|
aeccd36f16 | ||
|
|
925e7f869e | ||
|
|
9a5a2aec4f | ||
|
|
4b92181f2e | ||
|
|
c720eadd2c | ||
|
|
4d1349125d | ||
|
|
0df4170a2e | ||
|
|
a308d4269e | ||
|
|
2d41ad718d | ||
|
|
a556f4c398 | ||
|
|
ff03f49724 | ||
|
|
8418d58ff0 | ||
|
|
2712bcb44d | ||
|
|
69b2af4bd7 | ||
|
|
08d78224a0 | ||
|
|
8f1ac6fa17 | ||
|
|
96cbb32a4f | ||
|
|
9b811e1ed2 | ||
|
|
b4188ab1a2 | ||
|
|
de5aab12ae | ||
|
|
33393798b1 | ||
|
|
9423d8019a | ||
|
|
bf1b3e3c5e | ||
|
|
64ec962bb6 | ||
|
|
7d4e4ec273 | ||
|
|
9acf9781cb | ||
|
|
c643069b3e | ||
|
|
da93138017 | ||
|
|
39ab19b272 | ||
|
|
1075b6b24e | ||
|
|
9ae733a167 | ||
|
|
143b8a8ddc | ||
|
|
d609da0041 | ||
|
|
0e93d8ca66 | ||
|
|
d99380443b | ||
|
|
8ed83a311d | ||
|
|
5dc6b712e1 | ||
|
|
55e07a8a42 | ||
|
|
7d8e9fda29 | ||
|
|
472dc9289d | ||
|
|
f5c33a9cfb | ||
|
|
b959f2d941 | ||
|
|
051a1d95e5 | ||
|
|
e44a5384b7 | ||
|
|
009516dbd4 | ||
|
|
54a3012e89 | ||
|
|
e0ba2c8282 | ||
|
|
0a9acab040 | ||
|
|
34c052c5f1 | ||
|
|
953daca8ac | ||
|
|
02a205b14e | ||
|
|
b9faeb86b9 | ||
|
|
41bf9677db | ||
|
|
90f61d3d75 | ||
|
|
ccfe1a781e | ||
|
|
154fb43800 | ||
|
|
fa83c76be1 | ||
|
|
07541a3cbc | ||
|
|
0717ebfbd5 | ||
|
|
507a520994 | ||
|
|
fe64918118 | ||
|
|
3822887ba2 | ||
|
|
c69b13c879 | ||
|
|
183b16d83c | ||
|
|
0eaefcdc72 | ||
|
|
2fa044972c | ||
|
|
3788a3e286 | ||
|
|
34eac64f33 | ||
|
|
4118f53aae | ||
|
|
b12f8a3974 | ||
|
|
a1437a4c83 | ||
|
|
8328400e87 | ||
|
|
158230070f | ||
|
|
405c329f39 | ||
|
|
b78df91b23 | ||
|
|
29bcd191ee | ||
|
|
d80f43a1c8 | ||
|
|
390e3653d7 | ||
|
|
75163f0d3c | ||
|
|
d4b5e1f5e7 | ||
|
|
c823ff87ed | ||
|
|
44fa91f5c4 | ||
|
|
e36613608c | ||
|
|
019e10e190 | ||
|
|
314ba5796d | ||
|
|
67e7b11aa7 | ||
|
|
27987a0d7c | ||
|
|
2cc47f56b9 | ||
|
|
b560ea4b7d | ||
|
|
cdfb086b49 | ||
|
|
3c30276e23 | ||
|
|
16c9ce437e | ||
|
|
6909514692 | ||
|
|
f8c3659f6a | ||
|
|
ce39b79f69 | ||
|
|
20bf609c44 | ||
|
|
b63e0fcb2f | ||
|
|
1555426687 | ||
|
|
97b99316b2 | ||
|
|
788400c458 | ||
|
|
eb59dd21ca | ||
|
|
79a4b369cb | ||
|
|
f0e6cbcfe1 | ||
|
|
d71ea804b0 | ||
|
|
e148df9e57 | ||
|
|
2f55bfaf00 | ||
|
|
ea6de35699 | ||
|
|
fb343c99e3 | ||
|
|
7be26a0712 | ||
|
|
6d718ec987 | ||
|
|
e341e1c30c | ||
|
|
b43b1b3955 | ||
|
|
1b46a5fd9b | ||
|
|
b13360e4b8 | ||
|
|
c9de6d8579 | ||
|
|
10374afc18 | ||
|
|
0c1d96f89d | ||
|
|
3ccaafd1b3 | ||
|
|
469f783a92 | ||
|
|
33c02e0609 | ||
|
|
6331505dbe | ||
|
|
0c4fb42616 | ||
|
|
f5189b8bd7 | ||
|
|
e2fe653035 | ||
|
|
b11be59b08 | ||
|
|
24de060904 | ||
|
|
14195c51ca | ||
|
|
e833dfcf25 | ||
|
|
512c54bd59 | ||
|
|
3d40b4419d | ||
|
|
a6d4e7e82c | ||
|
|
f6c2225f68 | ||
|
|
53b13b295a | ||
|
|
4eafcaa3ac | ||
|
|
c33eb41c9c | ||
|
|
78f9687558 | ||
|
|
e5de9de391 | ||
|
|
7928c5f054 | ||
|
|
757fa60e6f | ||
|
|
a22b62f588 | ||
|
|
cad104879c | ||
|
|
58da92e36a | ||
|
|
2c92c78b46 | ||
|
|
75633872aa | ||
|
|
dafcc1a0cb | ||
|
|
0199ea8884 | ||
|
|
584e507fd1 | ||
|
|
5715bc7b57 | ||
|
|
1c957dbc6d | ||
|
|
b7b3b43f3b | ||
|
|
df631b987d | ||
|
|
c8759381e9 | ||
|
|
d41f758550 | ||
|
|
e1c561dd91 | ||
|
|
4d0b4a1ff4 | ||
|
|
8af67af462 | ||
|
|
da280586b5 | ||
|
|
2e42f7963c | ||
|
|
fc3beac83b | ||
|
|
fefe11d1e8 | ||
|
|
b156fc43cf | ||
|
|
0fea300fea | ||
|
|
6570a84904 | ||
|
|
63db96bdcc | ||
|
|
88ff031368 | ||
|
|
81ba47a07d | ||
|
|
d748b69142 | ||
|
|
f5f00b70e3 | ||
|
|
4760515add | ||
|
|
d19b90df08 | ||
|
|
ea8ec6b580 | ||
|
|
dbdf295244 | ||
|
|
82020ddd73 | ||
|
|
a8e5b5226b | ||
|
|
4bfb591fa0 | ||
|
|
49d9fb1ffd | ||
|
|
7233dea5bb | ||
|
|
727495d9c4 | ||
|
|
4542c2b19e | ||
|
|
0fb5fd0323 | ||
|
|
dbdc3e4718 | ||
|
|
dafd95d44a | ||
|
|
7b660d0952 | ||
|
|
23d38927bc | ||
|
|
84ba3a463a | ||
|
|
27c92b4382 | ||
|
|
6501c98c82 | ||
|
|
bfe5f20920 | ||
|
|
3024b246b5 | ||
|
|
61f3c26199 | ||
|
|
3ad7ccd3d6 | ||
|
|
eabe3f6e95 | ||
|
|
75e5ddec52 | ||
|
|
44d0c852f1 | ||
|
|
0eb91b6bfa | ||
|
|
87fb70534f | ||
|
|
fcb5347e33 | ||
|
|
aa294b4c67 | ||
|
|
414c83ef81 | ||
|
|
8b19e74736 | ||
|
|
3c8ec5169f | ||
|
|
d921af9a6b | ||
|
|
9421566352 | ||
|
|
ef48b8d39e | ||
|
|
8dc1e1ea6b | ||
|
|
3ef4588601 | ||
|
|
59c9d0ce4b | ||
|
|
378a8978df | ||
|
|
9f2f54b479 | ||
|
|
9a12934202 | ||
|
|
370e81321f | ||
|
|
56e74268b0 | ||
|
|
5f1cbe6de5 | ||
|
|
1ad4d05be8 | ||
|
|
e29ef31eb8 | ||
|
|
bc0227c49b | ||
|
|
43f6c0b975 | ||
|
|
95b675f67e | ||
|
|
d81a786e82 | ||
|
|
aebc4e37da | ||
|
|
b177e298d7 | ||
|
|
106a9bddef | ||
|
|
546e3cdab6 | ||
|
|
c04ee5aadf | ||
|
|
49aef0606b | ||
|
|
32ac10e6ef | ||
|
|
e3ca37ad9a | ||
|
|
dd2854e983 | ||
|
|
7addf2e53a | ||
|
|
1f5aea9fca | ||
|
|
867e504c94 | ||
|
|
90a148a9d8 | ||
|
|
3b0ea3a238 | ||
|
|
719079c5c1 | ||
|
|
563aeb8f71 | ||
|
|
299b34883f | ||
|
|
ed18444578 | ||
|
|
66ab2a8511 | ||
|
|
27144a428a | ||
|
|
6e7f311269 | ||
|
|
6567a94a4f | ||
|
|
631f63836b | ||
|
|
828f68be3c | ||
|
|
078d5368fb | ||
|
|
18fcecd211 | ||
|
|
d5a50d824f | ||
|
|
6920842d15 | ||
|
|
b8841a7135 | ||
|
|
b75a35417a | ||
|
|
bf11489d11 | ||
|
|
5e60d2e1b7 | ||
|
|
5ead61cb62 | ||
|
|
71316f7377 | ||
|
|
02cc581aff | ||
|
|
453d80a121 | ||
|
|
9474102c62 | ||
|
|
996602bfe9 | ||
|
|
72db13c0ab | ||
|
|
0431b02324 | ||
|
|
7be415d0ed | ||
|
|
b7923485bd | ||
|
|
ac62b8f24f | ||
|
|
39c5aeda13 | ||
|
|
7b760d9fa4 | ||
|
|
632d294a98 | ||
|
|
61dee21776 | ||
|
|
96fa76f07d | ||
|
|
f8058eaf71 | ||
|
|
36c87c91ea | ||
|
|
7484663b92 | ||
|
|
231be730ae | ||
|
|
1239ac3104 | ||
|
|
1b7458ac95 | ||
|
|
26dbf5805a | ||
|
|
b938847030 | ||
|
|
38b5fbab9c | ||
|
|
c70b6a8eb3 | ||
|
|
08ff07d037 | ||
|
|
5281b4ba02 | ||
|
|
1dda59034e | ||
|
|
500054535c | ||
|
|
a446f31262 | ||
|
|
d4acc5aa59 | ||
|
|
ccf17a438c | ||
|
|
e8b1e19b28 | ||
|
|
98791f48fd | ||
|
|
ce2d090e99 | ||
|
|
665516b33d | ||
|
|
d9693f4d5f | ||
|
|
6c990079a6 | ||
|
|
303c393900 | ||
|
|
db508ddcd1 | ||
|
|
9e3729c279 | ||
|
|
b98b245714 | ||
|
|
191cc1b952 | ||
|
|
3ada3055ff | ||
|
|
ef3ce7cc6c | ||
|
|
8212bd6c95 | ||
|
|
ba39c29648 | ||
|
|
6bee467550 | ||
|
|
d1b9b1b410 | ||
|
|
a7878d664f | ||
|
|
b66332eb46 | ||
|
|
8c8c75ca66 | ||
|
|
1e2ca3d214 | ||
|
|
5310673152 | ||
|
|
009a6bd762 | ||
|
|
8231c3e833 | ||
|
|
d70efe910a | ||
|
|
c311e58d99 | ||
|
|
42bcc63d29 | ||
|
|
bceabebf9c | ||
|
|
519cb85e28 | ||
|
|
e51191035b | ||
|
|
210ef26b93 | ||
|
|
f8a55860af | ||
|
|
1788c05998 | ||
|
|
3866ea1923 | ||
|
|
73e0ac75f1 | ||
|
|
48bcf8ee6e | ||
|
|
ee030740cb | ||
|
|
4968b79fc1 | ||
|
|
d4ea0e18a7 | ||
|
|
e89867be15 | ||
|
|
adbefca0e4 | ||
|
|
e76ae11b02 | ||
|
|
a78fe98fd0 | ||
|
|
aac723e2a1 | ||
|
|
ede351f47e | ||
|
|
de9dee83be | ||
|
|
be05480071 | ||
|
|
1994b23e46 | ||
|
|
81f59f9894 | ||
|
|
1927dc505a | ||
|
|
eeb76c227c | ||
|
|
5450618723 | ||
|
|
bdc15eaefb | ||
|
|
34172e4c78 | ||
|
|
d89a369485 | ||
|
|
05cb87f475 | ||
|
|
b7ce6aee71 | ||
|
|
495232b299 | ||
|
|
da7a031081 | ||
|
|
5db686a15c | ||
|
|
177a1e798a | ||
|
|
1fe90a6e9a | ||
|
|
82de8bd935 | ||
|
|
5b9031ccca | ||
|
|
a6fd6bd80c | ||
|
|
8c5bd8f5e2 | ||
|
|
8e12453058 | ||
|
|
ff00c27f99 | ||
|
|
f7b96aa3e9 | ||
|
|
90cfa83d95 | ||
|
|
923a6385bf | ||
|
|
590030d391 | ||
|
|
c8d423c7d5 | ||
|
|
87cde2cc2f | ||
|
|
f9a6916827 | ||
|
|
bf322781d1 | ||
|
|
9d17beef03 | ||
|
|
91c8d30655 | ||
|
|
451df78dd8 | ||
|
|
00487f93d4 | ||
|
|
dc7642c1fd | ||
|
|
172d43288e | ||
|
|
c909bef613 | ||
|
|
268743ef6b | ||
|
|
95030b9b74 | ||
|
|
2c4053cff5 | ||
|
|
52b5490bab | ||
|
|
36b81fab94 | ||
|
|
ed6739b8bc | ||
|
|
0d69f8952c | ||
|
|
09e8b1d219 | ||
|
|
6548f83ef4 | ||
|
|
e851cd5ad0 | ||
|
|
794525b706 | ||
|
|
4d8dce9769 | ||
|
|
08ad4e5194 | ||
|
|
53b6f7720e | ||
|
|
1beda3aa7c | ||
|
|
5b09469cc6 | ||
|
|
a224fbc424 | ||
|
|
e5c3aeb5cd | ||
|
|
ae655646ba | ||
|
|
f1533b8962 | ||
|
|
a545d0d39e | ||
|
|
04172f0438 | ||
|
|
d97f63fa5a | ||
|
|
6c8fa8e639 | ||
|
|
1f526b3561 | ||
|
|
0837391c38 | ||
|
|
9c945b1a32 | ||
|
|
084c246ef0 | ||
|
|
31dfdf7e62 | ||
|
|
d213369e73 | ||
|
|
c5740c2328 | ||
|
|
af942d90d3 | ||
|
|
3c0852d6b8 | ||
|
|
3506f71071 | ||
|
|
a6584170c3 | ||
|
|
3169270dbd | ||
|
|
e803f8b3c0 | ||
|
|
d022c87651 | ||
|
|
7229c756af | ||
|
|
07c9576377 | ||
|
|
435f70999c | ||
|
|
71c58c6afb | ||
|
|
f7f50a9d45 | ||
|
|
82e3e7a9fc | ||
|
|
85a7a16c15 | ||
|
|
c955c94098 | ||
|
|
98e62e3eac | ||
|
|
5135e836b8 | ||
|
|
f75e701be3 | ||
|
|
f2576cf558 | ||
|
|
1776b8f50b | ||
|
|
c2c72818de | ||
|
|
60aa553219 | ||
|
|
c708832b69 | ||
|
|
734a80ba82 | ||
|
|
41b19b045a | ||
|
|
fe52bd4a0a | ||
|
|
d23d05f2ea | ||
|
|
09dcd51feb | ||
|
|
9737bfa46a | ||
|
|
21fa46fdf6 | ||
|
|
f4c97559b3 | ||
|
|
917be4b425 | ||
|
|
48fd281c1d | ||
|
|
90632f223a | ||
|
|
3e9a7ea75a | ||
|
|
f17502d3d0 | ||
|
|
d360cc05be | ||
|
|
f952ea73e6 | ||
|
|
342d459436 | ||
|
|
c28574b8f4 | ||
|
|
32474c751f | ||
|
|
a017f24224 | ||
|
|
209c37664b | ||
|
|
8f43b802bc | ||
|
|
22d93d0708 | ||
|
|
511184a4a7 | ||
|
|
8ea7805541 | ||
|
|
380b3b3137 | ||
|
|
6fbafe76ba | ||
|
|
075a9bd6c4 | ||
|
|
2b758b83fd | ||
|
|
2fd0d27447 | ||
|
|
8f75d542f3 | ||
|
|
8074305b92 | ||
|
|
f2ca62aed0 | ||
|
|
a26f78329a | ||
|
|
ee928605df | ||
|
|
7cf0c5b205 | ||
|
|
68f61ae622 | ||
|
|
2d42fed621 | ||
|
|
0101b56bff | ||
|
|
f09fa83105 | ||
|
|
3fd1896ad6 | ||
|
|
78dfc568c1 | ||
|
|
35d3c058b8 | ||
|
|
25135b64e5 | ||
|
|
235737c232 | ||
|
|
1bc6f9c45c | ||
|
|
64bc9f73f7 | ||
|
|
eab9b28cd2 | ||
|
|
ce1b635eb2 | ||
|
|
f3f7d3edc0 | ||
|
|
cdb553d39b | ||
|
|
b35c7b6703 | ||
|
|
1a6812ef79 | ||
|
|
c4e8d01de1 | ||
|
|
a05efdc07f | ||
|
|
588dacb5af | ||
|
|
0ae3d31c58 | ||
|
|
a744508d4f | ||
|
|
7553870f2a | ||
|
|
944e125ef9 | ||
|
|
b875d64724 | ||
|
|
3f51ebc125 | ||
|
|
d1693a241b | ||
|
|
35f4ec0b1d | ||
|
|
76dd069fa6 | ||
|
|
d01362dbaa | ||
|
|
1e1c9be945 | ||
|
|
2166f262c8 | ||
|
|
9c899f871d | ||
|
|
c2dd9de9b1 | ||
|
|
0a085e6610 | ||
|
|
cd4ac2c088 | ||
|
|
e35ba4b06c | ||
|
|
a97820d12a | ||
|
|
d664856326 | ||
|
|
96ea39b7cd | ||
|
|
33a495beb7 | ||
|
|
0a46fb536f | ||
|
|
affa118161 | ||
|
|
16831aa1e8 | ||
|
|
6cbe13a135 | ||
|
|
c26e44ae46 | ||
|
|
51331ea2ac | ||
|
|
787ae4440c | ||
|
|
169c1ab6e1 | ||
|
|
ca7a592dfd | ||
|
|
545fb5583a | ||
|
|
c87a7519fe | ||
|
|
2745597b93 | ||
|
|
fb7170f312 | ||
|
|
eae8dbbb37 | ||
|
|
517ed7bf8c | ||
|
|
52ec6b7ea1 | ||
|
|
6ba1faca4c | ||
|
|
40f13b6ca4 | ||
|
|
0fd1e506ba | ||
|
|
f8856ae742 | ||
|
|
4b6cd7ba29 | ||
|
|
d6e315580b | ||
|
|
e7cdb2d7f4 | ||
|
|
755db5d66d | ||
|
|
b0f58696f3 | ||
|
|
f1ad808734 | ||
|
|
4006d07222 | ||
|
|
57ebcfb41c | ||
|
|
5f1656b7ce | ||
|
|
505074e6d3 | ||
|
|
b3b7643661 | ||
|
|
db1faf1091 | ||
|
|
63786b7814 | ||
|
|
b0e4449e4f | ||
|
|
de8da38a0c | ||
|
|
e42f8843bd | ||
|
|
0f2a4aedab | ||
|
|
b0cd53f813 | ||
|
|
ee54956a69 | ||
|
|
8cd03167ca | ||
|
|
6fd0becf64 | ||
|
|
b50a5b294a | ||
|
|
3a36db6de8 | ||
|
|
8c1543a402 | ||
|
|
e1781fb805 | ||
|
|
7aa5059f6d | ||
|
|
5736ecebc5 | ||
|
|
d31afc9ec3 | ||
|
|
2a232ad2f5 | ||
|
|
9dfa11eac5 | ||
|
|
fb865ba114 | ||
|
|
ca2e5f2a01 | ||
|
|
5f76c245b0 | ||
|
|
6db3355858 | ||
|
|
e53c31e9e6 | ||
|
|
9e4749a5b7 | ||
|
|
9e2b72ccdc | ||
|
|
a9b9f853ff | ||
|
|
012d259ca1 | ||
|
|
c5a5fb5836 | ||
|
|
3015743b19 | ||
|
|
36cf4d028b | ||
|
|
009674b5bc | ||
|
|
d430d32a30 | ||
|
|
c4d2ea19dd | ||
|
|
19c52ed2a7 | ||
|
|
491d85000d | ||
|
|
70cc1ff53b | ||
|
|
af6556bdba | ||
|
|
4b6d0c02f1 | ||
|
|
c3809f240d | ||
|
|
fadc59c562 | ||
|
|
402f847db2 | ||
|
|
61ee5cbd6c | ||
|
|
2edf983698 | ||
|
|
ab6fd88558 | ||
|
|
5323052290 | ||
|
|
86d0f71acb | ||
|
|
d86b7dcfcc | ||
|
|
1d8347d8ea | ||
|
|
444f56f9b4 | ||
|
|
6f68406803 | ||
|
|
e107247c16 | ||
|
|
4db91ec16e | ||
|
|
c01a424f4f | ||
|
|
bb237dcef3 | ||
|
|
29bcbc4db9 | ||
|
|
7e5010a608 | ||
|
|
15ca80fbf7 | ||
|
|
1e47c909f0 | ||
|
|
bdcf5b3275 | ||
|
|
4df1468e25 | ||
|
|
bbdc9c65f5 | ||
|
|
acf8e88db2 | ||
|
|
1d816d94f6 | ||
|
|
7212d8bd23 | ||
|
|
43ecec854f | ||
|
|
bd2301a28c | ||
|
|
9ec8b9c03f | ||
|
|
f72aadfc59 | ||
|
|
cc81e55649 | ||
|
|
6628d9f966 | ||
|
|
81f1d9aa99 | ||
|
|
6845eb69b3 | ||
|
|
be231ce4f3 | ||
|
|
079249f3d7 | ||
|
|
cd371b69a6 | ||
|
|
eb7919c1d8 | ||
|
|
576a2c97cf | ||
|
|
2cf4f333d4 | ||
|
|
eb03a4608b | ||
|
|
9b4e5ce369 | ||
|
|
3d4a14d449 | ||
|
|
ccfbabde5e | ||
|
|
c016a6ef47 | ||
|
|
44fc69e82d | ||
|
|
b829ec1fc9 | ||
|
|
0e2e7efdb2 | ||
|
|
c2dc8a0837 | ||
|
|
525e4325da | ||
|
|
39dd1f2a63 | ||
|
|
ba2df80f07 | ||
|
|
19802c0b69 | ||
|
|
242ecef012 | ||
|
|
76f65c13d7 | ||
|
|
9a21f4d3e3 | ||
|
|
1c61547284 | ||
|
|
19fb5c5801 | ||
|
|
be1aeccbe5 | ||
|
|
5a487d15c2 | ||
|
|
88d4c0aff8 | ||
|
|
8444e5f270 | ||
|
|
ad65b62c1c | ||
|
|
030105cc2e | ||
|
|
8ea24540c4 | ||
|
|
e3d55819ee | ||
|
|
eedf092930 | ||
|
|
8c62c31604 | ||
|
|
699f09c282 | ||
|
|
fb88521ed5 | ||
|
|
279993e965 | ||
|
|
9b8d3f7970 | ||
|
|
bdcf43a6f6 | ||
|
|
b7983d18c4 | ||
|
|
f8c79abd38 | ||
|
|
29a72e54dc | ||
|
|
1f938efcaf | ||
|
|
56e39123b9 | ||
|
|
369af47374 | ||
|
|
d93ffb9cb2 | ||
|
|
5c567604ff | ||
|
|
9dd1b768ee | ||
|
|
6715696ba1 | ||
|
|
c8e4cb0526 | ||
|
|
5c775fdb3f | ||
|
|
5638bdcc2d | ||
|
|
4ab8dbd774 | ||
|
|
5016f4d28c | ||
|
|
a996bdac2a | ||
|
|
7f154a178b | ||
|
|
463393647f | ||
|
|
3625808749 | ||
|
|
7c38b9a35c | ||
|
|
12435ff1c5 | ||
|
|
e40da1e7e4 | ||
|
|
ca822e1358 | ||
|
|
b879f8fef2 | ||
|
|
4b69144ee4 | ||
|
|
ac3b755fdc | ||
|
|
1feeed145d | ||
|
|
a7cb3e520a | ||
|
|
e39e8a0083 | ||
|
|
51b00181cf | ||
|
|
5f41bd1c1e | ||
|
|
c82f776632 | ||
|
|
3fcdd395fe | ||
|
|
ffa31c7ad7 | ||
|
|
6fd39bd3c5 | ||
|
|
b86d631486 | ||
|
|
f0856c264e | ||
|
|
a0a2046373 | ||
|
|
febd13af13 | ||
|
|
09393d3ef5 | ||
|
|
4061661a20 | ||
|
|
738dd11929 | ||
|
|
53ff8fbf97 | ||
|
|
a0a964fa18 | ||
|
|
ac38e16944 | ||
|
|
a7cd7d9500 | ||
|
|
11832a7651 | ||
|
|
e19a48682e | ||
|
|
2ac18b1cdf | ||
|
|
1db1a943e2 | ||
|
|
8a439ea15c | ||
|
|
1012d9fc51 | ||
|
|
3995e85ccf | ||
|
|
850e8db975 | ||
|
|
42d8fed577 | ||
|
|
18ed12e3f7 | ||
|
|
2038480b00 | ||
|
|
8fcb8efbea | ||
|
|
4ff543e629 | ||
|
|
4dd6bdef31 | ||
|
|
6786fbb292 | ||
|
|
52f54baea0 | ||
|
|
cdc0db3b81 | ||
|
|
6546e7f085 | ||
|
|
fe83328a57 | ||
|
|
6f91c97b7f | ||
|
|
2170505beb | ||
|
|
341e84682c | ||
|
|
1934c63512 | ||
|
|
54638924e4 | ||
|
|
564a288c4c | ||
|
|
b622f47d65 | ||
|
|
4313de6c68 | ||
|
|
47b67af226 | ||
|
|
db211a9804 | ||
|
|
c1362f54e5 | ||
|
|
4a08c09129 | ||
|
|
894c36fc15 | ||
|
|
e2823d8746 | ||
|
|
ef5972e9f0 | ||
|
|
732b86bb86 | ||
|
|
0d1c4cece2 | ||
|
|
73d56b3d5f | ||
|
|
f79206a9b8 | ||
|
|
9cd84ddffe | ||
|
|
4ada2e7678 | ||
|
|
202096c610 | ||
|
|
7110b29cba | ||
|
|
b6983c8615 | ||
|
|
b78556ca41 | ||
|
|
91e94c6e38 | ||
|
|
7bf36fa8a5 | ||
|
|
fd1cb3131d | ||
|
|
b1e37c2734 | ||
|
|
8b5c919d8c | ||
|
|
78f65ead59 | ||
|
|
c645ab5100 | ||
|
|
25c9bff6f3 | ||
|
|
ac51956c3f | ||
|
|
03309d4fdb | ||
|
|
b45b7606a9 | ||
|
|
8d020a4de8 | ||
|
|
e2f6401a15 | ||
|
|
b8bd64bac5 | ||
|
|
8ab1df5960 | ||
|
|
3eb8fad5ae | ||
|
|
900e868caf | ||
|
|
15c68c5660 | ||
|
|
2bd2b9b6e3 | ||
|
|
d0af9d62ea | ||
|
|
b178e47d6d | ||
|
|
16b318832a | ||
|
|
d1549712ab | ||
|
|
6737c291ca | ||
|
|
b9b1197c1a | ||
|
|
a2afb1d5dc | ||
|
|
f68ee9bc00 | ||
|
|
71ce8709ca | ||
|
|
0c46668e2e | ||
|
|
50694ec512 | ||
|
|
9deaed7350 | ||
|
|
a92715ea31 | ||
|
|
acc8cdf8ca | ||
|
|
7b527840b1 | ||
|
|
4af1092272 | ||
|
|
f9fb61ec49 | ||
|
|
13d0075a48 | ||
|
|
120d4780fd | ||
|
|
4f3cf3656c |
3
.gitignore
vendored
|
|
@ -9,5 +9,8 @@
|
||||||
# html files (as generated from markdown)
|
# html files (as generated from markdown)
|
||||||
*.html
|
*.html
|
||||||
|
|
||||||
|
# checksums file as used by $ScriptInstallUpdate
|
||||||
|
checksums.json
|
||||||
|
|
||||||
# Mac OS X folder settings file
|
# Mac OS X folder settings file
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
|
|
||||||
15
BRANCHES.md
|
|
@ -1,12 +1,19 @@
|
||||||
Installing from branches
|
Installing from branches
|
||||||
========================
|
========================
|
||||||
|
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/network)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
||||||
|
[](https://mikrotik.com/download/changelogs/)
|
||||||
|
[](https://t.me/routeros_scripts)
|
||||||
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
|
|
||||||
[⬅️ Go back to main README](README.md)
|
[⬅️ Go back to main README](README.md)
|
||||||
|
|
||||||
> ⚠️ **Warning**: Living on the edge? Great, read on!
|
> ⚠️ **Warning**: Living on the edge? Great, read on!
|
||||||
> If not: Please use the `main` branch and leave this page!
|
> If not: Please use the `main` branch and leave this page!
|
||||||
|
|
||||||
These scripts are developed in a [git](https://git-scm.com/) repository.
|
These scripts are developed in a [git ↗️](https://git-scm.com/) repository.
|
||||||
Development and experimental branches are used to provide early access
|
Development and experimental branches are used to provide early access
|
||||||
for specific changes. You can install scripts from these branches
|
for specific changes. You can install scripts from these branches
|
||||||
for testing.
|
for testing.
|
||||||
|
|
@ -15,13 +22,13 @@ for testing.
|
||||||
|
|
||||||
To install a single script from `next` branch:
|
To install a single script from `next` branch:
|
||||||
|
|
||||||
$ScriptInstallUpdate script-name "url-suffix=?h=next";
|
$ScriptInstallUpdate script-name "base-url=https://rsc.eworm.de/next/";
|
||||||
|
|
||||||
## Switch existing script
|
## Switch existing script
|
||||||
|
|
||||||
Alternatively switch an existing script to update from `next` branch:
|
Alternatively switch an existing script to update from `next` branch:
|
||||||
|
|
||||||
/system/script/set comment="url-suffix=?h=next" script-name;
|
/system/script/set comment="base-url=https://rsc.eworm.de/next/" script-name;
|
||||||
$ScriptInstallUpdate;
|
$ScriptInstallUpdate;
|
||||||
|
|
||||||
## Switch installation
|
## Switch installation
|
||||||
|
|
@ -29,7 +36,7 @@ Alternatively switch an existing script to update from `next` branch:
|
||||||
Last but not least - to switch the complete installation to the `next`
|
Last but not least - to switch the complete installation to the `next`
|
||||||
branch edit `global-config-overlay` and add:
|
branch edit `global-config-overlay` and add:
|
||||||
|
|
||||||
:global ScriptUpdatesUrlSuffix "?h=next";
|
:global ScriptUpdatesBaseUrl "https://rsc.eworm.de/next/";
|
||||||
|
|
||||||
... then reload the configuration and update:
|
... then reload the configuration and update:
|
||||||
|
|
||||||
|
|
|
||||||
BIN
CERTIFICATES.d/01-dialog-A.avif
Normal file
|
After Width: | Height: | Size: 29 KiB |
BIN
CERTIFICATES.d/02-dialog-B.avif
Normal file
|
After Width: | Height: | Size: 28 KiB |
BIN
CERTIFICATES.d/03-window.avif
Normal file
|
After Width: | Height: | Size: 47 KiB |
BIN
CERTIFICATES.d/04-certificate.avif
Normal file
|
After Width: | Height: | Size: 22 KiB |
83
CERTIFICATES.md
Normal file
|
|
@ -0,0 +1,83 @@
|
||||||
|
Certificate name from browser
|
||||||
|
=============================
|
||||||
|
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/network)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
||||||
|
[](https://mikrotik.com/download/changelogs/)
|
||||||
|
[](https://t.me/routeros_scripts)
|
||||||
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
|
|
||||||
|
[⬅️ Go back to main README](README.md)
|
||||||
|
|
||||||
|
All well known desktop, mobile and server operating systems come with a
|
||||||
|
certificate store that is populated with a set of well known and trusted
|
||||||
|
certificates, acting as *trust anchors*.
|
||||||
|
|
||||||
|
However RouterOS does not, still sometimes a specific certificate is
|
||||||
|
required to properly verify a chain of trust. One example is downloading
|
||||||
|
the scripts from this repository with `fetch` command, thus the very
|
||||||
|
first step of [installation](README.md#the-long-way-in-detail) is importing
|
||||||
|
the certificate.
|
||||||
|
|
||||||
|
The scripts can install additional certificates when required. This happens
|
||||||
|
from this repository if available, or from [mkcert.org ↗️](https://mkcert.org)
|
||||||
|
as a fallback.
|
||||||
|
|
||||||
|
Get the certificate's CommonName
|
||||||
|
--------------------------------
|
||||||
|
|
||||||
|
But how to determine what certificate may be required? Often easiest way
|
||||||
|
is to use a desktop browser to get that information. This demonstration uses
|
||||||
|
[Mozilla Firefox ↗️](https://www.mozilla.org/firefox/).
|
||||||
|
|
||||||
|
Let's assume we want to make sure the certificate for
|
||||||
|
[git.eworm.de](https://git.eworm.de/) is available. Open that page in the
|
||||||
|
browser, then click the *lock* icon in addressbar, followed by "*Connection
|
||||||
|
secure*".
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
The dialog will change, click "*More information*".
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
A new window opens, click the button "*View Certificate*". (That window
|
||||||
|
can be closed now.)
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
A new tab opens, showing information on the server certificate and its
|
||||||
|
chain of trust. The leftmost certificate is what we are interested in.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Now we know that "`ISRG Root X2`" is required, some scripts need just
|
||||||
|
that information.
|
||||||
|
|
||||||
|
Import a certificate by CommonName
|
||||||
|
----------------------------------
|
||||||
|
|
||||||
|
Running the function `$CertificateAvailable` with that name as parameter
|
||||||
|
makes sure the certificate is available in the device's store:
|
||||||
|
|
||||||
|
$CertificateAvailable "ISRG Root X2" "fetch";
|
||||||
|
|
||||||
|
If the certificate is actually available already nothing happens, and there
|
||||||
|
is no output. Otherwise the certificate is downloaded and imported.
|
||||||
|
|
||||||
|
If importing a certificate with that exact name fails a warning is given
|
||||||
|
and nothing is actually imported.
|
||||||
|
|
||||||
|
See also
|
||||||
|
--------
|
||||||
|
|
||||||
|
* [Download, import and update firewall address-lists](doc/fw-addr-lists.md)
|
||||||
|
* [Manage DNS and DoH servers from netwatch](doc/netwatch-dns.md)
|
||||||
|
* [Send notifications via Gotify](doc/mod/notification-gotify.md)
|
||||||
|
* [Send notifications via Matrix](doc/mod/notification-matrix.md)
|
||||||
|
* [Send notifications via Ntfy](doc/mod/notification-ntfy.md)
|
||||||
|
|
||||||
|
---
|
||||||
|
[⬅️ Go back to main README](README.md)
|
||||||
|
[⬆️ Go back to top](#top)
|
||||||
|
|
@ -1,6 +1,13 @@
|
||||||
Past Contributions
|
Past Contributions
|
||||||
==================
|
==================
|
||||||
|
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/network)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
||||||
|
[](https://mikrotik.com/download/changelogs/)
|
||||||
|
[](https://t.me/routeros_scripts)
|
||||||
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
|
|
||||||
[⬅️ Go back to main README](README.md)
|
[⬅️ Go back to main README](README.md)
|
||||||
|
|
||||||
Thanks a lot for your contributions! ❤️
|
Thanks a lot for your contributions! ❤️
|
||||||
|
|
@ -13,21 +20,29 @@ for details!
|
||||||
* [Anatoly Bubenkov](mailto:bubenkoff@gmail.com) (@bubenkoff)
|
* [Anatoly Bubenkov](mailto:bubenkoff@gmail.com) (@bubenkoff)
|
||||||
* [Ben Harris](mailto:mail@bharr.is) (@bharrisau)
|
* [Ben Harris](mailto:mail@bharr.is) (@bharrisau)
|
||||||
* [Daniel Ziegenberg](mailto:daniel@ziegenberg.at) (@ziegenberg)
|
* [Daniel Ziegenberg](mailto:daniel@ziegenberg.at) (@ziegenberg)
|
||||||
|
* [Ignacio Serrano](mailto:ignic@ignic.com) (@ignic)
|
||||||
|
* [Ilya Kulakov](mailto:kulakov.ilya@gmail.com) (@Kentzo)
|
||||||
|
* [Leonardo David Monteiro](mailto:leo@cub3.xyz) (@leosfsm)
|
||||||
* [Michael Gisbers](mailto:michael@gisbers.de) (@mgisbers)
|
* [Michael Gisbers](mailto:michael@gisbers.de) (@mgisbers)
|
||||||
|
* [Miquel Bonastre](mailto:mbonastre@yahoo.com) (@mbonastre)
|
||||||
|
* @netravnen
|
||||||
* [netztrip](mailto:dave-tvg@netztrip.de) (@netztrip)
|
* [netztrip](mailto:dave-tvg@netztrip.de) (@netztrip)
|
||||||
* [Stefan Müller](mailto:stefan.mueller.83@gmail.com) (@PackElend)
|
* [Stefan Müller](mailto:stefan.mueller.83@gmail.com) (@PackElend)
|
||||||
|
|
||||||
## Donations
|
## Donations
|
||||||
|
|
||||||
Add yourself to the list,
|
Add yourself to the list,
|
||||||
[donate with PayPal](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)!
|
[donate with PayPal ↗️](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)!
|
||||||
|
|
||||||
* Abdul Mannan Abbasi
|
* Abdul Mannan Abbasi
|
||||||
|
* Alex Maier
|
||||||
* Andrea Ruffini Perico
|
* Andrea Ruffini Perico
|
||||||
* Andrew Cox
|
* Andrew Cox
|
||||||
* Christoph Boss (@Kampfwurst)
|
* Christoph Boss (@Kampfwurst)
|
||||||
|
* Daniel Ziegenberg (@ziegenberg)
|
||||||
* Devin Dean (@dd2594gh)
|
* Devin Dean (@dd2594gh)
|
||||||
* Evaldo Gardenal
|
* Evaldo Gardenal
|
||||||
|
* Florian Estraviz
|
||||||
* Giorgio Bikos
|
* Giorgio Bikos
|
||||||
* Harold Schoemaker
|
* Harold Schoemaker
|
||||||
* Hugo BV
|
* Hugo BV
|
||||||
|
|
@ -38,6 +53,7 @@ Add yourself to the list,
|
||||||
* Marek Čábák
|
* Marek Čábák
|
||||||
* Oleksandr Yukhymchuk
|
* Oleksandr Yukhymchuk
|
||||||
* Peter Holtkamp
|
* Peter Holtkamp
|
||||||
|
* Peter Ponzel
|
||||||
* Reiner Vehrenkamp
|
* Reiner Vehrenkamp
|
||||||
* Richard Österreicher
|
* Richard Österreicher
|
||||||
* Simon Hitzemann
|
* Simon Hitzemann
|
||||||
|
|
|
||||||
63
DEBUG.md
Normal file
|
|
@ -0,0 +1,63 @@
|
||||||
|
Debug output and logs
|
||||||
|
=====================
|
||||||
|
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/network)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
||||||
|
[](https://mikrotik.com/download/changelogs/)
|
||||||
|
[](https://t.me/routeros_scripts)
|
||||||
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
|
|
||||||
|
[⬅️ Go back to main README](README.md)
|
||||||
|
|
||||||
|
Sometimes scripts do not behave as expected. In these cases debug output
|
||||||
|
or logs can help.
|
||||||
|
|
||||||
|
## Debug output
|
||||||
|
|
||||||
|
Run this command in a terminal:
|
||||||
|
|
||||||
|
:set PrintDebug true;
|
||||||
|
|
||||||
|
You will then see debug output when running the script from terminal.
|
||||||
|
|
||||||
|
To revert to default output run:
|
||||||
|
|
||||||
|
:set PrintDebug false;
|
||||||
|
|
||||||
|
### Debug output for specific script
|
||||||
|
|
||||||
|
Even having debug output for a specific script or function only (or a
|
||||||
|
set of) is possible. To enable debug output for `telegram-chat` run:
|
||||||
|
|
||||||
|
:set ($PrintDebugOverride->"telegram-chat") true;
|
||||||
|
|
||||||
|
## Debug logs
|
||||||
|
|
||||||
|
The debug info can go to system log. To make it show up in `memory` run:
|
||||||
|
|
||||||
|
/system/logging/add topics=script,debug action=memory;
|
||||||
|
|
||||||
|
Other actions (`disk`, `email`, `remote` or `support`) can be used as
|
||||||
|
well. I do not recommend using `echo` - use [debug output](#debug-output)
|
||||||
|
instead.
|
||||||
|
|
||||||
|
Disable or remove that setting to restore regular logging.
|
||||||
|
|
||||||
|
## Verbose output
|
||||||
|
|
||||||
|
Specific scripts can generate huge amount of output. These do use a function
|
||||||
|
`$LogPrintVerbose`, which is declared, but has no code, intentionally.
|
||||||
|
|
||||||
|
If you *really* want that output set the function to be the same as
|
||||||
|
`$LogPrint`:
|
||||||
|
|
||||||
|
:set LogPrintVerbose $LogPrint;
|
||||||
|
|
||||||
|
To revert that change just run:
|
||||||
|
|
||||||
|
:set LogPrintVerbose;
|
||||||
|
|
||||||
|
---
|
||||||
|
[⬅️ Go back to main README](README.md)
|
||||||
|
[⬆️ Go back to top](#top)
|
||||||
|
|
@ -1,34 +1,55 @@
|
||||||
Initial commands
|
Initial commands
|
||||||
================
|
================
|
||||||
|
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/network)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
||||||
|
[](https://mikrotik.com/download/changelogs/)
|
||||||
|
[](https://t.me/routeros_scripts)
|
||||||
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
|
|
||||||
[⬅️ Go back to main README](README.md)
|
[⬅️ Go back to main README](README.md)
|
||||||
|
|
||||||
> ⚠️ **Warning**: These command are inteneded for initial setup. If you are
|
> ⚠️ **Warning**: These commands are intended for initial setup. If you are
|
||||||
> not aware of the procedure please follow
|
> not aware of the procedure please follow
|
||||||
> [the long way in detail](README.md#the-long-way-in-detail).
|
> [the long way in detail](README.md#the-long-way-in-detail).
|
||||||
|
|
||||||
Run the complete base installation:
|
Run the complete base installation:
|
||||||
|
|
||||||
{
|
{
|
||||||
/tool/fetch "https://git.eworm.de/cgit/routeros-scripts/plain/certs/E1.pem" dst-path="letsencrypt-E1.pem" as-value;
|
:local BaseUrl "https://rsc.eworm.de/main/";
|
||||||
:delay 1s;
|
:local CertCommonName "ISRG Root X2";
|
||||||
/certificate/import file-name=letsencrypt-E1.pem passphrase="";
|
:local CertFileName "ISRG-Root-X2.pem";
|
||||||
:if ([ :len [ /certificate/find where fingerprint="46494e30379059df18be52124305e606fc59070e5b21076ce113954b60517cda" or fingerprint="69729b8e15a86efc177a57afb7171dfc64add28c2fca8cf1507e34453ccb1470" ] ] != 2) do={
|
:local CertFingerprint "69729b8e15a86efc177a57afb7171dfc64add28c2fca8cf1507e34453ccb1470";
|
||||||
:error "Something is wrong with your certificates!";
|
|
||||||
|
:local CertSettings [ /certificate/settings/get ];
|
||||||
|
:if (!((($CertSettings->"builtin-trust-anchors") = "trusted" || \
|
||||||
|
($CertSettings->"builtin-trust-store") ~ "fetch" || \
|
||||||
|
($CertSettings->"builtin-trust-store") = "all") && \
|
||||||
|
[[ :parse (":return [ :len [ /certificate/builtin/find where common-name=\"" . $CertCommonName . "\" ] ]") ]] > 0)) do={
|
||||||
|
:put "Importing certificate...";
|
||||||
|
/tool/fetch ($BaseUrl . "certs/" . $CertFileName) dst-path=$CertFileName as-value;
|
||||||
|
:delay 1s;
|
||||||
|
/certificate/import file-name=$CertFileName passphrase="";
|
||||||
|
:if ([ :len [ /certificate/find where fingerprint=$CertFingerprint ] ] != 1) do={
|
||||||
|
:error "Something is wrong with your certificates!";
|
||||||
|
};
|
||||||
|
:delay 1s;
|
||||||
};
|
};
|
||||||
/file/remove "letsencrypt-E1.pem";
|
:put "Renaming global-config-overlay, if exists...";
|
||||||
:delay 1s;
|
|
||||||
/system/script/set name=("global-config-overlay-" . [ /system/clock/get date ] . "-" . [ /system/clock/get time ]) [ find where name="global-config-overlay" ];
|
/system/script/set name=("global-config-overlay-" . [ /system/clock/get date ] . "-" . [ /system/clock/get time ]) [ find where name="global-config-overlay" ];
|
||||||
:foreach Script in={ "global-config"; "global-config-overlay"; "global-functions" } do={
|
:foreach Script in={ "global-config"; "global-config-overlay"; "global-functions" } do={
|
||||||
|
:put "Installing $Script...";
|
||||||
/system/script/remove [ find where name=$Script ];
|
/system/script/remove [ find where name=$Script ];
|
||||||
/system/script/add name=$Script owner=$Script source=([ /tool/fetch check-certificate=yes-without-crl ("https://git.eworm.de/cgit/routeros-scripts/plain/" . $Script . ".rsc") output=user as-value]->"data");
|
/system/script/add name=$Script owner=$Script source=([ /tool/fetch check-certificate=yes-without-crl ($BaseUrl . $Script . ".rsc") output=user as-value ]->"data");
|
||||||
};
|
};
|
||||||
|
:put "Loading configuration and functions...";
|
||||||
/system/script { run global-config; run global-functions; };
|
/system/script { run global-config; run global-functions; };
|
||||||
/system/scheduler/remove [ find where name="global-scripts" ];
|
:if ([ :len [ /certificate/find where fingerprint=$CertFingerprint ] ] > 0) do={
|
||||||
/system/scheduler/add name="global-scripts" start-time=startup on-event="/system/script { run global-config; run global-functions; }";
|
:put "Renaming certificate by its common-name...";
|
||||||
:global CertificateNameByCN;
|
:global CertificateNameByCN;
|
||||||
$CertificateNameByCN "E1";
|
$CertificateNameByCN $CertFingerprint;
|
||||||
$CertificateNameByCN "ISRG Root X2";
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
Then continue setup with
|
Then continue setup with
|
||||||
|
|
|
||||||
58
Makefile
|
|
@ -2,35 +2,45 @@
|
||||||
# template scripts -> final scripts
|
# template scripts -> final scripts
|
||||||
# markdown files -> html files
|
# markdown files -> html files
|
||||||
|
|
||||||
CAPSMAN = $(wildcard *.capsman.rsc)
|
ALL_RSC := $(wildcard *.rsc */*.rsc)
|
||||||
LOCAL = $(wildcard *.local.rsc)
|
GEN_RSC := $(wildcard *.capsman.rsc *.local.rsc *.wifi.rsc)
|
||||||
WIFI = $(wildcard *.wifi.rsc)
|
|
||||||
|
|
||||||
MARKDOWN = $(wildcard *.md doc/*.md doc/mod/*.md)
|
MARKDOWN := $(wildcard *.md doc/*.md doc/mod/*.md)
|
||||||
HTML = $(MARKDOWN:.md=.html)
|
HTML := $(MARKDOWN:.md=.html)
|
||||||
|
|
||||||
all: $(CAPSMAN) $(LOCAL) $(WIFI) $(HTML)
|
DATE ?= $(shell date --rfc-email)
|
||||||
|
VERSION ?= $(shell git symbolic-ref --short HEAD 2>/dev/null)/$(shell git rev-list --count HEAD 2>/dev/null)/$(shell git rev-parse --short=8 HEAD 2>/dev/null)
|
||||||
|
export DATE VERSION
|
||||||
|
|
||||||
%.html: %.md Makefile
|
.PHONY: all checksums commitinfo docs rsc clean
|
||||||
markdown $< | sed 's/href="\([-_\./[:alnum:]]*\)\.md"/href="\1.html"/g' > $@
|
|
||||||
|
|
||||||
%.capsman.rsc: %.template.rsc Makefile
|
all: checksums docs rsc
|
||||||
sed -e '/\/interface\/wifi\//d' -e '/\/interface\/wireless\//d' -e 's|%TEMPL%|.capsman|' \
|
|
||||||
-e '/^# NOT \/caps-man\/ #$$/,/^# NOT \/caps-man\/ #$$/d' \
|
|
||||||
-e '/^# !!/,/^# !!/c # !! Do not edit this file, it is generated from template!' \
|
|
||||||
< $< > $@
|
|
||||||
|
|
||||||
%.local.rsc: %.template.rsc Makefile
|
checksums: checksums.json
|
||||||
sed -e '/\/caps-man\//d' -e '/\/interface\/wifi\//d' -e 's|%TEMPL%|.local|' \
|
|
||||||
-e '/^# NOT \/interface\/wireless\/ #$$/,/^# NOT \/interface\/wireless\/ #$$/d' \
|
|
||||||
-e '/^# !!/,/^# !!/c # !! Do not edit this file, it is generated from template!' \
|
|
||||||
< $< > $@
|
|
||||||
|
|
||||||
%.wifi.rsc: %.template.rsc Makefile
|
checksums.json: contrib/checksums.sh $(ALL_RSC)
|
||||||
sed -e '/\/caps-man\//d' -e '/\/interface\/wireless\//d' -e 's|%TEMPL%|.wifi|' \
|
contrib/checksums.sh > $@
|
||||||
-e '/^# NOT \/interface\/wifi\/ #$$/,/^# NOT \/interface\/wifi\/ #$$/d' \
|
|
||||||
-e '/^# !!/,/^# !!/c # !! Do not edit this file, it is generated from template!' \
|
commitinfo: global-functions.rsc
|
||||||
< $< > $@
|
contrib/commitinfo.sh $< > $<~
|
||||||
|
mv $<~ $<
|
||||||
|
|
||||||
|
docs: $(HTML)
|
||||||
|
|
||||||
|
%.html: %.md general/style.css contrib/html.sh contrib/html.sh.d/head.html contrib/html.sh.d/foot.html
|
||||||
|
contrib/html.sh $< > $@
|
||||||
|
|
||||||
|
rsc: $(GEN_RSC)
|
||||||
|
|
||||||
|
%.capsman.rsc: %.template.rsc contrib/template-capsman.sh
|
||||||
|
contrib/template-capsman.sh $< > $@
|
||||||
|
|
||||||
|
%.local.rsc: %.template.rsc contrib/template-local.sh
|
||||||
|
contrib/template-local.sh $< > $@
|
||||||
|
|
||||||
|
%.wifi.rsc: %.template.rsc contrib/template-wifi.sh
|
||||||
|
contrib/template-wifi.sh $< > $@
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f $(HTML)
|
rm -f $(HTML) checksums.json
|
||||||
|
make -C contrib/ clean
|
||||||
|
|
|
||||||
|
Before Width: | Height: | Size: 4.3 KiB After Width: | Height: | Size: 2.7 KiB |
|
Before Width: | Height: | Size: 3.5 KiB After Width: | Height: | Size: 2 KiB |
|
Before Width: | Height: | Size: 9.1 KiB After Width: | Height: | Size: 5 KiB |
|
Before Width: | Height: | Size: 3.7 KiB After Width: | Height: | Size: 4.7 KiB |
|
Before Width: | Height: | Size: 1.9 KiB |
BIN
README.d/05-run-scripts.avif
Normal file
|
After Width: | Height: | Size: 2.3 KiB |
|
Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 3.1 KiB |
|
Before Width: | Height: | Size: 5 KiB After Width: | Height: | Size: 6 KiB |
|
Before Width: | Height: | Size: 2.4 KiB After Width: | Height: | Size: 1.8 KiB |
|
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 2.6 KiB |
|
Before Width: | Height: | Size: 2.4 KiB After Width: | Height: | Size: 2.9 KiB |
|
Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 2.9 KiB |
|
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 4.1 KiB |
|
Before Width: | Height: | Size: 4.5 KiB After Width: | Height: | Size: 2.8 KiB |
|
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.8 KiB |
|
Before Width: | Height: | Size: 14 KiB After Width: | Height: | Size: 8.5 KiB |
229
README.md
|
|
@ -4,19 +4,22 @@ RouterOS Scripts
|
||||||
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
||||||
[](https://github.com/eworm-de/routeros-scripts/network)
|
[](https://github.com/eworm-de/routeros-scripts/network)
|
||||||
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
||||||
[](https://mikrotik.com/download/changelogs/)
|
[](https://mikrotik.com/download/changelogs/)
|
||||||
[](https://t.me/routeros_scripts)
|
[](https://t.me/routeros_scripts)
|
||||||
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
|
|
||||||
|
**a collection of scripts for MikroTik RouterOS**
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
[RouterOS](https://mikrotik.com/software) is the operating system developed
|
[RouterOS ↗️](https://mikrotik.com/software) is the operating system developed
|
||||||
by [MikroTik](https://mikrotik.com/aboutus) for networking tasks. This
|
by [MikroTik ↗️](https://mikrotik.com/aboutus) for networking tasks. This
|
||||||
repository holds a number of [scripts](https://wiki.mikrotik.com/wiki/Manual:Scripting)
|
repository holds a number of [scripts ↗️](https://wiki.mikrotik.com/wiki/Manual:Scripting)
|
||||||
to manage RouterOS devices or extend their functionality.
|
to manage RouterOS devices or extend their functionality.
|
||||||
|
|
||||||
*Use at your own risk*, pay attention to
|
*Use at your own risk*, pay attention to
|
||||||
[license and warranty](#license-and-warranty)!
|
[license and warranty](#license-and-warranty), and
|
||||||
|
[disclaimer on external links](#disclaimer-on-external-links)!
|
||||||
|
|
||||||
Requirements
|
Requirements
|
||||||
------------
|
------------
|
||||||
|
|
@ -34,6 +37,12 @@ Specific scripts may require even newer RouterOS version.
|
||||||
> ℹ️ **Info**: The `main` branch is now RouterOS v7 only. If you are still
|
> ℹ️ **Info**: The `main` branch is now RouterOS v7 only. If you are still
|
||||||
> running RouterOS v6 switch to `routeros-v6` branch!
|
> running RouterOS v6 switch to `routeros-v6` branch!
|
||||||
|
|
||||||
|
Starting with RouterOS 7.17 the
|
||||||
|
[device-mode ↗️](https://help.mikrotik.com/docs/spaces/ROS/pages/93749258/Device-mode)
|
||||||
|
has been extended to give more fine-grained control over what features are
|
||||||
|
available. You need to enable `scheduler` and `fetch` at least, specific
|
||||||
|
scripts may require additional features.
|
||||||
|
|
||||||
### Hardware
|
### Hardware
|
||||||
|
|
||||||
RouterOS packages increase in size with each release. This becomes a
|
RouterOS packages increase in size with each release. This becomes a
|
||||||
|
|
@ -48,16 +57,19 @@ Initial setup
|
||||||
### Get me ready!
|
### Get me ready!
|
||||||
|
|
||||||
If you know how things work just copy and paste the
|
If you know how things work just copy and paste the
|
||||||
[initial commands](INITIAL-COMMANDS.md). Remember to edit and rerun
|
[initial commands](INITIAL-COMMANDS.md). These also support fixing an
|
||||||
|
existing but broken installation. Remember to edit and rerun
|
||||||
`global-config-overlay`!
|
`global-config-overlay`!
|
||||||
First time users should take the long way below.
|
|
||||||
|
> 💡️ **Hint**: First time users should take
|
||||||
|
> [the long way in detail](#the-long-way-in-detail) below.
|
||||||
|
|
||||||
### Live presentation
|
### Live presentation
|
||||||
|
|
||||||
Want to see it in action? I've had a presentation [Repository based
|
Want to see it in action? I've had a presentation [Repository based
|
||||||
RouterOS script distribution](https://www.youtube.com/watch?v=B9neG3oAhcY)
|
RouterOS script distribution ↗️](https://www.youtube.com/watch?v=B9neG3oAhcY)
|
||||||
including demonstation recorded live at [MUM Europe
|
including demonstration recorded live at [MUM Europe
|
||||||
2019](https://mum.mikrotik.com/2019/EU/) in Vienna.
|
2019 ↗️](https://mum.mikrotik.com/2019/EU/) in Vienna.
|
||||||
|
|
||||||
> ⚠️ **Warning**: Some details changed. So see the presentation, then follow
|
> ⚠️ **Warning**: Some details changed. So see the presentation, then follow
|
||||||
> the steps below for up-to-date commands.
|
> the steps below for up-to-date commands.
|
||||||
|
|
@ -65,58 +77,72 @@ including demonstation recorded live at [MUM Europe
|
||||||
### The long way in detail
|
### The long way in detail
|
||||||
|
|
||||||
The update script does server certificate verification, so first step is to
|
The update script does server certificate verification, so first step is to
|
||||||
download the certificates. If you intend to download the scripts from a
|
download the certificates.
|
||||||
|
|
||||||
|
> 💡️ **Hint**: RouterOS 7.19 comes with a builtin certificate store. You
|
||||||
|
> can skip the steps regarding certificate download and import and jump
|
||||||
|
> to [installation of scripts](#installation-of-scripts) if you set the
|
||||||
|
> trust for these builtin trust anchors:
|
||||||
|
> `/certificate/settings/set builtin-trust-anchors=trusted;`
|
||||||
|
> With RouterOS 7.21 the functionality was changed. Set this at minimum,
|
||||||
|
> but make sure not to drop other targets:
|
||||||
|
> `/certificate/settings/set builtin-trust-store=fetch;`
|
||||||
|
|
||||||
|
If you intend to download the scripts from a
|
||||||
different location (for example from github.com) install the corresponding
|
different location (for example from github.com) install the corresponding
|
||||||
certificate chain.
|
certificate chain.
|
||||||
|
|
||||||
/tool/fetch "https://git.eworm.de/cgit/routeros-scripts/plain/certs/E1.pem" dst-path="letsencrypt-E1.pem";
|
/tool/fetch "https://rsc.eworm.de/main/certs/ISRG-Root-X2.pem" dst-path="isrg-root-x2.pem";
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
Note that the commands above do *not* verify server certificate, so if you
|
Note that the commands above do *not* verify server certificate, so if you
|
||||||
want to be safe download with your workstations's browser and transfer the
|
want to be safe download with your workstations's browser and transfer the
|
||||||
files to your MikroTik device.
|
file to your MikroTik device.
|
||||||
|
|
||||||
* [ISRG Root X2](https://letsencrypt.org/certs/isrg-root-x2.pem)
|
* [ISRG Root X2 ↗️](https://letsencrypt.org/certs/isrg-root-x2.pem)
|
||||||
* Let's Encrypt [E1](https://letsencrypt.org/certs/lets-encrypt-e1.pem)
|
|
||||||
|
|
||||||
Then we import the certificates.
|
Then we import the certificate.
|
||||||
|
|
||||||
/certificate/import file-name=letsencrypt-E1.pem passphrase="";
|
/certificate/import file-name="isrg-root-x2.pem" passphrase="";
|
||||||
|
|
||||||
Do not worry that the command is not shown - that happens because it contains
|
Do not worry that the command is not shown - that happens because it contains
|
||||||
a sensitive property, the passphrase.
|
a sensitive property, the passphrase.
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
For basic verification we rename the certificates and print them by
|
For basic verification we rename the certificate and print it by
|
||||||
fingerprint. Make sure exactly these two certificates ("*E1*" and
|
fingerprint. Make sure exactly this one certificate ("*ISRG-Root-X2*")
|
||||||
"*ISRG-Root-X2*") are shown.
|
is shown.
|
||||||
|
|
||||||
/certificate/set name="E1" [ find where common-name="E1" ];
|
|
||||||
/certificate/set name="ISRG-Root-X2" [ find where common-name="ISRG Root X2" ];
|
/certificate/set name="ISRG-Root-X2" [ find where common-name="ISRG Root X2" ];
|
||||||
/certificate/print proplist=name where fingerprint="46494e30379059df18be52124305e606fc59070e5b21076ce113954b60517cda" or fingerprint="69729b8e15a86efc177a57afb7171dfc64add28c2fca8cf1507e34453ccb1470";
|
/certificate/print proplist=name,fingerprint where fingerprint="69729b8e15a86efc177a57afb7171dfc64add28c2fca8cf1507e34453ccb1470";
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
Always make sure there are no certificates installed you do not know or want!
|
Always make sure there are no certificates installed you do not know or want!
|
||||||
|
|
||||||
|
#### Installation of scripts
|
||||||
|
|
||||||
All following commands will verify the server certificate. For validity the
|
All following commands will verify the server certificate. For validity the
|
||||||
certificate's lifetime is checked with local time, so make sure the device's
|
certificate's lifetime is checked with local time, so make sure the device's
|
||||||
date and time is set correctly!
|
date and time is set correctly!
|
||||||
|
|
||||||
Now let's download the main scripts and add them in configuration on the fly.
|
Now let's download the main scripts and add them in configuration on the fly.
|
||||||
|
|
||||||
:foreach Script in={ "global-config"; "global-config-overlay"; "global-functions" } do={ /system/script/add name=$Script owner=$Script source=([ /tool/fetch check-certificate=yes-without-crl ("https://git.eworm.de/cgit/routeros-scripts/plain/" . $Script . ".rsc") output=user as-value]->"data"); };
|
:foreach Script in={ "global-config"; "global-config-overlay"; "global-functions" } do={ /system/script/add name=$Script owner=$Script source=([ /tool/fetch check-certificate=yes-without-crl ("https://rsc.eworm.de/main/" . $Script . ".rsc") output=user as-value ]->"data"); };
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
And finally load configuration and functions and add the scheduler.
|
And finally run configuration and functions. This will also add the
|
||||||
|
scheduler for loading at system startup automatically.
|
||||||
|
|
||||||
/system/script { run global-config; run global-functions; };
|
/system/script { run global-config; run global-functions; };
|
||||||
/system/scheduler/add name="global-scripts" start-time=startup on-event="/system/script { run global-config; run global-functions; }";
|
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
> 💡️ **Hint**: You see complaints regarding syntax errors? Most likely the
|
||||||
|
> RouterOS on your device is too old. Check for updates!
|
||||||
|
|
||||||
### Scheduled automatic updates
|
### Scheduled automatic updates
|
||||||
|
|
||||||
|
|
@ -139,6 +165,11 @@ Save changes and exit with `Ctrl-o`.
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
Additionally creating configuration snippets is supported. The script name
|
||||||
|
of these snippets has to start with `global-config-overlay.d/` to make them
|
||||||
|
being loaded automatically. This allows to split off parts of the
|
||||||
|
configuration.
|
||||||
|
|
||||||
To apply your changes run `global-config`, which will automatically load
|
To apply your changes run `global-config`, which will automatically load
|
||||||
the overlay as well:
|
the overlay as well:
|
||||||
|
|
||||||
|
|
@ -150,8 +181,8 @@ This last step is required when ever you make changes to your configuration.
|
||||||
|
|
||||||
> ℹ️ **Info**: It is recommended to edit the configuration using the command
|
> ℹ️ **Info**: It is recommended to edit the configuration using the command
|
||||||
> line interface. If using Winbox on Windows OS, the line endings may be
|
> line interface. If using Winbox on Windows OS, the line endings may be
|
||||||
> missing. To fix this run:
|
> missing. To fix this run:
|
||||||
> `/system/script/set source=[ $Unix2Dos [ get global-config-overlay source ] ] global-config-overlay;`
|
> `/system/script/set source=[ :tocrlf [ get global-config-overlay source ] ] global-config-overlay;`
|
||||||
|
|
||||||
Updating scripts
|
Updating scripts
|
||||||
----------------
|
----------------
|
||||||
|
|
@ -182,11 +213,11 @@ Scheduler and events
|
||||||
--------------------
|
--------------------
|
||||||
|
|
||||||
Most scripts are designed to run regularly from
|
Most scripts are designed to run regularly from
|
||||||
[scheduler](https://wiki.mikrotik.com/wiki/Manual:System/Scheduler). We just
|
[scheduler ↗️](https://wiki.mikrotik.com/wiki/Manual:System/Scheduler). We just
|
||||||
added `check-routeros-update`, so let's run it every hour to make sure not to
|
added `check-routeros-update`, so let's run it daily to make sure not to
|
||||||
miss an update.
|
miss an update.
|
||||||
|
|
||||||
/system/scheduler/add name="check-routeros-update" interval=1h on-event="/system/script/run check-routeros-update;";
|
/system/scheduler/add name="check-routeros-update" interval=1d start-time=startup on-event="/system/script/run check-routeros-update;";
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
|
@ -196,7 +227,7 @@ cleanup add a scheduler entry.
|
||||||
|
|
||||||
$ScriptInstallUpdate dhcp-to-dns,lease-script;
|
$ScriptInstallUpdate dhcp-to-dns,lease-script;
|
||||||
/ip/dhcp-server/set lease-script=lease-script [ find ];
|
/ip/dhcp-server/set lease-script=lease-script [ find ];
|
||||||
/system/scheduler/add name="dhcp-to-dns" interval=5m on-event="/system/script/run dhcp-to-dns;";
|
/system/scheduler/add name="dhcp-to-dns" interval=5m start-time=startup on-event="/system/script/run dhcp-to-dns;";
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
|
@ -205,60 +236,62 @@ There's much more to explore... Have fun!
|
||||||
Available scripts
|
Available scripts
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
* [Find and remove access list duplicates](doc/accesslist-duplicates.md)
|
* [Find and remove access list duplicates](doc/accesslist-duplicates.md) (`accesslist-duplicates`)
|
||||||
* [Upload backup to Mikrotik cloud](doc/backup-cloud.md)
|
* [Upload backup to Mikrotik cloud](doc/backup-cloud.md) (`backup-cloud`)
|
||||||
* [Send backup via e-mail](doc/backup-email.md)
|
* [Send backup via e-mail](doc/backup-email.md) (`backup-email`)
|
||||||
* [Save configuration to fallback partition](doc/backup-partition.md)
|
* [Save configuration to fallback partition](doc/backup-partition.md) (`backup-partition`)
|
||||||
* [Upload backup to server](doc/backup-upload.md)
|
* [Upload backup to server](doc/backup-upload.md) (`backup-upload`)
|
||||||
* [Download packages for CAP upgrade from CAPsMAN](doc/capsman-download-packages.md)
|
* [Download packages for CAP upgrade from CAPsMAN](doc/capsman-download-packages.md) (`capsman-download-packages`)
|
||||||
* [Run rolling CAP upgrades from CAPsMAN](doc/capsman-rolling-upgrade.md)
|
* [Run rolling CAP upgrades from CAPsMAN](doc/capsman-rolling-upgrade.md) (`capsman-rolling-upgrade`)
|
||||||
* [Renew locally issued certificates](doc/certificate-renew-issued.md)
|
* [Renew locally issued certificates](doc/certificate-renew-issued.md) (`certificate-renew-issued`)
|
||||||
* [Renew certificates and notify on expiration](doc/check-certificates.md)
|
* [Renew certificates and notify on expiration](doc/check-certificates.md) (`check-certificates`)
|
||||||
* [Notify about health state](doc/check-health.md)
|
* [Notify about health state](doc/check-health.md) (`check-health`)
|
||||||
* [Notify on LTE firmware upgrade](doc/check-lte-firmware-upgrade.md)
|
* [Notify on LTE firmware upgrade](doc/check-lte-firmware-upgrade.md) (`check-lte-firmware-upgrade`)
|
||||||
* [Notify on RouterOS update](doc/check-routeros-update.md)
|
* [Check perpetual license on CHR](doc/check-perpetual-license.md) (`check-perpetual-license`)
|
||||||
* [Collect MAC addresses in wireless access list](doc/collect-wireless-mac.md)
|
* [Notify on RouterOS update](doc/check-routeros-update.md) (`check-routeros-update`)
|
||||||
* [Use wireless network with daily psk](doc/daily-psk.md)
|
* [Collect MAC addresses in wireless access list](doc/collect-wireless-mac.md) (`collect-wireless-mac`)
|
||||||
* [Comment DHCP leases with info from access list](doc/dhcp-lease-comment.md)
|
* [Use wireless network with daily psk](doc/daily-psk.md) (`daily-psk`)
|
||||||
* [Create DNS records for DHCP leases](doc/dhcp-to-dns.md)
|
* [Comment DHCP leases with info from access list](doc/dhcp-lease-comment.md) (`dhcp-lease-comment`)
|
||||||
* [Automatically upgrade firmware and reboot](doc/firmware-upgrade-reboot.md)
|
* [Create DNS records for DHCP leases](doc/dhcp-to-dns.md) (`dhcp-to-dns`)
|
||||||
* [Download, import and update firewall address-lists](doc/fw-addr-lists.md)
|
* [Automatically upgrade firmware and reboot](doc/firmware-upgrade-reboot.md) (`firmware-upgrade-reboot`)
|
||||||
* [Wait for global functions und modules](doc/global-wait.md)
|
* [Download, import and update firewall address-lists](doc/fw-addr-lists.md) (`fw-addr-lists`)
|
||||||
* [Send GPS position to server](doc/gps-track.md)
|
* [Wait for global functions und modules](doc/global-wait.md) (`global-wait`)
|
||||||
* [Use WPA network with hotspot credentials](doc/hotspot-to-wpa.md)
|
* [Send GPS position to server](doc/gps-track.md) (`gps-track`)
|
||||||
* [Create DNS records for IPSec peers](doc/ipsec-to-dns.md)
|
* [Use WPA network with hotspot credentials](doc/hotspot-to-wpa.md) (`hotspot-to-wpa` & `hotspot-to-wpa-cleanup`)
|
||||||
* [Update configuration on IPv6 prefix change](doc/ipv6-update.md)
|
* [Create DNS records for IPSec peers](doc/ipsec-to-dns.md) (`ipsec-to-dns`)
|
||||||
* [Manage IP addresses with bridge status](doc/ip-addr-bridge.md)
|
* [Update configuration on IPv6 prefix change](doc/ipv6-update.md) (`ipv6-update`)
|
||||||
* [Run other scripts on DHCP lease](doc/lease-script.md)
|
* [Manage IP addresses with bridge status](doc/ip-addr-bridge.md) (`ip-addr-bridge`)
|
||||||
* [Manage LEDs dark mode](doc/leds-mode.md)
|
* [Run other scripts on DHCP lease](doc/lease-script.md) (`lease-script`)
|
||||||
* [Forward log messages via notification](doc/log-forward.md)
|
* [Manage LEDs dark mode](doc/leds-mode.md) (`leds-day-mode`, `leds-night-mode` & `leds-toggle-mode`)
|
||||||
* [Mode button with multiple presses](doc/mode-button.md)
|
* [Forward log messages via notification](doc/log-forward.md) (`log-forward`)
|
||||||
* [Manage DNS and DoH servers from netwatch](doc/netwatch-dns.md)
|
* [Mode button with multiple presses](doc/mode-button.md) (`mode-button`)
|
||||||
* [Notify on host up and down](doc/netwatch-notify.md)
|
* [Manage DNS and DoH servers from netwatch](doc/netwatch-dns.md) (`netwatch-dns`)
|
||||||
* [Visualize OSPF state via LEDs](doc/ospf-to-leds.md)
|
* [Notify on host up and down](doc/netwatch-notify.md) (`netwatch-notify`)
|
||||||
* [Manage system update](doc/packages-update.md)
|
* [Visualize OSPF state via LEDs](doc/ospf-to-leds.md) (`ospf-to-leds`)
|
||||||
* [Run scripts on ppp connection](doc/ppp-on-up.md)
|
* [Manage system update](doc/packages-update.md) (`packages-update`)
|
||||||
* [Act on received SMS](doc/sms-action.md)
|
* [Run scripts on ppp connection](doc/ppp-on-up.md) (`ppp-on-up`)
|
||||||
* [Forward received SMS](doc/sms-forward.md)
|
* [Act on received SMS](doc/sms-action.md) (`sms-action`)
|
||||||
* [Play Super Mario theme](doc/super-mario-theme.md)
|
* [Forward received SMS](doc/sms-forward.md) (`sms-forward`)
|
||||||
* [Chat with your router and send commands via Telegram bot](doc/telegram-chat.md)
|
* [Play Super Mario theme](doc/super-mario-theme.md) (`super-mario-theme`)
|
||||||
* [Install LTE firmware upgrade](doc/unattended-lte-firmware-upgrade.md)
|
* [Chat with your router and send commands via Telegram bot](doc/telegram-chat.md) (`telegram-chat`)
|
||||||
* [Update GRE configuration with dynamic addresses](doc/update-gre-address.md)
|
* [Install LTE firmware upgrade](doc/unattended-lte-firmware-upgrade.md) (`unattended-lte-firmware-upgrade`)
|
||||||
* [Update tunnelbroker configuration](doc/update-tunnelbroker.md)
|
* [Update GRE configuration with dynamic addresses](doc/update-gre-address.md) (`update-gre-address`)
|
||||||
|
* [Update tunnelbroker configuration](doc/update-tunnelbroker.md) (`update-tunnelbroker`)
|
||||||
|
|
||||||
Available modules
|
Available modules
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
* [Manage ports in bridge](doc/mod/bridge-port-to.md)
|
* [Manage ports in bridge](doc/mod/bridge-port-to.md) (`mod/bridge-port-to`)
|
||||||
* [Manage VLANs on bridge ports](doc/mod/bridge-port-vlan.md)
|
* [Manage VLANs on bridge ports](doc/mod/bridge-port-vlan.md) (`mod/bridge-port-vlan`)
|
||||||
* [Inspect variables](doc/mod/inspectvar.md)
|
* [Inspect variables](doc/mod/inspectvar.md) (`mod/inspectvar`)
|
||||||
* [IP address calculation](doc/mod/ipcalc.md)
|
* [IP address calculation](doc/mod/ipcalc.md) (`mod/ipcalc`)
|
||||||
* [Send notifications via e-mail](doc/mod/notification-email.md)
|
* [Send notifications via e-mail](doc/mod/notification-email.md) (`mod/notification-email`)
|
||||||
* [Send notifications via Matrix](doc/mod/notification-matrix.md)
|
* [Send notifications via Gotify](doc/mod/notification-gotify.md) (`mod/notification-gotify`)
|
||||||
* [Send notifications via Ntfy](doc/mod/notification-ntfy.md)
|
* [Send notifications via Matrix](doc/mod/notification-matrix.md) (`mod/notification-matrix`)
|
||||||
* [Send notifications via Telegram](doc/mod/notification-telegram.md)
|
* [Send notifications via Ntfy](doc/mod/notification-ntfy.md) (`mod/notification-ntfy`)
|
||||||
* [Download script and run it once](doc/mod/scriptrunonce.md)
|
* [Send notifications via Telegram](doc/mod/notification-telegram.md) (`mod/notification-telegram`)
|
||||||
* [Import ssh keys for public key authentication](doc/mod/ssh-keys-import.md)
|
* [Download script and run it once](doc/mod/scriptrunonce.md) (`mod/scriptrunonce`)
|
||||||
|
* [Import ssh keys for public key authentication](doc/mod/ssh-keys-import.md) (`mod/ssh-keys-import`)
|
||||||
|
|
||||||
Installing custom scripts & modules
|
Installing custom scripts & modules
|
||||||
-----------------------------------
|
-----------------------------------
|
||||||
|
|
@ -315,7 +348,7 @@ Possibly a scheduler and other configuration has to be removed as well.
|
||||||
Contact
|
Contact
|
||||||
-------
|
-------
|
||||||
|
|
||||||
We have a Telegram Group [RouterOS-Scripts](https://t.me/routeros_scripts)!
|
We have a Telegram Group [RouterOS-Scripts ↗️](https://t.me/routeros_scripts)!
|
||||||
|
|
||||||
[](https://t.me/routeros_scripts)
|
[](https://t.me/routeros_scripts)
|
||||||
|
|
||||||
|
|
@ -339,7 +372,7 @@ at github.
|
||||||
This project is developed in private spare time and usage is free of charge
|
This project is developed in private spare time and usage is free of charge
|
||||||
for you. If you like the scripts and think this is of value for you or your
|
for you. If you like the scripts and think this is of value for you or your
|
||||||
business please consider to
|
business please consider to
|
||||||
[donate with PayPal](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J).
|
[donate with PayPal ↗️](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J).
|
||||||
|
|
||||||
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
|
|
||||||
|
|
@ -358,15 +391,33 @@ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
[GNU General Public License](COPYING.md) for more details.
|
[GNU General Public License](COPYING.md) for more details.
|
||||||
|
|
||||||
|
Disclaimer on external links
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
Our website contains links to the websites of third parties ("external
|
||||||
|
links"). As the content of these websites is not under our control, we
|
||||||
|
cannot assume any liability for such external content. In all cases, the
|
||||||
|
provider of information of the linked websites is liable for the content
|
||||||
|
and accuracy of the information provided. At the point in time when the
|
||||||
|
links were placed, no infringements of the law were recognisable to us.
|
||||||
|
As soon as an infringement of the law becomes known to us, we will
|
||||||
|
immediately remove the link in question.
|
||||||
|
|
||||||
|
> 💡️ **Hint**: All external links are marked with an arrow pointing
|
||||||
|
> diagonally in an up-right (or north-east) direction (↗️).
|
||||||
|
|
||||||
Upstream
|
Upstream
|
||||||
--------
|
--------
|
||||||
|
|
||||||
URL:
|
[rsc.eworm.de](https://rsc.eworm.de/)
|
||||||
[GitHub.com](https://github.com/eworm-de/routeros-scripts#routeros-scripts)
|
|
||||||
|
|
||||||
Mirror:
|
[](https://rsc.eworm.de/)
|
||||||
[eworm.de](https://git.eworm.de/cgit/routeros-scripts/about/)
|
|
||||||
[GitLab.com](https://gitlab.com/eworm-de/routeros-scripts#routeros-scripts)
|
### Code hosting
|
||||||
|
|
||||||
|
* [git.eworm.de](https://git.eworm.de/cgit/routeros-scripts/about/)
|
||||||
|
* [GitHub.com](https://github.com/eworm-de/routeros-scripts#routeros-scripts)
|
||||||
|
* [GitLab.com](https://gitlab.com/eworm-de/routeros-scripts#routeros-scripts)
|
||||||
|
|
||||||
---
|
---
|
||||||
[⬆️ Go back to top](#top)
|
[⬆️ Go back to top](#top)
|
||||||
|
|
|
||||||
|
|
@ -1,27 +1,28 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: accesslist-duplicates.capsman
|
# RouterOS script: accesslist-duplicates.capsman
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# print duplicate antries in wireless access list
|
# print duplicate antries in wireless access list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/accesslist-duplicates.md
|
# https://rsc.eworm.de/doc/accesslist-duplicates.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Seen ({});
|
:local Seen ({});
|
||||||
|
|
||||||
:foreach AccList in=[ /caps-man/access-list/find where mac-address!="00:00:00:00:00:00" ] do={
|
:foreach AccList in=[ /caps-man/access-list/find where mac-address!="00:00:00:00:00:00" ] do={
|
||||||
:local Mac [ /caps-man/access-list/get $AccList mac-address ];
|
:local Mac [ /caps-man/access-list/get $AccList mac-address ];
|
||||||
:if ($Seen->$Mac = 1) do={
|
:if ($Seen->$Mac = 1) do={
|
||||||
/caps-man/access-list/print where mac-address=$Mac;
|
/caps-man/access-list/print without-paging where mac-address=$Mac;
|
||||||
:local Remove [ :tonum [ /terminal/ask prompt="\nNumeric id to remove, any key to skip!" ] ];
|
:local Remove [ :tonum [ /terminal/ask prompt="\nNumeric id to remove, any key to skip!" ] ];
|
||||||
|
|
||||||
:if ([ :typeof $Remove ] = "num") do={
|
:if ([ :typeof $Remove ] = "num") do={
|
||||||
|
|
@ -31,6 +32,6 @@
|
||||||
}
|
}
|
||||||
:set ($Seen->$Mac) 1;
|
:set ($Seen->$Mac) 1;
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,27 +1,28 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: accesslist-duplicates.local
|
# RouterOS script: accesslist-duplicates.local
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# print duplicate antries in wireless access list
|
# print duplicate antries in wireless access list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/accesslist-duplicates.md
|
# https://rsc.eworm.de/doc/accesslist-duplicates.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Seen ({});
|
:local Seen ({});
|
||||||
|
|
||||||
:foreach AccList in=[ /interface/wireless/access-list/find where mac-address!="00:00:00:00:00:00" ] do={
|
:foreach AccList in=[ /interface/wireless/access-list/find where mac-address!="00:00:00:00:00:00" ] do={
|
||||||
:local Mac [ /interface/wireless/access-list/get $AccList mac-address ];
|
:local Mac [ /interface/wireless/access-list/get $AccList mac-address ];
|
||||||
:if ($Seen->$Mac = 1) do={
|
:if ($Seen->$Mac = 1) do={
|
||||||
/interface/wireless/access-list/print where mac-address=$Mac;
|
/interface/wireless/access-list/print without-paging where mac-address=$Mac;
|
||||||
:local Remove [ :tonum [ /terminal/ask prompt="\nNumeric id to remove, any key to skip!" ] ];
|
:local Remove [ :tonum [ /terminal/ask prompt="\nNumeric id to remove, any key to skip!" ] ];
|
||||||
|
|
||||||
:if ([ :typeof $Remove ] = "num") do={
|
:if ([ :typeof $Remove ] = "num") do={
|
||||||
|
|
@ -31,6 +32,6 @@
|
||||||
}
|
}
|
||||||
:set ($Seen->$Mac) 1;
|
:set ($Seen->$Mac) 1;
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,21 +1,22 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: accesslist-duplicates%TEMPL%
|
# RouterOS script: accesslist-duplicates%TEMPL%
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# print duplicate antries in wireless access list
|
# print duplicate antries in wireless access list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/accesslist-duplicates.md
|
# https://rsc.eworm.de/doc/accesslist-duplicates.md
|
||||||
#
|
#
|
||||||
# !! This is just a template to generate the real script!
|
# !! This is just a template to generate the real script!
|
||||||
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Seen ({});
|
:local Seen ({});
|
||||||
|
|
||||||
|
|
@ -26,9 +27,9 @@
|
||||||
:local Mac [ /interface/wifi/access-list/get $AccList mac-address ];
|
:local Mac [ /interface/wifi/access-list/get $AccList mac-address ];
|
||||||
:local Mac [ /interface/wireless/access-list/get $AccList mac-address ];
|
:local Mac [ /interface/wireless/access-list/get $AccList mac-address ];
|
||||||
:if ($Seen->$Mac = 1) do={
|
:if ($Seen->$Mac = 1) do={
|
||||||
/caps-man/access-list/print where mac-address=$Mac;
|
/caps-man/access-list/print without-paging where mac-address=$Mac;
|
||||||
/interface/wifi/access-list/print where mac-address=$Mac;
|
/interface/wifi/access-list/print without-paging where mac-address=$Mac;
|
||||||
/interface/wireless/access-list/print where mac-address=$Mac;
|
/interface/wireless/access-list/print without-paging where mac-address=$Mac;
|
||||||
:local Remove [ :tonum [ /terminal/ask prompt="\nNumeric id to remove, any key to skip!" ] ];
|
:local Remove [ :tonum [ /terminal/ask prompt="\nNumeric id to remove, any key to skip!" ] ];
|
||||||
|
|
||||||
:if ([ :typeof $Remove ] = "num") do={
|
:if ([ :typeof $Remove ] = "num") do={
|
||||||
|
|
@ -40,6 +41,6 @@
|
||||||
}
|
}
|
||||||
:set ($Seen->$Mac) 1;
|
:set ($Seen->$Mac) 1;
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,27 +1,28 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: accesslist-duplicates.wifi
|
# RouterOS script: accesslist-duplicates.wifi
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# print duplicate antries in wireless access list
|
# print duplicate antries in wireless access list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/accesslist-duplicates.md
|
# https://rsc.eworm.de/doc/accesslist-duplicates.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Seen ({});
|
:local Seen ({});
|
||||||
|
|
||||||
:foreach AccList in=[ /interface/wifi/access-list/find where mac-address!="00:00:00:00:00:00" ] do={
|
:foreach AccList in=[ /interface/wifi/access-list/find where mac-address!="00:00:00:00:00:00" ] do={
|
||||||
:local Mac [ /interface/wifi/access-list/get $AccList mac-address ];
|
:local Mac [ /interface/wifi/access-list/get $AccList mac-address ];
|
||||||
:if ($Seen->$Mac = 1) do={
|
:if ($Seen->$Mac = 1) do={
|
||||||
/interface/wifi/access-list/print where mac-address=$Mac;
|
/interface/wifi/access-list/print without-paging where mac-address=$Mac;
|
||||||
:local Remove [ :tonum [ /terminal/ask prompt="\nNumeric id to remove, any key to skip!" ] ];
|
:local Remove [ :tonum [ /terminal/ask prompt="\nNumeric id to remove, any key to skip!" ] ];
|
||||||
|
|
||||||
:if ([ :typeof $Remove ] = "num") do={
|
:if ([ :typeof $Remove ] = "num") do={
|
||||||
|
|
@ -31,6 +32,6 @@
|
||||||
}
|
}
|
||||||
:set ($Seen->$Mac) 1;
|
:set ($Seen->$Mac) 1;
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,29 +1,32 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: backup-cloud
|
# RouterOS script: backup-cloud
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: backup-script, order=40
|
# provides: backup-script, order=40
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# upload backup to MikroTik cloud
|
# upload backup to MikroTik cloud
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/backup-cloud.md
|
# https://rsc.eworm.de/doc/backup-cloud.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global BackupRandomDelay;
|
:global BackupRandomDelay;
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
:global PackagesUpdateBackupFailure;
|
||||||
|
|
||||||
:global DeviceInfo;
|
:global DeviceInfo;
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global HumanReadableNum;
|
:global HumanReadableNum;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global MkDir;
|
:global MkDir;
|
||||||
:global RandomDelay;
|
:global RandomDelay;
|
||||||
|
:global RmDir;
|
||||||
:global ScriptFromTerminal;
|
:global ScriptFromTerminal;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
|
|
@ -32,8 +35,18 @@
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:if ([ :len [ /system/scheduler/find where name="running-from-backup-partition" ] ] > 0) do={
|
||||||
|
$LogPrint warning $ScriptName ("Running from backup partition, refusing to act.");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptFromTerminal $ScriptName ] = false && $BackupRandomDelay > 0) do={
|
:if ([ $ScriptFromTerminal $ScriptName ] = false && $BackupRandomDelay > 0) do={
|
||||||
|
|
@ -41,26 +54,34 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ $MkDir ("tmpfs/backup-cloud") ] = false) do={
|
:if ([ $MkDir ("tmpfs/backup-cloud") ] = false) do={
|
||||||
$LogPrintExit2 error $ScriptName ("Failed creating directory!") true;
|
$LogPrint error $ScriptName ("Failed creating directory!");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:execute {
|
:local I 5;
|
||||||
:global BackupPassword;
|
:do {
|
||||||
# we are not interested in output, but print is
|
:execute {
|
||||||
# required to fetch information from cloud
|
:global BackupPassword;
|
||||||
/system/backup/cloud/print as-value;
|
|
||||||
:delay 20ms;
|
:local Backup ([ /system/backup/cloud/find ]->0);
|
||||||
:if ([ :len [ /system/backup/cloud/find ] ] > 0) do={
|
:if ([ :typeof $Backup ] = "id") do={
|
||||||
/system/backup/cloud/upload-file action=create-and-upload \
|
/system/backup/cloud/upload-file action=create-and-upload \
|
||||||
password=$BackupPassword replace=[ get ([ find ]->0) name ];
|
password=$BackupPassword replace=$Backup;
|
||||||
} else={
|
} else={
|
||||||
/system/backup/cloud/upload-file action=create-and-upload \
|
/system/backup/cloud/upload-file action=create-and-upload \
|
||||||
password=$BackupPassword;
|
password=$BackupPassword;
|
||||||
}
|
}
|
||||||
/file/add name="tmpfs/backup-cloud/done";
|
/file/add name="tmpfs/backup-cloud/done";
|
||||||
} as-string;
|
} as-string;
|
||||||
|
:set I ($I - 1);
|
||||||
|
} while=([ $WaitForFile "tmpfs/backup-cloud/done" 200ms ] = false && $I > 0);
|
||||||
|
|
||||||
:if ([ $WaitForFile "tmpfs/backup-cloud/done" ] = true) do={
|
:if ([ $WaitForFile "tmpfs/backup-cloud/done" ] = true) do={
|
||||||
|
:if ($I < 4) do={
|
||||||
|
:log warning ($ScriptName . ": Retry successful, please discard previous connection errors.");
|
||||||
|
}
|
||||||
|
|
||||||
:local Cloud [ /system/backup/cloud/get ([ find ]->0) ];
|
:local Cloud [ /system/backup/cloud/get ([ find ]->0) ];
|
||||||
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
|
@ -68,15 +89,16 @@
|
||||||
message=("Uploaded backup for " . $Identity . " to cloud.\n\n" . \
|
message=("Uploaded backup for " . $Identity . " to cloud.\n\n" . \
|
||||||
[ $DeviceInfo ] . "\n\n" . \
|
[ $DeviceInfo ] . "\n\n" . \
|
||||||
[ $FormatLine "Name" ($Cloud->"name") ] . "\n" . \
|
[ $FormatLine "Name" ($Cloud->"name") ] . "\n" . \
|
||||||
[ $FormatLine "Size" ([ $HumanReadableNum ($Cloud->"size") 1024 ] . "iB") ] . "\n" . \
|
[ $FormatLine "Size" ([ $HumanReadableNum ($Cloud->"size") 1024 ] . "B") ] . "\n" . \
|
||||||
[ $FormatLine "Download key" ($Cloud->"secret-download-key") ]); silent=true });
|
[ $FormatLine "Download key" ($Cloud->"secret-download-key") ]); silent=true });
|
||||||
} else={
|
} else={
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "floppy-disk,warning-sign" ] . "Cloud backup failed"); \
|
subject=([ $SymbolForNotification "floppy-disk,warning-sign" ] . "Cloud backup failed"); \
|
||||||
message=("Failed uploading backup for " . $Identity . " to cloud!\n\n" . [ $DeviceInfo ]) });
|
message=("Failed uploading backup for " . $Identity . " to cloud!\n\n" . [ $DeviceInfo ]) });
|
||||||
$LogPrintExit2 error $ScriptName ("Failed uploading backup for " . $Identity . " to cloud!") true;
|
$LogPrint error $ScriptName ("Failed uploading backup for " . $Identity . " to cloud!");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
}
|
}
|
||||||
/file/remove "tmpfs/backup-cloud";
|
$RmDir "tmpfs/backup-cloud";
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,19 +1,20 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: backup-email
|
# RouterOS script: backup-email
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: backup-script, order=20
|
# provides: backup-script, order=20
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# create and email backup and config file
|
# create and email backup and config file
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/backup-email.md
|
# https://rsc.eworm.de/doc/backup-email.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global BackupPassword;
|
:global BackupPassword;
|
||||||
:global BackupRandomDelay;
|
:global BackupRandomDelay;
|
||||||
|
|
@ -22,11 +23,13 @@
|
||||||
:global BackupSendGlobalConfig;
|
:global BackupSendGlobalConfig;
|
||||||
:global Domain;
|
:global Domain;
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
:global PackagesUpdateBackupFailure;
|
||||||
|
|
||||||
:global CleanName;
|
:global CleanName;
|
||||||
:global DeviceInfo;
|
:global DeviceInfo;
|
||||||
|
:global FileExists;
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global MkDir;
|
:global MkDir;
|
||||||
:global RandomDelay;
|
:global RandomDelay;
|
||||||
:global ScriptFromTerminal;
|
:global ScriptFromTerminal;
|
||||||
|
|
@ -37,17 +40,31 @@
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ :typeof $SendEMail2 ] = "nothing") do={
|
:if ([ :typeof $SendEMail2 ] = "nothing") do={
|
||||||
$LogPrintExit2 error $ScriptName ("The module for sending notifications via e-mail is not installed.") true;
|
$LogPrint error $ScriptName ("The module for sending notifications via e-mail is not installed.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ($BackupSendBinary != true && \
|
:if ($BackupSendBinary != true && \
|
||||||
$BackupSendExport != true) do={
|
$BackupSendExport != true) do={
|
||||||
$LogPrintExit2 error $ScriptName ("Configured to send neither backup nor config export.") true;
|
$LogPrint error $ScriptName ("Configured to send neither backup nor config export.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:if ([ :len [ /system/scheduler/find where name="running-from-backup-partition" ] ] > 0) do={
|
||||||
|
$LogPrint warning $ScriptName ("Running from backup partition, refusing to act.");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptFromTerminal $ScriptName ] = false && $BackupRandomDelay > 0) do={
|
:if ([ $ScriptFromTerminal $ScriptName ] = false && $BackupRandomDelay > 0) do={
|
||||||
|
|
@ -64,7 +81,9 @@
|
||||||
:local Attach ({});
|
:local Attach ({});
|
||||||
|
|
||||||
:if ([ $MkDir $DirName ] = false) do={
|
:if ([ $MkDir $DirName ] = false) do={
|
||||||
$LogPrintExit2 error $ScriptName ("Failed creating directory!") true;
|
$LogPrint error $ScriptName ("Failed creating directory!");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
# binary backup
|
# binary backup
|
||||||
|
|
@ -106,14 +125,19 @@
|
||||||
attach=$Attach; remove-attach=true });
|
attach=$Attach; remove-attach=true });
|
||||||
|
|
||||||
# wait for the mail to be sent
|
# wait for the mail to be sent
|
||||||
:local I 0;
|
:do {
|
||||||
:while ([ :len [ /file/find where name ~ ($FilePath . "\\.(backup|rsc)\$") ] ] > 0) do={
|
:retry {
|
||||||
:if ($I >= 120) do={
|
:if ([ $FileExists ($FilePath . ".conf") ".conf file" ] = true || \
|
||||||
$LogPrintExit2 warning $ScriptName ("Files are still available, sending e-mail failed.") true;
|
[ $FileExists ($FilePath . ".backup") "backup" ] = true || \
|
||||||
}
|
[ $FileExists ($FilePath . ".rsc") "script" ] = true) do={
|
||||||
:delay 1s;
|
:error "Files are still available.";
|
||||||
:set I ($I + 1);
|
}
|
||||||
|
} delay=1s max=120;
|
||||||
|
} on-error={
|
||||||
|
$LogPrint warning $ScriptName ("Files are still available, sending e-mail failed.");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
}
|
}
|
||||||
|
# do not remove the files here, as the mail is still queued!
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,52 +1,128 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: backup-partition
|
# RouterOS script: backup-partition
|
||||||
# Copyright (c) 2022-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2022-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: backup-script, order=70
|
# provides: backup-script, order=70
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
|
# requires device-mode, scheduler
|
||||||
#
|
#
|
||||||
# save configuration to fallback partition
|
# save configuration to fallback partition
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/backup-partition.md
|
# https://rsc.eworm.de/doc/backup-partition.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Main do={
|
:global BackupPartitionCopyBeforeFeatureUpdate;
|
||||||
:local ScriptName [ :tostr $1 ];
|
:global PackagesUpdateBackupFailure;
|
||||||
|
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
|
:global ScriptFromTerminal;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
:global VersionToNum;
|
||||||
|
|
||||||
|
:local CopyTo do={
|
||||||
|
:local ScriptName [ :tostr $1 ];
|
||||||
|
:local FallbackTo [ :toid $2 ];
|
||||||
|
:local FallbackToName [ :tostr $3 ];
|
||||||
|
|
||||||
|
:global LogPrint;
|
||||||
|
|
||||||
|
:onerror Err {
|
||||||
|
/partitions/copy-to $FallbackTo;
|
||||||
|
$LogPrint info $ScriptName ("Copied RouterOS to partition '" . $FallbackToName . "'.");
|
||||||
|
} do={
|
||||||
|
$LogPrint error $ScriptName ("Failed copying RouterOS to partition '" . \
|
||||||
|
$FallbackToName . "': " . $Err);
|
||||||
|
:return false;
|
||||||
|
}
|
||||||
|
:return true;
|
||||||
|
}
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
|
||||||
|
:if ([ :len [ /system/scheduler/find where name="running-from-backup-partition" ] ] > 0) do={
|
||||||
|
$LogPrint warning $ScriptName ("Running from backup partition, refusing to act.");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /partitions/find ] ] < 2) do={
|
:if ([ :len [ /partitions/find ] ] < 2) do={
|
||||||
$LogPrintExit2 error $ScriptName ("Device does not have a fallback partition.") true;
|
$LogPrint error $ScriptName ("Device does not have a fallback partition.");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:local ActiveRunning [ /partitions/find where active running ];
|
:local ActiveRunning [ /partitions/find where active running ];
|
||||||
|
|
||||||
:if ([ :len $ActiveRunning ] < 1) do={
|
:if ([ :len $ActiveRunning ] < 1) do={
|
||||||
$LogPrintExit2 error $ScriptName ("Device is not running from active partition.") true;
|
$LogPrint error $ScriptName ("Device is not running from active partition.");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:local FallbackTo [ /partitions/get $ActiveRunning fallback-to ];
|
:local FallbackToName [ /partitions/get $ActiveRunning fallback-to ];
|
||||||
|
:local FallbackTo [ /partition/find where name=$FallbackToName !active ];
|
||||||
|
|
||||||
:do {
|
:if ([ :len $FallbackTo ] < 1) do={
|
||||||
|
$LogPrint error $ScriptName ("There is no inactive partition named '" . $FallbackToName . "'.");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
|
||||||
|
:if ([ /partitions/get $ActiveRunning version ] != [ /partitions/get $FallbackTo version]) do={
|
||||||
|
:if ([ $ScriptFromTerminal $ScriptName ] = true) do={
|
||||||
|
:put ("The partitions have different RouterOS versions. Copy over to '" . $FallbackToName . "'? [y/N]");
|
||||||
|
:if (([ /terminal/inkey timeout=60 ] % 32) = 25) do={
|
||||||
|
:if ([ $CopyTo $ScriptName $FallbackTo $FallbackToName ] = false) do={
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else={
|
||||||
|
:local Update [ /system/package/update/get ];
|
||||||
|
:local NumInstalled [ $VersionToNum ($Update->"installed-version") ];
|
||||||
|
:local NumLatest [ $VersionToNum ($Update->"latest-version") ];
|
||||||
|
:local BitMask [ $VersionToNum "255.255zero0" ];
|
||||||
|
:if ($BackupPartitionCopyBeforeFeatureUpdate = true && $NumLatest > 0 && \
|
||||||
|
($NumInstalled & $BitMask) != ($NumLatest & $BitMask)) do={
|
||||||
|
:if ([ $CopyTo $ScriptName $FallbackTo $FallbackToName ] = false) do={
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
:onerror Err {
|
||||||
/system/scheduler/add start-time=startup name="running-from-backup-partition" \
|
/system/scheduler/add start-time=startup name="running-from-backup-partition" \
|
||||||
on-event=(":log warning (\"Running from partition '\" . " . \
|
on-event=(":log warning (\"Running from partition '\" . " . \
|
||||||
"[ /partitions/get [ find where running ] name ] . \"'!\")");
|
"[ /partitions/get [ find where running ] name ] . \"'!\")");
|
||||||
/partitions/save-config-to $FallbackTo;
|
/partitions/save-config-to $FallbackTo;
|
||||||
/system/scheduler/remove "running-from-backup-partition";
|
/system/scheduler/remove "running-from-backup-partition";
|
||||||
$LogPrintExit2 info $ScriptName ("Saved configuration to partition '" . \
|
$LogPrint info $ScriptName ("Saved configuration to partition '" . $FallbackToName . "'.");
|
||||||
$FallbackTo . "'.") false;
|
} do={
|
||||||
} on-error={
|
|
||||||
/system/scheduler/remove [ find where name="running-from-backup-partition" ];
|
/system/scheduler/remove [ find where name="running-from-backup-partition" ];
|
||||||
$LogPrintExit2 error $ScriptName ("Failed saving configuration to partition '" . \
|
$LogPrint error $ScriptName ("Failed saving configuration to partition '" . \
|
||||||
$FallbackTo . "'!") true;
|
$FallbackToName . "': " . $Err);
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,19 +1,21 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: backup-upload
|
# RouterOS script: backup-upload
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: backup-script, order=50
|
# provides: backup-script, order=50
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
|
# requires device-mode, fetch
|
||||||
#
|
#
|
||||||
# create and upload backup and config file
|
# create and upload backup and config file
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/backup-upload.md
|
# https://rsc.eworm.de/doc/backup-upload.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global BackupPassword;
|
:global BackupPassword;
|
||||||
:global BackupRandomDelay;
|
:global BackupRandomDelay;
|
||||||
|
|
@ -25,13 +27,16 @@
|
||||||
:global BackupUploadUser;
|
:global BackupUploadUser;
|
||||||
:global Domain;
|
:global Domain;
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
:global PackagesUpdateBackupFailure;
|
||||||
|
|
||||||
:global CleanName;
|
:global CleanName;
|
||||||
:global DeviceInfo;
|
:global DeviceInfo;
|
||||||
:global IfThenElse;
|
:global IfThenElse;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global MkDir;
|
:global MkDir;
|
||||||
:global RandomDelay;
|
:global RandomDelay;
|
||||||
|
:global RmDir;
|
||||||
|
:global RmFile;
|
||||||
:global ScriptFromTerminal;
|
:global ScriptFromTerminal;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
|
|
@ -41,12 +46,24 @@
|
||||||
|
|
||||||
:if ($BackupSendBinary != true && \
|
:if ($BackupSendBinary != true && \
|
||||||
$BackupSendExport != true) do={
|
$BackupSendExport != true) do={
|
||||||
$LogPrintExit2 error $ScriptName ("Configured to send neither backup nor config export.") true;
|
$LogPrint error $ScriptName ("Configured to send neither backup nor config export.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:if ([ :len [ /system/scheduler/find where name="running-from-backup-partition" ] ] > 0) do={
|
||||||
|
$LogPrint warning $ScriptName ("Running from backup partition, refusing to act.");
|
||||||
|
:set PackagesUpdateBackupFailure true;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptFromTerminal $ScriptName ] = false && $BackupRandomDelay > 0) do={
|
:if ([ $ScriptFromTerminal $ScriptName ] = false && $BackupRandomDelay > 0) do={
|
||||||
|
|
@ -63,7 +80,9 @@
|
||||||
:local Failed 0;
|
:local Failed 0;
|
||||||
|
|
||||||
:if ([ $MkDir $DirName ] = false) do={
|
:if ([ $MkDir $DirName ] = false) do={
|
||||||
$LogPrintExit2 error $ScriptName ("Failed creating directory!") true;
|
$LogPrint error $ScriptName ("Failed creating directory!");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
# binary backup
|
# binary backup
|
||||||
|
|
@ -71,18 +90,18 @@
|
||||||
/system/backup/save encryption=aes-sha256 name=$FilePath password=$BackupPassword;
|
/system/backup/save encryption=aes-sha256 name=$FilePath password=$BackupPassword;
|
||||||
$WaitForFile ($FilePath . ".backup");
|
$WaitForFile ($FilePath . ".backup");
|
||||||
|
|
||||||
:do {
|
:onerror Err {
|
||||||
/tool/fetch upload=yes url=($BackupUploadUrl . "/" . $FileName . ".backup") \
|
/tool/fetch upload=yes url=($BackupUploadUrl . "/" . $FileName . ".backup") \
|
||||||
user=$BackupUploadUser password=$BackupUploadPass src-path=($FilePath . ".backup");
|
user=$BackupUploadUser password=$BackupUploadPass src-path=($FilePath . ".backup");
|
||||||
:set BackupFile [ /file/get ($FilePath . ".backup") ];
|
:set BackupFile [ /file/get ($FilePath . ".backup") ];
|
||||||
:set ($BackupFile->"name") ($FileName . ".backup");
|
:set ($BackupFile->"name") ($FileName . ".backup");
|
||||||
} on-error={
|
} do={
|
||||||
$LogPrintExit2 error $ScriptName ("Uploading backup file failed!") false;
|
$LogPrint error $ScriptName ("Uploading backup file failed: " . $Err);
|
||||||
:set BackupFile "failed";
|
:set BackupFile "failed";
|
||||||
:set Failed 1;
|
:set Failed 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/file/remove ($FilePath . ".backup");
|
$RmFile ($FilePath . ".backup");
|
||||||
}
|
}
|
||||||
|
|
||||||
# create configuration export
|
# create configuration export
|
||||||
|
|
@ -90,18 +109,18 @@
|
||||||
/export terse show-sensitive file=$FilePath;
|
/export terse show-sensitive file=$FilePath;
|
||||||
$WaitForFile ($FilePath . ".rsc");
|
$WaitForFile ($FilePath . ".rsc");
|
||||||
|
|
||||||
:do {
|
:onerror Err {
|
||||||
/tool/fetch upload=yes url=($BackupUploadUrl . "/" . $FileName . ".rsc") \
|
/tool/fetch upload=yes url=($BackupUploadUrl . "/" . $FileName . ".rsc") \
|
||||||
user=$BackupUploadUser password=$BackupUploadPass src-path=($FilePath . ".rsc");
|
user=$BackupUploadUser password=$BackupUploadPass src-path=($FilePath . ".rsc");
|
||||||
:set ExportFile [ /file/get ($FilePath . ".rsc") ];
|
:set ExportFile [ /file/get ($FilePath . ".rsc") ];
|
||||||
:set ($ExportFile->"name") ($FileName . ".rsc");
|
:set ($ExportFile->"name") ($FileName . ".rsc");
|
||||||
} on-error={
|
} do={
|
||||||
$LogPrintExit2 error $ScriptName ("Uploading configuration export failed!") false;
|
$LogPrint error $ScriptName ("Uploading configuration export failed: " . $Err);
|
||||||
:set ExportFile "failed";
|
:set ExportFile "failed";
|
||||||
:set Failed 1;
|
:set Failed 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/file/remove ($FilePath . ".rsc");
|
$RmFile ($FilePath . ".rsc");
|
||||||
}
|
}
|
||||||
|
|
||||||
# global-config-overlay
|
# global-config-overlay
|
||||||
|
|
@ -111,18 +130,18 @@
|
||||||
file=($FilePath . ".conf\00");
|
file=($FilePath . ".conf\00");
|
||||||
$WaitForFile ($FilePath . ".conf");
|
$WaitForFile ($FilePath . ".conf");
|
||||||
|
|
||||||
:do {
|
:onerror Err {
|
||||||
/tool/fetch upload=yes url=($BackupUploadUrl . "/" . $FileName . ".conf") \
|
/tool/fetch upload=yes url=($BackupUploadUrl . "/" . $FileName . ".conf") \
|
||||||
user=$BackupUploadUser password=$BackupUploadPass src-path=($FilePath . ".conf");
|
user=$BackupUploadUser password=$BackupUploadPass src-path=($FilePath . ".conf");
|
||||||
:set ConfigFile [ /file/get ($FilePath . ".conf") ];
|
:set ConfigFile [ /file/get ($FilePath . ".conf") ];
|
||||||
:set ($ConfigFile->"name") ($FileName . ".conf");
|
:set ($ConfigFile->"name") ($FileName . ".conf");
|
||||||
} on-error={
|
} do={
|
||||||
$LogPrintExit2 error $ScriptName ("Uploading global-config-overlay failed!") false;
|
$LogPrint error $ScriptName ("Uploading global-config-overlay failed: " . $Err);
|
||||||
:set ConfigFile "failed";
|
:set ConfigFile "failed";
|
||||||
:set Failed 1;
|
:set Failed 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/file/remove ($FilePath . ".conf");
|
$RmFile ($FilePath . ".conf");
|
||||||
}
|
}
|
||||||
|
|
||||||
:local FileInfo do={
|
:local FileInfo do={
|
||||||
|
|
@ -136,7 +155,7 @@
|
||||||
:return \
|
:return \
|
||||||
[ $IfThenElse ([ :typeof $File ] = "array") \
|
[ $IfThenElse ([ :typeof $File ] = "array") \
|
||||||
($Name . ":\n" . [ $FormatLine " name" ($File->"name") ] . "\n" . \
|
($Name . ":\n" . [ $FormatLine " name" ($File->"name") ] . "\n" . \
|
||||||
[ $FormatLine " size" ([ $HumanReadableNum ($File->"size") 1024 ] . "iB") ]) \
|
[ $FormatLine " size" ([ $HumanReadableNum ($File->"size") 1024 ] . "B") ]) \
|
||||||
[ $FormatLine $Name $File ] ];
|
[ $FormatLine $Name $File ] ];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -151,8 +170,9 @@
|
||||||
[ $FileInfo "Config file" $ConfigFile ]); silent=true });
|
[ $FileInfo "Config file" $ConfigFile ]); silent=true });
|
||||||
|
|
||||||
:if ($Failed = 1) do={
|
:if ($Failed = 1) do={
|
||||||
:error "An error occured!";
|
:set PackagesUpdateBackupFailure true;
|
||||||
}
|
}
|
||||||
|
$RmDir $DirName;
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,31 +1,35 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: capsman-download-packages.capsman
|
# RouterOS script: capsman-download-packages.capsman
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# download and cleanup packages for CAP installation from CAPsMAN
|
# download and cleanup packages for CAP installation from CAPsMAN
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/capsman-download-packages.md
|
# https://rsc.eworm.de/doc/capsman-download-packages.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global CleanFilePath;
|
:global CleanFilePath;
|
||||||
:global DownloadPackage;
|
:global DownloadPackage;
|
||||||
:global LogPrintExit2;
|
:global FileGet;
|
||||||
|
:global LogPrint;
|
||||||
:global MkDir;
|
:global MkDir;
|
||||||
|
:global RmFile;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
|
|
@ -34,19 +38,23 @@
|
||||||
:local Updated false;
|
:local Updated false;
|
||||||
|
|
||||||
:if ([ :len $PackagePath ] = 0) do={
|
:if ([ :len $PackagePath ] = 0) do={
|
||||||
$LogPrintExit2 warning $ScriptName ("The CAPsMAN package path is not defined, can not download packages.") true;
|
$LogPrint warning $ScriptName ("The CAPsMAN package path is not defined, can not download packages.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /file/find where name=$PackagePath type="directory" ] ] = 0) do={
|
:if ([ $FileGet $PackagePath ] = false) do={
|
||||||
:if ([ $MkDir $PackagePath ] = false) do={
|
:if ([ $MkDir $PackagePath ] = false) do={
|
||||||
$LogPrintExit2 warning $ScriptName ("Creating directory at CAPsMAN package path (" . \
|
$LogPrint warning $ScriptName ("Creating directory at CAPsMAN package path (" . \
|
||||||
$PackagePath . ") failed!") true;
|
$PackagePath . ") failed!");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$LogPrintExit2 info $ScriptName ("Created directory at CAPsMAN package path (" . $PackagePath . \
|
$LogPrint info $ScriptName ("Created directory at CAPsMAN package path (" . $PackagePath . \
|
||||||
"). Please place your packages!") false;
|
"). Please place your packages!");
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Package in=[ /file/find where type=package \
|
:foreach Package in=[ /file/find where type="package" \
|
||||||
package-version!=$InstalledVersion name~("^" . $PackagePath) ] do={
|
package-version!=$InstalledVersion name~("^" . $PackagePath) ] do={
|
||||||
:local File [ /file/get $Package ];
|
:local File [ /file/get $Package ];
|
||||||
:if ($File->"package-architecture" = "mips") do={
|
:if ($File->"package-architecture" = "mips") do={
|
||||||
|
|
@ -55,12 +63,12 @@
|
||||||
:if ([ $DownloadPackage ($File->"package-name") $InstalledVersion \
|
:if ([ $DownloadPackage ($File->"package-name") $InstalledVersion \
|
||||||
($File->"package-architecture") $PackagePath ] = true) do={
|
($File->"package-architecture") $PackagePath ] = true) do={
|
||||||
:set Updated true;
|
:set Updated true;
|
||||||
/file/remove $Package;
|
$RmFile ($File->"name");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /file/find where type=package name~("^" . $PackagePath) ] ] = 0) do={
|
:if ([ :len [ /file/find where type="package" name~("^" . $PackagePath) ] ] = 0) do={
|
||||||
$LogPrintExit2 info $ScriptName ("No packages available, downloading default set.") false;
|
$LogPrint info $ScriptName ("No packages available, downloading default set.");
|
||||||
:foreach Arch in={ "arm"; "mipsbe" } do={
|
:foreach Arch in={ "arm"; "mipsbe" } do={
|
||||||
:foreach Package in={ "routeros"; "wireless" } do={
|
:foreach Package in={ "routeros"; "wireless" } do={
|
||||||
:if ([ $DownloadPackage $Package $InstalledVersion $Arch $PackagePath ] = true) do={
|
:if ([ $DownloadPackage $Package $InstalledVersion $Arch $PackagePath ] = true) do={
|
||||||
|
|
@ -71,13 +79,15 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ($Updated = true) do={
|
:if ($Updated = true) do={
|
||||||
:local Script ([ /system/script/find where source~"\n# provides: capsman-rolling-upgrade\n" ]->0);
|
:local Scripts [ /system/script/find where source~"\n# provides: capsman-rolling-upgrade.capsman\r?\n" ];
|
||||||
:if ([ :len $Script ] > 0) do={
|
:if ([ :len $Scripts ] > 0) do={
|
||||||
/system/script/run $Script;
|
:foreach Script in=$Scripts do={
|
||||||
|
/system/script/run $Script;
|
||||||
|
}
|
||||||
} else={
|
} else={
|
||||||
/caps-man/remote-cap/upgrade [ find where version!=$InstalledVersion ];
|
/caps-man/remote-cap/upgrade [ find where version!=$InstalledVersion ];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,32 +1,36 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: capsman-download-packages%TEMPL%
|
# RouterOS script: capsman-download-packages%TEMPL%
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# download and cleanup packages for CAP installation from CAPsMAN
|
# download and cleanup packages for CAP installation from CAPsMAN
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/capsman-download-packages.md
|
# https://rsc.eworm.de/doc/capsman-download-packages.md
|
||||||
#
|
#
|
||||||
# !! This is just a template to generate the real script!
|
# !! This is just a template to generate the real script!
|
||||||
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global CleanFilePath;
|
:global CleanFilePath;
|
||||||
:global DownloadPackage;
|
:global DownloadPackage;
|
||||||
:global LogPrintExit2;
|
:global FileGet;
|
||||||
|
:global LogPrint;
|
||||||
:global MkDir;
|
:global MkDir;
|
||||||
|
:global RmFile;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
|
|
@ -36,19 +40,23 @@
|
||||||
:local Updated false;
|
:local Updated false;
|
||||||
|
|
||||||
:if ([ :len $PackagePath ] = 0) do={
|
:if ([ :len $PackagePath ] = 0) do={
|
||||||
$LogPrintExit2 warning $ScriptName ("The CAPsMAN package path is not defined, can not download packages.") true;
|
$LogPrint warning $ScriptName ("The CAPsMAN package path is not defined, can not download packages.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /file/find where name=$PackagePath type="directory" ] ] = 0) do={
|
:if ([ $FileGet $PackagePath ] = false) do={
|
||||||
:if ([ $MkDir $PackagePath ] = false) do={
|
:if ([ $MkDir $PackagePath ] = false) do={
|
||||||
$LogPrintExit2 warning $ScriptName ("Creating directory at CAPsMAN package path (" . \
|
$LogPrint warning $ScriptName ("Creating directory at CAPsMAN package path (" . \
|
||||||
$PackagePath . ") failed!") true;
|
$PackagePath . ") failed!");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$LogPrintExit2 info $ScriptName ("Created directory at CAPsMAN package path (" . $PackagePath . \
|
$LogPrint info $ScriptName ("Created directory at CAPsMAN package path (" . $PackagePath . \
|
||||||
"). Please place your packages!") false;
|
"). Please place your packages!");
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Package in=[ /file/find where type=package \
|
:foreach Package in=[ /file/find where type="package" \
|
||||||
package-version!=$InstalledVersion name~("^" . $PackagePath) ] do={
|
package-version!=$InstalledVersion name~("^" . $PackagePath) ] do={
|
||||||
:local File [ /file/get $Package ];
|
:local File [ /file/get $Package ];
|
||||||
:if ($File->"package-architecture" = "mips") do={
|
:if ($File->"package-architecture" = "mips") do={
|
||||||
|
|
@ -57,12 +65,12 @@
|
||||||
:if ([ $DownloadPackage ($File->"package-name") $InstalledVersion \
|
:if ([ $DownloadPackage ($File->"package-name") $InstalledVersion \
|
||||||
($File->"package-architecture") $PackagePath ] = true) do={
|
($File->"package-architecture") $PackagePath ] = true) do={
|
||||||
:set Updated true;
|
:set Updated true;
|
||||||
/file/remove $Package;
|
$RmFile ($File->"name");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /file/find where type=package name~("^" . $PackagePath) ] ] = 0) do={
|
:if ([ :len [ /file/find where type="package" name~("^" . $PackagePath) ] ] = 0) do={
|
||||||
$LogPrintExit2 info $ScriptName ("No packages available, downloading default set.") false;
|
$LogPrint info $ScriptName ("No packages available, downloading default set.");
|
||||||
# NOT /interface/wifi/ #
|
# NOT /interface/wifi/ #
|
||||||
:foreach Arch in={ "arm"; "mipsbe" } do={
|
:foreach Arch in={ "arm"; "mipsbe" } do={
|
||||||
:foreach Package in={ "routeros"; "wireless" } do={
|
:foreach Package in={ "routeros"; "wireless" } do={
|
||||||
|
|
@ -81,14 +89,16 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ($Updated = true) do={
|
:if ($Updated = true) do={
|
||||||
:local Script ([ /system/script/find where source~"\n# provides: capsman-rolling-upgrade\n" ]->0);
|
:local Scripts [ /system/script/find where source~"\n# provides: capsman-rolling-upgrade%TEMPL%\r?\n" ];
|
||||||
:if ([ :len $Script ] > 0) do={
|
:if ([ :len $Scripts ] > 0) do={
|
||||||
/system/script/run $Script;
|
:foreach Script in=$Scripts do={
|
||||||
|
/system/script/run $Script;
|
||||||
|
}
|
||||||
} else={
|
} else={
|
||||||
/caps-man/remote-cap/upgrade [ find where version!=$InstalledVersion ];
|
/caps-man/remote-cap/upgrade [ find where version!=$InstalledVersion ];
|
||||||
/interface/wifi/capsman/remote-cap/upgrade [ find where version!=$InstalledVersion ];
|
/interface/wifi/capsman/remote-cap/upgrade [ find where version!=$InstalledVersion ];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,31 +1,35 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: capsman-download-packages.wifi
|
# RouterOS script: capsman-download-packages.wifi
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# download and cleanup packages for CAP installation from CAPsMAN
|
# download and cleanup packages for CAP installation from CAPsMAN
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/capsman-download-packages.md
|
# https://rsc.eworm.de/doc/capsman-download-packages.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global CleanFilePath;
|
:global CleanFilePath;
|
||||||
:global DownloadPackage;
|
:global DownloadPackage;
|
||||||
:global LogPrintExit2;
|
:global FileGet;
|
||||||
|
:global LogPrint;
|
||||||
:global MkDir;
|
:global MkDir;
|
||||||
|
:global RmFile;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
|
|
@ -34,19 +38,23 @@
|
||||||
:local Updated false;
|
:local Updated false;
|
||||||
|
|
||||||
:if ([ :len $PackagePath ] = 0) do={
|
:if ([ :len $PackagePath ] = 0) do={
|
||||||
$LogPrintExit2 warning $ScriptName ("The CAPsMAN package path is not defined, can not download packages.") true;
|
$LogPrint warning $ScriptName ("The CAPsMAN package path is not defined, can not download packages.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /file/find where name=$PackagePath type="directory" ] ] = 0) do={
|
:if ([ $FileGet $PackagePath ] = false) do={
|
||||||
:if ([ $MkDir $PackagePath ] = false) do={
|
:if ([ $MkDir $PackagePath ] = false) do={
|
||||||
$LogPrintExit2 warning $ScriptName ("Creating directory at CAPsMAN package path (" . \
|
$LogPrint warning $ScriptName ("Creating directory at CAPsMAN package path (" . \
|
||||||
$PackagePath . ") failed!") true;
|
$PackagePath . ") failed!");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$LogPrintExit2 info $ScriptName ("Created directory at CAPsMAN package path (" . $PackagePath . \
|
$LogPrint info $ScriptName ("Created directory at CAPsMAN package path (" . $PackagePath . \
|
||||||
"). Please place your packages!") false;
|
"). Please place your packages!");
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Package in=[ /file/find where type=package \
|
:foreach Package in=[ /file/find where type="package" \
|
||||||
package-version!=$InstalledVersion name~("^" . $PackagePath) ] do={
|
package-version!=$InstalledVersion name~("^" . $PackagePath) ] do={
|
||||||
:local File [ /file/get $Package ];
|
:local File [ /file/get $Package ];
|
||||||
:if ($File->"package-architecture" = "mips") do={
|
:if ($File->"package-architecture" = "mips") do={
|
||||||
|
|
@ -55,12 +63,12 @@
|
||||||
:if ([ $DownloadPackage ($File->"package-name") $InstalledVersion \
|
:if ([ $DownloadPackage ($File->"package-name") $InstalledVersion \
|
||||||
($File->"package-architecture") $PackagePath ] = true) do={
|
($File->"package-architecture") $PackagePath ] = true) do={
|
||||||
:set Updated true;
|
:set Updated true;
|
||||||
/file/remove $Package;
|
$RmFile ($File->"name");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /file/find where type=package name~("^" . $PackagePath) ] ] = 0) do={
|
:if ([ :len [ /file/find where type="package" name~("^" . $PackagePath) ] ] = 0) do={
|
||||||
$LogPrintExit2 info $ScriptName ("No packages available, downloading default set.") false;
|
$LogPrint info $ScriptName ("No packages available, downloading default set.");
|
||||||
:foreach Arch in={ "arm"; "arm64" } do={
|
:foreach Arch in={ "arm"; "arm64" } do={
|
||||||
:local Packages { "arm"={ "routeros"; "wifi-qcom"; "wifi-qcom-ac" };
|
:local Packages { "arm"={ "routeros"; "wifi-qcom"; "wifi-qcom-ac" };
|
||||||
"arm64"={ "routeros"; "wifi-qcom" } };
|
"arm64"={ "routeros"; "wifi-qcom" } };
|
||||||
|
|
@ -73,13 +81,15 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ($Updated = true) do={
|
:if ($Updated = true) do={
|
||||||
:local Script ([ /system/script/find where source~"\n# provides: capsman-rolling-upgrade\n" ]->0);
|
:local Scripts [ /system/script/find where source~"\n# provides: capsman-rolling-upgrade.wifi\r?\n" ];
|
||||||
:if ([ :len $Script ] > 0) do={
|
:if ([ :len $Scripts ] > 0) do={
|
||||||
/system/script/run $Script;
|
:foreach Script in=$Scripts do={
|
||||||
|
/system/script/run $Script;
|
||||||
|
}
|
||||||
} else={
|
} else={
|
||||||
/interface/wifi/capsman/remote-cap/upgrade [ find where version!=$InstalledVersion ];
|
/interface/wifi/capsman/remote-cap/upgrade [ find where version!=$InstalledVersion ];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,28 +1,30 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: capsman-rolling-upgrade.capsman
|
# RouterOS script: capsman-rolling-upgrade.capsman
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: capsman-rolling-upgrade
|
# provides: capsman-rolling-upgrade.capsman
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# upgrade CAPs one after another
|
# upgrade CAPs one after another
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/capsman-rolling-upgrade.md
|
# https://rsc.eworm.de/doc/capsman-rolling-upgrade.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Main do={
|
:global LogPrint;
|
||||||
:local ScriptName [ :tostr $1 ];
|
|
||||||
|
|
||||||
:global LogPrintExit2;
|
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:local InstalledVersion [ /system/package/update/get installed-version ];
|
:local InstalledVersion [ /system/package/update/get installed-version ];
|
||||||
|
|
@ -34,15 +36,15 @@
|
||||||
:foreach RemoteCap in=[ /caps-man/remote-cap/find where version!=$InstalledVersion ] do={
|
:foreach RemoteCap in=[ /caps-man/remote-cap/find where version!=$InstalledVersion ] do={
|
||||||
:local RemoteCapVal [ /caps-man/remote-cap/get $RemoteCap ];
|
:local RemoteCapVal [ /caps-man/remote-cap/get $RemoteCap ];
|
||||||
:if ([ :len $RemoteCapVal ] > 1) do={
|
:if ([ :len $RemoteCapVal ] > 1) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Starting upgrade for " . $RemoteCapVal->"name" . \
|
$LogPrint info $ScriptName ("Starting upgrade for " . $RemoteCapVal->"name" . \
|
||||||
" (" . $RemoteCapVal->"identity" . ")...") false;
|
" (" . $RemoteCapVal->"identity" . ")...");
|
||||||
/caps-man/remote-cap/upgrade $RemoteCap;
|
/caps-man/remote-cap/upgrade $RemoteCap;
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 warning $ScriptName ("Remote CAP vanished, skipping upgrade.") false;
|
$LogPrint warning $ScriptName ("Remote CAP vanished, skipping upgrade.");
|
||||||
}
|
}
|
||||||
:delay ($Delay . "s");
|
:delay ($Delay . "s");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,29 +1,31 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: capsman-rolling-upgrade%TEMPL%
|
# RouterOS script: capsman-rolling-upgrade%TEMPL%
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: capsman-rolling-upgrade
|
# provides: capsman-rolling-upgrade%TEMPL%
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# upgrade CAPs one after another
|
# upgrade CAPs one after another
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/capsman-rolling-upgrade.md
|
# https://rsc.eworm.de/doc/capsman-rolling-upgrade.md
|
||||||
#
|
#
|
||||||
# !! This is just a template to generate the real script!
|
# !! This is just a template to generate the real script!
|
||||||
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Main do={
|
:global LogPrint;
|
||||||
:local ScriptName [ :tostr $1 ];
|
|
||||||
|
|
||||||
:global LogPrintExit2;
|
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:local InstalledVersion [ /system/package/update/get installed-version ];
|
:local InstalledVersion [ /system/package/update/get installed-version ];
|
||||||
|
|
@ -41,16 +43,16 @@
|
||||||
# NOT /caps-man/ #
|
# NOT /caps-man/ #
|
||||||
:set ($RemoteCapVal->"name") ($RemoteCapVal->"common-name");
|
:set ($RemoteCapVal->"name") ($RemoteCapVal->"common-name");
|
||||||
# NOT /caps-man/ #
|
# NOT /caps-man/ #
|
||||||
$LogPrintExit2 info $ScriptName ("Starting upgrade for " . $RemoteCapVal->"name" . \
|
$LogPrint info $ScriptName ("Starting upgrade for " . $RemoteCapVal->"name" . \
|
||||||
" (" . $RemoteCapVal->"identity" . ")...") false;
|
" (" . $RemoteCapVal->"identity" . ")...");
|
||||||
/caps-man/remote-cap/upgrade $RemoteCap;
|
/caps-man/remote-cap/upgrade $RemoteCap;
|
||||||
/interface/wifi/capsman/remote-cap/upgrade $RemoteCap;
|
/interface/wifi/capsman/remote-cap/upgrade $RemoteCap;
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 warning $ScriptName ("Remote CAP vanished, skipping upgrade.") false;
|
$LogPrint warning $ScriptName ("Remote CAP vanished, skipping upgrade.");
|
||||||
}
|
}
|
||||||
:delay ($Delay . "s");
|
:delay ($Delay . "s");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,28 +1,30 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: capsman-rolling-upgrade.wifi
|
# RouterOS script: capsman-rolling-upgrade.wifi
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: capsman-rolling-upgrade
|
# provides: capsman-rolling-upgrade.wifi
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# upgrade CAPs one after another
|
# upgrade CAPs one after another
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/capsman-rolling-upgrade.md
|
# https://rsc.eworm.de/doc/capsman-rolling-upgrade.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Main do={
|
:global LogPrint;
|
||||||
:local ScriptName [ :tostr $1 ];
|
|
||||||
|
|
||||||
:global LogPrintExit2;
|
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:local InstalledVersion [ /system/package/update/get installed-version ];
|
:local InstalledVersion [ /system/package/update/get installed-version ];
|
||||||
|
|
@ -35,15 +37,15 @@
|
||||||
:local RemoteCapVal [ /interface/wifi/capsman/remote-cap/get $RemoteCap ];
|
:local RemoteCapVal [ /interface/wifi/capsman/remote-cap/get $RemoteCap ];
|
||||||
:if ([ :len $RemoteCapVal ] > 1) do={
|
:if ([ :len $RemoteCapVal ] > 1) do={
|
||||||
:set ($RemoteCapVal->"name") ($RemoteCapVal->"common-name");
|
:set ($RemoteCapVal->"name") ($RemoteCapVal->"common-name");
|
||||||
$LogPrintExit2 info $ScriptName ("Starting upgrade for " . $RemoteCapVal->"name" . \
|
$LogPrint info $ScriptName ("Starting upgrade for " . $RemoteCapVal->"name" . \
|
||||||
" (" . $RemoteCapVal->"identity" . ")...") false;
|
" (" . $RemoteCapVal->"identity" . ")...");
|
||||||
/interface/wifi/capsman/remote-cap/upgrade $RemoteCap;
|
/interface/wifi/capsman/remote-cap/upgrade $RemoteCap;
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 warning $ScriptName ("Remote CAP vanished, skipping upgrade.") false;
|
$LogPrint warning $ScriptName ("Remote CAP vanished, skipping upgrade.");
|
||||||
}
|
}
|
||||||
:delay ($Delay . "s");
|
:delay ($Delay . "s");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,27 +1,29 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: certificate-renew-issued
|
# RouterOS script: certificate-renew-issued
|
||||||
# Copyright (c) 2019-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2019-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# renew locally issued certificates
|
# renew locally issued certificates
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/certificate-renew-issued.md
|
# https://rsc.eworm.de/doc/certificate-renew-issued.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global CertIssuedExportPass;
|
:global CertIssuedExportPass;
|
||||||
|
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global MkDir;
|
:global MkDir;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Cert in=[ /certificate/find where issued expires-after<3w ] do={
|
:foreach Cert in=[ /certificate/find where issued expires-after<3w ] do={
|
||||||
|
|
@ -36,15 +38,15 @@
|
||||||
/certificate/export-certificate ($CertVal->"name") type=pkcs12 \
|
/certificate/export-certificate ($CertVal->"name") type=pkcs12 \
|
||||||
file-name=("cert-issued/" . $CertVal->"common-name") \
|
file-name=("cert-issued/" . $CertVal->"common-name") \
|
||||||
export-passphrase=($CertIssuedExportPass->($CertVal->"common-name"));
|
export-passphrase=($CertIssuedExportPass->($CertVal->"common-name"));
|
||||||
$LogPrintExit2 info $ScriptName ("Issued a new certificate for \"" . $CertVal->"common-name" . \
|
$LogPrint info $ScriptName ("Issued a new certificate for '" . $CertVal->"common-name" . \
|
||||||
"\", exported to \"cert-issued/" . $CertVal->"common-name" . ".p12\".") false;
|
"', exported to 'cert-issued/" . $CertVal->"common-name" . ".p12'.");
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 warning $ScriptName ("Failed creating directory, not exporting certificate.") false;
|
$LogPrint warning $ScriptName ("Failed creating directory, not exporting certificate.");
|
||||||
}
|
}
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 info $ScriptName ("Issued a new certificate for \"" . $CertVal->"common-name" . "\".") false;
|
$LogPrint info $ScriptName ("Issued a new certificate for '" . $CertVal->"common-name" . "'.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
29
certs/Certum-Trusted-Network-CA.pem
Normal file
|
|
@ -0,0 +1,29 @@
|
||||||
|
# Issuer: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority
|
||||||
|
# Subject: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority
|
||||||
|
# Label: "Certum Trusted Network CA"
|
||||||
|
# Serial: 279744
|
||||||
|
# MD5 Fingerprint: d5:e9:81:40:c5:18:69:fc:46:2c:89:75:62:0f:aa:78
|
||||||
|
# SHA1 Fingerprint: 07:e0:32:e0:20:b7:2c:3f:19:2f:06:28:a2:59:3a:19:a7:0f:06:9e
|
||||||
|
# SHA256 Fingerprint: 5c:58:46:8d:55:f5:8e:49:7e:74:39:82:d2:b5:00:10:b6:d1:65:37:4a:cf:83:a7:d4:a3:2d:b7:68:c4:40:8e
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIIDuzCCAqOgAwIBAgIDBETAMA0GCSqGSIb3DQEBBQUAMH4xCzAJBgNVBAYTAlBM
|
||||||
|
MSIwIAYDVQQKExlVbml6ZXRvIFRlY2hub2xvZ2llcyBTLkEuMScwJQYDVQQLEx5D
|
||||||
|
ZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxIjAgBgNVBAMTGUNlcnR1bSBU
|
||||||
|
cnVzdGVkIE5ldHdvcmsgQ0EwHhcNMDgxMDIyMTIwNzM3WhcNMjkxMjMxMTIwNzM3
|
||||||
|
WjB+MQswCQYDVQQGEwJQTDEiMCAGA1UEChMZVW5pemV0byBUZWNobm9sb2dpZXMg
|
||||||
|
Uy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MSIw
|
||||||
|
IAYDVQQDExlDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENBMIIBIjANBgkqhkiG9w0B
|
||||||
|
AQEFAAOCAQ8AMIIBCgKCAQEA4/t9o3K6wvDJFIf1awFO4W5AB7ptJ11/91sts1rH
|
||||||
|
UV+rpDKmYYe2bg+G0jACl/jXaVehGDldamR5xgFZrDwxSjh80gTSSyjoIF87B6LM
|
||||||
|
TXPb865Px1bVWqeWifrzq2jUI4ZZJ88JJ7ysbnKDHDBy3+Ci6dLhdHUZvSqeexVU
|
||||||
|
BBvXQzmtVSjF4hq79MDkrjhJM8x2hZ85RdKknvISjFH4fOQtf/WsX+sWn7Et0brM
|
||||||
|
kUJ3TCXJkDhv2/DM+44el1k+1WBO5gUo7Ul5E0u6SNsv+XLTOcr+H9g0cvW0QM8x
|
||||||
|
AcPs3hEtF10fuFDRXhmnad4HMyjKUJX5p1TLVIZQRan5SQIDAQABo0IwQDAPBgNV
|
||||||
|
HRMBAf8EBTADAQH/MB0GA1UdDgQWBBQIds3LB/8k9sXN7buQvOKEN0Z19zAOBgNV
|
||||||
|
HQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQEFBQADggEBAKaorSLOAT2mo/9i0Eidi15y
|
||||||
|
sHhE49wcrwn9I0j6vSrEuVUEtRCjjSfeC4Jj0O7eDDd5QVsisrCaQVymcODU0HfL
|
||||||
|
I9MA4GxWL+FpDQ3Zqr8hgVDZBqWo/5U30Kr+4rP1mS1FhIrlQgnXdAIv94nYmem8
|
||||||
|
J9RHjboNRhx3zxSkHLmkMcScKHQDNP8zGSal6Q10tz6XxnboJ5ajZt3hrvJBW8qY
|
||||||
|
VoNzcOSGGtIxQbovvi0TWnZvTuhOgQ4/WwMioBK+ZlgRSssDxLQqKi2WF+A5VLxI
|
||||||
|
03YnnZotBqbJ7DnSq9ufmgsnAjUpsUCV5/nonFWIGUbWtzT1fs45mtk48VH3Tyw=
|
||||||
|
-----END CERTIFICATE-----
|
||||||
|
|
@ -1,163 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
0a:37:87:64:5e:5f:b4:8c:22:4e:fd:1b:ed:14:0c:3c
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C = IE, O = Baltimore, OU = CyberTrust, CN = Baltimore CyberTrust Root
|
|
||||||
Validity
|
|
||||||
Not Before: Jan 27 12:48:08 2020 GMT
|
|
||||||
Not After : Dec 31 23:59:59 2024 GMT
|
|
||||||
Subject: C = US, O = "Cloudflare, Inc.", CN = Cloudflare Inc ECC CA-3
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: id-ecPublicKey
|
|
||||||
Public-Key: (256 bit)
|
|
||||||
pub:
|
|
||||||
04:b9:ad:4d:66:99:14:0b:46:ec:1f:81:d1:2a:50:
|
|
||||||
1e:9d:03:15:2f:34:12:7d:2d:96:b8:88:38:9b:85:
|
|
||||||
5f:8f:bf:bb:4d:ef:61:46:c4:c9:73:d4:24:4f:e0:
|
|
||||||
ee:1c:ce:6c:b3:51:71:2f:6a:ee:4c:05:09:77:d3:
|
|
||||||
72:62:a4:9b:d7
|
|
||||||
ASN1 OID: prime256v1
|
|
||||||
NIST CURVE: P-256
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
A5:CE:37:EA:EB:B0:75:0E:94:67:88:B4:45:FA:D9:24:10:87:96:1F
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
E5:9D:59:30:82:47:58:CC:AC:FA:08:54:36:86:7B:3A:B5:04:4D:F0
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Extended Key Usage:
|
|
||||||
TLS Web Server Authentication, TLS Web Client Authentication
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:0
|
|
||||||
Authority Information Access:
|
|
||||||
OCSP - URI:http://ocsp.digicert.com
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
Full Name:
|
|
||||||
URI:http://crl3.digicert.com/Omniroot2025.crl
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: 2.16.840.1.114412.1.1
|
|
||||||
CPS: https://www.digicert.com/CPS
|
|
||||||
Policy: 2.16.840.1.114412.1.2
|
|
||||||
Policy: 2.23.140.1.2.1
|
|
||||||
Policy: 2.23.140.1.2.2
|
|
||||||
Policy: 2.23.140.1.2.3
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Signature Value:
|
|
||||||
05:24:1d:dd:1b:b0:2a:eb:98:d6:85:e3:39:4d:5e:6b:57:9d:
|
|
||||||
82:57:fc:eb:e8:31:a2:57:90:65:05:be:16:44:38:5a:77:02:
|
|
||||||
b9:cf:10:42:c6:e1:92:a4:e3:45:27:f8:00:47:2c:68:a8:56:
|
|
||||||
99:53:54:8f:ad:9e:40:c1:d0:0f:b6:d7:0d:0b:38:48:6c:50:
|
|
||||||
2c:49:90:06:5b:64:1d:8b:cc:48:30:2e:de:08:e2:9b:49:22:
|
|
||||||
c0:92:0c:11:5e:96:92:94:d5:fc:20:dc:56:6c:e5:92:93:bf:
|
|
||||||
7a:1c:c0:37:e3:85:49:15:fa:2b:e1:74:39:18:0f:b7:da:f3:
|
|
||||||
a2:57:58:60:4f:cc:8e:94:00:fc:46:7b:34:31:3e:4d:47:82:
|
|
||||||
81:3a:cb:f4:89:5d:0e:ef:4d:0d:6e:9c:1b:82:24:dd:32:25:
|
|
||||||
5d:11:78:51:10:3d:a0:35:23:04:2f:65:6f:9c:c1:d1:43:d7:
|
|
||||||
d0:1e:f3:31:67:59:27:dd:6b:d2:75:09:93:11:24:24:14:cf:
|
|
||||||
29:be:e6:23:c3:b8:8f:72:3f:e9:07:c8:24:44:53:7a:b3:b9:
|
|
||||||
61:65:a1:4c:0e:c6:48:00:c9:75:63:05:87:70:45:52:83:d3:
|
|
||||||
95:9d:45:ea:f0:e8:31:1d:7e:09:1f:0a:fe:3e:dd:aa:3c:5e:
|
|
||||||
74:d2:ac:b1
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIDzTCCArWgAwIBAgIQCjeHZF5ftIwiTv0b7RQMPDANBgkqhkiG9w0BAQsFADBa
|
|
||||||
MQswCQYDVQQGEwJJRTESMBAGA1UEChMJQmFsdGltb3JlMRMwEQYDVQQLEwpDeWJl
|
|
||||||
clRydXN0MSIwIAYDVQQDExlCYWx0aW1vcmUgQ3liZXJUcnVzdCBSb290MB4XDTIw
|
|
||||||
MDEyNzEyNDgwOFoXDTI0MTIzMTIzNTk1OVowSjELMAkGA1UEBhMCVVMxGTAXBgNV
|
|
||||||
BAoTEENsb3VkZmxhcmUsIEluYy4xIDAeBgNVBAMTF0Nsb3VkZmxhcmUgSW5jIEVD
|
|
||||||
QyBDQS0zMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEua1NZpkUC0bsH4HRKlAe
|
|
||||||
nQMVLzQSfS2WuIg4m4Vfj7+7Te9hRsTJc9QkT+DuHM5ss1FxL2ruTAUJd9NyYqSb
|
|
||||||
16OCAWgwggFkMB0GA1UdDgQWBBSlzjfq67B1DpRniLRF+tkkEIeWHzAfBgNVHSME
|
|
||||||
GDAWgBTlnVkwgkdYzKz6CFQ2hns6tQRN8DAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0l
|
|
||||||
BBYwFAYIKwYBBQUHAwEGCCsGAQUFBwMCMBIGA1UdEwEB/wQIMAYBAf8CAQAwNAYI
|
|
||||||
KwYBBQUHAQEEKDAmMCQGCCsGAQUFBzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5j
|
|
||||||
b20wOgYDVR0fBDMwMTAvoC2gK4YpaHR0cDovL2NybDMuZGlnaWNlcnQuY29tL09t
|
|
||||||
bmlyb290MjAyNS5jcmwwbQYDVR0gBGYwZDA3BglghkgBhv1sAQEwKjAoBggrBgEF
|
|
||||||
BQcCARYcaHR0cHM6Ly93d3cuZGlnaWNlcnQuY29tL0NQUzALBglghkgBhv1sAQIw
|
|
||||||
CAYGZ4EMAQIBMAgGBmeBDAECAjAIBgZngQwBAgMwDQYJKoZIhvcNAQELBQADggEB
|
|
||||||
AAUkHd0bsCrrmNaF4zlNXmtXnYJX/OvoMaJXkGUFvhZEOFp3ArnPEELG4ZKk40Un
|
|
||||||
+ABHLGioVplTVI+tnkDB0A+21w0LOEhsUCxJkAZbZB2LzEgwLt4I4ptJIsCSDBFe
|
|
||||||
lpKU1fwg3FZs5ZKTv3ocwDfjhUkV+ivhdDkYD7fa86JXWGBPzI6UAPxGezQxPk1H
|
|
||||||
goE6y/SJXQ7vTQ1unBuCJN0yJV0ReFEQPaA1IwQvZW+cwdFD19Ae8zFnWSfda9J1
|
|
||||||
CZMRJCQUzym+5iPDuI9yP+kHyCREU3qzuWFloUwOxkgAyXVjBYdwRVKD05WdRerw
|
|
||||||
6DEdfgkfCv4+3ao8XnTSrLE=
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number: 33554617 (0x20000b9)
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
Issuer: C = IE, O = Baltimore, OU = CyberTrust, CN = Baltimore CyberTrust Root
|
|
||||||
Validity
|
|
||||||
Not Before: May 12 18:46:00 2000 GMT
|
|
||||||
Not After : May 12 23:59:00 2025 GMT
|
|
||||||
Subject: C = IE, O = Baltimore, OU = CyberTrust, CN = Baltimore CyberTrust Root
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:a3:04:bb:22:ab:98:3d:57:e8:26:72:9a:b5:79:
|
|
||||||
d4:29:e2:e1:e8:95:80:b1:b0:e3:5b:8e:2b:29:9a:
|
|
||||||
64:df:a1:5d:ed:b0:09:05:6d:db:28:2e:ce:62:a2:
|
|
||||||
62:fe:b4:88:da:12:eb:38:eb:21:9d:c0:41:2b:01:
|
|
||||||
52:7b:88:77:d3:1c:8f:c7:ba:b9:88:b5:6a:09:e7:
|
|
||||||
73:e8:11:40:a7:d1:cc:ca:62:8d:2d:e5:8f:0b:a6:
|
|
||||||
50:d2:a8:50:c3:28:ea:f5:ab:25:87:8a:9a:96:1c:
|
|
||||||
a9:67:b8:3f:0c:d5:f7:f9:52:13:2f:c2:1b:d5:70:
|
|
||||||
70:f0:8f:c0:12:ca:06:cb:9a:e1:d9:ca:33:7a:77:
|
|
||||||
d6:f8:ec:b9:f1:68:44:42:48:13:d2:c0:c2:a4:ae:
|
|
||||||
5e:60:fe:b6:a6:05:fc:b4:dd:07:59:02:d4:59:18:
|
|
||||||
98:63:f5:a5:63:e0:90:0c:7d:5d:b2:06:7a:f3:85:
|
|
||||||
ea:eb:d4:03:ae:5e:84:3e:5f:ff:15:ed:69:bc:f9:
|
|
||||||
39:36:72:75:cf:77:52:4d:f3:c9:90:2c:b9:3d:e5:
|
|
||||||
c9:23:53:3f:1f:24:98:21:5c:07:99:29:bd:c6:3a:
|
|
||||||
ec:e7:6e:86:3a:6b:97:74:63:33:bd:68:18:31:f0:
|
|
||||||
78:8d:76:bf:fc:9e:8e:5d:2a:86:a7:4d:90:dc:27:
|
|
||||||
1a:39
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
E5:9D:59:30:82:47:58:CC:AC:FA:08:54:36:86:7B:3A:B5:04:4D:F0
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:3
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
Signature Value:
|
|
||||||
85:0c:5d:8e:e4:6f:51:68:42:05:a0:dd:bb:4f:27:25:84:03:
|
|
||||||
bd:f7:64:fd:2d:d7:30:e3:a4:10:17:eb:da:29:29:b6:79:3f:
|
|
||||||
76:f6:19:13:23:b8:10:0a:f9:58:a4:d4:61:70:bd:04:61:6a:
|
|
||||||
12:8a:17:d5:0a:bd:c5:bc:30:7c:d6:e9:0c:25:8d:86:40:4f:
|
|
||||||
ec:cc:a3:7e:38:c6:37:11:4f:ed:dd:68:31:8e:4c:d2:b3:01:
|
|
||||||
74:ee:be:75:5e:07:48:1a:7f:70:ff:16:5c:84:c0:79:85:b8:
|
|
||||||
05:fd:7f:be:65:11:a3:0f:c0:02:b4:f8:52:37:39:04:d5:a9:
|
|
||||||
31:7a:18:bf:a0:2a:f4:12:99:f7:a3:45:82:e3:3c:5e:f5:9d:
|
|
||||||
9e:b5:c8:9e:7c:2e:c8:a4:9e:4e:08:14:4b:6d:fd:70:6d:6b:
|
|
||||||
1a:63:bd:64:e6:1f:b7:ce:f0:f2:9f:2e:bb:1b:b7:f2:50:88:
|
|
||||||
73:92:c2:e2:e3:16:8d:9a:32:02:ab:8e:18:dd:e9:10:11:ee:
|
|
||||||
7e:35:ab:90:af:3e:30:94:7a:d0:33:3d:a7:65:0f:f5:fc:8e:
|
|
||||||
9e:62:cf:47:44:2c:01:5d:bb:1d:b5:32:d2:47:d2:38:2e:d0:
|
|
||||||
fe:81:dc:32:6a:1e:b5:ee:3c:d5:fc:e7:81:1d:19:c3:24:42:
|
|
||||||
ea:63:39:a9
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIDdzCCAl+gAwIBAgIEAgAAuTANBgkqhkiG9w0BAQUFADBaMQswCQYDVQQGEwJJ
|
|
||||||
RTESMBAGA1UEChMJQmFsdGltb3JlMRMwEQYDVQQLEwpDeWJlclRydXN0MSIwIAYD
|
|
||||||
VQQDExlCYWx0aW1vcmUgQ3liZXJUcnVzdCBSb290MB4XDTAwMDUxMjE4NDYwMFoX
|
|
||||||
DTI1MDUxMjIzNTkwMFowWjELMAkGA1UEBhMCSUUxEjAQBgNVBAoTCUJhbHRpbW9y
|
|
||||||
ZTETMBEGA1UECxMKQ3liZXJUcnVzdDEiMCAGA1UEAxMZQmFsdGltb3JlIEN5YmVy
|
|
||||||
VHJ1c3QgUm9vdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKMEuyKr
|
|
||||||
mD1X6CZymrV51Cni4eiVgLGw41uOKymaZN+hXe2wCQVt2yguzmKiYv60iNoS6zjr
|
|
||||||
IZ3AQSsBUnuId9Mcj8e6uYi1agnnc+gRQKfRzMpijS3ljwumUNKoUMMo6vWrJYeK
|
|
||||||
mpYcqWe4PwzV9/lSEy/CG9VwcPCPwBLKBsua4dnKM3p31vjsufFoREJIE9LAwqSu
|
|
||||||
XmD+tqYF/LTdB1kC1FkYmGP1pWPgkAx9XbIGevOF6uvUA65ehD5f/xXtabz5OTZy
|
|
||||||
dc93Uk3zyZAsuT3lySNTPx8kmCFcB5kpvcY67Oduhjprl3RjM71oGDHweI12v/ye
|
|
||||||
jl0qhqdNkNwnGjkCAwEAAaNFMEMwHQYDVR0OBBYEFOWdWTCCR1jMrPoIVDaGezq1
|
|
||||||
BE3wMBIGA1UdEwEB/wQIMAYBAf8CAQMwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3
|
|
||||||
DQEBBQUAA4IBAQCFDF2O5G9RaEIFoN27TyclhAO992T9Ldcw46QQF+vaKSm2eT92
|
|
||||||
9hkTI7gQCvlYpNRhcL0EYWoSihfVCr3FvDB81ukMJY2GQE/szKN+OMY3EU/t3Wgx
|
|
||||||
jkzSswF07r51XgdIGn9w/xZchMB5hbgF/X++ZRGjD8ACtPhSNzkE1akxehi/oCr0
|
|
||||||
Epn3o0WC4zxe9Z2etciefC7IpJ5OCBRLbf1wbWsaY71k5h+3zvDyny67G7fyUIhz
|
|
||||||
ksLi4xaNmjICq44Y3ekQEe5+NauQrz4wlHrQMz2nZQ/1/I6eYs9HRCwBXbsdtTLS
|
|
||||||
R9I4LtD+gdwyah617jzV/OeBHRnDJELqYzmp
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
|
|
@ -1,182 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
0c:f5:bd:06:2b:56:02:f4:7a:b8:50:2c:23:cc:f0:66
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C=US, O=DigiCert Inc, OU=www.digicert.com, CN=DigiCert Global Root G2
|
|
||||||
Validity
|
|
||||||
Not Before: Mar 30 00:00:00 2021 GMT
|
|
||||||
Not After : Mar 29 23:59:59 2031 GMT
|
|
||||||
Subject: C=US, O=DigiCert Inc, CN=DigiCert Global G2 TLS RSA SHA256 2020 CA1
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:cc:f7:10:62:4f:a6:bb:63:6f:ed:90:52:56:c5:
|
|
||||||
6d:27:7b:7a:12:56:8a:f1:f4:f9:d6:e7:e1:8f:bd:
|
|
||||||
95:ab:f2:60:41:15:70:db:12:00:fa:27:0a:b5:57:
|
|
||||||
38:5b:7d:b2:51:93:71:95:0e:6a:41:94:5b:35:1b:
|
|
||||||
fa:7b:fa:bb:c5:be:24:30:fe:56:ef:c4:f3:7d:97:
|
|
||||||
e3:14:f5:14:4d:cb:a7:10:f2:16:ea:ab:22:f0:31:
|
|
||||||
22:11:61:69:90:26:ba:78:d9:97:1f:e3:7d:66:ab:
|
|
||||||
75:44:95:73:c8:ac:ff:ef:5d:0a:8a:59:43:e1:ac:
|
|
||||||
b2:3a:0f:f3:48:fc:d7:6b:37:c1:63:dc:de:46:d6:
|
|
||||||
db:45:fe:7d:23:fd:90:e8:51:07:1e:51:a3:5f:ed:
|
|
||||||
49:46:54:7f:2c:88:c5:f4:13:9c:97:15:3c:03:e8:
|
|
||||||
a1:39:dc:69:0c:32:c1:af:16:57:4c:94:47:42:7c:
|
|
||||||
a2:c8:9c:7d:e6:d4:4d:54:af:42:99:a8:c1:04:c2:
|
|
||||||
77:9c:d6:48:e4:ce:11:e0:2a:80:99:f0:43:70:cf:
|
|
||||||
3f:76:6b:d1:4c:49:ab:24:5e:c2:0d:82:fd:46:a8:
|
|
||||||
ab:6c:93:cc:62:52:42:75:92:f8:9a:fa:5e:5e:b2:
|
|
||||||
b0:61:e5:1f:1f:b9:7f:09:98:e8:3d:fa:83:7f:47:
|
|
||||||
69:a1
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:0
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
74:85:80:C0:66:C7:DF:37:DE:CF:BD:29:37:AA:03:1D:BE:ED:CD:17
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
4E:22:54:20:18:95:E6:E3:6E:E6:0F:FA:FA:B9:12:ED:06:17:8F:39
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Extended Key Usage:
|
|
||||||
TLS Web Server Authentication, TLS Web Client Authentication
|
|
||||||
Authority Information Access:
|
|
||||||
OCSP - URI:http://ocsp.digicert.com
|
|
||||||
CA Issuers - URI:http://cacerts.digicert.com/DigiCertGlobalRootG2.crt
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
Full Name:
|
|
||||||
URI:http://crl3.digicert.com/DigiCertGlobalRootG2.crl
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: 2.16.840.1.114412.2.1
|
|
||||||
Policy: 2.23.140.1.1
|
|
||||||
Policy: 2.23.140.1.2.1
|
|
||||||
Policy: 2.23.140.1.2.2
|
|
||||||
Policy: 2.23.140.1.2.3
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Signature Value:
|
|
||||||
90:f1:70:cb:28:97:69:97:7c:74:fd:c0:fa:26:7b:53:ab:ad:
|
|
||||||
cd:65:fd:ba:9c:06:9c:8a:d7:5a:43:87:ed:4d:4c:56:5f:ad:
|
|
||||||
c1:c5:b5:05:20:2e:59:d1:ff:4a:f5:a0:2a:d8:b0:95:ad:c9:
|
|
||||||
2e:4a:3b:d7:a7:f6:6f:88:29:fc:30:3f:24:84:bb:c3:b7:7b:
|
|
||||||
93:07:2c:af:87:6b:76:33:ed:00:55:52:b2:59:9e:e4:b9:d0:
|
|
||||||
f3:df:e7:0f:fe:dd:f8:c4:b9:10:72:81:09:04:5f:cf:97:9e:
|
|
||||||
2e:32:75:8e:cf:9a:58:d2:57:31:7e:37:01:81:b2:66:6d:29:
|
|
||||||
1a:b1:66:09:6d:d1:6e:90:f4:b9:fa:2f:01:14:c5:5c:56:64:
|
|
||||||
01:d9:7d:87:a8:38:53:9f:8b:5d:46:6d:5c:c6:27:84:81:d4:
|
|
||||||
7e:8c:8c:a3:9b:52:e7:c6:88:ec:37:7c:2a:fb:f0:55:5a:38:
|
|
||||||
72:10:d8:00:13:cf:4c:73:db:aa:37:35:a8:29:81:69:9c:76:
|
|
||||||
bc:de:18:7b:90:d4:ca:cf:ef:67:03:fd:04:5a:21:16:b1:ff:
|
|
||||||
ea:3f:df:dc:82:f5:eb:f4:59:92:23:0d:24:2a:95:25:4c:ca:
|
|
||||||
a1:91:e6:d4:b7:ac:87:74:b3:f1:6d:a3:99:db:f9:d5:bd:84:
|
|
||||||
40:9f:07:98
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIEyDCCA7CgAwIBAgIQDPW9BitWAvR6uFAsI8zwZjANBgkqhkiG9w0BAQsFADBh
|
|
||||||
MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
|
|
||||||
d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBH
|
|
||||||
MjAeFw0yMTAzMzAwMDAwMDBaFw0zMTAzMjkyMzU5NTlaMFkxCzAJBgNVBAYTAlVT
|
|
||||||
MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxMzAxBgNVBAMTKkRpZ2lDZXJ0IEdsb2Jh
|
|
||||||
bCBHMiBUTFMgUlNBIFNIQTI1NiAyMDIwIENBMTCCASIwDQYJKoZIhvcNAQEBBQAD
|
|
||||||
ggEPADCCAQoCggEBAMz3EGJPprtjb+2QUlbFbSd7ehJWivH0+dbn4Y+9lavyYEEV
|
|
||||||
cNsSAPonCrVXOFt9slGTcZUOakGUWzUb+nv6u8W+JDD+Vu/E832X4xT1FE3LpxDy
|
|
||||||
FuqrIvAxIhFhaZAmunjZlx/jfWardUSVc8is/+9dCopZQ+GssjoP80j812s3wWPc
|
|
||||||
3kbW20X+fSP9kOhRBx5Ro1/tSUZUfyyIxfQTnJcVPAPooTncaQwywa8WV0yUR0J8
|
|
||||||
osicfebUTVSvQpmowQTCd5zWSOTOEeAqgJnwQ3DPP3Zr0UxJqyRewg2C/Uaoq2yT
|
|
||||||
zGJSQnWS+Jr6Xl6ysGHlHx+5fwmY6D36g39HaaECAwEAAaOCAYIwggF+MBIGA1Ud
|
|
||||||
EwEB/wQIMAYBAf8CAQAwHQYDVR0OBBYEFHSFgMBmx9833s+9KTeqAx2+7c0XMB8G
|
|
||||||
A1UdIwQYMBaAFE4iVCAYlebjbuYP+vq5Eu0GF485MA4GA1UdDwEB/wQEAwIBhjAd
|
|
||||||
BgNVHSUEFjAUBggrBgEFBQcDAQYIKwYBBQUHAwIwdgYIKwYBBQUHAQEEajBoMCQG
|
|
||||||
CCsGAQUFBzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5jb20wQAYIKwYBBQUHMAKG
|
|
||||||
NGh0dHA6Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydEdsb2JhbFJvb3RH
|
|
||||||
Mi5jcnQwQgYDVR0fBDswOTA3oDWgM4YxaHR0cDovL2NybDMuZGlnaWNlcnQuY29t
|
|
||||||
L0RpZ2lDZXJ0R2xvYmFsUm9vdEcyLmNybDA9BgNVHSAENjA0MAsGCWCGSAGG/WwC
|
|
||||||
ATAHBgVngQwBATAIBgZngQwBAgEwCAYGZ4EMAQICMAgGBmeBDAECAzANBgkqhkiG
|
|
||||||
9w0BAQsFAAOCAQEAkPFwyyiXaZd8dP3A+iZ7U6utzWX9upwGnIrXWkOH7U1MVl+t
|
|
||||||
wcW1BSAuWdH/SvWgKtiwla3JLko716f2b4gp/DA/JIS7w7d7kwcsr4drdjPtAFVS
|
|
||||||
slme5LnQ89/nD/7d+MS5EHKBCQRfz5eeLjJ1js+aWNJXMX43AYGyZm0pGrFmCW3R
|
|
||||||
bpD0ufovARTFXFZkAdl9h6g4U5+LXUZtXMYnhIHUfoyMo5tS58aI7Dd8KvvwVVo4
|
|
||||||
chDYABPPTHPbqjc1qCmBaZx2vN4Ye5DUys/vZwP9BFohFrH/6j/f3IL16/RZkiMN
|
|
||||||
JCqVJUzKoZHm1Lesh3Sz8W2jmdv51b2EQJ8HmA==
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
03:3a:f1:e6:a7:11:a9:a0:bb:28:64:b1:1d:09:fa:e5
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C=US, O=DigiCert Inc, OU=www.digicert.com, CN=DigiCert Global Root G2
|
|
||||||
Validity
|
|
||||||
Not Before: Aug 1 12:00:00 2013 GMT
|
|
||||||
Not After : Jan 15 12:00:00 2038 GMT
|
|
||||||
Subject: C=US, O=DigiCert Inc, OU=www.digicert.com, CN=DigiCert Global Root G2
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:bb:37:cd:34:dc:7b:6b:c9:b2:68:90:ad:4a:75:
|
|
||||||
ff:46:ba:21:0a:08:8d:f5:19:54:c9:fb:88:db:f3:
|
|
||||||
ae:f2:3a:89:91:3c:7a:e6:ab:06:1a:6b:cf:ac:2d:
|
|
||||||
e8:5e:09:24:44:ba:62:9a:7e:d6:a3:a8:7e:e0:54:
|
|
||||||
75:20:05:ac:50:b7:9c:63:1a:6c:30:dc:da:1f:19:
|
|
||||||
b1:d7:1e:de:fd:d7:e0:cb:94:83:37:ae:ec:1f:43:
|
|
||||||
4e:dd:7b:2c:d2:bd:2e:a5:2f:e4:a9:b8:ad:3a:d4:
|
|
||||||
99:a4:b6:25:e9:9b:6b:00:60:92:60:ff:4f:21:49:
|
|
||||||
18:f7:67:90:ab:61:06:9c:8f:f2:ba:e9:b4:e9:92:
|
|
||||||
32:6b:b5:f3:57:e8:5d:1b:cd:8c:1d:ab:95:04:95:
|
|
||||||
49:f3:35:2d:96:e3:49:6d:dd:77:e3:fb:49:4b:b4:
|
|
||||||
ac:55:07:a9:8f:95:b3:b4:23:bb:4c:6d:45:f0:f6:
|
|
||||||
a9:b2:95:30:b4:fd:4c:55:8c:27:4a:57:14:7c:82:
|
|
||||||
9d:cd:73:92:d3:16:4a:06:0c:8c:50:d1:8f:1e:09:
|
|
||||||
be:17:a1:e6:21:ca:fd:83:e5:10:bc:83:a5:0a:c4:
|
|
||||||
67:28:f6:73:14:14:3d:46:76:c3:87:14:89:21:34:
|
|
||||||
4d:af:0f:45:0c:a6:49:a1:ba:bb:9c:c5:b1:33:83:
|
|
||||||
29:85
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
4E:22:54:20:18:95:E6:E3:6E:E6:0F:FA:FA:B9:12:ED:06:17:8F:39
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Signature Value:
|
|
||||||
60:67:28:94:6f:0e:48:63:eb:31:dd:ea:67:18:d5:89:7d:3c:
|
|
||||||
c5:8b:4a:7f:e9:be:db:2b:17:df:b0:5f:73:77:2a:32:13:39:
|
|
||||||
81:67:42:84:23:f2:45:67:35:ec:88:bf:f8:8f:b0:61:0c:34:
|
|
||||||
a4:ae:20:4c:84:c6:db:f8:35:e1:76:d9:df:a6:42:bb:c7:44:
|
|
||||||
08:86:7f:36:74:24:5a:da:6c:0d:14:59:35:bd:f2:49:dd:b6:
|
|
||||||
1f:c9:b3:0d:47:2a:3d:99:2f:bb:5c:bb:b5:d4:20:e1:99:5f:
|
|
||||||
53:46:15:db:68:9b:f0:f3:30:d5:3e:31:e2:8d:84:9e:e3:8a:
|
|
||||||
da:da:96:3e:35:13:a5:5f:f0:f9:70:50:70:47:41:11:57:19:
|
|
||||||
4e:c0:8f:ae:06:c4:95:13:17:2f:1b:25:9f:75:f2:b1:8e:99:
|
|
||||||
a1:6f:13:b1:41:71:fe:88:2a:c8:4f:10:20:55:d7:f3:14:45:
|
|
||||||
e5:e0:44:f4:ea:87:95:32:93:0e:fe:53:46:fa:2c:9d:ff:8b:
|
|
||||||
22:b9:4b:d9:09:45:a4:de:a4:b8:9a:58:dd:1b:7d:52:9f:8e:
|
|
||||||
59:43:88:81:a4:9e:26:d5:6f:ad:dd:0d:c6:37:7d:ed:03:92:
|
|
||||||
1b:e5:77:5f:76:ee:3c:8d:c4:5d:56:5b:a2:d9:66:6e:b3:35:
|
|
||||||
37:e5:32:b6
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIDjjCCAnagAwIBAgIQAzrx5qcRqaC7KGSxHQn65TANBgkqhkiG9w0BAQsFADBh
|
|
||||||
MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
|
|
||||||
d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBH
|
|
||||||
MjAeFw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVT
|
|
||||||
MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j
|
|
||||||
b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEcyMIIBIjANBgkqhkiG
|
|
||||||
9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuzfNNNx7a8myaJCtSnX/RrohCgiN9RlUyfuI
|
|
||||||
2/Ou8jqJkTx65qsGGmvPrC3oXgkkRLpimn7Wo6h+4FR1IAWsULecYxpsMNzaHxmx
|
|
||||||
1x7e/dfgy5SDN67sH0NO3Xss0r0upS/kqbitOtSZpLYl6ZtrAGCSYP9PIUkY92eQ
|
|
||||||
q2EGnI/yuum06ZIya7XzV+hdG82MHauVBJVJ8zUtluNJbd134/tJS7SsVQepj5Wz
|
|
||||||
tCO7TG1F8PapspUwtP1MVYwnSlcUfIKdzXOS0xZKBgyMUNGPHgm+F6HmIcr9g+UQ
|
|
||||||
vIOlCsRnKPZzFBQ9RnbDhxSJITRNrw9FDKZJobq7nMWxM4MphQIDAQABo0IwQDAP
|
|
||||||
BgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUTiJUIBiV
|
|
||||||
5uNu5g/6+rkS7QYXjzkwDQYJKoZIhvcNAQELBQADggEBAGBnKJRvDkhj6zHd6mcY
|
|
||||||
1Yl9PMWLSn/pvtsrF9+wX3N3KjITOYFnQoQj8kVnNeyIv/iPsGEMNKSuIEyExtv4
|
|
||||||
NeF22d+mQrvHRAiGfzZ0JFrabA0UWTW98kndth/Jsw1HKj2ZL7tcu7XUIOGZX1NG
|
|
||||||
Fdtom/DzMNU+MeKNhJ7jitralj41E6Vf8PlwUHBHQRFXGU7Aj64GxJUTFy8bJZ91
|
|
||||||
8rGOmaFvE7FBcf6IKshPECBV1/MUReXgRPTqh5Uykw7+U0b6LJ3/iyK5S9kJRaTe
|
|
||||||
pLiaWN0bfVKfjllDiIGknibVb63dDcY3fe0Dkhvld1927jyNxF1WW6LZZm6zNTfl
|
|
||||||
MrY=
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
|
|
@ -1,174 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
07:f2:f3:5c:87:a8:77:af:7a:ef:e9:47:99:35:25:bd
|
|
||||||
Signature Algorithm: sha384WithRSAEncryption
|
|
||||||
Issuer: C = US, O = DigiCert Inc, OU = www.digicert.com, CN = DigiCert Global Root CA
|
|
||||||
Validity
|
|
||||||
Not Before: Apr 14 00:00:00 2021 GMT
|
|
||||||
Not After : Apr 13 23:59:59 2031 GMT
|
|
||||||
Subject: C = US, O = DigiCert Inc, CN = DigiCert TLS Hybrid ECC SHA384 2020 CA1
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: id-ecPublicKey
|
|
||||||
Public-Key: (384 bit)
|
|
||||||
pub:
|
|
||||||
04:c1:1b:c6:9a:5b:98:d9:a4:29:a0:e9:d4:04:b5:
|
|
||||||
db:eb:a6:b2:6c:55:c0:ff:ed:98:c6:49:2f:06:27:
|
|
||||||
51:cb:bf:70:c1:05:7a:c3:b1:9d:87:89:ba:ad:b4:
|
|
||||||
13:17:c9:a8:b4:83:c8:b8:90:d1:cc:74:35:36:3c:
|
|
||||||
83:72:b0:b5:d0:f7:22:69:c8:f1:80:c4:7b:40:8f:
|
|
||||||
cf:68:87:26:5c:39:89:f1:4d:91:4d:da:89:8b:e4:
|
|
||||||
03:c3:43:e5:bf:2f:73
|
|
||||||
ASN1 OID: secp384r1
|
|
||||||
NIST CURVE: P-384
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:0
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
0A:BC:08:29:17:8C:A5:39:6D:7A:0E:CE:33:C7:2E:B3:ED:FB:C3:7A
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:03:DE:50:35:56:D1:4C:BB:66:F0:A3:E2:1B:1B:C3:97:B2:3D:D1:55
|
|
||||||
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Extended Key Usage:
|
|
||||||
TLS Web Server Authentication, TLS Web Client Authentication
|
|
||||||
Authority Information Access:
|
|
||||||
OCSP - URI:http://ocsp.digicert.com
|
|
||||||
CA Issuers - URI:http://cacerts.digicert.com/DigiCertGlobalRootCA.crt
|
|
||||||
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
|
|
||||||
Full Name:
|
|
||||||
URI:http://crl3.digicert.com/DigiCertGlobalRootCA.crl
|
|
||||||
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: 2.16.840.1.114412.2.1
|
|
||||||
Policy: 2.23.140.1.1
|
|
||||||
Policy: 2.23.140.1.2.1
|
|
||||||
Policy: 2.23.140.1.2.2
|
|
||||||
Policy: 2.23.140.1.2.3
|
|
||||||
|
|
||||||
Signature Algorithm: sha384WithRSAEncryption
|
|
||||||
47:59:81:7f:d4:1b:1f:b0:71:f6:98:5d:18:ba:98:47:98:b0:
|
|
||||||
7e:76:2b:ea:ff:1a:8b:ac:26:b3:42:8d:31:e6:4a:e8:19:d0:
|
|
||||||
ef:da:14:e7:d7:14:92:a1:92:f2:a7:2e:2d:af:fb:1d:f6:fb:
|
|
||||||
53:b0:8a:3f:fc:d8:16:0a:e9:b0:2e:b6:a5:0b:18:90:35:26:
|
|
||||||
a2:da:f6:a8:b7:32:fc:95:23:4b:c6:45:b9:c4:cf:e4:7c:ee:
|
|
||||||
e6:c9:f8:90:bd:72:e3:99:c3:1d:0b:05:7c:6a:97:6d:b2:ab:
|
|
||||||
02:36:d8:c2:bc:2c:01:92:3f:04:a3:8b:75:11:c7:b9:29:bc:
|
|
||||||
11:d0:86:ba:92:bc:26:f9:65:c8:37:cd:26:f6:86:13:0c:04:
|
|
||||||
aa:89:e5:78:b1:c1:4e:79:bc:76:a3:0b:51:e4:c5:d0:9e:6a:
|
|
||||||
fe:1a:2c:56:ae:06:36:27:a3:73:1c:08:7d:93:32:d0:c2:44:
|
|
||||||
19:da:8d:f4:0e:7b:1d:28:03:2b:09:8a:76:ca:77:dc:87:7a:
|
|
||||||
ac:7b:52:26:55:a7:72:0f:9d:d2:88:4f:fe:b1:21:c5:1a:a1:
|
|
||||||
aa:39:f5:56:db:c2:84:c4:35:1f:70:da:bb:46:f0:86:bf:64:
|
|
||||||
00:c4:3e:f7:9f:46:1b:9d:23:05:b9:7d:b3:4f:0f:a9:45:3a:
|
|
||||||
e3:74:30:98
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIEFzCCAv+gAwIBAgIQB/LzXIeod6967+lHmTUlvTANBgkqhkiG9w0BAQwFADBh
|
|
||||||
MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
|
|
||||||
d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBD
|
|
||||||
QTAeFw0yMTA0MTQwMDAwMDBaFw0zMTA0MTMyMzU5NTlaMFYxCzAJBgNVBAYTAlVT
|
|
||||||
MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxMDAuBgNVBAMTJ0RpZ2lDZXJ0IFRMUyBI
|
|
||||||
eWJyaWQgRUNDIFNIQTM4NCAyMDIwIENBMTB2MBAGByqGSM49AgEGBSuBBAAiA2IA
|
|
||||||
BMEbxppbmNmkKaDp1AS12+umsmxVwP/tmMZJLwYnUcu/cMEFesOxnYeJuq20ExfJ
|
|
||||||
qLSDyLiQ0cx0NTY8g3KwtdD3ImnI8YDEe0CPz2iHJlw5ifFNkU3aiYvkA8ND5b8v
|
|
||||||
c6OCAYIwggF+MBIGA1UdEwEB/wQIMAYBAf8CAQAwHQYDVR0OBBYEFAq8CCkXjKU5
|
|
||||||
bXoOzjPHLrPt+8N6MB8GA1UdIwQYMBaAFAPeUDVW0Uy7ZvCj4hsbw5eyPdFVMA4G
|
|
||||||
A1UdDwEB/wQEAwIBhjAdBgNVHSUEFjAUBggrBgEFBQcDAQYIKwYBBQUHAwIwdgYI
|
|
||||||
KwYBBQUHAQEEajBoMCQGCCsGAQUFBzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5j
|
|
||||||
b20wQAYIKwYBBQUHMAKGNGh0dHA6Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNvbS9EaWdp
|
|
||||||
Q2VydEdsb2JhbFJvb3RDQS5jcnQwQgYDVR0fBDswOTA3oDWgM4YxaHR0cDovL2Ny
|
|
||||||
bDMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0R2xvYmFsUm9vdENBLmNybDA9BgNVHSAE
|
|
||||||
NjA0MAsGCWCGSAGG/WwCATAHBgVngQwBATAIBgZngQwBAgEwCAYGZ4EMAQICMAgG
|
|
||||||
BmeBDAECAzANBgkqhkiG9w0BAQwFAAOCAQEAR1mBf9QbH7Bx9phdGLqYR5iwfnYr
|
|
||||||
6v8ai6wms0KNMeZK6BnQ79oU59cUkqGS8qcuLa/7Hfb7U7CKP/zYFgrpsC62pQsY
|
|
||||||
kDUmotr2qLcy/JUjS8ZFucTP5Hzu5sn4kL1y45nDHQsFfGqXbbKrAjbYwrwsAZI/
|
|
||||||
BKOLdRHHuSm8EdCGupK8JvllyDfNJvaGEwwEqonleLHBTnm8dqMLUeTF0J5q/hos
|
|
||||||
Vq4GNiejcxwIfZMy0MJEGdqN9A57HSgDKwmKdsp33Id6rHtSJlWncg+d0ohP/rEh
|
|
||||||
xRqhqjn1VtvChMQ1H3Dau0bwhr9kAMQ+959GG50jBbl9s08PqUU643QwmA==
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
08:3b:e0:56:90:42:46:b1:a1:75:6a:c9:59:91:c7:4a
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
Issuer: C = US, O = DigiCert Inc, OU = www.digicert.com, CN = DigiCert Global Root CA
|
|
||||||
Validity
|
|
||||||
Not Before: Nov 10 00:00:00 2006 GMT
|
|
||||||
Not After : Nov 10 00:00:00 2031 GMT
|
|
||||||
Subject: C = US, O = DigiCert Inc, OU = www.digicert.com, CN = DigiCert Global Root CA
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:e2:3b:e1:11:72:de:a8:a4:d3:a3:57:aa:50:a2:
|
|
||||||
8f:0b:77:90:c9:a2:a5:ee:12:ce:96:5b:01:09:20:
|
|
||||||
cc:01:93:a7:4e:30:b7:53:f7:43:c4:69:00:57:9d:
|
|
||||||
e2:8d:22:dd:87:06:40:00:81:09:ce:ce:1b:83:bf:
|
|
||||||
df:cd:3b:71:46:e2:d6:66:c7:05:b3:76:27:16:8f:
|
|
||||||
7b:9e:1e:95:7d:ee:b7:48:a3:08:da:d6:af:7a:0c:
|
|
||||||
39:06:65:7f:4a:5d:1f:bc:17:f8:ab:be:ee:28:d7:
|
|
||||||
74:7f:7a:78:99:59:85:68:6e:5c:23:32:4b:bf:4e:
|
|
||||||
c0:e8:5a:6d:e3:70:bf:77:10:bf:fc:01:f6:85:d9:
|
|
||||||
a8:44:10:58:32:a9:75:18:d5:d1:a2:be:47:e2:27:
|
|
||||||
6a:f4:9a:33:f8:49:08:60:8b:d4:5f:b4:3a:84:bf:
|
|
||||||
a1:aa:4a:4c:7d:3e:cf:4f:5f:6c:76:5e:a0:4b:37:
|
|
||||||
91:9e:dc:22:e6:6d:ce:14:1a:8e:6a:cb:fe:cd:b3:
|
|
||||||
14:64:17:c7:5b:29:9e:32:bf:f2:ee:fa:d3:0b:42:
|
|
||||||
d4:ab:b7:41:32:da:0c:d4:ef:f8:81:d5:bb:8d:58:
|
|
||||||
3f:b5:1b:e8:49:28:a2:70:da:31:04:dd:f7:b2:16:
|
|
||||||
f2:4c:0a:4e:07:a8:ed:4a:3d:5e:b5:7f:a3:90:c3:
|
|
||||||
af:27
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
03:DE:50:35:56:D1:4C:BB:66:F0:A3:E2:1B:1B:C3:97:B2:3D:D1:55
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:03:DE:50:35:56:D1:4C:BB:66:F0:A3:E2:1B:1B:C3:97:B2:3D:D1:55
|
|
||||||
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
cb:9c:37:aa:48:13:12:0a:fa:dd:44:9c:4f:52:b0:f4:df:ae:
|
|
||||||
04:f5:79:79:08:a3:24:18:fc:4b:2b:84:c0:2d:b9:d5:c7:fe:
|
|
||||||
f4:c1:1f:58:cb:b8:6d:9c:7a:74:e7:98:29:ab:11:b5:e3:70:
|
|
||||||
a0:a1:cd:4c:88:99:93:8c:91:70:e2:ab:0f:1c:be:93:a9:ff:
|
|
||||||
63:d5:e4:07:60:d3:a3:bf:9d:5b:09:f1:d5:8e:e3:53:f4:8e:
|
|
||||||
63:fa:3f:a7:db:b4:66:df:62:66:d6:d1:6e:41:8d:f2:2d:b5:
|
|
||||||
ea:77:4a:9f:9d:58:e2:2b:59:c0:40:23:ed:2d:28:82:45:3e:
|
|
||||||
79:54:92:26:98:e0:80:48:a8:37:ef:f0:d6:79:60:16:de:ac:
|
|
||||||
e8:0e:cd:6e:ac:44:17:38:2f:49:da:e1:45:3e:2a:b9:36:53:
|
|
||||||
cf:3a:50:06:f7:2e:e8:c4:57:49:6c:61:21:18:d5:04:ad:78:
|
|
||||||
3c:2c:3a:80:6b:a7:eb:af:15:14:e9:d8:89:c1:b9:38:6c:e2:
|
|
||||||
91:6c:8a:ff:64:b9:77:25:57:30:c0:1b:24:a3:e1:dc:e9:df:
|
|
||||||
47:7c:b5:b4:24:08:05:30:ec:2d:bd:0b:bf:45:bf:50:b9:a9:
|
|
||||||
f3:eb:98:01:12:ad:c8:88:c6:98:34:5f:8d:0a:3c:c6:e9:d5:
|
|
||||||
95:95:6d:de
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIDrzCCApegAwIBAgIQCDvgVpBCRrGhdWrJWZHHSjANBgkqhkiG9w0BAQUFADBh
|
|
||||||
MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
|
|
||||||
d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBD
|
|
||||||
QTAeFw0wNjExMTAwMDAwMDBaFw0zMTExMTAwMDAwMDBaMGExCzAJBgNVBAYTAlVT
|
|
||||||
MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j
|
|
||||||
b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IENBMIIBIjANBgkqhkiG
|
|
||||||
9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4jvhEXLeqKTTo1eqUKKPC3eQyaKl7hLOllsB
|
|
||||||
CSDMAZOnTjC3U/dDxGkAV53ijSLdhwZAAIEJzs4bg7/fzTtxRuLWZscFs3YnFo97
|
|
||||||
nh6Vfe63SKMI2tavegw5BmV/Sl0fvBf4q77uKNd0f3p4mVmFaG5cIzJLv07A6Fpt
|
|
||||||
43C/dxC//AH2hdmoRBBYMql1GNXRor5H4idq9Joz+EkIYIvUX7Q6hL+hqkpMfT7P
|
|
||||||
T19sdl6gSzeRntwi5m3OFBqOasv+zbMUZBfHWymeMr/y7vrTC0LUq7dBMtoM1O/4
|
|
||||||
gdW7jVg/tRvoSSiicNoxBN33shbyTApOB6jtSj1etX+jkMOvJwIDAQABo2MwYTAO
|
|
||||||
BgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUA95QNVbR
|
|
||||||
TLtm8KPiGxvDl7I90VUwHwYDVR0jBBgwFoAUA95QNVbRTLtm8KPiGxvDl7I90VUw
|
|
||||||
DQYJKoZIhvcNAQEFBQADggEBAMucN6pIExIK+t1EnE9SsPTfrgT1eXkIoyQY/Esr
|
|
||||||
hMAtudXH/vTBH1jLuG2cenTnmCmrEbXjcKChzUyImZOMkXDiqw8cvpOp/2PV5Adg
|
|
||||||
06O/nVsJ8dWO41P0jmP6P6fbtGbfYmbW0W5BjfIttep3Sp+dWOIrWcBAI+0tKIJF
|
|
||||||
PnlUkiaY4IBIqDfv8NZ5YBberOgOzW6sRBc4L0na4UU+Krk2U886UAb3LujEV0ls
|
|
||||||
YSEY1QSteDwsOoBrp+uvFRTp2InBuThs4pFsiv9kuXclVzDAGySj4dzp30d8tbQk
|
|
||||||
CAUw7C29C79Fv1C5qfPrmAESrciIxpg0X40KPMbp1ZWVbd4=
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
29
certs/DigiCert-Global-Root-G2.pem
Normal file
|
|
@ -0,0 +1,29 @@
|
||||||
|
# Issuer: CN=DigiCert Global Root G2 O=DigiCert Inc OU=www.digicert.com
|
||||||
|
# Subject: CN=DigiCert Global Root G2 O=DigiCert Inc OU=www.digicert.com
|
||||||
|
# Label: "DigiCert Global Root G2"
|
||||||
|
# Serial: 4293743540046975378534879503202253541
|
||||||
|
# MD5 Fingerprint: e4:a6:8a:c8:54:ac:52:42:46:0a:fd:72:48:1b:2a:44
|
||||||
|
# SHA1 Fingerprint: df:3c:24:f9:bf:d6:66:76:1b:26:80:73:fe:06:d1:cc:8d:4f:82:a4
|
||||||
|
# SHA256 Fingerprint: cb:3c:cb:b7:60:31:e5:e0:13:8f:8d:d3:9a:23:f9:de:47:ff:c3:5e:43:c1:14:4c:ea:27:d4:6a:5a:b1:cb:5f
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIIDjjCCAnagAwIBAgIQAzrx5qcRqaC7KGSxHQn65TANBgkqhkiG9w0BAQsFADBh
|
||||||
|
MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3
|
||||||
|
d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBH
|
||||||
|
MjAeFw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVT
|
||||||
|
MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j
|
||||||
|
b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEcyMIIBIjANBgkqhkiG
|
||||||
|
9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuzfNNNx7a8myaJCtSnX/RrohCgiN9RlUyfuI
|
||||||
|
2/Ou8jqJkTx65qsGGmvPrC3oXgkkRLpimn7Wo6h+4FR1IAWsULecYxpsMNzaHxmx
|
||||||
|
1x7e/dfgy5SDN67sH0NO3Xss0r0upS/kqbitOtSZpLYl6ZtrAGCSYP9PIUkY92eQ
|
||||||
|
q2EGnI/yuum06ZIya7XzV+hdG82MHauVBJVJ8zUtluNJbd134/tJS7SsVQepj5Wz
|
||||||
|
tCO7TG1F8PapspUwtP1MVYwnSlcUfIKdzXOS0xZKBgyMUNGPHgm+F6HmIcr9g+UQ
|
||||||
|
vIOlCsRnKPZzFBQ9RnbDhxSJITRNrw9FDKZJobq7nMWxM4MphQIDAQABo0IwQDAP
|
||||||
|
BgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUTiJUIBiV
|
||||||
|
5uNu5g/6+rkS7QYXjzkwDQYJKoZIhvcNAQELBQADggEBAGBnKJRvDkhj6zHd6mcY
|
||||||
|
1Yl9PMWLSn/pvtsrF9+wX3N3KjITOYFnQoQj8kVnNeyIv/iPsGEMNKSuIEyExtv4
|
||||||
|
NeF22d+mQrvHRAiGfzZ0JFrabA0UWTW98kndth/Jsw1HKj2ZL7tcu7XUIOGZX1NG
|
||||||
|
Fdtom/DzMNU+MeKNhJ7jitralj41E6Vf8PlwUHBHQRFXGU7Aj64GxJUTFy8bJZ91
|
||||||
|
8rGOmaFvE7FBcf6IKshPECBV1/MUReXgRPTqh5Uykw7+U0b6LJ3/iyK5S9kJRaTe
|
||||||
|
pLiaWN0bfVKfjllDiIGknibVb63dDcY3fe0Dkhvld1927jyNxF1WW6LZZm6zNTfl
|
||||||
|
MrY=
|
||||||
|
-----END CERTIFICATE-----
|
||||||
22
certs/DigiCert-Global-Root-G3.pem
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
# Issuer: CN=DigiCert Global Root G3 O=DigiCert Inc OU=www.digicert.com
|
||||||
|
# Subject: CN=DigiCert Global Root G3 O=DigiCert Inc OU=www.digicert.com
|
||||||
|
# Label: "DigiCert Global Root G3"
|
||||||
|
# Serial: 7089244469030293291760083333884364146
|
||||||
|
# MD5 Fingerprint: f5:5d:a4:50:a5:fb:28:7e:1e:0f:0d:cc:96:57:56:ca
|
||||||
|
# SHA1 Fingerprint: 7e:04:de:89:6a:3e:66:6d:00:e6:87:d3:3f:fa:d9:3b:e8:3d:34:9e
|
||||||
|
# SHA256 Fingerprint: 31:ad:66:48:f8:10:41:38:c7:38:f3:9e:a4:32:01:33:39:3e:3a:18:cc:02:29:6e:f9:7c:2a:c9:ef:67:31:d0
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIICPzCCAcWgAwIBAgIQBVVWvPJepDU1w6QP1atFcjAKBggqhkjOPQQDAzBhMQsw
|
||||||
|
CQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cu
|
||||||
|
ZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBHMzAe
|
||||||
|
Fw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVTMRUw
|
||||||
|
EwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20x
|
||||||
|
IDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEczMHYwEAYHKoZIzj0CAQYF
|
||||||
|
K4EEACIDYgAE3afZu4q4C/sLfyHS8L6+c/MzXRq8NOrexpu80JX28MzQC7phW1FG
|
||||||
|
fp4tn+6OYwwX7Adw9c+ELkCDnOg/QW07rdOkFFk2eJ0DQ+4QE2xy3q6Ip6FrtUPO
|
||||||
|
Z9wj/wMco+I+o0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAd
|
||||||
|
BgNVHQ4EFgQUs9tIpPmhxdiuNkHMEWNpYim8S8YwCgYIKoZIzj0EAwMDaAAwZQIx
|
||||||
|
AK288mw/EkrRLTnDCgmXc/SINoyIJ7vmiI1Qhadj+Z4y3maTD/HMsQmP3Wyr+mt/
|
||||||
|
oAIwOWZbwmSNuJ5Q3KjVSaLtx9zRSX8XAbjIho9OjIgrqJqpisXRAL34VOKa5Vt8
|
||||||
|
sycX
|
||||||
|
-----END CERTIFICATE-----
|
||||||
124
certs/E1.pem
|
|
@ -1,124 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
b3:bd:df:f8:a7:84:5b:bc:e9:03:a0:41:35:b3:4a:45
|
|
||||||
Signature Algorithm: ecdsa-with-SHA384
|
|
||||||
Issuer: C = US, O = Internet Security Research Group, CN = ISRG Root X2
|
|
||||||
Validity
|
|
||||||
Not Before: Sep 4 00:00:00 2020 GMT
|
|
||||||
Not After : Sep 15 16:00:00 2025 GMT
|
|
||||||
Subject: C = US, O = Let's Encrypt, CN = E1
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: id-ecPublicKey
|
|
||||||
Public-Key: (384 bit)
|
|
||||||
pub:
|
|
||||||
04:24:5c:2d:a2:2a:fd:1c:4b:a6:5d:97:73:27:31:
|
|
||||||
ac:b2:a0:69:62:ef:65:e8:a6:b0:f0:ac:4b:9f:ff:
|
|
||||||
1c:0b:70:0f:d3:98:2f:4d:fc:0f:00:9b:37:f0:74:
|
|
||||||
05:57:32:97:2e:05:ef:2a:43:25:a3:fb:6e:34:27:
|
|
||||||
13:f6:4f:7e:69:d3:02:99:5e:eb:24:47:92:c1:24:
|
|
||||||
9b:e6:b1:21:8f:c1:24:81:fc:68:cc:1f:69:ba:58:
|
|
||||||
f5:19:22:f7:74:c6:16
|
|
||||||
ASN1 OID: secp384r1
|
|
||||||
NIST CURVE: P-384
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Extended Key Usage:
|
|
||||||
TLS Web Client Authentication, TLS Web Server Authentication
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:0
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
5A:F3:ED:2B:FC:36:C2:37:79:B9:52:30:EA:54:6F:CF:55:CB:2E:AC
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:7C:42:96:AE:DE:4B:48:3B:FA:92:F8:9E:8C:CF:6D:8B:A9:72:37:95
|
|
||||||
|
|
||||||
Authority Information Access:
|
|
||||||
CA Issuers - URI:http://x2.i.lencr.org/
|
|
||||||
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
|
|
||||||
Full Name:
|
|
||||||
URI:http://x2.c.lencr.org/
|
|
||||||
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: 2.23.140.1.2.1
|
|
||||||
Policy: 1.3.6.1.4.1.44947.1.1.1
|
|
||||||
|
|
||||||
Signature Algorithm: ecdsa-with-SHA384
|
|
||||||
30:64:02:30:7b:74:d5:52:13:8d:61:fe:0d:ba:3f:03:00:9d:
|
|
||||||
f3:d7:98:84:d9:57:2e:bd:e9:0f:9c:5c:48:04:21:f2:cb:b3:
|
|
||||||
60:72:8e:97:d6:12:4f:ca:44:f6:42:c9:d3:7b:86:a9:02:30:
|
|
||||||
5a:b1:b1:b4:ed:ea:60:99:20:b1:38:03:ca:3d:a0:26:b8:ee:
|
|
||||||
6e:2d:4a:f6:c6:66:1f:33:9a:db:92:4a:d5:f5:29:13:c6:70:
|
|
||||||
62:28:ba:23:8c:cf:3d:2f:cb:82:e9:7f
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIICxjCCAk2gAwIBAgIRALO93/inhFu86QOgQTWzSkUwCgYIKoZIzj0EAwMwTzEL
|
|
||||||
MAkGA1UEBhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2VhcmNo
|
|
||||||
IEdyb3VwMRUwEwYDVQQDEwxJU1JHIFJvb3QgWDIwHhcNMjAwOTA0MDAwMDAwWhcN
|
|
||||||
MjUwOTE1MTYwMDAwWjAyMQswCQYDVQQGEwJVUzEWMBQGA1UEChMNTGV0J3MgRW5j
|
|
||||||
cnlwdDELMAkGA1UEAxMCRTEwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQkXC2iKv0c
|
|
||||||
S6Zdl3MnMayyoGli72XoprDwrEuf/xwLcA/TmC9N/A8AmzfwdAVXMpcuBe8qQyWj
|
|
||||||
+240JxP2T35p0wKZXuskR5LBJJvmsSGPwSSB/GjMH2m6WPUZIvd0xhajggEIMIIB
|
|
||||||
BDAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0lBBYwFAYIKwYBBQUHAwIGCCsGAQUFBwMB
|
|
||||||
MBIGA1UdEwEB/wQIMAYBAf8CAQAwHQYDVR0OBBYEFFrz7Sv8NsI3eblSMOpUb89V
|
|
||||||
yy6sMB8GA1UdIwQYMBaAFHxClq7eS0g7+pL4nozPbYupcjeVMDIGCCsGAQUFBwEB
|
|
||||||
BCYwJDAiBggrBgEFBQcwAoYWaHR0cDovL3gyLmkubGVuY3Iub3JnLzAnBgNVHR8E
|
|
||||||
IDAeMBygGqAYhhZodHRwOi8veDIuYy5sZW5jci5vcmcvMCIGA1UdIAQbMBkwCAYG
|
|
||||||
Z4EMAQIBMA0GCysGAQQBgt8TAQEBMAoGCCqGSM49BAMDA2cAMGQCMHt01VITjWH+
|
|
||||||
Dbo/AwCd89eYhNlXLr3pD5xcSAQh8suzYHKOl9YST8pE9kLJ03uGqQIwWrGxtO3q
|
|
||||||
YJkgsTgDyj2gJrjubi1K9sZmHzOa25JK1fUpE8ZwYii6I4zPPS/Lgul/
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
41:d2:9d:d1:72:ea:ee:a7:80:c1:2c:6c:e9:2f:87:52
|
|
||||||
Signature Algorithm: ecdsa-with-SHA384
|
|
||||||
Issuer: C = US, O = Internet Security Research Group, CN = ISRG Root X2
|
|
||||||
Validity
|
|
||||||
Not Before: Sep 4 00:00:00 2020 GMT
|
|
||||||
Not After : Sep 17 16:00:00 2040 GMT
|
|
||||||
Subject: C = US, O = Internet Security Research Group, CN = ISRG Root X2
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: id-ecPublicKey
|
|
||||||
Public-Key: (384 bit)
|
|
||||||
pub:
|
|
||||||
04:cd:9b:d5:9f:80:83:0a:ec:09:4a:f3:16:4a:3e:
|
|
||||||
5c:cf:77:ac:de:67:05:0d:1d:07:b6:dc:16:fb:5a:
|
|
||||||
8b:14:db:e2:71:60:c4:ba:45:95:11:89:8e:ea:06:
|
|
||||||
df:f7:2a:16:1c:a4:b9:c5:c5:32:e0:03:e0:1e:82:
|
|
||||||
18:38:8b:d7:45:d8:0a:6a:6e:e6:00:77:fb:02:51:
|
|
||||||
7d:22:d8:0a:6e:9a:5b:77:df:f0:fa:41:ec:39:dc:
|
|
||||||
75:ca:68:07:0c:1f:ea
|
|
||||||
ASN1 OID: secp384r1
|
|
||||||
NIST CURVE: P-384
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
7C:42:96:AE:DE:4B:48:3B:FA:92:F8:9E:8C:CF:6D:8B:A9:72:37:95
|
|
||||||
Signature Algorithm: ecdsa-with-SHA384
|
|
||||||
30:65:02:30:7b:79:4e:46:50:84:c2:44:87:46:1b:45:70:ff:
|
|
||||||
58:99:de:f4:fd:a4:d2:55:a6:20:2d:74:d6:34:bc:41:a3:50:
|
|
||||||
5f:01:27:56:b4:be:27:75:06:af:12:2e:75:98:8d:fc:02:31:
|
|
||||||
00:8b:f5:77:6c:d4:c8:65:aa:e0:0b:2c:ee:14:9d:27:37:a4:
|
|
||||||
f9:53:a5:51:e4:29:83:d7:f8:90:31:5b:42:9f:0a:f5:fe:ae:
|
|
||||||
00:68:e7:8c:49:0f:b6:6f:5b:5b:15:f2:e7
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIICGzCCAaGgAwIBAgIQQdKd0XLq7qeAwSxs6S+HUjAKBggqhkjOPQQDAzBPMQsw
|
|
||||||
CQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJuZXQgU2VjdXJpdHkgUmVzZWFyY2gg
|
|
||||||
R3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBYMjAeFw0yMDA5MDQwMDAwMDBaFw00
|
|
||||||
MDA5MTcxNjAwMDBaME8xCzAJBgNVBAYTAlVTMSkwJwYDVQQKEyBJbnRlcm5ldCBT
|
|
||||||
ZWN1cml0eSBSZXNlYXJjaCBHcm91cDEVMBMGA1UEAxMMSVNSRyBSb290IFgyMHYw
|
|
||||||
EAYHKoZIzj0CAQYFK4EEACIDYgAEzZvVn4CDCuwJSvMWSj5cz3es3mcFDR0HttwW
|
|
||||||
+1qLFNvicWDEukWVEYmO6gbf9yoWHKS5xcUy4APgHoIYOIvXRdgKam7mAHf7AlF9
|
|
||||||
ItgKbppbd9/w+kHsOdx1ymgHDB/qo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0T
|
|
||||||
AQH/BAUwAwEB/zAdBgNVHQ4EFgQUfEKWrt5LSDv6kviejM9ti6lyN5UwCgYIKoZI
|
|
||||||
zj0EAwMDaAAwZQIwe3lORlCEwkSHRhtFcP9Ymd70/aTSVaYgLXTWNLxBo1BfASdW
|
|
||||||
tL4ndQavEi51mI38AjEAi/V3bNTIZargCyzuFJ0nN6T5U6VR5CmD1/iQMVtCnwr1
|
|
||||||
/q4AaOeMSQ+2b1tbFfLn
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
|
|
@ -1,242 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
02:03:bc:53:59:6b:34:c7:18:f5:01:50:66
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C = US, O = Google Trust Services LLC, CN = GTS Root R1
|
|
||||||
Validity
|
|
||||||
Not Before: Aug 13 00:00:42 2020 GMT
|
|
||||||
Not After : Sep 30 00:00:42 2027 GMT
|
|
||||||
Subject: C = US, O = Google Trust Services LLC, CN = GTS CA 1C3
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:f5:88:df:e7:62:8c:1e:37:f8:37:42:90:7f:6c:
|
|
||||||
87:d0:fb:65:82:25:fd:e8:cb:6b:a4:ff:6d:e9:5a:
|
|
||||||
23:e2:99:f6:1c:e9:92:03:99:13:7c:09:0a:8a:fa:
|
|
||||||
42:d6:5e:56:24:aa:7a:33:84:1f:d1:e9:69:bb:b9:
|
|
||||||
74:ec:57:4c:66:68:93:77:37:55:53:fe:39:10:4d:
|
|
||||||
b7:34:bb:5f:25:77:37:3b:17:94:ea:3c:e5:9d:d5:
|
|
||||||
bc:c3:b4:43:eb:2e:a7:47:ef:b0:44:11:63:d8:b4:
|
|
||||||
41:85:dd:41:30:48:93:1b:bf:b7:f6:e0:45:02:21:
|
|
||||||
e0:96:42:17:cf:d9:2b:65:56:34:07:26:04:0d:a8:
|
|
||||||
fd:7d:ca:2e:ef:ea:48:7c:37:4d:3f:00:9f:83:df:
|
|
||||||
ef:75:84:2e:79:57:5c:fc:57:6e:1a:96:ff:fc:8c:
|
|
||||||
9a:a6:99:be:25:d9:7f:96:2c:06:f7:11:2a:02:80:
|
|
||||||
80:eb:63:18:3c:50:49:87:e5:8a:ca:5f:19:2b:59:
|
|
||||||
96:81:00:a0:fb:51:db:ca:77:0b:0b:c9:96:4f:ef:
|
|
||||||
70:49:c7:5c:6d:20:fd:99:b4:b4:e2:ca:2e:77:fd:
|
|
||||||
2d:dc:0b:b6:6b:13:0c:8c:19:2b:17:96:98:b9:f0:
|
|
||||||
8b:f6:a0:27:bb:b6:e3:8d:51:8f:bd:ae:c7:9b:b1:
|
|
||||||
89:9d
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Extended Key Usage:
|
|
||||||
TLS Web Server Authentication, TLS Web Client Authentication
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:0
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
8A:74:7F:AF:85:CD:EE:95:CD:3D:9C:D0:E2:46:14:F3:71:35:1D:27
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:E4:AF:2B:26:71:1A:2B:48:27:85:2F:52:66:2C:EF:F0:89:13:71:3E
|
|
||||||
|
|
||||||
Authority Information Access:
|
|
||||||
OCSP - URI:http://ocsp.pki.goog/gtsr1
|
|
||||||
CA Issuers - URI:http://pki.goog/repo/certs/gtsr1.der
|
|
||||||
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
|
|
||||||
Full Name:
|
|
||||||
URI:http://crl.pki.goog/gtsr1/gtsr1.crl
|
|
||||||
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: 1.3.6.1.4.1.11129.2.5.3
|
|
||||||
CPS: https://pki.goog/repository/
|
|
||||||
Policy: 2.23.140.1.2.1
|
|
||||||
Policy: 2.23.140.1.2.2
|
|
||||||
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
89:7d:ac:20:5c:0c:3c:be:9a:a8:57:95:1b:b4:ae:fa:ab:a5:
|
|
||||||
72:71:b4:36:95:fd:df:40:11:03:4c:c2:46:14:bb:14:24:ab:
|
|
||||||
f0:50:71:22:db:ad:c4:6e:7f:cf:f1:6a:6f:c8:83:1b:d8:ce:
|
|
||||||
89:5f:87:6c:87:b8:a9:0c:a3:9b:a1:62:94:93:95:df:5b:ae:
|
|
||||||
66:19:0b:02:96:9e:fc:b5:e7:10:69:3e:7a:cb:46:49:5f:46:
|
|
||||||
e1:41:b1:d7:98:4d:65:34:00:80:1a:3f:4f:9f:6c:7f:49:00:
|
|
||||||
81:53:41:a4:92:21:82:82:1a:f1:a3:44:5b:2a:50:12:13:4d:
|
|
||||||
c1:53:36:f3:42:08:af:54:fa:8e:77:53:1b:64:38:27:17:09:
|
|
||||||
bd:58:c9:1b:7c:39:2d:5b:f3:ce:d4:ed:97:db:14:03:bf:09:
|
|
||||||
53:24:1f:c2:0c:04:79:98:26:f2:61:f1:53:52:fd:42:8c:1b:
|
|
||||||
66:2b:3f:15:a1:bb:ff:f6:9b:e3:81:9a:01:06:71:89:35:28:
|
|
||||||
24:dd:e1:bd:eb:19:2d:e1:48:cb:3d:59:83:51:b4:74:c6:9d:
|
|
||||||
7c:c6:b1:86:5b:af:cc:34:c4:d3:cc:d4:81:11:95:00:a1:f4:
|
|
||||||
12:22:01:fa:b4:83:71:af:8c:b7:8c:73:24:ac:37:53:c2:00:
|
|
||||||
90:3f:11:fe:5c:ed:36:94:10:3b:bd:29:ae:e2:c7:3a:62:3b:
|
|
||||||
6c:63:d9:80:bf:59:71:ac:63:27:b9:4c:17:a0:da:f6:73:15:
|
|
||||||
bf:2a:de:8f:f3:a5:6c:32:81:33:03:d0:86:51:71:99:34:ba:
|
|
||||||
93:8d:5d:b5:51:58:f7:b2:93:e8:01:f6:59:be:71:9b:fd:4d:
|
|
||||||
28:ce:cf:6d:c7:16:dc:f7:d1:d6:46:9b:a7:ca:6b:e9:77:0f:
|
|
||||||
fd:a0:b6:1b:23:83:1d:10:1a:d9:09:00:84:e0:44:d3:a2:75:
|
|
||||||
23:b3:34:86:f6:20:b0:a4:5e:10:1d:e0:52:46:00:9d:b1:0f:
|
|
||||||
1f:21:70:51:f5:9a:dd:06:fc:55:f4:2b:0e:33:77:c3:4b:42:
|
|
||||||
c2:f1:77:13:fc:73:80:94:eb:1f:bb:37:3f:ce:02:2a:66:b0:
|
|
||||||
73:1d:32:a5:32:6c:32:b0:8e:e0:c4:23:ff:5b:7d:4d:65:70:
|
|
||||||
ac:2b:9b:3d:ce:db:e0:6d:8e:32:80:be:96:9f:92:63:bc:97:
|
|
||||||
bb:5d:b9:f4:e1:71:5e:2a:e4:ef:03:22:b1:8a:65:3a:8f:c0:
|
|
||||||
93:65:d4:85:cd:0f:0f:5b:83:59:16:47:16:2d:9c:24:3a:c8:
|
|
||||||
80:a6:26:14:85:9b:f6:37:9b:ac:6f:f9:c5:c3:06:51:f3:e2:
|
|
||||||
7f:c5:b1:10:ba:51:f4:dd
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
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
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
6e:47:a9:c5:4b:47:0c:0d:ec:33:d0:89:b9:1c:f4:e1
|
|
||||||
Signature Algorithm: sha384WithRSAEncryption
|
|
||||||
Issuer: C = US, O = Google Trust Services LLC, CN = GTS Root R1
|
|
||||||
Validity
|
|
||||||
Not Before: Jun 22 00:00:00 2016 GMT
|
|
||||||
Not After : Jun 22 00:00:00 2036 GMT
|
|
||||||
Subject: C = US, O = Google Trust Services LLC, CN = GTS Root R1
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (4096 bit)
|
|
||||||
Modulus:
|
|
||||||
00:b6:11:02:8b:1e:e3:a1:77:9b:3b:dc:bf:94:3e:
|
|
||||||
b7:95:a7:40:3c:a1:fd:82:f9:7d:32:06:82:71:f6:
|
|
||||||
f6:8c:7f:fb:e8:db:bc:6a:2e:97:97:a3:8c:4b:f9:
|
|
||||||
2b:f6:b1:f9:ce:84:1d:b1:f9:c5:97:de:ef:b9:f2:
|
|
||||||
a3:e9:bc:12:89:5e:a7:aa:52:ab:f8:23:27:cb:a4:
|
|
||||||
b1:9c:63:db:d7:99:7e:f0:0a:5e:eb:68:a6:f4:c6:
|
|
||||||
5a:47:0d:4d:10:33:e3:4e:b1:13:a3:c8:18:6c:4b:
|
|
||||||
ec:fc:09:90:df:9d:64:29:25:23:07:a1:b4:d2:3d:
|
|
||||||
2e:60:e0:cf:d2:09:87:bb:cd:48:f0:4d:c2:c2:7a:
|
|
||||||
88:8a:bb:ba:cf:59:19:d6:af:8f:b0:07:b0:9e:31:
|
|
||||||
f1:82:c1:c0:df:2e:a6:6d:6c:19:0e:b5:d8:7e:26:
|
|
||||||
1a:45:03:3d:b0:79:a4:94:28:ad:0f:7f:26:e5:a8:
|
|
||||||
08:fe:96:e8:3c:68:94:53:ee:83:3a:88:2b:15:96:
|
|
||||||
09:b2:e0:7a:8c:2e:75:d6:9c:eb:a7:56:64:8f:96:
|
|
||||||
4f:68:ae:3d:97:c2:84:8f:c0:bc:40:c0:0b:5c:bd:
|
|
||||||
f6:87:b3:35:6c:ac:18:50:7f:84:e0:4c:cd:92:d3:
|
|
||||||
20:e9:33:bc:52:99:af:32:b5:29:b3:25:2a:b4:48:
|
|
||||||
f9:72:e1:ca:64:f7:e6:82:10:8d:e8:9d:c2:8a:88:
|
|
||||||
fa:38:66:8a:fc:63:f9:01:f9:78:fd:7b:5c:77:fa:
|
|
||||||
76:87:fa:ec:df:b1:0e:79:95:57:b4:bd:26:ef:d6:
|
|
||||||
01:d1:eb:16:0a:bb:8e:0b:b5:c5:c5:8a:55:ab:d3:
|
|
||||||
ac:ea:91:4b:29:cc:19:a4:32:25:4e:2a:f1:65:44:
|
|
||||||
d0:02:ce:aa:ce:49:b4:ea:9f:7c:83:b0:40:7b:e7:
|
|
||||||
43:ab:a7:6c:a3:8f:7d:89:81:fa:4c:a5:ff:d5:8e:
|
|
||||||
c3:ce:4b:e0:b5:d8:b3:8e:45:cf:76:c0:ed:40:2b:
|
|
||||||
fd:53:0f:b0:a7:d5:3b:0d:b1:8a:a2:03:de:31:ad:
|
|
||||||
cc:77:ea:6f:7b:3e:d6:df:91:22:12:e6:be:fa:d8:
|
|
||||||
32:fc:10:63:14:51:72:de:5d:d6:16:93:bd:29:68:
|
|
||||||
33:ef:3a:66:ec:07:8a:26:df:13:d7:57:65:78:27:
|
|
||||||
de:5e:49:14:00:a2:00:7f:9a:a8:21:b6:a9:b1:95:
|
|
||||||
b0:a5:b9:0d:16:11:da:c7:6c:48:3c:40:e0:7e:0d:
|
|
||||||
5a:cd:56:3c:d1:97:05:b9:cb:4b:ed:39:4b:9c:c4:
|
|
||||||
3f:d2:55:13:6e:24:b0:d6:71:fa:f4:c1:ba:cc:ed:
|
|
||||||
1b:f5:fe:81:41:d8:00:98:3d:3a:c8:ae:7a:98:37:
|
|
||||||
18:05:95
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
E4:AF:2B:26:71:1A:2B:48:27:85:2F:52:66:2C:EF:F0:89:13:71:3E
|
|
||||||
Signature Algorithm: sha384WithRSAEncryption
|
|
||||||
38:96:0a:ee:3d:b4:96:1e:5f:ef:9d:9c:0b:33:9f:2b:e0:ca:
|
|
||||||
fd:d2:8e:0a:1f:41:74:a5:7c:aa:84:d4:e5:f2:1e:e6:37:52:
|
|
||||||
32:9c:0b:d1:61:1d:bf:28:c1:b6:44:29:35:75:77:98:b2:7c:
|
|
||||||
d9:bd:74:ac:8a:68:e3:a9:31:09:29:01:60:73:e3:47:7c:53:
|
|
||||||
a8:90:4a:27:ef:4b:d7:9f:93:e7:82:36:ce:9a:68:0c:82:e7:
|
|
||||||
cf:d4:10:16:6f:5f:0e:99:5c:f6:1f:71:7d:ef:ef:7b:2f:7e:
|
|
||||||
ea:36:d6:97:70:0b:15:ee:d7:5c:56:6a:33:a5:e3:49:38:0c:
|
|
||||||
b8:7d:fb:8d:85:a4:b1:59:5e:f4:6a:e1:dd:a1:f6:64:44:ae:
|
|
||||||
e6:51:83:21:66:c6:11:3e:f3:ce:47:ee:9c:28:1f:25:da:ff:
|
|
||||||
ac:66:95:dd:35:0f:5c:ef:20:2c:62:fd:91:ba:a9:cc:fc:5a:
|
|
||||||
9c:93:81:83:29:97:4a:7c:5a:72:b4:39:d0:b7:77:cb:79:fd:
|
|
||||||
69:3a:92:37:ed:6e:38:65:46:7e:e9:60:bd:79:88:97:5f:38:
|
|
||||||
12:f4:ee:af:5b:82:c8:86:d5:e1:99:6d:8c:04:f2:76:ba:49:
|
|
||||||
f6:6e:e9:6d:1e:5f:a0:ef:27:82:76:40:f8:a6:d3:58:5c:0f:
|
|
||||||
2c:42:da:42:c6:7b:88:34:c7:c1:d8:45:9b:c1:3e:c5:61:1d:
|
|
||||||
d9:63:50:49:f6:34:85:6a:e0:18:c5:6e:47:ab:41:42:29:9b:
|
|
||||||
f6:60:0d:d2:31:d3:63:98:23:93:5a:00:81:48:b4:ef:cd:8a:
|
|
||||||
cd:c9:cf:99:ee:d9:9e:aa:36:e1:68:4b:71:49:14:36:28:3a:
|
|
||||||
3d:1d:ce:9a:8f:25:e6:80:71:61:2b:b5:7b:cc:f9:25:16:81:
|
|
||||||
e1:31:5f:a1:a3:7e:16:a4:9c:16:6a:97:18:bd:76:72:a5:0b:
|
|
||||||
9e:1d:36:e6:2f:a1:2f:be:70:91:0f:a8:e6:da:f8:c4:92:40:
|
|
||||||
6c:25:7e:7b:b3:09:dc:b2:17:ad:80:44:f0:68:a5:8f:94:75:
|
|
||||||
ff:74:5a:e8:a8:02:7c:0c:09:e2:a9:4b:0b:a0:85:0b:62:b9:
|
|
||||||
ef:a1:31:92:fb:ef:f6:51:04:89:6c:e8:a9:74:a1:bb:17:b3:
|
|
||||||
b5:fd:49:0f:7c:3c:ec:83:18:20:43:4e:d5:93:ba:b4:34:b1:
|
|
||||||
1f:16:36:1f:0c:e6:64:39:16:4c:dc:e0:fe:1d:c8:a9:62:3d:
|
|
||||||
40:ea:ca:c5:34:02:b4:ae:89:88:33:35:dc:2c:13:73:d8:27:
|
|
||||||
f1:d0:72:ee:75:3b:22:de:98:68:66:5b:f1:c6:63:47:55:1c:
|
|
||||||
ba:a5:08:51:75:a6:48:25
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
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
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
|
|
@ -1,238 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
02:03:bc:50:a3:27:53:f0:91:80:22:ed:f1
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C=US, O=Google Trust Services LLC, CN=GTS Root R1
|
|
||||||
Validity
|
|
||||||
Not Before: Aug 13 00:00:42 2020 GMT
|
|
||||||
Not After : Sep 30 00:00:42 2027 GMT
|
|
||||||
Subject: C=US, O=Google Trust Services LLC, CN=GTS CA 1P5
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:b3:82:f0:24:8c:bf:2d:87:af:b2:d9:a7:ae:fa:
|
|
||||||
ca:ba:44:d6:5b:3e:fe:b2:f7:b2:65:16:dc:de:10:
|
|
||||||
e8:4f:2d:10:58:5a:28:86:87:a1:ee:6a:b3:a0:d9:
|
|
||||||
75:4f:7f:a1:52:01:8b:55:a8:4a:5b:06:48:c8:36:
|
|
||||||
12:25:ab:89:f9:f2:23:5f:9d:60:65:f9:5c:da:be:
|
|
||||||
3a:e8:5c:6d:7d:9c:d0:84:18:85:30:cd:4e:9b:ec:
|
|
||||||
3c:d8:b3:e1:96:d4:f3:c5:0b:65:db:8f:b0:74:cb:
|
|
||||||
f6:1e:f3:78:f1:ac:95:c5:dd:73:c3:31:88:81:af:
|
|
||||||
74:aa:6f:fd:0c:e3:05:95:f0:c5:10:4f:65:63:fa:
|
|
||||||
a0:af:c6:18:3d:c5:a1:df:97:79:d7:05:89:b3:30:
|
|
||||||
b0:74:ae:3d:92:10:6b:8c:15:77:dd:0b:04:57:fb:
|
|
||||||
81:03:dd:ea:22:34:d5:e5:56:b2:f0:c4:8d:41:b1:
|
|
||||||
c3:02:db:62:ec:80:d0:ff:76:d4:86:e4:04:1a:b6:
|
|
||||||
b6:0c:2b:62:71:7d:d9:af:d9:f1:5e:fa:c0:1e:ca:
|
|
||||||
a0:19:5c:55:f0:80:d1:2a:0c:07:86:90:9f:35:e3:
|
|
||||||
28:2b:5b:ef:23:c8:a3:1d:a4:a3:3a:ee:fe:83:dc:
|
|
||||||
82:4c:25:b0:4d:c5:51:ad:9e:9b:d3:5b:84:c2:1a:
|
|
||||||
5a:e9
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Extended Key Usage:
|
|
||||||
TLS Web Server Authentication, TLS Web Client Authentication
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:0
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
D5:FC:9E:0D:DF:1E:CA:DD:08:97:97:6E:2B:C5:5F:C5:2B:F5:EC:B8
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
E4:AF:2B:26:71:1A:2B:48:27:85:2F:52:66:2C:EF:F0:89:13:71:3E
|
|
||||||
Authority Information Access:
|
|
||||||
OCSP - URI:http://ocsp.pki.goog/gtsr1
|
|
||||||
CA Issuers - URI:http://pki.goog/repo/certs/gtsr1.der
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
Full Name:
|
|
||||||
URI:http://crl.pki.goog/gtsr1/gtsr1.crl
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: 1.3.6.1.4.1.11129.2.5.3
|
|
||||||
CPS: https://pki.goog/repository/
|
|
||||||
Policy: 2.23.140.1.2.1
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Signature Value:
|
|
||||||
6c:63:27:ee:23:df:e5:52:68:4d:81:66:91:85:df:7d:65:e5:
|
|
||||||
5b:37:31:08:26:b2:07:5d:9a:be:b1:ca:01:b9:ad:bf:9d:77:
|
|
||||||
f6:51:1d:d7:98:c5:0b:49:a1:7b:a1:d7:d3:68:e5:44:0f:8b:
|
|
||||||
ba:36:dd:42:82:77:d2:8d:dd:f5:3f:fb:eb:c8:07:98:93:ee:
|
|
||||||
5a:d0:b5:3d:de:4b:1c:2d:8c:4d:ec:7e:8c:7b:fe:4e:40:fd:
|
|
||||||
f0:b4:b3:59:02:10:51:5c:e3:c0:2b:fd:b7:06:48:51:7e:09:
|
|
||||||
5e:3f:0f:dc:a7:fe:97:e7:79:c5:0e:44:89:78:c5:69:59:29:
|
|
||||||
a0:9a:3a:48:36:29:a6:94:93:55:2d:b8:47:b5:e9:96:b5:9f:
|
|
||||||
07:cd:a6:ab:3e:32:8a:c0:86:83:c5:c1:41:c8:9f:2f:35:8e:
|
|
||||||
0d:c0:07:7a:e1:ac:c9:65:b5:cb:8a:a7:dd:71:d8:61:65:39:
|
|
||||||
84:ac:32:3e:f7:7a:36:f1:56:9f:57:a9:41:6d:5a:90:a7:db:
|
|
||||||
3a:ea:75:80:0c:63:0b:69:74:6f:07:4c:15:f3:37:28:a5:19:
|
|
||||||
a4:6e:f5:f6:20:cd:63:b2:7e:c4:2b:09:75:89:da:d1:3c:2e:
|
|
||||||
72:4f:36:1a:a1:9e:44:d0:cd:9b:a6:23:08:3f:97:a1:a7:9e:
|
|
||||||
5a:a5:f7:09:94:ad:5d:76:5d:28:56:d1:1a:66:51:51:07:7b:
|
|
||||||
de:3d:b0:c8:ef:30:7a:24:2d:be:b8:b3:86:f6:4b:f7:f0:b5:
|
|
||||||
4f:ff:ce:c6:f9:f6:3f:2a:27:08:0f:09:3e:23:5a:c7:e3:42:
|
|
||||||
2d:7a:36:e4:3d:98:96:60:39:98:ea:d1:db:63:2a:eb:78:09:
|
|
||||||
b1:4e:21:b3:8e:b7:ce:3e:92:f1:95:5c:a4:39:d0:c0:2b:c8:
|
|
||||||
53:15:f5:d2:2f:82:cd:06:74:67:99:90:77:37:0a:97:2d:c5:
|
|
||||||
1c:1e:f4:d0:5b:e9:15:e3:ea:02:09:c8:13:d7:13:70:65:bf:
|
|
||||||
fb:88:9b:5a:25:be:77:09:e1:a7:6a:4e:11:75:b9:1e:4d:f1:
|
|
||||||
00:1b:6a:66:79:8e:c3:6e:d8:6d:a2:22:a2:6d:05:fb:2c:f2:
|
|
||||||
f1:50:e5:a0:d1:d8:9f:35:7d:fc:70:ab:59:2a:02:f1:be:b0:
|
|
||||||
d3:f1:f8:cd:12:b9:6a:25:90:5b:e3:85:20:e6:f5:da:cb:40:
|
|
||||||
1c:19:34:20:03:61:77:ba:7f:48:0f:49:0b:29:eb:e7:61:64:
|
|
||||||
c7:63:d1:47:eb:1c:e1:ee:94:46:ef:39:73:cc:ee:4f:2b:8d:
|
|
||||||
dc:fb:58:a7:b3:65:20:99:95:b9:fb:55:6f:d7:96:6e:94:3d:
|
|
||||||
f4:7a:92:8e:63:1d:df:6d
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
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
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
02:03:e5:93:6f:31:b0:13:49:88:6b:a2:17
|
|
||||||
Signature Algorithm: sha384WithRSAEncryption
|
|
||||||
Issuer: C=US, O=Google Trust Services LLC, CN=GTS Root R1
|
|
||||||
Validity
|
|
||||||
Not Before: Jun 22 00:00:00 2016 GMT
|
|
||||||
Not After : Jun 22 00:00:00 2036 GMT
|
|
||||||
Subject: C=US, O=Google Trust Services LLC, CN=GTS Root R1
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (4096 bit)
|
|
||||||
Modulus:
|
|
||||||
00:b6:11:02:8b:1e:e3:a1:77:9b:3b:dc:bf:94:3e:
|
|
||||||
b7:95:a7:40:3c:a1:fd:82:f9:7d:32:06:82:71:f6:
|
|
||||||
f6:8c:7f:fb:e8:db:bc:6a:2e:97:97:a3:8c:4b:f9:
|
|
||||||
2b:f6:b1:f9:ce:84:1d:b1:f9:c5:97:de:ef:b9:f2:
|
|
||||||
a3:e9:bc:12:89:5e:a7:aa:52:ab:f8:23:27:cb:a4:
|
|
||||||
b1:9c:63:db:d7:99:7e:f0:0a:5e:eb:68:a6:f4:c6:
|
|
||||||
5a:47:0d:4d:10:33:e3:4e:b1:13:a3:c8:18:6c:4b:
|
|
||||||
ec:fc:09:90:df:9d:64:29:25:23:07:a1:b4:d2:3d:
|
|
||||||
2e:60:e0:cf:d2:09:87:bb:cd:48:f0:4d:c2:c2:7a:
|
|
||||||
88:8a:bb:ba:cf:59:19:d6:af:8f:b0:07:b0:9e:31:
|
|
||||||
f1:82:c1:c0:df:2e:a6:6d:6c:19:0e:b5:d8:7e:26:
|
|
||||||
1a:45:03:3d:b0:79:a4:94:28:ad:0f:7f:26:e5:a8:
|
|
||||||
08:fe:96:e8:3c:68:94:53:ee:83:3a:88:2b:15:96:
|
|
||||||
09:b2:e0:7a:8c:2e:75:d6:9c:eb:a7:56:64:8f:96:
|
|
||||||
4f:68:ae:3d:97:c2:84:8f:c0:bc:40:c0:0b:5c:bd:
|
|
||||||
f6:87:b3:35:6c:ac:18:50:7f:84:e0:4c:cd:92:d3:
|
|
||||||
20:e9:33:bc:52:99:af:32:b5:29:b3:25:2a:b4:48:
|
|
||||||
f9:72:e1:ca:64:f7:e6:82:10:8d:e8:9d:c2:8a:88:
|
|
||||||
fa:38:66:8a:fc:63:f9:01:f9:78:fd:7b:5c:77:fa:
|
|
||||||
76:87:fa:ec:df:b1:0e:79:95:57:b4:bd:26:ef:d6:
|
|
||||||
01:d1:eb:16:0a:bb:8e:0b:b5:c5:c5:8a:55:ab:d3:
|
|
||||||
ac:ea:91:4b:29:cc:19:a4:32:25:4e:2a:f1:65:44:
|
|
||||||
d0:02:ce:aa:ce:49:b4:ea:9f:7c:83:b0:40:7b:e7:
|
|
||||||
43:ab:a7:6c:a3:8f:7d:89:81:fa:4c:a5:ff:d5:8e:
|
|
||||||
c3:ce:4b:e0:b5:d8:b3:8e:45:cf:76:c0:ed:40:2b:
|
|
||||||
fd:53:0f:b0:a7:d5:3b:0d:b1:8a:a2:03:de:31:ad:
|
|
||||||
cc:77:ea:6f:7b:3e:d6:df:91:22:12:e6:be:fa:d8:
|
|
||||||
32:fc:10:63:14:51:72:de:5d:d6:16:93:bd:29:68:
|
|
||||||
33:ef:3a:66:ec:07:8a:26:df:13:d7:57:65:78:27:
|
|
||||||
de:5e:49:14:00:a2:00:7f:9a:a8:21:b6:a9:b1:95:
|
|
||||||
b0:a5:b9:0d:16:11:da:c7:6c:48:3c:40:e0:7e:0d:
|
|
||||||
5a:cd:56:3c:d1:97:05:b9:cb:4b:ed:39:4b:9c:c4:
|
|
||||||
3f:d2:55:13:6e:24:b0:d6:71:fa:f4:c1:ba:cc:ed:
|
|
||||||
1b:f5:fe:81:41:d8:00:98:3d:3a:c8:ae:7a:98:37:
|
|
||||||
18:05:95
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
E4:AF:2B:26:71:1A:2B:48:27:85:2F:52:66:2C:EF:F0:89:13:71:3E
|
|
||||||
Signature Algorithm: sha384WithRSAEncryption
|
|
||||||
Signature Value:
|
|
||||||
9f:aa:42:26:db:0b:9b:be:ff:1e:96:92:2e:3e:a2:65:4a:6a:
|
|
||||||
98:ba:22:cb:7d:c1:3a:d8:82:0a:06:c6:f6:a5:de:c0:4e:87:
|
|
||||||
66:79:a1:f9:a6:58:9c:aa:f9:b5:e6:60:e7:e0:e8:b1:1e:42:
|
|
||||||
41:33:0b:37:3d:ce:89:70:15:ca:b5:24:a8:cf:6b:b5:d2:40:
|
|
||||||
21:98:cf:22:34:cf:3b:c5:22:84:e0:c5:0e:8a:7c:5d:88:e4:
|
|
||||||
35:24:ce:9b:3e:1a:54:1e:6e:db:b2:87:a7:fc:f3:fa:81:55:
|
|
||||||
14:62:0a:59:a9:22:05:31:3e:82:d6:ee:db:57:34:bc:33:95:
|
|
||||||
d3:17:1b:e8:27:a2:8b:7b:4e:26:1a:7a:5a:64:b6:d1:ac:37:
|
|
||||||
f1:fd:a0:f3:38:ec:72:f0:11:75:9d:cb:34:52:8d:e6:76:6b:
|
|
||||||
17:c6:df:86:ab:27:8e:49:2b:75:66:81:10:21:a6:ea:3e:f4:
|
|
||||||
ae:25:ff:7c:15:de:ce:8c:25:3f:ca:62:70:0a:f7:2f:09:66:
|
|
||||||
07:c8:3f:1c:fc:f0:db:45:30:df:62:88:c1:b5:0f:9d:c3:9f:
|
|
||||||
4a:de:59:59:47:c5:87:22:36:e6:82:a7:ed:0a:b9:e2:07:a0:
|
|
||||||
8d:7b:7a:4a:3c:71:d2:e2:03:a1:1f:32:07:dd:1b:e4:42:ce:
|
|
||||||
0c:00:45:61:80:b5:0b:20:59:29:78:bd:f9:55:cb:63:c5:3c:
|
|
||||||
4c:f4:b6:ff:db:6a:5f:31:6b:99:9e:2c:c1:6b:50:a4:d7:e6:
|
|
||||||
18:14:bd:85:3f:67:ab:46:9f:a0:ff:42:a7:3a:7f:5c:cb:5d:
|
|
||||||
b0:70:1d:2b:34:f5:d4:76:09:0c:eb:78:4c:59:05:f3:33:42:
|
|
||||||
c3:61:15:10:1b:77:4d:ce:22:8c:d4:85:f2:45:7d:b7:53:ea:
|
|
||||||
ef:40:5a:94:0a:5c:20:5f:4e:40:5d:62:22:76:df:ff:ce:61:
|
|
||||||
bd:8c:23:78:d2:37:02:e0:8e:de:d1:11:37:89:f6:bf:ed:49:
|
|
||||||
07:62:ae:92:ec:40:1a:af:14:09:d9:d0:4e:b2:a2:f7:be:ee:
|
|
||||||
ee:d8:ff:dc:1a:2d:de:b8:36:71:e2:fc:79:b7:94:25:d1:48:
|
|
||||||
73:5b:a1:35:e7:b3:99:67:75:c1:19:3a:2b:47:4e:d3:42:8e:
|
|
||||||
fd:31:c8:16:66:da:d2:0c:3c:db:b3:8e:c9:a1:0d:80:0f:7b:
|
|
||||||
16:77:14:bf:ff:db:09:94:b2:93:bc:20:58:15:e9:db:71:43:
|
|
||||||
f3:de:10:c3:00:dc:a8:2a:95:b6:c2:d6:3f:90:6b:76:db:6c:
|
|
||||||
fe:8c:bc:f2:70:35:0c:dc:99:19:35:dc:d7:c8:46:63:d5:36:
|
|
||||||
71:ae:57:fb:b7:82:6d:dc
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
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
|
|
||||||
bP6MvPJwNQzcmRk13NfIRmPVNnGuV/u3gm3c
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
38
certs/GTS-Root-R1.pem
Normal file
|
|
@ -0,0 +1,38 @@
|
||||||
|
# Issuer: CN=GTS Root R1 O=Google Trust Services LLC
|
||||||
|
# Subject: CN=GTS Root R1 O=Google Trust Services LLC
|
||||||
|
# Label: "GTS Root R1"
|
||||||
|
# Serial: 159662320309726417404178440727
|
||||||
|
# MD5 Fingerprint: 05:fe:d0:bf:71:a8:a3:76:63:da:01:e0:d8:52:dc:40
|
||||||
|
# SHA1 Fingerprint: e5:8c:1c:c4:91:3b:38:63:4b:e9:10:6e:e3:ad:8e:6b:9d:d9:81:4a
|
||||||
|
# SHA256 Fingerprint: d9:47:43:2a:bd:e7:b7:fa:90:fc:2e:6b:59:10:1b:12:80:e0:e1:c7:e4:e4:0f:a3:c6:88:7f:ff:57:a7:f4:cf
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
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
|
||||||
|
bP6MvPJwNQzcmRk13NfIRmPVNnGuV/u3gm3c
|
||||||
|
-----END CERTIFICATE-----
|
||||||
20
certs/GTS-Root-R4.pem
Normal file
|
|
@ -0,0 +1,20 @@
|
||||||
|
# Issuer: CN=GTS Root R4 O=Google Trust Services LLC
|
||||||
|
# Subject: CN=GTS Root R4 O=Google Trust Services LLC
|
||||||
|
# Label: "GTS Root R4"
|
||||||
|
# Serial: 159662532700760215368942768210
|
||||||
|
# MD5 Fingerprint: 43:96:83:77:19:4d:76:b3:9d:65:52:e4:1d:22:a5:e8
|
||||||
|
# SHA1 Fingerprint: 77:d3:03:67:b5:e0:0c:15:f6:0c:38:61:df:7c:e1:3b:92:46:4d:47
|
||||||
|
# SHA256 Fingerprint: 34:9d:fa:40:58:c5:e2:63:12:3b:39:8a:e7:95:57:3c:4e:13:13:c8:3f:e6:8f:93:55:6c:d5:e8:03:1b:3c:7d
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIICCTCCAY6gAwIBAgINAgPlwGjvYxqccpBQUjAKBggqhkjOPQQDAzBHMQswCQYD
|
||||||
|
VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG
|
||||||
|
A1UEAxMLR1RTIFJvb3QgUjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw
|
||||||
|
WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz
|
||||||
|
IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcqhkjOPQIBBgUrgQQAIgNi
|
||||||
|
AATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa6zzuhXyi
|
||||||
|
QHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/lxKvR
|
||||||
|
HYqjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW
|
||||||
|
BBSATNbrdP9JNqPV2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNpADBmAjEA6ED/g94D
|
||||||
|
9J+uHXqnLrmvT/aDHQ4thQEd0dlq7A/Cr8deVl5c1RxYIigL9zC2L7F8AjEA8GE8
|
||||||
|
p/SgguMh1YQdc4acLa/KNJvxn7kjNuK8YAOdgLOaVsjh4rsUecrNIdSUtUlD
|
||||||
|
-----END CERTIFICATE-----
|
||||||
|
|
@ -1,177 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
7c:2a:0c:21:3f:c6:55:53:45:c9:1f:19:1f:b8:4e:fa
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: OU = GlobalSign Root CA - R3, O = GlobalSign, CN = GlobalSign
|
|
||||||
Validity
|
|
||||||
Not Before: Apr 20 12:00:00 2022 GMT
|
|
||||||
Not After : Apr 20 00:00:00 2025 GMT
|
|
||||||
Subject: C = BE, O = GlobalSign nv-sa, CN = GlobalSign Atlas R3 DV TLS CA 2022 Q3
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:b8:a8:7a:66:3c:4e:66:9c:ce:37:a5:54:35:4d:
|
|
||||||
36:c7:99:d3:a8:27:36:f2:2f:c6:d5:18:3e:e9:09:
|
|
||||||
dd:05:d6:d7:2c:34:32:7c:08:63:49:d1:10:37:e5:
|
|
||||||
78:5d:11:62:ce:6d:fb:2f:3f:37:94:db:8f:7b:30:
|
|
||||||
e9:5e:2c:d9:55:3f:b2:db:b9:a0:b5:60:37:8b:a4:
|
|
||||||
06:32:35:50:a4:09:af:0a:45:ff:a8:1f:9b:65:8e:
|
|
||||||
dd:4a:e0:40:a1:e3:63:37:58:90:dd:75:3b:fc:0e:
|
|
||||||
1c:82:40:98:bd:70:b1:c1:48:14:14:3c:04:4b:69:
|
|
||||||
dd:d4:9c:01:a6:e9:21:e3:82:0a:fe:e4:aa:bf:34:
|
|
||||||
a0:8c:cb:c9:79:6e:3e:5c:6a:52:9e:c4:ed:2b:c5:
|
|
||||||
69:fe:50:3c:93:9d:b5:ff:2d:28:a8:6c:06:6c:9d:
|
|
||||||
c5:af:b2:59:fb:59:77:0d:74:7a:88:84:a4:d4:1d:
|
|
||||||
d4:ba:20:06:cc:b5:1e:48:4e:74:21:15:86:75:c0:
|
|
||||||
cc:5a:d1:05:cf:57:16:7a:13:17:ec:c2:4a:ae:d5:
|
|
||||||
1e:72:aa:22:5a:8c:9c:82:32:c4:10:e6:42:6e:21:
|
|
||||||
86:68:7c:80:23:30:35:d3:bd:b0:5e:0a:29:2b:f0:
|
|
||||||
14:b1:18:37:d9:59:25:c3:e7:38:d9:e9:d4:2d:36:
|
|
||||||
35:65
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Extended Key Usage:
|
|
||||||
TLS Web Server Authentication, TLS Web Client Authentication
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:0
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
FA:91:39:63:9A:FB:AD:10:24:E5:BE:B5:B9:DA:AB:D9:C4:46:69:AB
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
8F:F0:4B:7F:A8:2E:45:24:AE:4D:50:FA:63:9A:8B:DE:E2:DD:1B:BC
|
|
||||||
Authority Information Access:
|
|
||||||
OCSP - URI:http://ocsp2.globalsign.com/rootr3
|
|
||||||
CA Issuers - URI:http://secure.globalsign.com/cacert/root-r3.crt
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
Full Name:
|
|
||||||
URI:http://crl.globalsign.com/root-r3.crl
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: 2.23.140.1.2.1
|
|
||||||
Policy: 1.3.6.1.4.1.4146.10.1.3
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Signature Value:
|
|
||||||
14:33:2c:79:e5:3f:82:c6:70:3f:da:59:38:a7:bb:a2:76:ac:
|
|
||||||
61:18:05:68:57:d9:0d:fb:8a:46:bc:f1:a8:e8:0c:70:02:1d:
|
|
||||||
c6:2f:97:ed:36:3e:9e:52:86:2f:5c:62:d8:d5:47:43:9a:73:
|
|
||||||
d1:2b:25:87:9f:44:b4:14:eb:26:bc:21:47:74:20:bd:9f:a4:
|
|
||||||
bf:b3:80:1d:4d:35:7d:cd:b9:b5:da:55:f2:90:50:c8:b2:17:
|
|
||||||
4e:0e:b4:61:88:29:5f:44:5d:03:7f:57:91:81:d0:eb:30:ae:
|
|
||||||
d5:2a:ec:82:20:ce:4e:d2:b0:8b:95:02:61:73:d8:69:34:f4:
|
|
||||||
ad:63:0e:5c:e4:20:1f:a9:7d:ed:8e:e5:1c:04:bb:22:9f:c7:
|
|
||||||
a9:22:ca:99:3d:02:a7:67:e8:06:2d:fa:04:6b:bb:49:d2:6c:
|
|
||||||
99:57:63:6c:2d:c2:61:78:e1:20:b1:fb:f6:bf:e1:82:39:39:
|
|
||||||
3c:7b:ef:7d:1a:95:4a:b2:72:da:55:90:ae:ed:dd:e2:70:90:
|
|
||||||
7c:1a:ee:b5:32:5a:5d:cf:d6:fa:45:f2:9e:01:0c:31:2f:89:
|
|
||||||
84:fe:31:60:0f:fd:ee:a6:5b:84:d5:c7:18:e6:a4:f9:40:30:
|
|
||||||
29:18:1e:fe:fc:41:b5:b9:29:05:75:8b:62:1a:5b:22:2e:bf:
|
|
||||||
e4:59:6c:b0
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIEjzCCA3egAwIBAgIQfCoMIT/GVVNFyR8ZH7hO+jANBgkqhkiG9w0BAQsFADBM
|
|
||||||
MSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMzETMBEGA1UEChMKR2xv
|
|
||||||
YmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjAeFw0yMjA0MjAxMjAwMDBaFw0y
|
|
||||||
NTA0MjAwMDAwMDBaMFgxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWdu
|
|
||||||
IG52LXNhMS4wLAYDVQQDEyVHbG9iYWxTaWduIEF0bGFzIFIzIERWIFRMUyBDQSAy
|
|
||||||
MDIyIFEzMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuKh6ZjxOZpzO
|
|
||||||
N6VUNU02x5nTqCc28i/G1Rg+6QndBdbXLDQyfAhjSdEQN+V4XRFizm37Lz83lNuP
|
|
||||||
ezDpXizZVT+y27mgtWA3i6QGMjVQpAmvCkX/qB+bZY7dSuBAoeNjN1iQ3XU7/A4c
|
|
||||||
gkCYvXCxwUgUFDwES2nd1JwBpukh44IK/uSqvzSgjMvJeW4+XGpSnsTtK8Vp/lA8
|
|
||||||
k521/y0oqGwGbJ3Fr7JZ+1l3DXR6iISk1B3UuiAGzLUeSE50IRWGdcDMWtEFz1cW
|
|
||||||
ehMX7MJKrtUecqoiWoycgjLEEOZCbiGGaHyAIzA1072wXgopK/AUsRg32Vklw+c4
|
|
||||||
2enULTY1ZQIDAQABo4IBXzCCAVswDgYDVR0PAQH/BAQDAgGGMB0GA1UdJQQWMBQG
|
|
||||||
CCsGAQUFBwMBBggrBgEFBQcDAjASBgNVHRMBAf8ECDAGAQH/AgEAMB0GA1UdDgQW
|
|
||||||
BBT6kTljmvutECTlvrW52qvZxEZpqzAfBgNVHSMEGDAWgBSP8Et/qC5FJK5NUPpj
|
|
||||||
move4t0bvDB7BggrBgEFBQcBAQRvMG0wLgYIKwYBBQUHMAGGImh0dHA6Ly9vY3Nw
|
|
||||||
Mi5nbG9iYWxzaWduLmNvbS9yb290cjMwOwYIKwYBBQUHMAKGL2h0dHA6Ly9zZWN1
|
|
||||||
cmUuZ2xvYmFsc2lnbi5jb20vY2FjZXJ0L3Jvb3QtcjMuY3J0MDYGA1UdHwQvMC0w
|
|
||||||
K6ApoCeGJWh0dHA6Ly9jcmwuZ2xvYmFsc2lnbi5jb20vcm9vdC1yMy5jcmwwIQYD
|
|
||||||
VR0gBBowGDAIBgZngQwBAgEwDAYKKwYBBAGgMgoBAzANBgkqhkiG9w0BAQsFAAOC
|
|
||||||
AQEAFDMseeU/gsZwP9pZOKe7onasYRgFaFfZDfuKRrzxqOgMcAIdxi+X7TY+nlKG
|
|
||||||
L1xi2NVHQ5pz0Sslh59EtBTrJrwhR3QgvZ+kv7OAHU01fc25tdpV8pBQyLIXTg60
|
|
||||||
YYgpX0RdA39XkYHQ6zCu1SrsgiDOTtKwi5UCYXPYaTT0rWMOXOQgH6l97Y7lHAS7
|
|
||||||
Ip/HqSLKmT0Cp2foBi36BGu7SdJsmVdjbC3CYXjhILH79r/hgjk5PHvvfRqVSrJy
|
|
||||||
2lWQru3d4nCQfBrutTJaXc/W+kXyngEMMS+JhP4xYA/97qZbhNXHGOak+UAwKRge
|
|
||||||
/vxBtbkpBXWLYhpbIi6/5FlssA==
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
04:00:00:00:00:01:21:58:53:08:a2
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: OU = GlobalSign Root CA - R3, O = GlobalSign, CN = GlobalSign
|
|
||||||
Validity
|
|
||||||
Not Before: Mar 18 10:00:00 2009 GMT
|
|
||||||
Not After : Mar 18 10:00:00 2029 GMT
|
|
||||||
Subject: OU = GlobalSign Root CA - R3, O = GlobalSign, CN = GlobalSign
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:cc:25:76:90:79:06:78:22:16:f5:c0:83:b6:84:
|
|
||||||
ca:28:9e:fd:05:76:11:c5:ad:88:72:fc:46:02:43:
|
|
||||||
c7:b2:8a:9d:04:5f:24:cb:2e:4b:e1:60:82:46:e1:
|
|
||||||
52:ab:0c:81:47:70:6c:dd:64:d1:eb:f5:2c:a3:0f:
|
|
||||||
82:3d:0c:2b:ae:97:d7:b6:14:86:10:79:bb:3b:13:
|
|
||||||
80:77:8c:08:e1:49:d2:6a:62:2f:1f:5e:fa:96:68:
|
|
||||||
df:89:27:95:38:9f:06:d7:3e:c9:cb:26:59:0d:73:
|
|
||||||
de:b0:c8:e9:26:0e:83:15:c6:ef:5b:8b:d2:04:60:
|
|
||||||
ca:49:a6:28:f6:69:3b:f6:cb:c8:28:91:e5:9d:8a:
|
|
||||||
61:57:37:ac:74:14:dc:74:e0:3a:ee:72:2f:2e:9c:
|
|
||||||
fb:d0:bb:bf:f5:3d:00:e1:06:33:e8:82:2b:ae:53:
|
|
||||||
a6:3a:16:73:8c:dd:41:0e:20:3a:c0:b4:a7:a1:e9:
|
|
||||||
b2:4f:90:2e:32:60:e9:57:cb:b9:04:92:68:68:e5:
|
|
||||||
38:26:60:75:b2:9f:77:ff:91:14:ef:ae:20:49:fc:
|
|
||||||
ad:40:15:48:d1:02:31:61:19:5e:b8:97:ef:ad:77:
|
|
||||||
b7:64:9a:7a:bf:5f:c1:13:ef:9b:62:fb:0d:6c:e0:
|
|
||||||
54:69:16:a9:03:da:6e:e9:83:93:71:76:c6:69:85:
|
|
||||||
82:17
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
8F:F0:4B:7F:A8:2E:45:24:AE:4D:50:FA:63:9A:8B:DE:E2:DD:1B:BC
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Signature Value:
|
|
||||||
4b:40:db:c0:50:aa:fe:c8:0c:ef:f7:96:54:45:49:bb:96:00:
|
|
||||||
09:41:ac:b3:13:86:86:28:07:33:ca:6b:e6:74:b9:ba:00:2d:
|
|
||||||
ae:a4:0a:d3:f5:f1:f1:0f:8a:bf:73:67:4a:83:c7:44:7b:78:
|
|
||||||
e0:af:6e:6c:6f:03:29:8e:33:39:45:c3:8e:e4:b9:57:6c:aa:
|
|
||||||
fc:12:96:ec:53:c6:2d:e4:24:6c:b9:94:63:fb:dc:53:68:67:
|
|
||||||
56:3e:83:b8:cf:35:21:c3:c9:68:fe:ce:da:c2:53:aa:cc:90:
|
|
||||||
8a:e9:f0:5d:46:8c:95:dd:7a:58:28:1a:2f:1d:de:cd:00:37:
|
|
||||||
41:8f:ed:44:6d:d7:53:28:97:7e:f3:67:04:1e:15:d7:8a:96:
|
|
||||||
b4:d3:de:4c:27:a4:4c:1b:73:73:76:f4:17:99:c2:1f:7a:0e:
|
|
||||||
e3:2d:08:ad:0a:1c:2c:ff:3c:ab:55:0e:0f:91:7e:36:eb:c3:
|
|
||||||
57:49:be:e1:2e:2d:7c:60:8b:c3:41:51:13:23:9d:ce:f7:32:
|
|
||||||
6b:94:01:a8:99:e7:2c:33:1f:3a:3b:25:d2:86:40:ce:3b:2c:
|
|
||||||
86:78:c9:61:2f:14:ba:ee:db:55:6f:df:84:ee:05:09:4d:bd:
|
|
||||||
28:d8:72:ce:d3:62:50:65:1e:eb:92:97:83:31:d9:b3:b5:ca:
|
|
||||||
47:58:3f:5f
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIDXzCCAkegAwIBAgILBAAAAAABIVhTCKIwDQYJKoZIhvcNAQELBQAwTDEgMB4G
|
|
||||||
A1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjMxEzARBgNVBAoTCkdsb2JhbFNp
|
|
||||||
Z24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMDkwMzE4MTAwMDAwWhcNMjkwMzE4
|
|
||||||
MTAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMzETMBEG
|
|
||||||
A1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCASIwDQYJKoZI
|
|
||||||
hvcNAQEBBQADggEPADCCAQoCggEBAMwldpB5BngiFvXAg7aEyiie/QV2EcWtiHL8
|
|
||||||
RgJDx7KKnQRfJMsuS+FggkbhUqsMgUdwbN1k0ev1LKMPgj0MK66X17YUhhB5uzsT
|
|
||||||
gHeMCOFJ0mpiLx9e+pZo34knlTifBtc+ycsmWQ1z3rDI6SYOgxXG71uL0gRgykmm
|
|
||||||
KPZpO/bLyCiR5Z2KYVc3rHQU3HTgOu5yLy6c+9C7v/U9AOEGM+iCK65TpjoWc4zd
|
|
||||||
QQ4gOsC0p6Hpsk+QLjJg6VfLuQSSaGjlOCZgdbKfd/+RFO+uIEn8rUAVSNECMWEZ
|
|
||||||
XriX7613t2Saer9fwRPvm2L7DWzgVGkWqQPabumDk3F2xmmFghcCAwEAAaNCMEAw
|
|
||||||
DgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI/wS3+o
|
|
||||||
LkUkrk1Q+mOai97i3Ru8MA0GCSqGSIb3DQEBCwUAA4IBAQBLQNvAUKr+yAzv95ZU
|
|
||||||
RUm7lgAJQayzE4aGKAczymvmdLm6AC2upArT9fHxD4q/c2dKg8dEe3jgr25sbwMp
|
|
||||||
jjM5RcOO5LlXbKr8EpbsU8Yt5CRsuZRj+9xTaGdWPoO4zzUhw8lo/s7awlOqzJCK
|
|
||||||
6fBdRoyV3XpYKBovHd7NADdBj+1EbddTKJd+82cEHhXXipa0095MJ6RMG3NzdvQX
|
|
||||||
mcIfeg7jLQitChws/zyrVQ4PkX4268NXSb7hLi18YIvDQVETI53O9zJrlAGomecs
|
|
||||||
Mx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7rkpeDMdmztcpH
|
|
||||||
WD9f
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
|
|
@ -1,178 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number: 7 (0x7)
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C = US, ST = Arizona, L = Scottsdale, O = "GoDaddy.com, Inc.", CN = Go Daddy Root Certificate Authority - G2
|
|
||||||
Validity
|
|
||||||
Not Before: May 3 07:00:00 2011 GMT
|
|
||||||
Not After : May 3 07:00:00 2031 GMT
|
|
||||||
Subject: C = US, ST = Arizona, L = Scottsdale, O = "GoDaddy.com, Inc.", OU = http://certs.godaddy.com/repository/, CN = Go Daddy Secure Certificate Authority - G2
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:b9:e0:cb:10:d4:af:76:bd:d4:93:62:eb:30:64:
|
|
||||||
b8:81:08:6c:c3:04:d9:62:17:8e:2f:ff:3e:65:cf:
|
|
||||||
8f:ce:62:e6:3c:52:1c:da:16:45:4b:55:ab:78:6b:
|
|
||||||
63:83:62:90:ce:0f:69:6c:99:c8:1a:14:8b:4c:cc:
|
|
||||||
45:33:ea:88:dc:9e:a3:af:2b:fe:80:61:9d:79:57:
|
|
||||||
c4:cf:2e:f4:3f:30:3c:5d:47:fc:9a:16:bc:c3:37:
|
|
||||||
96:41:51:8e:11:4b:54:f8:28:be:d0:8c:be:f0:30:
|
|
||||||
38:1e:f3:b0:26:f8:66:47:63:6d:de:71:26:47:8f:
|
|
||||||
38:47:53:d1:46:1d:b4:e3:dc:00:ea:45:ac:bd:bc:
|
|
||||||
71:d9:aa:6f:00:db:db:cd:30:3a:79:4f:5f:4c:47:
|
|
||||||
f8:1d:ef:5b:c2:c4:9d:60:3b:b1:b2:43:91:d8:a4:
|
|
||||||
33:4e:ea:b3:d6:27:4f:ad:25:8a:a5:c6:f4:d5:d0:
|
|
||||||
a6:ae:74:05:64:57:88:b5:44:55:d4:2d:2a:3a:3e:
|
|
||||||
f8:b8:bd:e9:32:0a:02:94:64:c4:16:3a:50:f1:4a:
|
|
||||||
ae:e7:79:33:af:0c:20:07:7f:e8:df:04:39:c2:69:
|
|
||||||
02:6c:63:52:fa:77:c1:1b:c8:74:87:c8:b9:93:18:
|
|
||||||
50:54:35:4b:69:4e:bc:3b:d3:49:2e:1f:dc:c1:d2:
|
|
||||||
52:fb
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
40:C2:BD:27:8E:CC:34:83:30:A2:33:D7:FB:6C:B3:F0:B4:2C:80:CE
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:3A:9A:85:07:10:67:28:B6:EF:F6:BD:05:41:6E:20:C1:94:DA:0F:DE
|
|
||||||
|
|
||||||
Authority Information Access:
|
|
||||||
OCSP - URI:http://ocsp.godaddy.com/
|
|
||||||
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
|
|
||||||
Full Name:
|
|
||||||
URI:http://crl.godaddy.com/gdroot-g2.crl
|
|
||||||
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: X509v3 Any Policy
|
|
||||||
CPS: https://certs.godaddy.com/repository/
|
|
||||||
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
08:7e:6c:93:10:c8:38:b8:96:a9:90:4b:ff:a1:5f:4f:04:ef:
|
|
||||||
6c:3e:9c:88:06:c9:50:8f:a6:73:f7:57:31:1b:be:bc:e4:2f:
|
|
||||||
db:f8:ba:d3:5b:e0:b4:e7:e6:79:62:0e:0c:a2:d7:6a:63:73:
|
|
||||||
31:b5:f5:a8:48:a4:3b:08:2d:a2:5d:90:d7:b4:7c:25:4f:11:
|
|
||||||
56:30:c4:b6:44:9d:7b:2c:9d:e5:5e:e6:ef:0c:61:aa:bf:e4:
|
|
||||||
2a:1b:ee:84:9e:b8:83:7d:c1:43:ce:44:a7:13:70:0d:91:1f:
|
|
||||||
f4:c8:13:ad:83:60:d9:d8:72:a8:73:24:1e:b5:ac:22:0e:ca:
|
|
||||||
17:89:62:58:44:1b:ab:89:25:01:00:0f:cd:c4:1b:62:db:51:
|
|
||||||
b4:d3:0f:51:2a:9b:f4:bc:73:fc:76:ce:36:a4:cd:d9:d8:2c:
|
|
||||||
ea:ae:9b:f5:2a:b2:90:d1:4d:75:18:8a:3f:8a:41:90:23:7d:
|
|
||||||
5b:4b:fe:a4:03:58:9b:46:b2:c3:60:60:83:f8:7d:50:41:ce:
|
|
||||||
c2:a1:90:c3:bb:ef:02:2f:d2:15:54:ee:44:15:d9:0a:ae:a7:
|
|
||||||
8a:33:ed:b1:2d:76:36:26:dc:04:eb:9f:f7:61:1f:15:dc:87:
|
|
||||||
6f:ee:46:96:28:ad:a1:26:7d:0a:09:a7:2e:04:a3:8d:bc:f8:
|
|
||||||
bc:04:30:01
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIE0DCCA7igAwIBAgIBBzANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMx
|
|
||||||
EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoT
|
|
||||||
EUdvRGFkZHkuY29tLCBJbmMuMTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRp
|
|
||||||
ZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTExMDUwMzA3MDAwMFoXDTMxMDUwMzA3
|
|
||||||
MDAwMFowgbQxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQH
|
|
||||||
EwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjEtMCsGA1UE
|
|
||||||
CxMkaHR0cDovL2NlcnRzLmdvZGFkZHkuY29tL3JlcG9zaXRvcnkvMTMwMQYDVQQD
|
|
||||||
EypHbyBEYWRkeSBTZWN1cmUgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IC0gRzIwggEi
|
|
||||||
MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC54MsQ1K92vdSTYuswZLiBCGzD
|
|
||||||
BNliF44v/z5lz4/OYuY8UhzaFkVLVat4a2ODYpDOD2lsmcgaFItMzEUz6ojcnqOv
|
|
||||||
K/6AYZ15V8TPLvQ/MDxdR/yaFrzDN5ZBUY4RS1T4KL7QjL7wMDge87Am+GZHY23e
|
|
||||||
cSZHjzhHU9FGHbTj3ADqRay9vHHZqm8A29vNMDp5T19MR/gd71vCxJ1gO7GyQ5HY
|
|
||||||
pDNO6rPWJ0+tJYqlxvTV0KaudAVkV4i1RFXULSo6Pvi4vekyCgKUZMQWOlDxSq7n
|
|
||||||
eTOvDCAHf+jfBDnCaQJsY1L6d8EbyHSHyLmTGFBUNUtpTrw700kuH9zB0lL7AgMB
|
|
||||||
AAGjggEaMIIBFjAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNV
|
|
||||||
HQ4EFgQUQMK9J47MNIMwojPX+2yz8LQsgM4wHwYDVR0jBBgwFoAUOpqFBxBnKLbv
|
|
||||||
9r0FQW4gwZTaD94wNAYIKwYBBQUHAQEEKDAmMCQGCCsGAQUFBzABhhhodHRwOi8v
|
|
||||||
b2NzcC5nb2RhZGR5LmNvbS8wNQYDVR0fBC4wLDAqoCigJoYkaHR0cDovL2NybC5n
|
|
||||||
b2RhZGR5LmNvbS9nZHJvb3QtZzIuY3JsMEYGA1UdIAQ/MD0wOwYEVR0gADAzMDEG
|
|
||||||
CCsGAQUFBwIBFiVodHRwczovL2NlcnRzLmdvZGFkZHkuY29tL3JlcG9zaXRvcnkv
|
|
||||||
MA0GCSqGSIb3DQEBCwUAA4IBAQAIfmyTEMg4uJapkEv/oV9PBO9sPpyIBslQj6Zz
|
|
||||||
91cxG7685C/b+LrTW+C05+Z5Yg4MotdqY3MxtfWoSKQ7CC2iXZDXtHwlTxFWMMS2
|
|
||||||
RJ17LJ3lXubvDGGqv+QqG+6EnriDfcFDzkSnE3ANkR/0yBOtg2DZ2HKocyQetawi
|
|
||||||
DsoXiWJYRBuriSUBAA/NxBti21G00w9RKpv0vHP8ds42pM3Z2Czqrpv1KrKQ0U11
|
|
||||||
GIo/ikGQI31bS/6kA1ibRrLDYGCD+H1QQc7CoZDDu+8CL9IVVO5EFdkKrqeKM+2x
|
|
||||||
LXY2JtwE65/3YR8V3Idv7kaWKK2hJn0KCacuBKONvPi8BDAB
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number: 0 (0x0)
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C = US, ST = Arizona, L = Scottsdale, O = "GoDaddy.com, Inc.", CN = Go Daddy Root Certificate Authority - G2
|
|
||||||
Validity
|
|
||||||
Not Before: Sep 1 00:00:00 2009 GMT
|
|
||||||
Not After : Dec 31 23:59:59 2037 GMT
|
|
||||||
Subject: C = US, ST = Arizona, L = Scottsdale, O = "GoDaddy.com, Inc.", CN = Go Daddy Root Certificate Authority - G2
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:bf:71:62:08:f1:fa:59:34:f7:1b:c9:18:a3:f7:
|
|
||||||
80:49:58:e9:22:83:13:a6:c5:20:43:01:3b:84:f1:
|
|
||||||
e6:85:49:9f:27:ea:f6:84:1b:4e:a0:b4:db:70:98:
|
|
||||||
c7:32:01:b1:05:3e:07:4e:ee:f4:fa:4f:2f:59:30:
|
|
||||||
22:e7:ab:19:56:6b:e2:80:07:fc:f3:16:75:80:39:
|
|
||||||
51:7b:e5:f9:35:b6:74:4e:a9:8d:82:13:e4:b6:3f:
|
|
||||||
a9:03:83:fa:a2:be:8a:15:6a:7f:de:0b:c3:b6:19:
|
|
||||||
14:05:ca:ea:c3:a8:04:94:3b:46:7c:32:0d:f3:00:
|
|
||||||
66:22:c8:8d:69:6d:36:8c:11:18:b7:d3:b2:1c:60:
|
|
||||||
b4:38:fa:02:8c:ce:d3:dd:46:07:de:0a:3e:eb:5d:
|
|
||||||
7c:c8:7c:fb:b0:2b:53:a4:92:62:69:51:25:05:61:
|
|
||||||
1a:44:81:8c:2c:a9:43:96:23:df:ac:3a:81:9a:0e:
|
|
||||||
29:c5:1c:a9:e9:5d:1e:b6:9e:9e:30:0a:39:ce:f1:
|
|
||||||
88:80:fb:4b:5d:cc:32:ec:85:62:43:25:34:02:56:
|
|
||||||
27:01:91:b4:3b:70:2a:3f:6e:b1:e8:9c:88:01:7d:
|
|
||||||
9f:d4:f9:db:53:6d:60:9d:bf:2c:e7:58:ab:b8:5f:
|
|
||||||
46:fc:ce:c4:1b:03:3c:09:eb:49:31:5c:69:46:b3:
|
|
||||||
e0:47
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
3A:9A:85:07:10:67:28:B6:EF:F6:BD:05:41:6E:20:C1:94:DA:0F:DE
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
99:db:5d:79:d5:f9:97:59:67:03:61:f1:7e:3b:06:31:75:2d:
|
|
||||||
a1:20:8e:4f:65:87:b4:f7:a6:9c:bc:d8:e9:2f:d0:db:5a:ee:
|
|
||||||
cf:74:8c:73:b4:38:42:da:05:7b:f8:02:75:b8:fd:a5:b1:d7:
|
|
||||||
ae:f6:d7:de:13:cb:53:10:7e:8a:46:d1:97:fa:b7:2e:2b:11:
|
|
||||||
ab:90:b0:27:80:f9:e8:9f:5a:e9:37:9f:ab:e4:df:6c:b3:85:
|
|
||||||
17:9d:3d:d9:24:4f:79:91:35:d6:5f:04:eb:80:83:ab:9a:02:
|
|
||||||
2d:b5:10:f4:d8:90:c7:04:73:40:ed:72:25:a0:a9:9f:ec:9e:
|
|
||||||
ab:68:12:99:57:c6:8f:12:3a:09:a4:bd:44:fd:06:15:37:c1:
|
|
||||||
9b:e4:32:a3:ed:38:e8:d8:64:f3:2c:7e:14:fc:02:ea:9f:cd:
|
|
||||||
ff:07:68:17:db:22:90:38:2d:7a:8d:d1:54:f1:69:e3:5f:33:
|
|
||||||
ca:7a:3d:7b:0a:e3:ca:7f:5f:39:e5:e2:75:ba:c5:76:18:33:
|
|
||||||
ce:2c:f0:2f:4c:ad:f7:b1:e7:ce:4f:a8:c4:9b:4a:54:06:c5:
|
|
||||||
7f:7d:d5:08:0f:e2:1c:fe:7e:17:b8:ac:5e:f6:d4:16:b2:43:
|
|
||||||
09:0c:4d:f6:a7:6b:b4:99:84:65:ca:7a:88:e2:e2:44:be:5c:
|
|
||||||
f7:ea:1c:f5
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMx
|
|
||||||
EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoT
|
|
||||||
EUdvRGFkZHkuY29tLCBJbmMuMTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRp
|
|
||||||
ZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIz
|
|
||||||
NTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQH
|
|
||||||
EwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8GA1UE
|
|
||||||
AxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIw
|
|
||||||
DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKD
|
|
||||||
E6bFIEMBO4Tx5oVJnyfq9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH
|
|
||||||
/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD+qK+ihVqf94Lw7YZFAXK6sOoBJQ7Rnwy
|
|
||||||
DfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutdfMh8+7ArU6SSYmlRJQVh
|
|
||||||
GkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMlNAJWJwGR
|
|
||||||
tDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEA
|
|
||||||
AaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE
|
|
||||||
FDqahQcQZyi27/a9BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmX
|
|
||||||
WWcDYfF+OwYxdS2hII5PZYe096acvNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu
|
|
||||||
9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r5N9ss4UXnT3ZJE95kTXWXwTr
|
|
||||||
gIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYVN8Gb5DKj7Tjo
|
|
||||||
2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO
|
|
||||||
LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI
|
|
||||||
4uJEvlz36hz1
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
30
certs/Go-Daddy-Root-Certificate-Authority-G2.pem
Normal file
|
|
@ -0,0 +1,30 @@
|
||||||
|
# Issuer: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc.
|
||||||
|
# Subject: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc.
|
||||||
|
# Label: "Go Daddy Root Certificate Authority - G2"
|
||||||
|
# Serial: 0
|
||||||
|
# MD5 Fingerprint: 80:3a:bc:22:c1:e6:fb:8d:9b:3b:27:4a:32:1b:9a:01
|
||||||
|
# SHA1 Fingerprint: 47:be:ab:c9:22:ea:e8:0e:78:78:34:62:a7:9f:45:c2:54:fd:e6:8b
|
||||||
|
# SHA256 Fingerprint: 45:14:0b:32:47:eb:9c:c8:c5:b4:f0:d7:b5:30:91:f7:32:92:08:9e:6e:5a:63:e2:74:9d:d3:ac:a9:19:8e:da
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMx
|
||||||
|
EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoT
|
||||||
|
EUdvRGFkZHkuY29tLCBJbmMuMTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRp
|
||||||
|
ZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIz
|
||||||
|
NTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQH
|
||||||
|
EwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8GA1UE
|
||||||
|
AxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIw
|
||||||
|
DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKD
|
||||||
|
E6bFIEMBO4Tx5oVJnyfq9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH
|
||||||
|
/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD+qK+ihVqf94Lw7YZFAXK6sOoBJQ7Rnwy
|
||||||
|
DfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutdfMh8+7ArU6SSYmlRJQVh
|
||||||
|
GkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMlNAJWJwGR
|
||||||
|
tDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEA
|
||||||
|
AaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE
|
||||||
|
FDqahQcQZyi27/a9BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmX
|
||||||
|
WWcDYfF+OwYxdS2hII5PZYe096acvNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu
|
||||||
|
9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r5N9ss4UXnT3ZJE95kTXWXwTr
|
||||||
|
gIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYVN8Gb5DKj7Tjo
|
||||||
|
2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO
|
||||||
|
LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI
|
||||||
|
4uJEvlz36hz1
|
||||||
|
-----END CERTIFICATE-----
|
||||||
38
certs/ISRG-Root-X1.pem
Normal file
|
|
@ -0,0 +1,38 @@
|
||||||
|
# Issuer: CN=ISRG Root X1 O=Internet Security Research Group
|
||||||
|
# Subject: CN=ISRG Root X1 O=Internet Security Research Group
|
||||||
|
# Label: "ISRG Root X1"
|
||||||
|
# Serial: 172886928669790476064670243504169061120
|
||||||
|
# MD5 Fingerprint: 0c:d2:f9:e0:da:17:73:e9:ed:86:4d:a5:e3:70:e7:4e
|
||||||
|
# SHA1 Fingerprint: ca:bd:2a:79:a1:07:6a:31:f2:1d:25:36:35:cb:03:9d:43:29:a5:e8
|
||||||
|
# SHA256 Fingerprint: 96:bc:ec:06:26:49:76:f3:74:60:77:9a:cf:28:c5:a7:cf:e8:a3:c0:aa:e1:1a:8f:fc:ee:05:c0:bd:df:08:c6
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
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
|
||||||
|
-----END CERTIFICATE-----
|
||||||
21
certs/ISRG-Root-X2.pem
Normal file
|
|
@ -0,0 +1,21 @@
|
||||||
|
# Issuer: CN=ISRG Root X2 O=Internet Security Research Group
|
||||||
|
# Subject: CN=ISRG Root X2 O=Internet Security Research Group
|
||||||
|
# Label: "ISRG Root X2"
|
||||||
|
# Serial: 87493402998870891108772069816698636114
|
||||||
|
# MD5 Fingerprint: d3:9e:c4:1e:23:3c:a6:df:cf:a3:7e:6d:e0:14:e6:e5
|
||||||
|
# SHA1 Fingerprint: bd:b1:b9:3c:d5:97:8d:45:c6:26:14:55:f8:db:95:c7:5a:d1:53:af
|
||||||
|
# SHA256 Fingerprint: 69:72:9b:8e:15:a8:6e:fc:17:7a:57:af:b7:17:1d:fc:64:ad:d2:8c:2f:ca:8c:f1:50:7e:34:45:3c:cb:14:70
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIICGzCCAaGgAwIBAgIQQdKd0XLq7qeAwSxs6S+HUjAKBggqhkjOPQQDAzBPMQsw
|
||||||
|
CQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJuZXQgU2VjdXJpdHkgUmVzZWFyY2gg
|
||||||
|
R3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBYMjAeFw0yMDA5MDQwMDAwMDBaFw00
|
||||||
|
MDA5MTcxNjAwMDBaME8xCzAJBgNVBAYTAlVTMSkwJwYDVQQKEyBJbnRlcm5ldCBT
|
||||||
|
ZWN1cml0eSBSZXNlYXJjaCBHcm91cDEVMBMGA1UEAxMMSVNSRyBSb290IFgyMHYw
|
||||||
|
EAYHKoZIzj0CAQYFK4EEACIDYgAEzZvVn4CDCuwJSvMWSj5cz3es3mcFDR0HttwW
|
||||||
|
+1qLFNvicWDEukWVEYmO6gbf9yoWHKS5xcUy4APgHoIYOIvXRdgKam7mAHf7AlF9
|
||||||
|
ItgKbppbd9/w+kHsOdx1ymgHDB/qo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0T
|
||||||
|
AQH/BAUwAwEB/zAdBgNVHQ4EFgQUfEKWrt5LSDv6kviejM9ti6lyN5UwCgYIKoZI
|
||||||
|
zj0EAwMDaAAwZQIwe3lORlCEwkSHRhtFcP9Ymd70/aTSVaYgLXTWNLxBo1BfASdW
|
||||||
|
tL4ndQavEi51mI38AjEAi/V3bNTIZargCyzuFJ0nN6T5U6VR5CmD1/iQMVtCnwr1
|
||||||
|
/q4AaOeMSQ+2b1tbFfLn
|
||||||
|
-----END CERTIFICATE-----
|
||||||
58
certs/Makefile
Normal file
|
|
@ -0,0 +1,58 @@
|
||||||
|
# Makefile to check certificates
|
||||||
|
|
||||||
|
CURL = curl \
|
||||||
|
--capath /dev/null \
|
||||||
|
--connect-timeout 5 \
|
||||||
|
--output /dev/null \
|
||||||
|
--silent
|
||||||
|
|
||||||
|
DOMAINS_DUAL = \
|
||||||
|
api.macvendors.com/GTS-Root-R4 \
|
||||||
|
api.telegram.org/Go-Daddy-Root-Certificate-Authority-G2 \
|
||||||
|
cloudflare-dns.com/DigiCert-Global-Root-G2 \
|
||||||
|
dns.google/GTS-Root-R4 \
|
||||||
|
dns.quad9.net/DigiCert-Global-Root-G3 \
|
||||||
|
git.eworm.de/ISRG-Root-X2 \
|
||||||
|
lists.blocklist.de/Certum-Trusted-Network-CA \
|
||||||
|
matrix.org/GTS-Root-R4 \
|
||||||
|
raw.githubusercontent.com/USERTrust-RSA-Certification-Authority \
|
||||||
|
rsc.eworm.de/ISRG-Root-X2 \
|
||||||
|
upgrade.mikrotik.com/ISRG-Root-X1
|
||||||
|
DOMAINS_IPV4 = \
|
||||||
|
1.1.1.1/DigiCert-Global-Root-G2 \
|
||||||
|
8.8.8.8/GTS-Root-R1 \
|
||||||
|
9.9.9.9/DigiCert-Global-Root-G3 \
|
||||||
|
api.mullvad.net/ISRG-Root-X1 \
|
||||||
|
ipv4.showipv6.de/ISRG-Root-X1 \
|
||||||
|
ipv4.tunnelbroker.net/Starfield-Root-Certificate-Authority-G2 \
|
||||||
|
mkcert.org/ISRG-Root-X1 \
|
||||||
|
ntfy.sh/ISRG-Root-X1 \
|
||||||
|
www.dshield.org/ISRG-Root-X1 \
|
||||||
|
www.spamhaus.org/GTS-Root-R4
|
||||||
|
DOMAINS_IPV6 = \
|
||||||
|
[2606\:4700\:4700\:\:1111]/DigiCert-Global-Root-G2 \
|
||||||
|
[2001\:4860\:4860\:\:8888]/GTS-Root-R1 \
|
||||||
|
[2620\:fe\:\:9]/DigiCert-Global-Root-G3 \
|
||||||
|
ipv6.showipv6.de/ISRG-Root-X1
|
||||||
|
|
||||||
|
.PHONY: $(DOMAINS_DUAL) $(DOMAINS_IPV4) $(DOMAINS_IPV6)
|
||||||
|
|
||||||
|
all: $(DOMAINS_DUAL) $(DOMAINS_IPV4) $(DOMAINS_IPV6)
|
||||||
|
|
||||||
|
$(DOMAINS_DUAL):
|
||||||
|
ifndef NOIPV4
|
||||||
|
$(CURL) -4 --cacert $(notdir $@).pem https://$(dir $@)
|
||||||
|
endif
|
||||||
|
ifndef NOIPV6
|
||||||
|
$(CURL) -6 --cacert $(notdir $@).pem https://$(dir $@)
|
||||||
|
endif
|
||||||
|
|
||||||
|
$(DOMAINS_IPV4):
|
||||||
|
ifndef NOIPV4
|
||||||
|
$(CURL) -4 --cacert $(notdir $@).pem https://$(dir $@)
|
||||||
|
endif
|
||||||
|
|
||||||
|
$(DOMAINS_IPV6):
|
||||||
|
ifndef NOIPV6
|
||||||
|
$(CURL) -6 --cacert $(notdir $@).pem https://$(dir $@)
|
||||||
|
endif
|
||||||
237
certs/R3.pem
|
|
@ -1,237 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
91:2b:08:4a:cf:0c:18:a7:53:f6:d6:2e:25:a7:5f:5a
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C = US, O = Internet Security Research Group, CN = ISRG Root X1
|
|
||||||
Validity
|
|
||||||
Not Before: Sep 4 00:00:00 2020 GMT
|
|
||||||
Not After : Sep 15 16:00:00 2025 GMT
|
|
||||||
Subject: C = US, O = Let's Encrypt, CN = R3
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:bb:02:15:28:cc:f6:a0:94:d3:0f:12:ec:8d:55:
|
|
||||||
92:c3:f8:82:f1:99:a6:7a:42:88:a7:5d:26:aa:b5:
|
|
||||||
2b:b9:c5:4c:b1:af:8e:6b:f9:75:c8:a3:d7:0f:47:
|
|
||||||
94:14:55:35:57:8c:9e:a8:a2:39:19:f5:82:3c:42:
|
|
||||||
a9:4e:6e:f5:3b:c3:2e:db:8d:c0:b0:5c:f3:59:38:
|
|
||||||
e7:ed:cf:69:f0:5a:0b:1b:be:c0:94:24:25:87:fa:
|
|
||||||
37:71:b3:13:e7:1c:ac:e1:9b:ef:db:e4:3b:45:52:
|
|
||||||
45:96:a9:c1:53:ce:34:c8:52:ee:b5:ae:ed:8f:de:
|
|
||||||
60:70:e2:a5:54:ab:b6:6d:0e:97:a5:40:34:6b:2b:
|
|
||||||
d3:bc:66:eb:66:34:7c:fa:6b:8b:8f:57:29:99:f8:
|
|
||||||
30:17:5d:ba:72:6f:fb:81:c5:ad:d2:86:58:3d:17:
|
|
||||||
c7:e7:09:bb:f1:2b:f7:86:dc:c1:da:71:5d:d4:46:
|
|
||||||
e3:cc:ad:25:c1:88:bc:60:67:75:66:b3:f1:18:f7:
|
|
||||||
a2:5c:e6:53:ff:3a:88:b6:47:a5:ff:13:18:ea:98:
|
|
||||||
09:77:3f:9d:53:f9:cf:01:e5:f5:a6:70:17:14:af:
|
|
||||||
63:a4:ff:99:b3:93:9d:dc:53:a7:06:fe:48:85:1d:
|
|
||||||
a1:69:ae:25:75:bb:13:cc:52:03:f5:ed:51:a1:8b:
|
|
||||||
db:15
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Digital Signature, Certificate Sign, CRL Sign
|
|
||||||
X509v3 Extended Key Usage:
|
|
||||||
TLS Web Client Authentication, TLS Web Server Authentication
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE, pathlen:0
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
14:2E:B3:17:B7:58:56:CB:AE:50:09:40:E6:1F:AF:9D:8B:14:C2:C6
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:79:B4:59:E6:7B:B6:E5:E4:01:73:80:08:88:C8:1A:58:F6:E9:9B:6E
|
|
||||||
|
|
||||||
Authority Information Access:
|
|
||||||
CA Issuers - URI:http://x1.i.lencr.org/
|
|
||||||
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
|
|
||||||
Full Name:
|
|
||||||
URI:http://x1.c.lencr.org/
|
|
||||||
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: 2.23.140.1.2.1
|
|
||||||
Policy: 1.3.6.1.4.1.44947.1.1.1
|
|
||||||
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
85:ca:4e:47:3e:a3:f7:85:44:85:bc:d5:67:78:b2:98:63:ad:
|
|
||||||
75:4d:1e:96:3d:33:65:72:54:2d:81:a0:ea:c3:ed:f8:20:bf:
|
|
||||||
5f:cc:b7:70:00:b7:6e:3b:f6:5e:94:de:e4:20:9f:a6:ef:8b:
|
|
||||||
b2:03:e7:a2:b5:16:3c:91:ce:b4:ed:39:02:e7:7c:25:8a:47:
|
|
||||||
e6:65:6e:3f:46:f4:d9:f0:ce:94:2b:ee:54:ce:12:bc:8c:27:
|
|
||||||
4b:b8:c1:98:2f:a2:af:cd:71:91:4a:08:b7:c8:b8:23:7b:04:
|
|
||||||
2d:08:f9:08:57:3e:83:d9:04:33:0a:47:21:78:09:82:27:c3:
|
|
||||||
2a:c8:9b:b9:ce:5c:f2:64:c8:c0:be:79:c0:4f:8e:6d:44:0c:
|
|
||||||
5e:92:bb:2e:f7:8b:10:e1:e8:1d:44:29:db:59:20:ed:63:b9:
|
|
||||||
21:f8:12:26:94:93:57:a0:1d:65:04:c1:0a:22:ae:10:0d:43:
|
|
||||||
97:a1:18:1f:7e:e0:e0:86:37:b5:5a:b1:bd:30:bf:87:6e:2b:
|
|
||||||
2a:ff:21:4e:1b:05:c3:f5:18:97:f0:5e:ac:c3:a5:b8:6a:f0:
|
|
||||||
2e:bc:3b:33:b9:ee:4b:de:cc:fc:e4:af:84:0b:86:3f:c0:55:
|
|
||||||
43:36:f6:68:e1:36:17:6a:8e:99:d1:ff:a5:40:a7:34:b7:c0:
|
|
||||||
d0:63:39:35:39:75:6e:f2:ba:76:c8:93:02:e9:a9:4b:6c:17:
|
|
||||||
ce:0c:02:d9:bd:81:fb:9f:b7:68:d4:06:65:b3:82:3d:77:53:
|
|
||||||
f8:8e:79:03:ad:0a:31:07:75:2a:43:d8:55:97:72:c4:29:0e:
|
|
||||||
f7:c4:5d:4e:c8:ae:46:84:30:d7:f2:85:5f:18:a1:79:bb:e7:
|
|
||||||
5e:70:8b:07:e1:86:93:c3:b9:8f:dc:61:71:25:2a:af:df:ed:
|
|
||||||
25:50:52:68:8b:92:dc:e5:d6:b5:e3:da:7d:d0:87:6c:84:21:
|
|
||||||
31:ae:82:f5:fb:b9:ab:c8:89:17:3d:e1:4c:e5:38:0e:f6:bd:
|
|
||||||
2b:bd:96:81:14:eb:d5:db:3d:20:a7:7e:59:d3:e2:f8:58:f9:
|
|
||||||
5b:b8:48:cd:fe:5c:4f:16:29:fe:1e:55:23:af:c8:11:b0:8d:
|
|
||||||
ea:7c:93:90:17:2f:fd:ac:a2:09:47:46:3f:f0:e9:b0:b7:ff:
|
|
||||||
28:4d:68:32:d6:67:5e:1e:69:a3:93:b8:f5:9d:8b:2f:0b:d2:
|
|
||||||
52:43:a6:6f:32:57:65:4d:32:81:df:38:53:85:5d:7e:5d:66:
|
|
||||||
29:ea:b8:dd:e4:95:b5:cd:b5:56:12:42:cd:c4:4e:c6:25:38:
|
|
||||||
44:50:6d:ec:ce:00:55:18:fe:e9:49:64:d4:4e:ca:97:9c:b4:
|
|
||||||
5b:c0:73:a8:ab:b8:47:c2
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
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
|
|
||||||
nLRbwHOoq7hHwg==
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
82:10:cf:b0:d2:40:e3:59:44:63:e0:bb:63:82:8b:00
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C = US, O = Internet Security Research Group, CN = ISRG Root X1
|
|
||||||
Validity
|
|
||||||
Not Before: Jun 4 11:04:38 2015 GMT
|
|
||||||
Not After : Jun 4 11:04:38 2035 GMT
|
|
||||||
Subject: C = US, O = Internet Security Research Group, CN = ISRG Root X1
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (4096 bit)
|
|
||||||
Modulus:
|
|
||||||
00:ad:e8:24:73:f4:14:37:f3:9b:9e:2b:57:28:1c:
|
|
||||||
87:be:dc:b7:df:38:90:8c:6e:3c:e6:57:a0:78:f7:
|
|
||||||
75:c2:a2:fe:f5:6a:6e:f6:00:4f:28:db:de:68:86:
|
|
||||||
6c:44:93:b6:b1:63:fd:14:12:6b:bf:1f:d2:ea:31:
|
|
||||||
9b:21:7e:d1:33:3c:ba:48:f5:dd:79:df:b3:b8:ff:
|
|
||||||
12:f1:21:9a:4b:c1:8a:86:71:69:4a:66:66:6c:8f:
|
|
||||||
7e:3c:70:bf:ad:29:22:06:f3:e4:c0:e6:80:ae:e2:
|
|
||||||
4b:8f:b7:99:7e:94:03:9f:d3:47:97:7c:99:48:23:
|
|
||||||
53:e8:38:ae:4f:0a:6f:83:2e:d1:49:57:8c:80:74:
|
|
||||||
b6:da:2f:d0:38:8d:7b:03:70:21:1b:75:f2:30:3c:
|
|
||||||
fa:8f:ae:dd:da:63:ab:eb:16:4f:c2:8e:11:4b:7e:
|
|
||||||
cf:0b:e8:ff:b5:77:2e:f4:b2:7b:4a:e0:4c:12:25:
|
|
||||||
0c:70:8d:03:29:a0:e1:53:24:ec:13:d9:ee:19:bf:
|
|
||||||
10:b3:4a:8c:3f:89:a3:61:51:de:ac:87:07:94:f4:
|
|
||||||
63:71:ec:2e:e2:6f:5b:98:81:e1:89:5c:34:79:6c:
|
|
||||||
76:ef:3b:90:62:79:e6:db:a4:9a:2f:26:c5:d0:10:
|
|
||||||
e1:0e:de:d9:10:8e:16:fb:b7:f7:a8:f7:c7:e5:02:
|
|
||||||
07:98:8f:36:08:95:e7:e2:37:96:0d:36:75:9e:fb:
|
|
||||||
0e:72:b1:1d:9b:bc:03:f9:49:05:d8:81:dd:05:b4:
|
|
||||||
2a:d6:41:e9:ac:01:76:95:0a:0f:d8:df:d5:bd:12:
|
|
||||||
1f:35:2f:28:17:6c:d2:98:c1:a8:09:64:77:6e:47:
|
|
||||||
37:ba:ce:ac:59:5e:68:9d:7f:72:d6:89:c5:06:41:
|
|
||||||
29:3e:59:3e:dd:26:f5:24:c9:11:a7:5a:a3:4c:40:
|
|
||||||
1f:46:a1:99:b5:a7:3a:51:6e:86:3b:9e:7d:72:a7:
|
|
||||||
12:05:78:59:ed:3e:51:78:15:0b:03:8f:8d:d0:2f:
|
|
||||||
05:b2:3e:7b:4a:1c:4b:73:05:12:fc:c6:ea:e0:50:
|
|
||||||
13:7c:43:93:74:b3:ca:74:e7:8e:1f:01:08:d0:30:
|
|
||||||
d4:5b:71:36:b4:07:ba:c1:30:30:5c:48:b7:82:3b:
|
|
||||||
98:a6:7d:60:8a:a2:a3:29:82:cc:ba:bd:83:04:1b:
|
|
||||||
a2:83:03:41:a1:d6:05:f1:1b:c2:b6:f0:a8:7c:86:
|
|
||||||
3b:46:a8:48:2a:88:dc:76:9a:76:bf:1f:6a:a5:3d:
|
|
||||||
19:8f:eb:38:f3:64:de:c8:2b:0d:0a:28:ff:f7:db:
|
|
||||||
e2:15:42:d4:22:d0:27:5d:e1:79:fe:18:e7:70:88:
|
|
||||||
ad:4e:e6:d9:8b:3a:c6:dd:27:51:6e:ff:bc:64:f5:
|
|
||||||
33:43:4f
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
79:B4:59:E6:7B:B6:E5:E4:01:73:80:08:88:C8:1A:58:F6:E9:9B:6E
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
55:1f:58:a9:bc:b2:a8:50:d0:0c:b1:d8:1a:69:20:27:29:08:
|
|
||||||
ac:61:75:5c:8a:6e:f8:82:e5:69:2f:d5:f6:56:4b:b9:b8:73:
|
|
||||||
10:59:d3:21:97:7e:e7:4c:71:fb:b2:d2:60:ad:39:a8:0b:ea:
|
|
||||||
17:21:56:85:f1:50:0e:59:eb:ce:e0:59:e9:ba:c9:15:ef:86:
|
|
||||||
9d:8f:84:80:f6:e4:e9:91:90:dc:17:9b:62:1b:45:f0:66:95:
|
|
||||||
d2:7c:6f:c2:ea:3b:ef:1f:cf:cb:d6:ae:27:f1:a9:b0:c8:ae:
|
|
||||||
fd:7d:7e:9a:fa:22:04:eb:ff:d9:7f:ea:91:2b:22:b1:17:0e:
|
|
||||||
8f:f2:8a:34:5b:58:d8:fc:01:c9:54:b9:b8:26:cc:8a:88:33:
|
|
||||||
89:4c:2d:84:3c:82:df:ee:96:57:05:ba:2c:bb:f7:c4:b7:c7:
|
|
||||||
4e:3b:82:be:31:c8:22:73:73:92:d1:c2:80:a4:39:39:10:33:
|
|
||||||
23:82:4c:3c:9f:86:b2:55:98:1d:be:29:86:8c:22:9b:9e:e2:
|
|
||||||
6b:3b:57:3a:82:70:4d:dc:09:c7:89:cb:0a:07:4d:6c:e8:5d:
|
|
||||||
8e:c9:ef:ce:ab:c7:bb:b5:2b:4e:45:d6:4a:d0:26:cc:e5:72:
|
|
||||||
ca:08:6a:a5:95:e3:15:a1:f7:a4:ed:c9:2c:5f:a5:fb:ff:ac:
|
|
||||||
28:02:2e:be:d7:7b:bb:e3:71:7b:90:16:d3:07:5e:46:53:7c:
|
|
||||||
37:07:42:8c:d3:c4:96:9c:d5:99:b5:2a:e0:95:1a:80:48:ae:
|
|
||||||
4c:39:07:ce:cc:47:a4:52:95:2b:ba:b8:fb:ad:d2:33:53:7d:
|
|
||||||
e5:1d:4d:6d:d5:a1:b1:c7:42:6f:e6:40:27:35:5c:a3:28:b7:
|
|
||||||
07:8d:e7:8d:33:90:e7:23:9f:fb:50:9c:79:6c:46:d5:b4:15:
|
|
||||||
b3:96:6e:7e:9b:0c:96:3a:b8:52:2d:3f:d6:5b:e1:fb:08:c2:
|
|
||||||
84:fe:24:a8:a3:89:da:ac:6a:e1:18:2a:b1:a8:43:61:5b:d3:
|
|
||||||
1f:dc:3b:8d:76:f2:2d:e8:8d:75:df:17:33:6c:3d:53:fb:7b:
|
|
||||||
cb:41:5f:ff:dc:a2:d0:61:38:e1:96:b8:ac:5d:8b:37:d7:75:
|
|
||||||
d5:33:c0:99:11:ae:9d:41:c1:72:75:84:be:02:41:42:5f:67:
|
|
||||||
24:48:94:d1:9b:27:be:07:3f:b9:b8:4f:81:74:51:e1:7a:b7:
|
|
||||||
ed:9d:23:e2:be:e0:d5:28:04:13:3c:31:03:9e:dd:7a:6c:8f:
|
|
||||||
c6:07:18:c6:7f:de:47:8e:3f:28:9e:04:06:cf:a5:54:34:77:
|
|
||||||
bd:ec:89:9b:e9:17:43:df:5b:db:5f:fe:8e:1e:57:a2:cd:40:
|
|
||||||
9d:7e:62:22:da:de:18:27
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
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
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
|
|
@ -1,179 +0,0 @@
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number: 7 (0x7)
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C = US, ST = Arizona, L = Scottsdale, O = "Starfield Technologies, Inc.", CN = Starfield Root Certificate Authority - G2
|
|
||||||
Validity
|
|
||||||
Not Before: May 3 07:00:00 2011 GMT
|
|
||||||
Not After : May 3 07:00:00 2031 GMT
|
|
||||||
Subject: C = US, ST = Arizona, L = Scottsdale, O = "Starfield Technologies, Inc.", OU = http://certs.starfieldtech.com/repository/, CN = Starfield Secure Certificate Authority - G2
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:e5:90:66:4b:ec:f9:46:71:a9:20:83:be:e9:6c:
|
|
||||||
bf:4a:c9:48:69:81:75:4e:6d:24:f6:cb:17:13:f8:
|
|
||||||
b0:71:59:84:7a:6b:2b:85:a4:34:b5:16:e5:cb:cc:
|
|
||||||
e9:41:70:2c:a4:2e:d6:fa:32:7d:e1:a8:de:94:10:
|
|
||||||
ac:31:c1:c0:d8:6a:ff:59:27:ab:76:d6:fc:0b:74:
|
|
||||||
6b:b8:a7:ae:3f:c4:54:f4:b4:31:44:dd:93:56:8c:
|
|
||||||
a4:4c:5e:9b:89:cb:24:83:9b:e2:57:7d:b7:d8:12:
|
|
||||||
1f:c9:85:6d:f4:d1:80:f1:50:9b:87:ae:d4:0b:10:
|
|
||||||
05:fb:27:ba:28:6d:17:e9:0e:d6:4d:b9:39:55:06:
|
|
||||||
ff:0a:24:05:7e:2f:c6:1d:72:6c:d4:8b:29:8c:57:
|
|
||||||
7d:da:d9:eb:66:1a:d3:4f:a7:df:7f:52:c4:30:c5:
|
|
||||||
a5:c9:0e:02:c5:53:bf:77:38:68:06:24:c3:66:c8:
|
|
||||||
37:7e:30:1e:45:71:23:35:ff:90:d8:2a:9d:8d:e7:
|
|
||||||
b0:92:4d:3c:7f:2a:0a:93:dc:cd:16:46:65:f7:60:
|
|
||||||
84:8b:76:4b:91:27:73:14:92:e0:ea:ee:8f:16:ea:
|
|
||||||
8d:0e:3e:76:17:bf:7d:89:80:80:44:43:e7:2d:e0:
|
|
||||||
43:09:75:da:36:e8:ad:db:89:3a:f5:5d:12:8e:23:
|
|
||||||
04:83
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
25:45:81:68:50:26:38:3D:3B:2D:2C:BE:CD:6A:D9:B6:3D:B3:66:63
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:7C:0C:32:1F:A7:D9:30:7F:C4:7D:68:A3:62:A8:A1:CE:AB:07:5B:27
|
|
||||||
|
|
||||||
Authority Information Access:
|
|
||||||
OCSP - URI:http://ocsp.starfieldtech.com/
|
|
||||||
|
|
||||||
X509v3 CRL Distribution Points:
|
|
||||||
|
|
||||||
Full Name:
|
|
||||||
URI:http://crl.starfieldtech.com/sfroot-g2.crl
|
|
||||||
|
|
||||||
X509v3 Certificate Policies:
|
|
||||||
Policy: X509v3 Any Policy
|
|
||||||
CPS: https://certs.starfieldtech.com/repository/
|
|
||||||
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
56:65:ca:fe:f3:3f:0a:a8:93:8b:18:c7:de:43:69:13:34:20:
|
|
||||||
be:4e:5f:78:a8:6b:9c:db:6a:4d:41:db:c1:13:ec:dc:31:00:
|
|
||||||
22:5e:f7:00:9e:0c:e0:34:65:34:f9:b1:3a:4e:48:c8:12:81:
|
|
||||||
88:5c:5b:3e:08:53:7a:f7:1a:64:df:b8:50:61:cc:53:51:40:
|
|
||||||
29:4b:c2:f4:ae:3a:5f:e4:ca:ad:26:cc:4e:61:43:e5:fd:57:
|
|
||||||
a6:37:70:ce:43:2b:b0:94:c3:92:e9:e1:5f:aa:10:49:b7:69:
|
|
||||||
e4:e0:d0:1f:64:a4:2b:cd:1f:6f:a0:f8:84:24:18:ce:79:3d:
|
|
||||||
a9:91:bf:54:18:13:89:99:54:11:0d:55:c5:26:0b:79:4f:5a:
|
|
||||||
1c:6e:f9:63:db:14:80:a4:07:ab:fa:b2:a5:b9:88:dd:91:fe:
|
|
||||||
65:3b:a4:a3:79:be:89:4d:e1:d0:b0:f4:c8:17:0c:0a:96:14:
|
|
||||||
7c:09:b7:6c:e1:c2:d8:55:d4:18:a0:aa:41:69:70:24:a3:b9:
|
|
||||||
ef:e9:5a:dc:3e:eb:94:4a:f0:b7:de:5f:0e:76:fa:fb:fb:69:
|
|
||||||
03:45:40:50:ee:72:0c:a4:12:86:81:cd:13:d1:4e:c4:3c:ca:
|
|
||||||
4e:0d:d2:26:f1:00:b7:b4:a6:a2:e1:6e:7a:81:fd:30:ac:7a:
|
|
||||||
1f:c7:59:7b
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIIFADCCA+igAwIBAgIBBzANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMx
|
|
||||||
EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT
|
|
||||||
HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVs
|
|
||||||
ZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTExMDUwMzA3MDAw
|
|
||||||
MFoXDTMxMDUwMzA3MDAwMFowgcYxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6
|
|
||||||
b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQgVGVj
|
|
||||||
aG5vbG9naWVzLCBJbmMuMTMwMQYDVQQLEypodHRwOi8vY2VydHMuc3RhcmZpZWxk
|
|
||||||
dGVjaC5jb20vcmVwb3NpdG9yeS8xNDAyBgNVBAMTK1N0YXJmaWVsZCBTZWN1cmUg
|
|
||||||
Q2VydGlmaWNhdGUgQXV0aG9yaXR5IC0gRzIwggEiMA0GCSqGSIb3DQEBAQUAA4IB
|
|
||||||
DwAwggEKAoIBAQDlkGZL7PlGcakgg77pbL9KyUhpgXVObST2yxcT+LBxWYR6ayuF
|
|
||||||
pDS1FuXLzOlBcCykLtb6Mn3hqN6UEKwxwcDYav9ZJ6t21vwLdGu4p64/xFT0tDFE
|
|
||||||
3ZNWjKRMXpuJyySDm+JXfbfYEh/JhW300YDxUJuHrtQLEAX7J7oobRfpDtZNuTlV
|
|
||||||
Bv8KJAV+L8YdcmzUiymMV33a2etmGtNPp99/UsQwxaXJDgLFU793OGgGJMNmyDd+
|
|
||||||
MB5FcSM1/5DYKp2N57CSTTx/KgqT3M0WRmX3YISLdkuRJ3MUkuDq7o8W6o0OPnYX
|
|
||||||
v32JgIBEQ+ct4EMJddo26K3biTr1XRKOIwSDAgMBAAGjggEsMIIBKDAPBgNVHRMB
|
|
||||||
Af8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUJUWBaFAmOD07LSy+
|
|
||||||
zWrZtj2zZmMwHwYDVR0jBBgwFoAUfAwyH6fZMH/EfWijYqihzqsHWycwOgYIKwYB
|
|
||||||
BQUHAQEELjAsMCoGCCsGAQUFBzABhh5odHRwOi8vb2NzcC5zdGFyZmllbGR0ZWNo
|
|
||||||
LmNvbS8wOwYDVR0fBDQwMjAwoC6gLIYqaHR0cDovL2NybC5zdGFyZmllbGR0ZWNo
|
|
||||||
LmNvbS9zZnJvb3QtZzIuY3JsMEwGA1UdIARFMEMwQQYEVR0gADA5MDcGCCsGAQUF
|
|
||||||
BwIBFitodHRwczovL2NlcnRzLnN0YXJmaWVsZHRlY2guY29tL3JlcG9zaXRvcnkv
|
|
||||||
MA0GCSqGSIb3DQEBCwUAA4IBAQBWZcr+8z8KqJOLGMfeQ2kTNCC+Tl94qGuc22pN
|
|
||||||
QdvBE+zcMQAiXvcAngzgNGU0+bE6TkjIEoGIXFs+CFN69xpk37hQYcxTUUApS8L0
|
|
||||||
rjpf5MqtJsxOYUPl/VemN3DOQyuwlMOS6eFfqhBJt2nk4NAfZKQrzR9voPiEJBjO
|
|
||||||
eT2pkb9UGBOJmVQRDVXFJgt5T1ocbvlj2xSApAer+rKluYjdkf5lO6Sjeb6JTeHQ
|
|
||||||
sPTIFwwKlhR8Cbds4cLYVdQYoKpBaXAko7nv6VrcPuuUSvC33l8Odvr7+2kDRUBQ
|
|
||||||
7nIMpBKGgc0T0U7EPMpODdIm8QC3tKai4W56gf0wrHofx1l7
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number: 0 (0x0)
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
Issuer: C = US, ST = Arizona, L = Scottsdale, O = "Starfield Technologies, Inc.", CN = Starfield Root Certificate Authority - G2
|
|
||||||
Validity
|
|
||||||
Not Before: Sep 1 00:00:00 2009 GMT
|
|
||||||
Not After : Dec 31 23:59:59 2037 GMT
|
|
||||||
Subject: C = US, ST = Arizona, L = Scottsdale, O = "Starfield Technologies, Inc.", CN = Starfield Root Certificate Authority - G2
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public-Key: (2048 bit)
|
|
||||||
Modulus:
|
|
||||||
00:bd:ed:c1:03:fc:f6:8f:fc:02:b1:6f:5b:9f:48:
|
|
||||||
d9:9d:79:e2:a2:b7:03:61:56:18:c3:47:b6:d7:ca:
|
|
||||||
3d:35:2e:89:43:f7:a1:69:9b:de:8a:1a:fd:13:20:
|
|
||||||
9c:b4:49:77:32:29:56:fd:b9:ec:8c:dd:22:fa:72:
|
|
||||||
dc:27:61:97:ee:f6:5a:84:ec:6e:19:b9:89:2c:dc:
|
|
||||||
84:5b:d5:74:fb:6b:5f:c5:89:a5:10:52:89:46:55:
|
|
||||||
f4:b8:75:1c:e6:7f:e4:54:ae:4b:f8:55:72:57:02:
|
|
||||||
19:f8:17:71:59:eb:1e:28:07:74:c5:9d:48:be:6c:
|
|
||||||
b4:f4:a4:b0:f3:64:37:79:92:c0:ec:46:5e:7f:e1:
|
|
||||||
6d:53:4c:62:af:cd:1f:0b:63:bb:3a:9d:fb:fc:79:
|
|
||||||
00:98:61:74:cf:26:82:40:63:f3:b2:72:6a:19:0d:
|
|
||||||
99:ca:d4:0e:75:cc:37:fb:8b:89:c1:59:f1:62:7f:
|
|
||||||
5f:b3:5f:65:30:f8:a7:b7:4d:76:5a:1e:76:5e:34:
|
|
||||||
c0:e8:96:56:99:8a:b3:f0:7f:a4:cd:bd:dc:32:31:
|
|
||||||
7c:91:cf:e0:5f:11:f8:6b:aa:49:5c:d1:99:94:d1:
|
|
||||||
a2:e3:63:5b:09:76:b5:56:62:e1:4b:74:1d:96:d4:
|
|
||||||
26:d4:08:04:59:d0:98:0e:0e:e6:de:fc:c3:ec:1f:
|
|
||||||
90:f1
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Basic Constraints: critical
|
|
||||||
CA:TRUE
|
|
||||||
X509v3 Key Usage: critical
|
|
||||||
Certificate Sign, CRL Sign
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
7C:0C:32:1F:A7:D9:30:7F:C4:7D:68:A3:62:A8:A1:CE:AB:07:5B:27
|
|
||||||
Signature Algorithm: sha256WithRSAEncryption
|
|
||||||
11:59:fa:25:4f:03:6f:94:99:3b:9a:1f:82:85:39:d4:76:05:
|
|
||||||
94:5e:e1:28:93:6d:62:5d:09:c2:a0:a8:d4:b0:75:38:f1:34:
|
|
||||||
6a:9d:e4:9f:8a:86:26:51:e6:2c:d1:c6:2d:6e:95:20:4a:92:
|
|
||||||
01:ec:b8:8a:67:7b:31:e2:67:2e:8c:95:03:26:2e:43:9d:4a:
|
|
||||||
31:f6:0e:b5:0c:bb:b7:e2:37:7f:22:ba:00:a3:0e:7b:52:fb:
|
|
||||||
6b:bb:3b:c4:d3:79:51:4e:cd:90:f4:67:07:19:c8:3c:46:7a:
|
|
||||||
0d:01:7d:c5:58:e7:6d:e6:85:30:17:9a:24:c4:10:e0:04:f7:
|
|
||||||
e0:f2:7f:d4:aa:0a:ff:42:1d:37:ed:94:e5:64:59:12:20:77:
|
|
||||||
38:d3:32:3e:38:81:75:96:73:fa:68:8f:b1:cb:ce:1f:c5:ec:
|
|
||||||
fa:9c:7e:cf:7e:b1:f1:07:2d:b6:fc:bf:ca:a4:bf:d0:97:05:
|
|
||||||
4a:bc:ea:18:28:02:90:bd:54:78:09:21:71:d3:d1:7d:1d:d9:
|
|
||||||
16:b0:a9:61:3d:d0:0a:00:22:fc:c7:7b:cb:09:64:45:0b:3b:
|
|
||||||
40:81:f7:7d:7c:32:f5:98:ca:58:8e:7d:2a:ee:90:59:73:64:
|
|
||||||
f9:36:74:5e:25:a1:f5:66:05:2e:7f:39:15:a9:2a:fb:50:8b:
|
|
||||||
8e:85:69:f4
|
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMx
|
|
||||||
EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT
|
|
||||||
HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVs
|
|
||||||
ZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAw
|
|
||||||
MFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6
|
|
||||||
b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQgVGVj
|
|
||||||
aG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZp
|
|
||||||
Y2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC
|
|
||||||
ggEBAL3twQP89o/8ArFvW59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMg
|
|
||||||
nLRJdzIpVv257IzdIvpy3Cdhl+72WoTsbhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1
|
|
||||||
HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNkN3mSwOxGXn/hbVNMYq/N
|
|
||||||
Hwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7NfZTD4p7dN
|
|
||||||
dloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0
|
|
||||||
HZbUJtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO
|
|
||||||
BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0G
|
|
||||||
CSqGSIb3DQEBCwUAA4IBAQARWfolTwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjU
|
|
||||||
sHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx4mcujJUDJi5DnUox9g61DLu3
|
|
||||||
4jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUwF5okxBDgBPfg
|
|
||||||
8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K
|
|
||||||
pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1
|
|
||||||
mMpYjn0q7pBZc2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0
|
|
||||||
-----END CERTIFICATE-----
|
|
||||||
30
certs/Starfield-Root-Certificate-Authority-G2.pem
Normal file
|
|
@ -0,0 +1,30 @@
|
||||||
|
# Issuer: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc.
|
||||||
|
# Subject: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc.
|
||||||
|
# Label: "Starfield Root Certificate Authority - G2"
|
||||||
|
# Serial: 0
|
||||||
|
# MD5 Fingerprint: d6:39:81:c6:52:7e:96:69:fc:fc:ca:66:ed:05:f2:96
|
||||||
|
# SHA1 Fingerprint: b5:1c:06:7c:ee:2b:0c:3d:f8:55:ab:2d:92:f4:fe:39:d4:e7:0f:0e
|
||||||
|
# SHA256 Fingerprint: 2c:e1:cb:0b:f9:d2:f9:e1:02:99:3f:be:21:51:52:c3:b2:dd:0c:ab:de:1c:68:e5:31:9b:83:91:54:db:b7:f5
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMx
|
||||||
|
EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT
|
||||||
|
HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVs
|
||||||
|
ZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAw
|
||||||
|
MFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6
|
||||||
|
b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQgVGVj
|
||||||
|
aG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZp
|
||||||
|
Y2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC
|
||||||
|
ggEBAL3twQP89o/8ArFvW59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMg
|
||||||
|
nLRJdzIpVv257IzdIvpy3Cdhl+72WoTsbhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1
|
||||||
|
HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNkN3mSwOxGXn/hbVNMYq/N
|
||||||
|
Hwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7NfZTD4p7dN
|
||||||
|
dloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0
|
||||||
|
HZbUJtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO
|
||||||
|
BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0G
|
||||||
|
CSqGSIb3DQEBCwUAA4IBAQARWfolTwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjU
|
||||||
|
sHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx4mcujJUDJi5DnUox9g61DLu3
|
||||||
|
4jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUwF5okxBDgBPfg
|
||||||
|
8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K
|
||||||
|
pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1
|
||||||
|
mMpYjn0q7pBZc2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0
|
||||||
|
-----END CERTIFICATE-----
|
||||||
41
certs/USERTrust-RSA-Certification-Authority.pem
Normal file
|
|
@ -0,0 +1,41 @@
|
||||||
|
# Issuer: CN=USERTrust RSA Certification Authority O=The USERTRUST Network
|
||||||
|
# Subject: CN=USERTrust RSA Certification Authority O=The USERTRUST Network
|
||||||
|
# Label: "USERTrust RSA Certification Authority"
|
||||||
|
# Serial: 2645093764781058787591871645665788717
|
||||||
|
# MD5 Fingerprint: 1b:fe:69:d1:91:b7:19:33:a3:72:a8:0f:e1:55:e5:b5
|
||||||
|
# SHA1 Fingerprint: 2b:8f:1b:57:33:0d:bb:a2:d0:7a:6c:51:f7:0e:e9:0d:da:b9:ad:8e
|
||||||
|
# SHA256 Fingerprint: e7:93:c9:b0:2f:d8:aa:13:e2:1c:31:22:8a:cc:b0:81:19:64:3b:74:9c:89:89:64:b1:74:6d:46:c3:d4:cb:d2
|
||||||
|
-----BEGIN CERTIFICATE-----
|
||||||
|
MIIF3jCCA8agAwIBAgIQAf1tMPyjylGoG7xkDjUDLTANBgkqhkiG9w0BAQwFADCB
|
||||||
|
iDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0pl
|
||||||
|
cnNleSBDaXR5MR4wHAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNV
|
||||||
|
BAMTJVVTRVJUcnVzdCBSU0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAw
|
||||||
|
MjAxMDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UEBhMCVVMxEzARBgNV
|
||||||
|
BAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVU
|
||||||
|
aGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBSU0EgQ2Vy
|
||||||
|
dGlmaWNhdGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIK
|
||||||
|
AoICAQCAEmUXNg7D2wiz0KxXDXbtzSfTTK1Qg2HiqiBNCS1kCdzOiZ/MPans9s/B
|
||||||
|
3PHTsdZ7NygRK0faOca8Ohm0X6a9fZ2jY0K2dvKpOyuR+OJv0OwWIJAJPuLodMkY
|
||||||
|
tJHUYmTbf6MG8YgYapAiPLz+E/CHFHv25B+O1ORRxhFnRghRy4YUVD+8M/5+bJz/
|
||||||
|
Fp0YvVGONaanZshyZ9shZrHUm3gDwFA66Mzw3LyeTP6vBZY1H1dat//O+T23LLb2
|
||||||
|
VN3I5xI6Ta5MirdcmrS3ID3KfyI0rn47aGYBROcBTkZTmzNg95S+UzeQc0PzMsNT
|
||||||
|
79uq/nROacdrjGCT3sTHDN/hMq7MkztReJVni+49Vv4M0GkPGw/zJSZrM233bkf6
|
||||||
|
c0Plfg6lZrEpfDKEY1WJxA3Bk1QwGROs0303p+tdOmw1XNtB1xLaqUkL39iAigmT
|
||||||
|
Yo61Zs8liM2EuLE/pDkP2QKe6xJMlXzzawWpXhaDzLhn4ugTncxbgtNMs+1b/97l
|
||||||
|
c6wjOy0AvzVVdAlJ2ElYGn+SNuZRkg7zJn0cTRe8yexDJtC/QV9AqURE9JnnV4ee
|
||||||
|
UB9XVKg+/XRjL7FQZQnmWEIuQxpMtPAlR1n6BB6T1CZGSlCBst6+eLf8ZxXhyVeE
|
||||||
|
Hg9j1uliutZfVS7qXMYoCAQlObgOK6nyTJccBz8NUvXt7y+CDwIDAQABo0IwQDAd
|
||||||
|
BgNVHQ4EFgQUU3m/WqorSs9UgOHYm8Cd8rIDZsswDgYDVR0PAQH/BAQDAgEGMA8G
|
||||||
|
A1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAFzUfA3P9wF9QZllDHPF
|
||||||
|
Up/L+M+ZBn8b2kMVn54CVVeWFPFSPCeHlCjtHzoBN6J2/FNQwISbxmtOuowhT6KO
|
||||||
|
VWKR82kV2LyI48SqC/3vqOlLVSoGIG1VeCkZ7l8wXEskEVX/JJpuXior7gtNn3/3
|
||||||
|
ATiUFJVDBwn7YKnuHKsSjKCaXqeYalltiz8I+8jRRa8YFWSQEg9zKC7F4iRO/Fjs
|
||||||
|
8PRF/iKz6y+O0tlFYQXBl2+odnKPi4w2r78NBc5xjeambx9spnFixdjQg3IM8WcR
|
||||||
|
iQycE0xyNN+81XHfqnHd4blsjDwSXWXavVcStkNr/+XeTWYRUc+ZruwXtuhxkYze
|
||||||
|
Sf7dNXGiFSeUHM9h4ya7b6NnJSFd5t0dCy5oGzuCr+yDZ4XUmFF0sbmZgIn/f3gZ
|
||||||
|
XHlKYC6SQK5MNyosycdiyA5d9zZbyuAlJQG03RoHnHcAP9Dc1ew91Pq7P8yF1m9/
|
||||||
|
qS3fuQL39ZeatTXaw2ewh0qpKJ4jjv9cJ2vhsE/zB+4ALtRZh8tSQZXq9EfX7mRB
|
||||||
|
VXyNWQKV3WKdwrnuWih0hKWbt5DHDAff9Yk2dDLWKMGwsAvgnEzDHNb842m1R0aB
|
||||||
|
L6KCq9NjRHDEjf8tM7qtj3u1cIiuPhnPQCjY/MiQu12ZIvVS5ljFH4gxQ+6IHdfG
|
||||||
|
jjxDah2nGN59PRbxYvnKkKj9
|
||||||
|
-----END CERTIFICATE-----
|
||||||
|
|
@ -1,28 +1,30 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: check-certificates
|
# RouterOS script: check-certificates
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
|
# requires device-mode, fetch
|
||||||
#
|
#
|
||||||
# check for certificate validity
|
# check for certificate validity
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/check-certificates.md
|
# https://rsc.eworm.de/doc/check-certificates.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global CertRenewTime;
|
:global CertRenewTime;
|
||||||
:global CertRenewUrl;
|
:global CertRenewUrl;
|
||||||
:global CertWarnTime;
|
:global CertWarnTime;
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
:global CertificateAvailable
|
:global CertificateAvailable;
|
||||||
:global EscapeForRegEx;
|
:global EscapeForRegEx;
|
||||||
:global IfThenElse;
|
:global IfThenElse;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ParseKeyValueStore;
|
:global ParseKeyValueStore;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
|
|
@ -31,52 +33,62 @@
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:local CheckCertificatesDownloadImport do={
|
:local CheckCertificatesDownloadImport do={
|
||||||
:local Name [ :tostr $1 ];
|
:local ScriptName [ :tostr $1 ];
|
||||||
|
:local CertName [ :tostr $2 ];
|
||||||
|
:local FetchName [ :tostr $3 ];
|
||||||
|
|
||||||
:global CertRenewUrl;
|
:global CertRenewUrl;
|
||||||
:global CertRenewPass;
|
:global CertRenewPass;
|
||||||
|
|
||||||
:global CertificateNameByCN;
|
:global CertificateNameByCN;
|
||||||
:global EscapeForRegEx;
|
:global EscapeForRegEx;
|
||||||
:global FetchUserAgent;
|
:global FetchUserAgentStr;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
|
:global RmFile;
|
||||||
:global UrlEncode;
|
:global UrlEncode;
|
||||||
:global WaitForFile;
|
:global WaitForFile;
|
||||||
|
|
||||||
:local Return false;
|
:foreach Type in={ "p12"; "pem" } do={
|
||||||
|
:local CertFileName ([ $UrlEncode $FetchName ] . "." . $Type);
|
||||||
|
$LogPrint debug $ScriptName ("Trying type '" . $Type . "' for '" . $CertName . \
|
||||||
|
"' (file '" . $CertFileName . "')...");
|
||||||
|
|
||||||
:foreach Type in={ ".pem"; ".p12" } do={
|
|
||||||
:local CertFileName ([ $UrlEncode $Name ] . $Type);
|
|
||||||
:do {
|
:do {
|
||||||
/tool/fetch check-certificate=yes-without-crl http-header-field=({ $FetchUserAgent }) \
|
/tool/fetch check-certificate=yes-without-crl http-header-field=({ [ $FetchUserAgentStr $ScriptName ] }) \
|
||||||
($CertRenewUrl . $CertFileName) dst-path=$CertFileName as-value;
|
($CertRenewUrl . $CertFileName) dst-path=$CertFileName as-value;
|
||||||
$WaitForFile $CertFileName;
|
$WaitForFile $CertFileName;
|
||||||
|
|
||||||
:local DecryptionFailed true;
|
:local DecryptionFailed true;
|
||||||
:foreach PassPhrase in=$CertRenewPass do={
|
:foreach I,PassPhrase in=$CertRenewPass do={
|
||||||
:local Result [ /certificate/import file-name=$CertFileName passphrase=$PassPhrase as-value ];
|
:do {
|
||||||
:if ($Result->"decryption-failures" = 0) do={
|
$LogPrint debug $ScriptName ("Trying " . $I . ". passphrase... ");
|
||||||
:set DecryptionFailed false;
|
:local Result [ /certificate/import file-name=$CertFileName passphrase=$PassPhrase as-value ];
|
||||||
}
|
:if ($Result->"decryption-failures" = 0) do={
|
||||||
|
$LogPrint debug $ScriptName ("Success!");
|
||||||
|
:set DecryptionFailed false;
|
||||||
|
}
|
||||||
|
} on-error={ }
|
||||||
}
|
}
|
||||||
/file/remove [ find where name=$CertFileName ];
|
$RmFile $CertFileName;
|
||||||
|
|
||||||
:if ($DecryptionFailed = true) do={
|
:if ($DecryptionFailed = true) do={
|
||||||
$LogPrintExit2 warning $0 ("Decryption failed for certificate file '" . $CertFileName . "'.") false;
|
$LogPrint warning $ScriptName ("Decryption failed for certificate file '" . $CertFileName . "'.");
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach CertInChain in=[ /certificate/find where name~("^" . [ $EscapeForRegEx $CertFileName ] . "_[0-9]+\$") \
|
:foreach CertInChain in=[ /certificate/find where common-name!=$CertName !private-key \
|
||||||
common-name!=$Name !(subject-alt-name~("(^|\\W)(DNS|IP):" . [ $EscapeForRegEx $Name ] . "(\\W|\$)")) !(common-name=[]) ] do={
|
name~("^" . [ $EscapeForRegEx $CertFileName ] . "_[0-9]+\$") \
|
||||||
|
!(subject-alt-name~("(^|\\W)(DNS|IP):" . [ $EscapeForRegEx $CertName ] . "(\\W|\$)")) \
|
||||||
|
!(common-name=[]) ] do={
|
||||||
$CertificateNameByCN [ /certificate/get $CertInChain common-name ];
|
$CertificateNameByCN [ /certificate/get $CertInChain common-name ];
|
||||||
}
|
}
|
||||||
|
|
||||||
:set Return true;
|
:return true;
|
||||||
} on-error={
|
} on-error={
|
||||||
$LogPrintExit2 debug $0 ("Could not download certificate file '" . $CertFileName . "'.") false;
|
$LogPrint debug $ScriptName ("Could not download certificate file '" . $CertFileName . "'.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:return $Return;
|
:return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:local FormatInfo do={
|
:local FormatInfo do={
|
||||||
|
|
@ -98,8 +110,12 @@
|
||||||
:global ParseKeyValueStore;
|
:global ParseKeyValueStore;
|
||||||
|
|
||||||
:local CertVal [ /certificate/get $Cert ];
|
:local CertVal [ /certificate/get $Cert ];
|
||||||
:local Return "";
|
|
||||||
|
|
||||||
|
:if ([ :typeof ($CertVal->"issuer") ] = "nothing") do={
|
||||||
|
:return "self-signed";
|
||||||
|
}
|
||||||
|
|
||||||
|
:local Return "";
|
||||||
:for I from=0 to=5 do={
|
:for I from=0 to=5 do={
|
||||||
:set Return ($Return . [ $EitherOr ([ $ParseKeyValueStore ($CertVal->"issuer") ]->"CN") \
|
:set Return ($Return . [ $EitherOr ([ $ParseKeyValueStore ($CertVal->"issuer") ]->"CN") \
|
||||||
([ $ParseKeyValueStore (($CertVal->"issuer")->0) ]->"CN") ]);
|
([ $ParseKeyValueStore (($CertVal->"issuer")->0) ]->"CN") ]);
|
||||||
|
|
@ -128,49 +144,59 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
:foreach Cert in=[ /certificate/find where !revoked !ca !scep-url expires-after<$CertRenewTime ] do={
|
:foreach Cert in=[ /certificate/find where !revoked !ca !scep-url expires-after<$CertRenewTime ] do={
|
||||||
:local CertVal [ /certificate/get $Cert ];
|
:local CertVal [ /certificate/get $Cert ];
|
||||||
:local CertNew;
|
|
||||||
:local LastName;
|
:local LastName;
|
||||||
|
:local FetchName;
|
||||||
|
|
||||||
:do {
|
:do {
|
||||||
:if ([ :len $CertRenewUrl ] = 0) do={
|
:if ([ :len $CertRenewUrl ] = 0) do={
|
||||||
$LogPrintExit2 info $ScriptName ("No CertRenewUrl given.") true;
|
$LogPrint info $ScriptName ("No CertRenewUrl given.");
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$LogPrintExit2 info $ScriptName ("Attempting to renew certificate '" . ($CertVal->"name") . "'.") false;
|
$LogPrint info $ScriptName ("Attempting to renew certificate '" . ($CertVal->"name") . "'.");
|
||||||
|
|
||||||
:local ImportSuccess false;
|
:local ImportSuccess false;
|
||||||
:set LastName ($CertVal->"common-name");
|
:set LastName ($CertVal->"common-name");
|
||||||
:set ImportSuccess [ $CheckCertificatesDownloadImport $LastName ];
|
:set FetchName $LastName;
|
||||||
|
:set ImportSuccess [ $CheckCertificatesDownloadImport $ScriptName $LastName $FetchName ];
|
||||||
:foreach SAN in=($CertVal->"subject-alt-name") do={
|
:foreach SAN in=($CertVal->"subject-alt-name") do={
|
||||||
:if ($ImportSuccess = false) do={
|
:if ($ImportSuccess = false) do={
|
||||||
:set LastName [ :pick $SAN ([ :find $SAN ":" ] + 1) [ :len $SAN ] ];
|
:set LastName [ :pick $SAN ([ :find $SAN ":" ] + 1) [ :len $SAN ] ];
|
||||||
:set ImportSuccess [ $CheckCertificatesDownloadImport $LastName ];
|
:set FetchName $LastName;
|
||||||
|
:set ImportSuccess [ $CheckCertificatesDownloadImport $ScriptName $LastName $FetchName ];
|
||||||
|
:if ($ImportSuccess = false && [ :pick $LastName 0 2 ] = "*.") do={
|
||||||
|
:set FetchName ("star." . [ :pick $LastName 2 [ :len $LastName ] ]);
|
||||||
|
:set ImportSuccess [ $CheckCertificatesDownloadImport $ScriptName $LastName $FetchName ];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
:if ($ImportSuccess = false) do={ :error false; }
|
||||||
|
|
||||||
:if ([ :len ($CertVal->"fingerprint") ] > 0 && $CertVal->"fingerprint" != [ /certificate/get $Cert fingerprint ]) do={
|
:if ([ :len ($CertVal->"fingerprint") ] > 0 && $CertVal->"fingerprint" != [ /certificate/get $Cert fingerprint ]) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("Certificate '" . $CertVal->"name" . "' was updated in place.") false;
|
$LogPrint debug $ScriptName ("Certificate '" . $CertVal->"name" . "' was updated in place.");
|
||||||
:set CertVal [ /certificate/get $Cert ];
|
:set CertVal [ /certificate/get $Cert ];
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 debug $ScriptName ("Certificate '" . $CertVal->"name" . "' was not updated, but replaced.") false;
|
$LogPrint debug $ScriptName ("Certificate '" . $CertVal->"name" . "' was not updated, but replaced.");
|
||||||
|
|
||||||
:set CertNew [ /certificate/find where name~("^" . [ $EscapeForRegEx [ $UrlEncode $LastName ] ] . "\\.(p12|pem)_[0-9]+\$") \
|
:local CertNew [ /certificate/find where name~("^" . [ $EscapeForRegEx [ $UrlEncode $FetchName ] ] . "\\.(p12|pem)_[0-9]+\$") \
|
||||||
(common-name=($CertVal->"common-name") or subject-alt-name~("(^|\\W)(DNS|IP):" . [ $EscapeForRegEx $LastName ] . "(\\W|\$)")) \
|
(common-name=($CertVal->"common-name") or subject-alt-name~("(^|\\W)(DNS|IP):" . [ $EscapeForRegEx $LastName ] . "(\\W|\$)")) \
|
||||||
fingerprint!=[ :tostr ($CertVal->"fingerprint") ] expires-after>$CertRenewTime ];
|
fingerprint!=[ :tostr ($CertVal->"fingerprint") ] expires-after>$CertRenewTime ];
|
||||||
:local CertNewVal [ /certificate/get $CertNew ];
|
:local CertNewVal [ /certificate/get $CertNew ];
|
||||||
|
|
||||||
:if ([ $CertificateAvailable ([ $ParseKeyValueStore ($CertNewVal->"issuer") ]->"CN") ] = false) do={
|
:if ([ $CertificateAvailable ([ $ParseKeyValueStore ($CertNewVal->"issuer") ]->"CN") "fetch" ] = false) do={
|
||||||
$LogPrintExit2 warning $ScriptName ("The certificate chain is not available!") false;
|
$LogPrint warning $ScriptName ("The certificate chain is not available!");
|
||||||
}
|
}
|
||||||
|
|
||||||
:if (($CertVal->"private-key") = true && ($CertVal->"private-key") != ($CertNewVal->"private-key")) do={
|
:if (($CertVal->"private-key") = true && ($CertVal->"private-key") != ($CertNewVal->"private-key")) do={
|
||||||
/certificate/remove $CertNew;
|
/certificate/remove $CertNew;
|
||||||
$LogPrintExit2 warning $ScriptName ("Old certificate '" . ($CertVal->"name") . "' has a private key, new certificate does not. Aborting renew.") true;
|
$LogPrint warning $ScriptName ("Old certificate '" . ($CertVal->"name") . "' has a private key, new certificate does not. Aborting renew.");
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/ip/service/set certificate=($CertNewVal->"name") [ find where certificate=($CertVal->"name") ];
|
/ip/service/set certificate=($CertNewVal->"name") [ find where certificate=($CertVal->"name") ];
|
||||||
|
|
@ -182,16 +208,16 @@
|
||||||
|
|
||||||
/certificate/remove $Cert;
|
/certificate/remove $Cert;
|
||||||
/certificate/set $CertNew name=($CertVal->"name");
|
/certificate/set $CertNew name=($CertVal->"name");
|
||||||
:set CertNewVal;
|
:set Cert $CertNew;
|
||||||
:set CertVal [ /certificate/get $CertNew ];
|
:set CertVal [ /certificate/get $CertNew ];
|
||||||
}
|
}
|
||||||
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; silent=true; \
|
$SendNotification2 ({ origin=$ScriptName; silent=true; \
|
||||||
subject=([ $SymbolForNotification "lock-with-ink-pen" ] . "Certificate renewed: " . ($CertVal->"name")); \
|
subject=([ $SymbolForNotification "lock-with-ink-pen" ] . "Certificate renewed: " . ($CertVal->"name")); \
|
||||||
message=("A certificate on " . $Identity . " has been renewed.\n\n" . [ $FormatInfo $CertNew ]) });
|
message=("A certificate on " . $Identity . " has been renewed.\n\n" . [ $FormatInfo $Cert ]) });
|
||||||
$LogPrintExit2 info $ScriptName ("The certificate '" . ($CertVal->"name") . "' has been renewed.") false;
|
$LogPrint info $ScriptName ("The certificate '" . ($CertVal->"name") . "' has been renewed.");
|
||||||
} on-error={
|
} on-error={
|
||||||
$LogPrintExit2 debug $ScriptName ("Could not renew certificate '" . ($CertVal->"name") . "'.") false;
|
$LogPrint debug $ScriptName ("Could not renew certificate '" . ($CertVal->"name") . "'.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -200,17 +226,17 @@
|
||||||
:local CertVal [ /certificate/get $Cert ];
|
:local CertVal [ /certificate/get $Cert ];
|
||||||
|
|
||||||
:if ([ :len [ /certificate/scep-server/find where ca-cert=($CertVal->"ca") ] ] > 0) do={
|
:if ([ :len [ /certificate/scep-server/find where ca-cert=($CertVal->"ca") ] ] > 0) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("Certificate '" . ($CertVal->"name") . "' is handled by SCEP, skipping.") false;
|
$LogPrint debug $ScriptName ("Certificate '" . ($CertVal->"name") . "' is handled by SCEP, skipping.");
|
||||||
} else={
|
} else={
|
||||||
:local State [ $IfThenElse (($CertVal->"expired") = true) "expired" "is about to expire" ];
|
:local State [ $IfThenElse (($CertVal->"expired") = true) "expired" "is about to expire" ];
|
||||||
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "warning-sign" ] . "Certificate warning: " . ($CertVal->"name")); \
|
subject=([ $SymbolForNotification "lock-with-ink-pen,warning-sign" ] . "Certificate warning: " . ($CertVal->"name")); \
|
||||||
message=("A certificate on " . $Identity . " " . $State . ".\n\n" . [ $FormatInfo $Cert ]) });
|
message=("A certificate on " . $Identity . " " . $State . ".\n\n" . [ $FormatInfo $Cert ]) });
|
||||||
$LogPrintExit2 info $ScriptName ("The certificate '" . ($CertVal->"name") . "' " . $State . \
|
$LogPrint info $ScriptName ("The certificate '" . ($CertVal->"name") . "' " . $State . \
|
||||||
", it is invalid after " . ($CertVal->"invalid-after") . ".") false;
|
", it is invalid after " . ($CertVal->"invalid-after") . ".");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
49
check-health.d/state.rsc
Normal file
|
|
@ -0,0 +1,49 @@
|
||||||
|
#!rsc by RouterOS
|
||||||
|
# RouterOS script: check-health.d/state
|
||||||
|
# Copyright (c) 2019-2026 Christian Hesse <mail@eworm.de>
|
||||||
|
# https://rsc.eworm.de/COPYING.md
|
||||||
|
#
|
||||||
|
# requires RouterOS, version=7.15
|
||||||
|
#
|
||||||
|
# check for RouterOS health state - state plugin
|
||||||
|
# https://rsc.eworm.de/doc/check-health.md
|
||||||
|
|
||||||
|
:global CheckHealthPlugins;
|
||||||
|
|
||||||
|
:set ($CheckHealthPlugins->[ :jobname ]) do={
|
||||||
|
:local FuncName [ :tostr $0 ];
|
||||||
|
:local ScriptName [ :tostr $1 ];
|
||||||
|
|
||||||
|
:global CheckHealthLast;
|
||||||
|
:global Identity;
|
||||||
|
|
||||||
|
:global LogPrint;
|
||||||
|
:global SendNotification2;
|
||||||
|
:global SymbolForNotification;
|
||||||
|
|
||||||
|
:if ([ :len [ /system/health/find where type="" name~"-state\$"] ] = 0) do={
|
||||||
|
$LogPrint debug $FuncName ("Your device does not provide any state health values.");
|
||||||
|
:return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
:foreach State in=[ /system/health/find where type="" name~"-state\$" ] do={
|
||||||
|
:local Name [ /system/health/get $State name ];
|
||||||
|
:local Value [ /system/health/get $State value ];
|
||||||
|
|
||||||
|
:if ([ :typeof ($CheckHealthLast->$Name) ] != "nothing") do={
|
||||||
|
:if ($CheckHealthLast->$Name = "ok" && \
|
||||||
|
$Value != "ok") do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "cross-mark" ] . "Health warning: " . $Name); \
|
||||||
|
message=("The device '" . $Name . "' on " . $Identity . " failed!") });
|
||||||
|
}
|
||||||
|
:if ($CheckHealthLast->$Name != "ok" && \
|
||||||
|
$Value = "ok") do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "white-heavy-check-mark" ] . "Health recovery: " . $Name); \
|
||||||
|
message=("The device '" . $Name . "' on " . $Identity . " recovered!") });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
:set ($CheckHealthLast->$Name) $Value;
|
||||||
|
}
|
||||||
|
}
|
||||||
75
check-health.d/temperature.rsc
Normal file
|
|
@ -0,0 +1,75 @@
|
||||||
|
#!rsc by RouterOS
|
||||||
|
# RouterOS script: check-health.d/temperature
|
||||||
|
# Copyright (c) 2019-2026 Christian Hesse <mail@eworm.de>
|
||||||
|
# https://rsc.eworm.de/COPYING.md
|
||||||
|
#
|
||||||
|
# requires RouterOS, version=7.15
|
||||||
|
#
|
||||||
|
# check for RouterOS health state - temperature plugin
|
||||||
|
# https://rsc.eworm.de/doc/check-health.md
|
||||||
|
|
||||||
|
:global CheckHealthPlugins;
|
||||||
|
|
||||||
|
:set ($CheckHealthPlugins->[ :jobname ]) do={
|
||||||
|
:local FuncName [ :tostr $0 ];
|
||||||
|
:local ScriptName [ :tostr $1 ];
|
||||||
|
|
||||||
|
:global CheckHealthLast;
|
||||||
|
:global CheckHealthTemperature;
|
||||||
|
:global CheckHealthTemperatureDeviation;
|
||||||
|
:global CheckHealthTemperatureNotified;
|
||||||
|
:global Identity;
|
||||||
|
|
||||||
|
:global LogPrint;
|
||||||
|
:global SendNotification2;
|
||||||
|
:global SymbolForNotification;
|
||||||
|
|
||||||
|
:if ([ :len [ /system/health/find where type="C" ] ] = 0) do={
|
||||||
|
$LogPrint debug $FuncName ("Your device does not provide any voltage health values.");
|
||||||
|
:return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
:local TempToNum do={
|
||||||
|
:global CharacterReplace;
|
||||||
|
:local T [ :toarray [ $CharacterReplace $1 "." "," ] ];
|
||||||
|
:return ($T->0 * 10 + $T->1);
|
||||||
|
}
|
||||||
|
|
||||||
|
:if ([ :typeof $CheckHealthTemperatureNotified ] != "array") do={
|
||||||
|
:set CheckHealthTemperatureNotified ({});
|
||||||
|
}
|
||||||
|
|
||||||
|
:foreach Temperature in=[ /system/health/find where type="C" ] do={
|
||||||
|
:local Name [ /system/health/get $Temperature name ];
|
||||||
|
:local Value [ /system/health/get $Temperature value ];
|
||||||
|
|
||||||
|
:if ([ :typeof ($CheckHealthLast->$Name) ] != "nothing") do={
|
||||||
|
:if ([ :typeof ($CheckHealthTemperature->$Name) ] != "num" ) do={
|
||||||
|
$LogPrint info $FuncName ("No threshold given for " . $Name . ", assuming 50C.");
|
||||||
|
:set ($CheckHealthTemperature->$Name) 50;
|
||||||
|
}
|
||||||
|
:local Validate [ /system/health/get [ find where name=$Name ] value ];
|
||||||
|
:while ($Value != $Validate) do={
|
||||||
|
:set Value $Validate;
|
||||||
|
:set Validate [ /system/health/get [ find where name=$Name ] value ];
|
||||||
|
}
|
||||||
|
:if ($Value > $CheckHealthTemperature->$Name && \
|
||||||
|
$CheckHealthTemperatureNotified->$Name != true) do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "fire" ] . "Health warning: " . $Name); \
|
||||||
|
message=("The " . $Name . " on " . $Identity . " is above threshold: " . \
|
||||||
|
$Value . "\C2\B0" . "C") });
|
||||||
|
:set ($CheckHealthTemperatureNotified->$Name) true;
|
||||||
|
}
|
||||||
|
:if ($Value <= ($CheckHealthTemperature->$Name - $CheckHealthTemperatureDeviation) && \
|
||||||
|
$CheckHealthTemperatureNotified->$Name = true) do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "white-heavy-check-mark" ] . "Health recovery: " . $Name); \
|
||||||
|
message=("The " . $Name . " on " . $Identity . " dropped below threshold: " . \
|
||||||
|
$Value . "\C2\B0" . "C") });
|
||||||
|
:set ($CheckHealthTemperatureNotified->$Name) false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
:set ($CheckHealthLast->$Name) $Value;
|
||||||
|
}
|
||||||
|
}
|
||||||
64
check-health.d/voltage.rsc
Normal file
|
|
@ -0,0 +1,64 @@
|
||||||
|
#!rsc by RouterOS
|
||||||
|
# RouterOS script: check-health.d/voltage
|
||||||
|
# Copyright (c) 2019-2026 Christian Hesse <mail@eworm.de>
|
||||||
|
# https://rsc.eworm.de/COPYING.md
|
||||||
|
#
|
||||||
|
# requires RouterOS, version=7.15
|
||||||
|
#
|
||||||
|
# check for RouterOS health state - voltage plugin
|
||||||
|
# https://rsc.eworm.de/doc/check-health.md
|
||||||
|
|
||||||
|
:global CheckHealthPlugins;
|
||||||
|
|
||||||
|
:set ($CheckHealthPlugins->[ :jobname ]) do={
|
||||||
|
:local FuncName [ :tostr $0 ];
|
||||||
|
:local ScriptName [ :tostr $1 ];
|
||||||
|
|
||||||
|
:global CheckHealthLast;
|
||||||
|
:global CheckHealthVoltageLow;
|
||||||
|
:global CheckHealthVoltagePercent;
|
||||||
|
:global Identity;
|
||||||
|
|
||||||
|
:global FormatLine;
|
||||||
|
:global IfThenElse;
|
||||||
|
:global LogPrint;
|
||||||
|
:global SendNotification2;
|
||||||
|
:global SymbolForNotification;
|
||||||
|
|
||||||
|
:if ([ :len [ /system/health/find where type="V" ] ] = 0) do={
|
||||||
|
$LogPrint debug $FuncName ("Your device does not provide any voltage health values.");
|
||||||
|
:return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
:foreach Voltage in=[ /system/health/find where type="V" ] do={
|
||||||
|
:local Name [ /system/health/get $Voltage name ];
|
||||||
|
:local Value [ /system/health/get $Voltage value ];
|
||||||
|
|
||||||
|
:if ([ :typeof ($CheckHealthLast->$Name) ] != "nothing") do={
|
||||||
|
:local NumCurr [ $TempToNum $Value ];
|
||||||
|
:local NumLast [ $TempToNum ($CheckHealthLast->$Name) ];
|
||||||
|
|
||||||
|
:if ($NumLast * (100 + $CheckHealthVoltagePercent) < $NumCurr * 100 || \
|
||||||
|
$NumLast * 100 > $NumCurr * (100 + $CheckHealthVoltagePercent)) do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification ("high-voltage-sign,chart-" . [ $IfThenElse ($NumLast < \
|
||||||
|
$NumCurr) "in" "de" ] . "creasing") ] . "Health warning: " . $Name); \
|
||||||
|
message=("The " . $Name . " on " . $Identity . " jumped more than " . $CheckHealthVoltagePercent . "%.\n\n" . \
|
||||||
|
[ $FormatLine "old value" ($CheckHealthLast->$Name . " V") 12 ] . "\n" . \
|
||||||
|
[ $FormatLine "new value" ($Value . " V") 12 ]) });
|
||||||
|
} else={
|
||||||
|
:if ($NumCurr <= $CheckHealthVoltageLow && $NumLast > $CheckHealthVoltageLow) do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "high-voltage-sign,chart-decreasing" ] . "Health warning: Low " . $Name); \
|
||||||
|
message=("The " . $Name . " on " . $Identity . " dropped to " . $Value . " V below hard limit.") });
|
||||||
|
}
|
||||||
|
:if ($NumCurr > $CheckHealthVoltageLow && $NumLast <= $CheckHealthVoltageLow) do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "high-voltage-sign,chart-increasing" ] . "Health recovery: Low " . $Name); \
|
||||||
|
message=("The " . $Name . " on " . $Identity . " recovered to " . $Value . " V above hard limit.") });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
:set ($CheckHealthLast->$Name) $Value;
|
||||||
|
}
|
||||||
|
}
|
||||||
146
check-health.rsc
|
|
@ -1,37 +1,34 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: check-health
|
# RouterOS script: check-health
|
||||||
# Copyright (c) 2019-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2019-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# check for RouterOS health state
|
# check for RouterOS health state
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/check-health.md
|
# https://rsc.eworm.de/doc/check-health.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global CheckHealthCPUUtilization;
|
:global CheckHealthCPUUtilization;
|
||||||
:global CheckHealthCPUUtilizationNotified;
|
:global CheckHealthCPUUtilizationNotified;
|
||||||
:global CheckHealthLast;
|
:global CheckHealthLast;
|
||||||
:global CheckHealthRAMUtilizationNotified;
|
:global CheckHealthRAMUtilizationNotified;
|
||||||
:global CheckHealthTemperature;
|
|
||||||
:global CheckHealthTemperatureDeviation;
|
|
||||||
:global CheckHealthTemperatureNotified;
|
|
||||||
:global CheckHealthVoltageLow;
|
|
||||||
:global CheckHealthVoltagePercent;
|
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global HumanReadableNum;
|
:global HumanReadableNum;
|
||||||
:global IfThenElse;
|
:global IfThenElse;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
:global ValidateSyntax;
|
||||||
|
|
||||||
:local TempToNum do={
|
:local TempToNum do={
|
||||||
:global CharacterReplace;
|
:global CharacterReplace;
|
||||||
|
|
@ -40,7 +37,8 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:local Resource [ /system/resource/get ];
|
:local Resource [ /system/resource/get ];
|
||||||
|
|
@ -64,9 +62,9 @@
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "card-file-box,chart-increasing" ] . "Health warning: RAM utilization"); \
|
subject=([ $SymbolForNotification "card-file-box,chart-increasing" ] . "Health warning: RAM utilization"); \
|
||||||
message=("The RAM utilization on " . $Identity . " is at " . $CheckHealthRAMUtilization . "%!\n\n" . \
|
message=("The RAM utilization on " . $Identity . " is at " . $CheckHealthRAMUtilization . "%!\n\n" . \
|
||||||
[ $FormatLine "total" ([ $HumanReadableNum ($Resource->"total-memory") 1024 ] . "iB") 8 ] . "\n" . \
|
[ $FormatLine "total" ([ $HumanReadableNum ($Resource->"total-memory") 1024 ] . "B") 8 ] . "\n" . \
|
||||||
[ $FormatLine "used" ([ $HumanReadableNum ($Resource->"total-memory" - $Resource->"free-memory") 1024 ] . "iB") 8 ] . "\n" . \
|
[ $FormatLine "used" ([ $HumanReadableNum ($Resource->"total-memory" - $Resource->"free-memory") 1024 ] . "B") 8 ] . "\n" . \
|
||||||
[ $FormatLine "free" ([ $HumanReadableNum ($Resource->"free-memory") 1024 ] . "iB") 8 ]) });
|
[ $FormatLine "free" ([ $HumanReadableNum ($Resource->"free-memory") 1024 ] . "B") 8 ]) });
|
||||||
:set CheckHealthRAMUtilizationNotified true;
|
:set CheckHealthRAMUtilizationNotified true;
|
||||||
}
|
}
|
||||||
:if ($CheckHealthRAMUtilization < 70 && $CheckHealthRAMUtilizationNotified = true) do={
|
:if ($CheckHealthRAMUtilization < 70 && $CheckHealthRAMUtilizationNotified = true) do={
|
||||||
|
|
@ -76,105 +74,37 @@
|
||||||
:set CheckHealthRAMUtilizationNotified false;
|
:set CheckHealthRAMUtilizationNotified false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /system/health/find ] ] = 0) do={
|
:local Plugins [ /system/script/find where name~"^check-health.d/." ];
|
||||||
$LogPrintExit2 debug $ScriptName ("Your device does not provide any health values.") false;
|
:if ([ :len $Plugins ] = 0) do={
|
||||||
:return true;
|
$LogPrint debug $ScriptName ("No plugins installed.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:global CheckHealthPlugins ({});
|
||||||
:if ([ :typeof $CheckHealthLast ] != "array") do={
|
:if ([ :typeof $CheckHealthLast ] != "array") do={
|
||||||
:set CheckHealthLast ({});
|
:set CheckHealthLast ({});
|
||||||
}
|
}
|
||||||
:if ([ :typeof $CheckHealthTemperatureNotified ] != "array") do={
|
|
||||||
:set CheckHealthTemperatureNotified ({});
|
|
||||||
}
|
|
||||||
|
|
||||||
|
:foreach Plugin in=$Plugins do={
|
||||||
:foreach Voltage in=[ /system/health/find where type="V" ] do={
|
:local PluginVal [ /system/script/get $Plugin ];
|
||||||
:local Name [ /system/health/get $Voltage name ];
|
:if ([ $ValidateSyntax ($PluginVal->"source") ] = true) do={
|
||||||
:local Value [ /system/health/get $Voltage value ];
|
:onerror Err {
|
||||||
|
/system/script/run $Plugin;
|
||||||
:if ([ :typeof ($CheckHealthLast->$Name) ] != "nothing") do={
|
} do={
|
||||||
:local NumCurr [ $TempToNum $Value ];
|
$LogPrint error $ScriptName ("Plugin '" . $PluginVal->"name" . "' failed to run: " . $Err);
|
||||||
:local NumLast [ $TempToNum ($CheckHealthLast->$Name) ];
|
|
||||||
|
|
||||||
:if ($NumLast * (100 + $CheckHealthVoltagePercent) < $NumCurr * 100 || \
|
|
||||||
$NumLast * 100 > $NumCurr * (100 + $CheckHealthVoltagePercent)) do={
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
|
||||||
subject=([ $SymbolForNotification ("high-voltage-sign,chart-" . [ $IfThenElse ($NumLast < \
|
|
||||||
$NumCurr) "in" "de" ] . "creasing") ] . "Health warning: " . $Name); \
|
|
||||||
message=("The " . $Name . " on " . $Identity . " jumped more than " . $CheckHealthVoltagePercent . "%.\n\n" . \
|
|
||||||
[ $FormatLine "old value" ($CheckHealthLast->$Name . " V") 12 ] . "\n" . \
|
|
||||||
[ $FormatLine "new value" ($Value . " V") 12 ]) });
|
|
||||||
} else={
|
|
||||||
:if ($NumCurr <= $CheckHealthVoltageLow && $NumLast > $CheckHealthVoltageLow) do={
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
|
||||||
subject=([ $SymbolForNotification "high-voltage-sign,chart-decreasing" ] . "Health warning: Low " . $Name); \
|
|
||||||
message=("The " . $Name . " on " . $Identity . " dropped to " . $Value . " V below hard limit.") });
|
|
||||||
}
|
|
||||||
:if ($NumCurr > $CheckHealthVoltageLow && $NumLast <= $CheckHealthVoltageLow) do={
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
|
||||||
subject=([ $SymbolForNotification "high-voltage-sign,chart-increasing" ] . "Health recovery: Low " . $Name); \
|
|
||||||
message=("The " . $Name . " on " . $Identity . " recovered to " . $Value . " V above hard limit.") });
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
} else={
|
||||||
|
$LogPrint error $ScriptName ("Plugin '" . $PluginVal->"name" . "' failed syntax validation, skipping.");
|
||||||
}
|
}
|
||||||
:set ($CheckHealthLast->$Name) $Value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach PSU in=[ /system/health/find where name~"^psu.*-state\$" ] do={
|
:foreach PluginName,Discard in=$CheckHealthPlugins do={
|
||||||
:local Name [ /system/health/get $PSU name ];
|
($CheckHealthPlugins->$PluginName) \
|
||||||
:local Value [ /system/health/get $PSU value ];
|
("\$CheckHealthPlugins->\"" . $PluginName . "\"") $ScriptName;
|
||||||
|
|
||||||
:if ([ :typeof ($CheckHealthLast->$Name) ] != "nothing") do={
|
|
||||||
:if ($CheckHealthLast->$Name = "ok" && \
|
|
||||||
$Value != "ok") do={
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
|
||||||
subject=([ $SymbolForNotification "cross-mark" ] . "Health warning: " . $Name); \
|
|
||||||
message=("The power supply unit '" . $Name . "' on " . $Identity . " failed!") });
|
|
||||||
}
|
|
||||||
:if ($CheckHealthLast->$Name != "ok" && \
|
|
||||||
$Value = "ok") do={
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
|
||||||
subject=([ $SymbolForNotification "white-heavy-check-mark" ] . "Health recovery: " . $Name); \
|
|
||||||
message=("The power supply unit '" . $Name . "' on " . $Identity . " recovered!") });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
:set ($CheckHealthLast->$Name) $Value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Temperature in=[ /system/health/find where type="C" ] do={
|
:set CheckHealthPlugins;
|
||||||
:local Name [ /system/health/get $Temperature name ];
|
} do={
|
||||||
:local Value [ /system/health/get $Temperature value ];
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
|
|
||||||
:if ([ :typeof ($CheckHealthLast->$Name) ] != "nothing") do={
|
|
||||||
:if ([ :typeof ($CheckHealthTemperature->$Name) ] != "num" ) do={
|
|
||||||
$LogPrintExit2 info $ScriptName ("No threshold given for " . $Name . ", assuming 50C.") false;
|
|
||||||
:set ($CheckHealthTemperature->$Name) 50;
|
|
||||||
}
|
|
||||||
:local Validate [ /system/health/get [ find where name=$Name ] value ];
|
|
||||||
:while ($Value != $Validate) do={
|
|
||||||
:set Value $Validate;
|
|
||||||
:set Validate [ /system/health/get [ find where name=$Name ] value ];
|
|
||||||
}
|
|
||||||
:if ($Value > $CheckHealthTemperature->$Name && \
|
|
||||||
$CheckHealthTemperatureNotified->$Name != true) do={
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
|
||||||
subject=([ $SymbolForNotification "fire" ] . "Health warning: " . $Name); \
|
|
||||||
message=("The " . $Name . " on " . $Identity . " is above threshold: " . \
|
|
||||||
$Value . "\C2\B0" . "C") });
|
|
||||||
:set ($CheckHealthTemperatureNotified->$Name) true;
|
|
||||||
}
|
|
||||||
:if ($Value <= ($CheckHealthTemperature->$Name - $CheckHealthTemperatureDeviation) && \
|
|
||||||
$CheckHealthTemperatureNotified->$Name = true) do={
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
|
||||||
subject=([ $SymbolForNotification "white-heavy-check-mark" ] . "Health recovery: " . $Name); \
|
|
||||||
message=("The " . $Name . " on " . $Identity . " dropped below threshold: " . \
|
|
||||||
$Value . "\C2\B0" . "C") });
|
|
||||||
:set ($CheckHealthTemperatureNotified->$Name) false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
:set ($CheckHealthLast->$Name) $Value;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,25 +1,27 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: check-lte-firmware-upgrade
|
# RouterOS script: check-lte-firmware-upgrade
|
||||||
# Copyright (c) 2018-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2018-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# check for LTE firmware upgrade, send notification
|
# check for LTE firmware upgrade, send notification
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/check-lte-firmware-upgrade.md
|
# https://rsc.eworm.de/doc/check-lte-firmware-upgrade.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global SentLteFirmwareUpgradeNotification;
|
:global SentLteFirmwareUpgradeNotification;
|
||||||
|
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :typeof $SentLteFirmwareUpgradeNotification ] != "array") do={
|
:if ([ :typeof $SentLteFirmwareUpgradeNotification ] != "array") do={
|
||||||
|
|
@ -35,7 +37,7 @@
|
||||||
|
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global IfThenElse;
|
:global IfThenElse;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptFromTerminal;
|
:global ScriptFromTerminal;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
@ -43,23 +45,23 @@
|
||||||
:local IntName [ /interface/lte/get $Interface name ];
|
:local IntName [ /interface/lte/get $Interface name ];
|
||||||
:local Firmware;
|
:local Firmware;
|
||||||
:local Info;
|
:local Info;
|
||||||
:do {
|
:onerror Err {
|
||||||
:set Firmware [ /interface/lte/firmware-upgrade $Interface once as-value ];
|
:set Firmware [ /interface/lte/firmware-upgrade $Interface as-value ];
|
||||||
:set Info [ /interface/lte/monitor $Interface once as-value ];
|
:set Info [ /interface/lte/monitor $Interface once as-value ];
|
||||||
} on-error={
|
} do={
|
||||||
$LogPrintExit2 debug $ScriptName ("Could not get latest LTE firmware version for interface " . \
|
$LogPrint debug $ScriptName ("Could not get latest LTE firmware version for interface " . \
|
||||||
$IntName . ".") false;
|
$IntName . ": " . $Err);
|
||||||
:return false;
|
:return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len ($Firmware->"latest") ] = 0) do={
|
:if ([ :len ($Firmware->"latest") ] = 0) do={
|
||||||
$LogPrintExit2 info $ScriptName ("An empty string is not a valid version.") false;
|
$LogPrint info $ScriptName ("An empty string is not a valid version.");
|
||||||
:return false;
|
:return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if (($Firmware->"installed") = ($Firmware->"latest")) do={
|
:if (($Firmware->"installed") = ($Firmware->"latest")) do={
|
||||||
:if ([ $ScriptFromTerminal $ScriptName ] = true) do={
|
:if ([ $ScriptFromTerminal $ScriptName ] = true) do={
|
||||||
$LogPrintExit2 info $ScriptName ("No firmware upgrade available for LTE interface " . $IntName . ".") false;
|
$LogPrint info $ScriptName ("No firmware upgrade available for LTE interface " . $IntName . ".");
|
||||||
}
|
}
|
||||||
:return true;
|
:return true;
|
||||||
}
|
}
|
||||||
|
|
@ -69,7 +71,7 @@
|
||||||
:put ("Do you want to start unattended lte firmware upgrade for interface " . $IntName . "? [y/N]");
|
:put ("Do you want to start unattended lte firmware upgrade for interface " . $IntName . "? [y/N]");
|
||||||
:if (([ /terminal/inkey timeout=60 ] % 32) = 25) do={
|
:if (([ /terminal/inkey timeout=60 ] % 32) = 25) do={
|
||||||
/system/script/run unattended-lte-firmware-upgrade;
|
/system/script/run unattended-lte-firmware-upgrade;
|
||||||
$LogPrintExit2 info $ScriptName ("Scheduled lte firmware upgrade for interface " . $IntName . "...") false;
|
$LogPrint info $ScriptName ("Scheduled lte firmware upgrade for interface " . $IntName . "...");
|
||||||
:return true;
|
:return true;
|
||||||
} else={
|
} else={
|
||||||
:put "Canceled...";
|
:put "Canceled...";
|
||||||
|
|
@ -77,13 +79,13 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
:if (($SentLteFirmwareUpgradeNotification->$IntName) = ($Firmware->"latest")) do={
|
:if (($SentLteFirmwareUpgradeNotification->$IntName) = ($Firmware->"latest")) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("Already sent the LTE firmware upgrade notification for version " . \
|
$LogPrint debug $ScriptName ("Already sent the LTE firmware upgrade notification for version " . \
|
||||||
($Firmware->"latest") . ".") false;
|
($Firmware->"latest") . ".");
|
||||||
:return false;
|
:return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$LogPrintExit2 info $ScriptName ("A new firmware version " . ($Firmware->"latest") . " is available for " . \
|
$LogPrint info $ScriptName ("A new firmware version " . ($Firmware->"latest") . " is available for " . \
|
||||||
"LTE interface " . $IntName . ".") false;
|
"LTE interface " . $IntName . ".");
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "sparkles" ] . "LTE firmware upgrade"); \
|
subject=([ $SymbolForNotification "sparkles" ] . "LTE firmware upgrade"); \
|
||||||
message=("A new firmware version " . ($Firmware->"latest") . " is available for " . \
|
message=("A new firmware version " . ($Firmware->"latest") . " is available for " . \
|
||||||
|
|
@ -100,6 +102,6 @@
|
||||||
:foreach Interface in=[ /interface/lte/find ] do={
|
:foreach Interface in=[ /interface/lte/find ] do={
|
||||||
$CheckInterface $ScriptName $Interface;
|
$CheckInterface $ScriptName $Interface;
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
78
check-perpetual-license.rsc
Normal file
|
|
@ -0,0 +1,78 @@
|
||||||
|
#!rsc by RouterOS
|
||||||
|
# RouterOS script: check-perpetual-license
|
||||||
|
# Copyright (c) 2025-2026 Christian Hesse <mail@eworm.de>
|
||||||
|
# https://rsc.eworm.de/COPYING.md
|
||||||
|
#
|
||||||
|
# requires RouterOS, version=7.15
|
||||||
|
#
|
||||||
|
# check perpetual license on CHR
|
||||||
|
# https://rsc.eworm.de/doc/check-perpetual-license.md
|
||||||
|
|
||||||
|
:local ExitOK false;
|
||||||
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
|
:global Identity;
|
||||||
|
:global SentCertificateNotification;
|
||||||
|
|
||||||
|
:global LogPrint;
|
||||||
|
:global ScriptLock;
|
||||||
|
:global SendNotification2;
|
||||||
|
:global SymbolForNotification;
|
||||||
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$WaitFullyConnected;
|
||||||
|
|
||||||
|
:local License [ /system/license/get ];
|
||||||
|
:if ([ :typeof ($License->"deadline-at") ] != "str") do={
|
||||||
|
$LogPrint info $ScriptName ("This device does not have a perpetual license.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
|
}
|
||||||
|
|
||||||
|
:if ([ :len ($License->"next-renewal-at") ] = 0 && ($License->"limited-upgrades") = true) do={
|
||||||
|
$LogPrint warning $ScriptName ("Your license expired on " . ($License->"deadline-at") . "!");
|
||||||
|
:if ($SentCertificateNotification != "expired") do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "scroll,cross-mark" ] . "License expired!"); \
|
||||||
|
message=("Your license expired on " . ($License->"deadline-at") . \
|
||||||
|
", can no longer update RouterOS on " . $Identity . "...") });
|
||||||
|
:set SentCertificateNotification "expired";
|
||||||
|
}
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
|
}
|
||||||
|
|
||||||
|
:if ([ :totime ($License->"deadline-at") ] - 3w < [ :timestamp ]) do={
|
||||||
|
$LogPrint warning $ScriptName ("Your license will expire on " . ($License->"deadline-at") . "!");
|
||||||
|
:if ($SentCertificateNotification != "warning") do={
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "scroll,warning-sign" ] . "License about to expire!"); \
|
||||||
|
message=("Your license failed to renew and is about to expire on " . \
|
||||||
|
($License->"deadline-at") . " on " . $Identity . "...") });
|
||||||
|
:set SentCertificateNotification "warning";
|
||||||
|
}
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
|
}
|
||||||
|
|
||||||
|
:if ([ :typeof $SentCertificateNotification ] = "str" && \
|
||||||
|
[ :totime ($License->"deadline-at") ] - 4w > [ :timestamp ]) do={
|
||||||
|
$LogPrint info $ScriptName ("Your license was successfully renewed.");
|
||||||
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
subject=([ $SymbolForNotification "scroll,white-heavy-check-mark" ] . "License renewed"); \
|
||||||
|
message=("Your license was successfully renewed on " . $Identity . \
|
||||||
|
". It is now valid until " . ($License->"deadline-at") . ".") });
|
||||||
|
:set SentCertificateNotification;
|
||||||
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
|
}
|
||||||
|
|
@ -1,18 +1,20 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: check-routeros-update
|
# RouterOS script: check-routeros-update
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
|
# requires device-mode, fetch, scheduler
|
||||||
#
|
#
|
||||||
# check for RouterOS update, send notification and/or install
|
# check for RouterOS update, send notification and/or install
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/check-routeros-update.md
|
# https://rsc.eworm.de/doc/check-routeros-update.md
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global Identity;
|
:global Identity;
|
||||||
:global SafeUpdateAll;
|
:global SafeUpdateAll;
|
||||||
|
|
@ -24,7 +26,9 @@
|
||||||
|
|
||||||
:global DeviceInfo;
|
:global DeviceInfo;
|
||||||
:global EscapeForRegEx;
|
:global EscapeForRegEx;
|
||||||
:global LogPrintExit2;
|
:global FetchUserAgentStr;
|
||||||
|
:global LogPrint;
|
||||||
|
:global RebootForUpdate;
|
||||||
:global ScriptFromTerminal;
|
:global ScriptFromTerminal;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
|
|
@ -33,58 +37,92 @@
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:local DoUpdate do={
|
:local DoUpdate do={
|
||||||
|
:local ScriptName [ :tostr $1 ];
|
||||||
|
|
||||||
:if ([ :len [ /system/script/find where name="packages-update" ] ] > 0) do={
|
:if ([ :len [ /system/script/find where name="packages-update" ] ] > 0) do={
|
||||||
/system/script/run packages-update;
|
/system/script/run packages-update;
|
||||||
} else={
|
} else={
|
||||||
/system/package/update/install without-paging;
|
/system/package/update/install without-paging;
|
||||||
}
|
}
|
||||||
:error "Waiting for system to reboot.";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:if ([ :len [ /system/scheduler/find where name="running-from-backup-partition" ] ] > 0) do={
|
||||||
|
$LogPrint warning $ScriptName ("Running from backup partition, refusing to act.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
|
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ :len [ /system/scheduler/find where name="_RebootForUpdate" ] ] > 0) do={
|
:if ([ :len [ /system/scheduler/find where name="_RebootForUpdate" ] ] > 0) do={
|
||||||
:error "A reboot for update is already scheduled.";
|
:if ([ :typeof $RebootForUpdate ] = "nothing") do={
|
||||||
|
$LogPrint info $ScriptName ("Found a stale scheduler for reboot, removing.");
|
||||||
|
/system/scheduler/remove "_RebootForUpdate";
|
||||||
|
} else={
|
||||||
|
$LogPrint info $ScriptName ("A reboot for update is already scheduled.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$LogPrintExit2 debug $ScriptName ("Checking for updates...") false;
|
$LogPrint debug $ScriptName ("Checking for updates...");
|
||||||
/system/package/update/check-for-updates without-paging as-value;
|
/system/package/update/check-for-updates without-paging as-value;
|
||||||
:local Update [ /system/package/update/get ];
|
:local Update [ /system/package/update/get ];
|
||||||
|
|
||||||
:if ([ $ScriptFromTerminal $ScriptName ] = true && ($Update->"installed-version") = ($Update->"latest-version")) do={
|
:if (($Update->"installed-version") = ($Update->"latest-version")) do={
|
||||||
$LogPrintExit2 info $ScriptName ("System is already up to date.") false;
|
:if ([ $ScriptFromTerminal $ScriptName ] = true) do={
|
||||||
:return true;
|
$LogPrint info $ScriptName ("System is already up to date.");
|
||||||
|
}
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
|
}
|
||||||
|
|
||||||
|
:if ([ :len ($Update->"latest-version") ] = 0) do={
|
||||||
|
$LogPrint info $ScriptName ("Received an empty version string from server.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:local NumInstalled [ $VersionToNum ($Update->"installed-version") ];
|
:local NumInstalled [ $VersionToNum ($Update->"installed-version") ];
|
||||||
:local NumLatest [ $VersionToNum ($Update->"latest-version") ];
|
:local NumLatest [ $VersionToNum ($Update->"latest-version") ];
|
||||||
|
:local BitMask [ $VersionToNum "255.255zero0" ];
|
||||||
|
:local NumInstalledFeature ($NumInstalled & $BitMask);
|
||||||
|
:local NumLatestFeature ($NumLatest & $BitMask);
|
||||||
:local Link ("https://mikrotik.com/download/changelogs/" . $Update->"channel" . "-release-tree");
|
:local Link ("https://mikrotik.com/download/changelogs/" . $Update->"channel" . "-release-tree");
|
||||||
|
|
||||||
:if ($NumLatest < 117505792) do={
|
:if ($NumLatest < [ $VersionToNum "7.0" ]) do={
|
||||||
$LogPrintExit2 info $ScriptName ("The version '" . ($Update->"latest-version") . "' is not a valid version.") true;
|
$LogPrint warning $ScriptName ("The version '" . ($Update->"latest-version") . "' is not a valid version.");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ($NumInstalled < $NumLatest) do={
|
:if ($NumInstalled < $NumLatest) do={
|
||||||
:if ($SafeUpdateAll ~ "^YES,? ?PLEASE!?\$") do={
|
:if ($SafeUpdateAll ~ "^YES,? ?PLEASE!?\$") do={
|
||||||
$LogPrintExit2 info $ScriptName ("Installing ALL versions automatically, including " . \
|
$LogPrint info $ScriptName ("Installing ALL versions automatically, including " . \
|
||||||
$Update->"latest-version" . "...") false;
|
$Update->"latest-version" . "...");
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "sparkles" ] . "RouterOS update: " . $Update->"latest-version"); \
|
subject=([ $SymbolForNotification "sparkles" ] . "RouterOS update: " . $Update->"latest-version"); \
|
||||||
message=("Installing ALL versions automatically, including " . $Update->"latest-version" . \
|
message=("Installing ALL versions automatically, including " . $Update->"latest-version" . \
|
||||||
"... Updating on " . $Identity . "..."); link=$Link; silent=true });
|
"... Updating on " . $Identity . "..."); link=$Link; silent=true });
|
||||||
$DoUpdate;
|
$DoUpdate $ScriptName;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ($SafeUpdatePatch = true && ($NumInstalled & 0xffff0000) = ($NumLatest & 0xffff0000)) do={
|
:if ($SafeUpdatePatch = true && $NumInstalledFeature = $NumLatestFeature) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Version " . $Update->"latest-version" . " is a patch release, updating...") false;
|
$LogPrint info $ScriptName ("Version " . $Update->"latest-version" . " is a patch release, updating...");
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "sparkles" ] . "RouterOS update: " . $Update->"latest-version"); \
|
subject=([ $SymbolForNotification "sparkles" ] . "RouterOS update: " . $Update->"latest-version"); \
|
||||||
message=("Version " . $Update->"latest-version" . " is a patch update for " . $Update->"channel" . \
|
message=("Version " . $Update->"latest-version" . " is a patch update for " . $Update->"channel" . \
|
||||||
", updating on " . $Identity . "..."); link=$Link; silent=true });
|
", updating on " . $Identity . "..."); link=$Link; silent=true });
|
||||||
$DoUpdate;
|
$DoUpdate $ScriptName;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ($SafeUpdateNeighbor = true) do={
|
:if ($SafeUpdateNeighbor = true) do={
|
||||||
|
|
@ -92,48 +130,66 @@
|
||||||
version~("^" . [ $EscapeForRegEx ($Update->"latest-version") ] . "\\b") ];
|
version~("^" . [ $EscapeForRegEx ($Update->"latest-version") ] . "\\b") ];
|
||||||
:if ([ :len $Neighbors ] > 0) do={
|
:if ([ :len $Neighbors ] > 0) do={
|
||||||
:local Neighbor [ /ip/neighbor/get ($Neighbors->0) identity ];
|
:local Neighbor [ /ip/neighbor/get ($Neighbors->0) identity ];
|
||||||
$LogPrintExit2 info $ScriptName ("Seen a neighbor (" . $Neighbor . ") running version " . \
|
$LogPrint info $ScriptName ("Seen a neighbor (" . $Neighbor . ") running version " . \
|
||||||
$Update->"latest-version" . " from " . $Update->"channel" . ", updating...") false;
|
$Update->"latest-version" . " from " . $Update->"channel" . ", updating...");
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "sparkles" ] . "RouterOS update: " . $Update->"latest-version"); \
|
subject=([ $SymbolForNotification "sparkles" ] . "RouterOS update: " . $Update->"latest-version"); \
|
||||||
message=("Seen a neighbor (" . $Neighbor . ") running version " . $Update->"latest-version" . \
|
message=("Seen a neighbor (" . $Neighbor . ") running version " . $Update->"latest-version" . \
|
||||||
" from " . $Update->"channel" . ", updating on " . $Identity . "..."); link=$Link; silent=true });
|
" from " . $Update->"channel" . ", updating on " . $Identity . "..."); link=$Link; silent=true });
|
||||||
$DoUpdate;
|
$DoUpdate $ScriptName;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len $SafeUpdateUrl ] > 0) do={
|
:if ([ :len $SafeUpdateUrl ] > 0) do={
|
||||||
:local Result;
|
:local Result;
|
||||||
:do {
|
:onerror Err {
|
||||||
:set Result [ /tool/fetch check-certificate=yes-without-crl \
|
:set Result [ /tool/fetch check-certificate=yes-without-crl \
|
||||||
($SafeUpdateUrl . $Update->"channel" . "?installed=" . $Update->"installed-version" . \
|
($SafeUpdateUrl . $Update->"channel" . "?installed=" . $Update->"installed-version" . \
|
||||||
"&latest=" . $Update->"latest-version") output=user as-value ];
|
"&latest=" . $Update->"latest-version") http-header-field=({ [ $FetchUserAgentStr $ScriptName ] }) \
|
||||||
} on-error={
|
output=user as-value ];
|
||||||
$LogPrintExit2 warning $ScriptName ("Failed receiving safe version for " . $Update->"channel" . ".") false;
|
} do={
|
||||||
|
$LogPrint warning $ScriptName ("Failed receiving safe version for " . $Update->"channel" . ": " . $Err);
|
||||||
}
|
}
|
||||||
:if ($Result->"status" = "finished" && $Result->"data" = $Update->"latest-version") do={
|
:if ($Result->"status" = "finished" && $Result->"data" = $Update->"latest-version") do={
|
||||||
$LogPrintExit2 info $ScriptName ("Version " . $Update->"latest-version" . " is considered safe, updating...") false;
|
$LogPrint info $ScriptName ("Version " . $Update->"latest-version" . " is considered safe, updating...");
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "sparkles" ] . "RouterOS update: " . $Update->"latest-version"); \
|
subject=([ $SymbolForNotification "sparkles" ] . "RouterOS update: " . $Update->"latest-version"); \
|
||||||
message=("Version " . $Update->"latest-version" . " is considered safe for " . $Update->"channel" . \
|
message=("Version " . $Update->"latest-version" . " is considered safe for " . $Update->"channel" . \
|
||||||
", updating on " . $Identity . "..."); link=$Link; silent=true });
|
", updating on " . $Identity . "..."); link=$Link; silent=true });
|
||||||
$DoUpdate;
|
$DoUpdate $ScriptName;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ $ScriptFromTerminal $ScriptName ] = true) do={
|
:if ([ $ScriptFromTerminal $ScriptName ] = true) do={
|
||||||
|
:if (($Update->"channel") = "testing" && $NumInstalledFeature < $NumLatestFeature) do={
|
||||||
|
:put ("This is a feature update in testing channel. Switch to channel 'stable'? [y/N]");
|
||||||
|
:if (([ /terminal/inkey timeout=60 ] % 32) = 25) do={
|
||||||
|
/system/package/update/set channel=stable;
|
||||||
|
$LogPrint info $ScriptName ("Switched to channel 'stable', please re-run!");
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
:put ("Do you want to install RouterOS version " . $Update->"latest-version" . "? [y/N]");
|
:put ("Do you want to install RouterOS version " . $Update->"latest-version" . "? [y/N]");
|
||||||
:if (([ /terminal/inkey timeout=60 ] % 32) = 25) do={
|
:if (([ /terminal/inkey timeout=60 ] % 32) = 25) do={
|
||||||
$DoUpdate;
|
$DoUpdate $ScriptName;
|
||||||
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
} else={
|
} else={
|
||||||
:put "Canceled...";
|
:put "Canceled...";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ($SentRouterosUpdateNotification = $Update->"latest-version") do={
|
:if ($SentRouterosUpdateNotification = $Update->"latest-version") do={
|
||||||
$LogPrintExit2 info $ScriptName ("Already sent the RouterOS update notification for version " . \
|
$LogPrint info $ScriptName ("Already sent the RouterOS update notification for version " . \
|
||||||
$Update->"latest-version" . ".") false;
|
$Update->"latest-version" . ".");
|
||||||
:return true;
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
}
|
}
|
||||||
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
|
@ -146,9 +202,10 @@
|
||||||
|
|
||||||
:if ($NumInstalled > $NumLatest) do={
|
:if ($NumInstalled > $NumLatest) do={
|
||||||
:if ($SentRouterosUpdateNotification = $Update->"latest-version") do={
|
:if ($SentRouterosUpdateNotification = $Update->"latest-version") do={
|
||||||
$LogPrintExit2 info $ScriptName ("Already sent the RouterOS downgrade notification for version " . \
|
$LogPrint info $ScriptName ("Already sent the RouterOS downgrade notification for version " . \
|
||||||
$Update->"latest-version" . ".") false;
|
$Update->"latest-version" . ".");
|
||||||
:return true;
|
:set ExitOK true;
|
||||||
|
:error true;
|
||||||
}
|
}
|
||||||
|
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
|
|
@ -156,10 +213,10 @@
|
||||||
message=("A different RouterOS version " . ($Update->"latest-version") . \
|
message=("A different RouterOS version " . ($Update->"latest-version") . \
|
||||||
" is available for " . $Identity . ", but it is a downgrade.\n\n" . \
|
" is available for " . $Identity . ", but it is a downgrade.\n\n" . \
|
||||||
[ $DeviceInfo ]); link=$Link; silent=true });
|
[ $DeviceInfo ]); link=$Link; silent=true });
|
||||||
$LogPrintExit2 info $ScriptName ("A different RouterOS version " . ($Update->"latest-version") . \
|
$LogPrint info $ScriptName ("A different RouterOS version " . ($Update->"latest-version") . \
|
||||||
" is available for downgrade.") false;
|
" is available for downgrade.");
|
||||||
:set SentRouterosUpdateNotification ($Update->"latest-version");
|
:set SentRouterosUpdateNotification ($Update->"latest-version");
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,21 +1,22 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: collect-wireless-mac.capsman
|
# RouterOS script: collect-wireless-mac.capsman
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: lease-script, order=40
|
# provides: lease-script, order=40
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# collect wireless mac adresses in access list
|
# collect wireless mac adresses in access list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/collect-wireless-mac.md
|
# https://rsc.eworm.de/doc/collect-wireless-mac.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
|
|
@ -23,18 +24,19 @@
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global FormatMultiLines;
|
:global FormatMultiLines;
|
||||||
:global GetMacVendor;
|
:global GetMacVendor;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName 10 ] = false) do={
|
:if ([ $ScriptLock $ScriptName 10 ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /caps-man/access-list/find where comment="--- collected above ---" disabled ] ] = 0) do={
|
:if ([ :len [ /caps-man/access-list/find where comment="--- collected above ---" disabled ] ] = 0) do={
|
||||||
/caps-man/access-list/add comment="--- collected above ---" disabled=yes;
|
/caps-man/access-list/add comment="--- collected above ---" disabled=yes;
|
||||||
$LogPrintExit2 warning $ScriptName ("Added disabled access-list entry with comment '--- collected above ---'.") false;
|
$LogPrint warning $ScriptName ("Added disabled access-list entry with comment '--- collected above ---'.");
|
||||||
}
|
}
|
||||||
:local PlaceBefore ([ /caps-man/access-list/find where comment="--- collected above ---" disabled ]->0);
|
:local PlaceBefore ([ /caps-man/access-list/find where comment="--- collected above ---" disabled ]->0);
|
||||||
|
|
||||||
|
|
@ -43,14 +45,14 @@
|
||||||
:do {
|
:do {
|
||||||
:set RegVal [ /caps-man/registration-table/get $Reg ];
|
:set RegVal [ /caps-man/registration-table/get $Reg ];
|
||||||
} on-error={
|
} on-error={
|
||||||
$LogPrintExit2 debug $ScriptName ("Device already gone... Ignoring.") false;
|
$LogPrint debug $ScriptName ("Device already gone... Ignoring.");
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len ($RegVal->"mac-address") ] > 0) do={
|
:if ([ :len ($RegVal->"mac-address") ] > 0) do={
|
||||||
:local AccessList ([ /caps-man/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
:local AccessList ([ /caps-man/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
||||||
:if ([ :len $AccessList ] > 0) do={
|
:if ([ :len $AccessList ] > 0) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("MAC address " . $RegVal->"mac-address" . " already known: " . \
|
$LogPrint debug $ScriptName ("MAC address " . $RegVal->"mac-address" . " already known: " . \
|
||||||
[ /caps-man/access-list/get $AccessList comment ]) false;
|
[ /caps-man/access-list/get $AccessList comment ]);
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len $AccessList ] = 0) do={
|
:if ([ :len $AccessList ] = 0) do={
|
||||||
|
|
@ -74,7 +76,7 @@
|
||||||
:local Vendor [ $GetMacVendor ($RegVal->"mac-address") ];
|
:local Vendor [ $GetMacVendor ($RegVal->"mac-address") ];
|
||||||
:local Message ("MAC address " . $RegVal->"mac-address" . " (" . $Vendor . ", " . $HostName . ") " . \
|
:local Message ("MAC address " . $RegVal->"mac-address" . " (" . $Vendor . ", " . $HostName . ") " . \
|
||||||
"first seen on " . $DateTime . " connected to SSID " . $RegVal->"ssid" . ", interface " . $RegVal->"interface");
|
"first seen on " . $DateTime . " connected to SSID " . $RegVal->"ssid" . ", interface " . $RegVal->"interface");
|
||||||
$LogPrintExit2 info $ScriptName $Message false;
|
$LogPrint info $ScriptName $Message;
|
||||||
/caps-man/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
/caps-man/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "mobile-phone" ] . $RegVal->"mac-address" . " connected to " . $RegVal->"ssid"); \
|
subject=([ $SymbolForNotification "mobile-phone" ] . $RegVal->"mac-address" . " connected to " . $RegVal->"ssid"); \
|
||||||
|
|
@ -90,9 +92,9 @@
|
||||||
[ $FormatLine "Date" $DateTime ]) });
|
[ $FormatLine "Date" $DateTime ]) });
|
||||||
}
|
}
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 debug $ScriptName ("No mac address available... Ignoring.") false;
|
$LogPrint debug $ScriptName ("No mac address available... Ignoring.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,21 +1,22 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: collect-wireless-mac.local
|
# RouterOS script: collect-wireless-mac.local
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: lease-script, order=40
|
# provides: lease-script, order=40
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# collect wireless mac adresses in access list
|
# collect wireless mac adresses in access list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/collect-wireless-mac.md
|
# https://rsc.eworm.de/doc/collect-wireless-mac.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
|
|
@ -23,18 +24,19 @@
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global FormatMultiLines;
|
:global FormatMultiLines;
|
||||||
:global GetMacVendor;
|
:global GetMacVendor;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName 10 ] = false) do={
|
:if ([ $ScriptLock $ScriptName 10 ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /interface/wireless/access-list/find where comment="--- collected above ---" disabled ] ] = 0) do={
|
:if ([ :len [ /interface/wireless/access-list/find where comment="--- collected above ---" disabled ] ] = 0) do={
|
||||||
/interface/wireless/access-list/add comment="--- collected above ---" disabled=yes;
|
/interface/wireless/access-list/add comment="--- collected above ---" disabled=yes;
|
||||||
$LogPrintExit2 warning $ScriptName ("Added disabled access-list entry with comment '--- collected above ---'.") false;
|
$LogPrint warning $ScriptName ("Added disabled access-list entry with comment '--- collected above ---'.");
|
||||||
}
|
}
|
||||||
:local PlaceBefore ([ /interface/wireless/access-list/find where comment="--- collected above ---" disabled ]->0);
|
:local PlaceBefore ([ /interface/wireless/access-list/find where comment="--- collected above ---" disabled ]->0);
|
||||||
|
|
||||||
|
|
@ -43,14 +45,14 @@
|
||||||
:do {
|
:do {
|
||||||
:set RegVal [ /interface/wireless/registration-table/get $Reg ];
|
:set RegVal [ /interface/wireless/registration-table/get $Reg ];
|
||||||
} on-error={
|
} on-error={
|
||||||
$LogPrintExit2 debug $ScriptName ("Device already gone... Ignoring.") false;
|
$LogPrint debug $ScriptName ("Device already gone... Ignoring.");
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len ($RegVal->"mac-address") ] > 0) do={
|
:if ([ :len ($RegVal->"mac-address") ] > 0) do={
|
||||||
:local AccessList ([ /interface/wireless/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
:local AccessList ([ /interface/wireless/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
||||||
:if ([ :len $AccessList ] > 0) do={
|
:if ([ :len $AccessList ] > 0) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("MAC address " . $RegVal->"mac-address" . " already known: " . \
|
$LogPrint debug $ScriptName ("MAC address " . $RegVal->"mac-address" . " already known: " . \
|
||||||
[ /interface/wireless/access-list/get $AccessList comment ]) false;
|
[ /interface/wireless/access-list/get $AccessList comment ]);
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len $AccessList ] = 0) do={
|
:if ([ :len $AccessList ] = 0) do={
|
||||||
|
|
@ -75,7 +77,7 @@
|
||||||
:local Vendor [ $GetMacVendor ($RegVal->"mac-address") ];
|
:local Vendor [ $GetMacVendor ($RegVal->"mac-address") ];
|
||||||
:local Message ("MAC address " . $RegVal->"mac-address" . " (" . $Vendor . ", " . $HostName . ") " . \
|
:local Message ("MAC address " . $RegVal->"mac-address" . " (" . $Vendor . ", " . $HostName . ") " . \
|
||||||
"first seen on " . $DateTime . " connected to SSID " . $RegVal->"ssid" . ", interface " . $RegVal->"interface");
|
"first seen on " . $DateTime . " connected to SSID " . $RegVal->"ssid" . ", interface " . $RegVal->"interface");
|
||||||
$LogPrintExit2 info $ScriptName $Message false;
|
$LogPrint info $ScriptName $Message;
|
||||||
/interface/wireless/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
/interface/wireless/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "mobile-phone" ] . $RegVal->"mac-address" . " connected to " . $RegVal->"ssid"); \
|
subject=([ $SymbolForNotification "mobile-phone" ] . $RegVal->"mac-address" . " connected to " . $RegVal->"ssid"); \
|
||||||
|
|
@ -91,9 +93,9 @@
|
||||||
[ $FormatLine "Date" $DateTime ]) });
|
[ $FormatLine "Date" $DateTime ]) });
|
||||||
}
|
}
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 debug $ScriptName ("No mac address available... Ignoring.") false;
|
$LogPrint debug $ScriptName ("No mac address available... Ignoring.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,22 +1,23 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: collect-wireless-mac%TEMPL%
|
# RouterOS script: collect-wireless-mac%TEMPL%
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: lease-script, order=40
|
# provides: lease-script, order=40
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# collect wireless mac adresses in access list
|
# collect wireless mac adresses in access list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/collect-wireless-mac.md
|
# https://rsc.eworm.de/doc/collect-wireless-mac.md
|
||||||
#
|
#
|
||||||
# !! This is just a template to generate the real script!
|
# !! This is just a template to generate the real script!
|
||||||
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
|
|
@ -24,13 +25,14 @@
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global FormatMultiLines;
|
:global FormatMultiLines;
|
||||||
:global GetMacVendor;
|
:global GetMacVendor;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName 10 ] = false) do={
|
:if ([ $ScriptLock $ScriptName 10 ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /caps-man/access-list/find where comment="--- collected above ---" disabled ] ] = 0) do={
|
:if ([ :len [ /caps-man/access-list/find where comment="--- collected above ---" disabled ] ] = 0) do={
|
||||||
|
|
@ -39,7 +41,7 @@
|
||||||
/caps-man/access-list/add comment="--- collected above ---" disabled=yes;
|
/caps-man/access-list/add comment="--- collected above ---" disabled=yes;
|
||||||
/interface/wifi/access-list/add comment="--- collected above ---" disabled=yes;
|
/interface/wifi/access-list/add comment="--- collected above ---" disabled=yes;
|
||||||
/interface/wireless/access-list/add comment="--- collected above ---" disabled=yes;
|
/interface/wireless/access-list/add comment="--- collected above ---" disabled=yes;
|
||||||
$LogPrintExit2 warning $ScriptName ("Added disabled access-list entry with comment '--- collected above ---'.") false;
|
$LogPrint warning $ScriptName ("Added disabled access-list entry with comment '--- collected above ---'.");
|
||||||
}
|
}
|
||||||
:local PlaceBefore ([ /caps-man/access-list/find where comment="--- collected above ---" disabled ]->0);
|
:local PlaceBefore ([ /caps-man/access-list/find where comment="--- collected above ---" disabled ]->0);
|
||||||
:local PlaceBefore ([ /interface/wifi/access-list/find where comment="--- collected above ---" disabled ]->0);
|
:local PlaceBefore ([ /interface/wifi/access-list/find where comment="--- collected above ---" disabled ]->0);
|
||||||
|
|
@ -54,7 +56,7 @@
|
||||||
:set RegVal [ /interface/wifi/registration-table/get $Reg ];
|
:set RegVal [ /interface/wifi/registration-table/get $Reg ];
|
||||||
:set RegVal [ /interface/wireless/registration-table/get $Reg ];
|
:set RegVal [ /interface/wireless/registration-table/get $Reg ];
|
||||||
} on-error={
|
} on-error={
|
||||||
$LogPrintExit2 debug $ScriptName ("Device already gone... Ignoring.") false;
|
$LogPrint debug $ScriptName ("Device already gone... Ignoring.");
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len ($RegVal->"mac-address") ] > 0) do={
|
:if ([ :len ($RegVal->"mac-address") ] > 0) do={
|
||||||
|
|
@ -62,10 +64,10 @@
|
||||||
:local AccessList ([ /interface/wifi/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
:local AccessList ([ /interface/wifi/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
||||||
:local AccessList ([ /interface/wireless/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
:local AccessList ([ /interface/wireless/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
||||||
:if ([ :len $AccessList ] > 0) do={
|
:if ([ :len $AccessList ] > 0) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("MAC address " . $RegVal->"mac-address" . " already known: " . \
|
$LogPrint debug $ScriptName ("MAC address " . $RegVal->"mac-address" . " already known: " . \
|
||||||
[ /caps-man/access-list/get $AccessList comment ]) false;
|
[ /caps-man/access-list/get $AccessList comment ]);
|
||||||
[ /interface/wifi/access-list/get $AccessList comment ]) false;
|
[ /interface/wifi/access-list/get $AccessList comment ]);
|
||||||
[ /interface/wireless/access-list/get $AccessList comment ]) false;
|
[ /interface/wireless/access-list/get $AccessList comment ]);
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len $AccessList ] = 0) do={
|
:if ([ :len $AccessList ] = 0) do={
|
||||||
|
|
@ -90,7 +92,7 @@
|
||||||
:local Vendor [ $GetMacVendor ($RegVal->"mac-address") ];
|
:local Vendor [ $GetMacVendor ($RegVal->"mac-address") ];
|
||||||
:local Message ("MAC address " . $RegVal->"mac-address" . " (" . $Vendor . ", " . $HostName . ") " . \
|
:local Message ("MAC address " . $RegVal->"mac-address" . " (" . $Vendor . ", " . $HostName . ") " . \
|
||||||
"first seen on " . $DateTime . " connected to SSID " . $RegVal->"ssid" . ", interface " . $RegVal->"interface");
|
"first seen on " . $DateTime . " connected to SSID " . $RegVal->"ssid" . ", interface " . $RegVal->"interface");
|
||||||
$LogPrintExit2 info $ScriptName $Message false;
|
$LogPrint info $ScriptName $Message;
|
||||||
/caps-man/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
/caps-man/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
||||||
/interface/wifi/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
/interface/wifi/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
||||||
/interface/wireless/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
/interface/wireless/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
||||||
|
|
@ -108,9 +110,9 @@
|
||||||
[ $FormatLine "Date" $DateTime ]) });
|
[ $FormatLine "Date" $DateTime ]) });
|
||||||
}
|
}
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 debug $ScriptName ("No mac address available... Ignoring.") false;
|
$LogPrint debug $ScriptName ("No mac address available... Ignoring.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,21 +1,22 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: collect-wireless-mac.wifi
|
# RouterOS script: collect-wireless-mac.wifi
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: lease-script, order=40
|
# provides: lease-script, order=40
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# collect wireless mac adresses in access list
|
# collect wireless mac adresses in access list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/collect-wireless-mac.md
|
# https://rsc.eworm.de/doc/collect-wireless-mac.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
|
|
@ -23,18 +24,19 @@
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global FormatMultiLines;
|
:global FormatMultiLines;
|
||||||
:global GetMacVendor;
|
:global GetMacVendor;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName 10 ] = false) do={
|
:if ([ $ScriptLock $ScriptName 10 ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len [ /interface/wifi/access-list/find where comment="--- collected above ---" disabled ] ] = 0) do={
|
:if ([ :len [ /interface/wifi/access-list/find where comment="--- collected above ---" disabled ] ] = 0) do={
|
||||||
/interface/wifi/access-list/add comment="--- collected above ---" disabled=yes;
|
/interface/wifi/access-list/add comment="--- collected above ---" disabled=yes;
|
||||||
$LogPrintExit2 warning $ScriptName ("Added disabled access-list entry with comment '--- collected above ---'.") false;
|
$LogPrint warning $ScriptName ("Added disabled access-list entry with comment '--- collected above ---'.");
|
||||||
}
|
}
|
||||||
:local PlaceBefore ([ /interface/wifi/access-list/find where comment="--- collected above ---" disabled ]->0);
|
:local PlaceBefore ([ /interface/wifi/access-list/find where comment="--- collected above ---" disabled ]->0);
|
||||||
|
|
||||||
|
|
@ -43,14 +45,14 @@
|
||||||
:do {
|
:do {
|
||||||
:set RegVal [ /interface/wifi/registration-table/get $Reg ];
|
:set RegVal [ /interface/wifi/registration-table/get $Reg ];
|
||||||
} on-error={
|
} on-error={
|
||||||
$LogPrintExit2 debug $ScriptName ("Device already gone... Ignoring.") false;
|
$LogPrint debug $ScriptName ("Device already gone... Ignoring.");
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len ($RegVal->"mac-address") ] > 0) do={
|
:if ([ :len ($RegVal->"mac-address") ] > 0) do={
|
||||||
:local AccessList ([ /interface/wifi/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
:local AccessList ([ /interface/wifi/access-list/find where mac-address=($RegVal->"mac-address") ]->0);
|
||||||
:if ([ :len $AccessList ] > 0) do={
|
:if ([ :len $AccessList ] > 0) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("MAC address " . $RegVal->"mac-address" . " already known: " . \
|
$LogPrint debug $ScriptName ("MAC address " . $RegVal->"mac-address" . " already known: " . \
|
||||||
[ /interface/wifi/access-list/get $AccessList comment ]) false;
|
[ /interface/wifi/access-list/get $AccessList comment ]);
|
||||||
}
|
}
|
||||||
|
|
||||||
:if ([ :len $AccessList ] = 0) do={
|
:if ([ :len $AccessList ] = 0) do={
|
||||||
|
|
@ -74,7 +76,7 @@
|
||||||
:local Vendor [ $GetMacVendor ($RegVal->"mac-address") ];
|
:local Vendor [ $GetMacVendor ($RegVal->"mac-address") ];
|
||||||
:local Message ("MAC address " . $RegVal->"mac-address" . " (" . $Vendor . ", " . $HostName . ") " . \
|
:local Message ("MAC address " . $RegVal->"mac-address" . " (" . $Vendor . ", " . $HostName . ") " . \
|
||||||
"first seen on " . $DateTime . " connected to SSID " . $RegVal->"ssid" . ", interface " . $RegVal->"interface");
|
"first seen on " . $DateTime . " connected to SSID " . $RegVal->"ssid" . ", interface " . $RegVal->"interface");
|
||||||
$LogPrintExit2 info $ScriptName $Message false;
|
$LogPrint info $ScriptName $Message;
|
||||||
/interface/wifi/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
/interface/wifi/access-list/add place-before=$PlaceBefore comment=$Message mac-address=($RegVal->"mac-address") disabled=yes;
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "mobile-phone" ] . $RegVal->"mac-address" . " connected to " . $RegVal->"ssid"); \
|
subject=([ $SymbolForNotification "mobile-phone" ] . $RegVal->"mac-address" . " connected to " . $RegVal->"ssid"); \
|
||||||
|
|
@ -90,9 +92,9 @@
|
||||||
[ $FormatLine "Date" $DateTime ]) });
|
[ $FormatLine "Date" $DateTime ]) });
|
||||||
}
|
}
|
||||||
} else={
|
} else={
|
||||||
$LogPrintExit2 debug $ScriptName ("No mac address available... Ignoring.") false;
|
$LogPrint debug $ScriptName ("No mac address available... Ignoring.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
17
contrib/Makefile
Normal file
|
|
@ -0,0 +1,17 @@
|
||||||
|
# Makefile
|
||||||
|
|
||||||
|
HTML := $(shell grep -xl '<!-- static html //-->' *.html)
|
||||||
|
|
||||||
|
.PHONY: all docs clean
|
||||||
|
|
||||||
|
all: docs
|
||||||
|
|
||||||
|
badges.html: badges.md
|
||||||
|
markdown $< > $@
|
||||||
|
|
||||||
|
docs: static-html.sh $(HTML) badges.html
|
||||||
|
./static-html.sh $(HTML)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f badges.html
|
||||||
|
git checkout HEAD -- $(HTML)
|
||||||
6
contrib/badges.md
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/network)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
||||||
|
[](https://mikrotik.com/download/changelogs/)
|
||||||
|
[](https://t.me/routeros_scripts)
|
||||||
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
9
contrib/checksums.sh
Executable file
|
|
@ -0,0 +1,9 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# generate a checksums file as used by $ScriptInstallUpdate
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
md5sum $(find -name '*.rsc' | sort) | \
|
||||||
|
sed -e "s| \./||" -e 's|.rsc$||' | \
|
||||||
|
jq --raw-input --null-input '[ inputs | split (" ") | { (.[1]): (.[0]) }] | add'
|
||||||
6
contrib/commitinfo.sh
Executable file
|
|
@ -0,0 +1,6 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
sed \
|
||||||
|
-e "/^:global CommitId/c :global CommitId \"${COMMITID:-unknown}\";" \
|
||||||
|
-e "/^:global CommitInfo/c :global CommitInfo \"${COMMITINFO:-unknown}\";" \
|
||||||
|
< "${1}"
|
||||||
23
contrib/html.sh
Executable file
|
|
@ -0,0 +1,23 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
RELTO="$(dirname "${1}")"
|
||||||
|
|
||||||
|
sed \
|
||||||
|
-e "s|__TITLE__|$(head -n1 "${1}")|" \
|
||||||
|
-e "s|__GENERAL__|$(realpath --relative-to="${RELTO}" general/)|" \
|
||||||
|
-e "s|__ROOT__|$(realpath --relative-to="${RELTO}" ./)|" \
|
||||||
|
< "${0}.d/head.html"
|
||||||
|
|
||||||
|
markdown -f toc,idanchor "${1}" | sed \
|
||||||
|
-e 's/href="\([-_\./[:alnum:]]*\)\.md\(#[-[:alnum:]]*\)\?"/href="\1.html\2"/g' \
|
||||||
|
-e '/<h[1234] /s| id="\(.*\)">| id="\L\1">|' \
|
||||||
|
-e '/<h[1234] /s|-2[1789cd]-||g' -e '/<h[1234] /s|--26-amp-3b-||g' \
|
||||||
|
-e '/^<pre>/s|pre|pre class="code" onclick="CopyToClipboard(this)"|g' \
|
||||||
|
-e '/The above link may be broken on code hosting sites/s|blockquote|blockquote style="display: none;"|'
|
||||||
|
|
||||||
|
sed \
|
||||||
|
-e "s|__DATE__|${DATE:-$(date --rfc-email)}|" \
|
||||||
|
-e "s|__VERSION__|${VERSION:-unknown}|" \
|
||||||
|
< "${0}.d/foot.html"
|
||||||
5
contrib/html.sh.d/foot.html
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
|
||||||
|
<p class="foot">RouterOS Scripts documentation generated on <i>__DATE__</i> for <i>__VERSION__</i><br />
|
||||||
|
Copyright © 2013-2026 Christian Hesse <mail@eworm.de></p>
|
||||||
|
|
||||||
|
</body></html>
|
||||||
16
contrib/html.sh.d/head.html
Normal file
|
|
@ -0,0 +1,16 @@
|
||||||
|
<!DOCTYPE html><html lang="en">
|
||||||
|
<head><meta http-equiv="content-type" content="text/html; charset=UTF-8">
|
||||||
|
<title>RouterOS Scripts :: __TITLE__</title>
|
||||||
|
<link rel="stylesheet" type="text/css" href="__GENERAL__/style.css">
|
||||||
|
<link rel="icon" type="image/png" href="__ROOT__/logo.png">
|
||||||
|
<script type="text/javascript" src="__GENERAL__/clipboard.js"></script>
|
||||||
|
</head><body>
|
||||||
|
|
||||||
|
<table><tr>
|
||||||
|
<td><img src="__GENERAL__/eworm-meadow.avif" alt="eworm on meadow" /></td>
|
||||||
|
<td><img src="__GENERAL__/qr-code.png" alt="QR code: rsc.eworm.de" /></td>
|
||||||
|
<td class="head"><span class="top">RouterOS Scripts</span><br />
|
||||||
|
<span class="bottom">a collection of scripts for MikroTik RouterOS</span></td>
|
||||||
|
</tr></table>
|
||||||
|
<hr />
|
||||||
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
body {
|
|
||||||
font-family: fira-sans, sans-serif;
|
|
||||||
font-size: 10pt;
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
@ -1,14 +1,30 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html><html lang="en">
|
||||||
<html lang="en">
|
<!-- static html //-->
|
||||||
<head>
|
<head><meta http-equiv="content-type" content="text/html; charset=UTF-8">
|
||||||
<meta charset="UTF-8">
|
<title>RouterOS Scripts :: Logo Color Changer</title>
|
||||||
<title>RouterOS-Scripts Logo Color Changer</title>
|
<link rel="stylesheet" type="text/css" href="../general/style.css">
|
||||||
<link rel="stylesheet" type="text/css" href="logo-color.d/style.css">
|
<link rel="icon" type="image/png" href="../logo.png">
|
||||||
<script src="logo-color.d/script.js"></script>
|
<script src="logo-color.d/script.js"></script>
|
||||||
</head>
|
</head><body>
|
||||||
<body>
|
|
||||||
|
|
||||||
<h1>RouterOS-Scripts Logo Color Changer</h1>
|
<table><tr>
|
||||||
|
<td><img src="../general/eworm-meadow.avif" alt="eworm on meadow" /></td>
|
||||||
|
<td><img src="../general/qr-code.png" alt="QR code: rsc.eworm.de" /></td>
|
||||||
|
<td class="head"><span class="top">RouterOS Scripts</span><br />
|
||||||
|
<span class="bottom">a collection of scripts for MikroTik RouterOS</span></td>
|
||||||
|
</tr></table>
|
||||||
|
<hr />
|
||||||
|
|
||||||
|
<h1>Logo Color Changer</h1>
|
||||||
|
|
||||||
|
<!-- badges here //-->
|
||||||
|
|
||||||
|
<p><a href="../README.md">⬅️ Go back to main README</a></p>
|
||||||
|
|
||||||
|
<blockquote style="/* display */"><p>💡️ <strong>Hint</strong>: This site or links
|
||||||
|
on it may be broken on code hosting sites. Use
|
||||||
|
<a href="https://rsc.eworm.de/main/contrib/logo-color.html">Logo Color Changer</a>
|
||||||
|
instead.</p></blockquote>
|
||||||
|
|
||||||
<p>You want the logo for your own notifications? But you joined the
|
<p>You want the logo for your own notifications? But you joined the
|
||||||
<a href="https://t.me/routeros_scripts">Telegram Group</a> and want
|
<a href="https://t.me/routeros_scripts">Telegram Group</a> and want
|
||||||
|
|
@ -24,17 +40,23 @@ something that differentiates? Color it!</p>
|
||||||
<p>Then right-click, click "<i>Take Screenshot</i>" and finally select the
|
<p>Then right-click, click "<i>Take Screenshot</i>" and finally select the
|
||||||
logo and download it.</p>
|
logo and download it.</p>
|
||||||
|
|
||||||
<p><img src="logo-color.d/browser-01.avif" width=533 height=482 alt="Screenshot Browser 01">
|
<p><img src="logo-color.d/browser-01.avif" alt="Screenshot Browser 01"></p>
|
||||||
<img src="logo-color.d/browser-02.avif" width=533 height=482 alt="Screenshot Browser 02">
|
<p><img src="logo-color.d/browser-02.avif" alt="Screenshot Browser 02"></p>
|
||||||
<img src="logo-color.d/browser-03.avif" width=533 height=482 alt="Screenshot Browser 03"></p>
|
<p><img src="logo-color.d/browser-03.avif" alt="Screenshot Browser 03"></p>
|
||||||
|
|
||||||
<p>(This example is with
|
<p>(This example is with
|
||||||
<a href="https://www.mozilla.org/de/firefox/new/">Firefox</a>. The workflow
|
<a href="https://www.mozilla.org/de/firefox/new/">Firefox</a>. The workflow
|
||||||
for other browsers may differ.)</p>
|
for other browsers may differ.)</p>
|
||||||
|
|
||||||
<p>See how to
|
<p>See how to
|
||||||
<a href="../../about/doc/mod/notification-telegram.md#set-a-profile-photo">Set
|
<a href="../doc/mod/notification-telegram.md#set-a-profile-photo">Set
|
||||||
a profile photo</a> for your Telegram bot.</p>
|
a profile photo</a> for your Telegram bot.</p>
|
||||||
|
|
||||||
</body>
|
<hr />
|
||||||
</html>
|
|
||||||
|
<p><a href="../README.md">⬅️ Go back to main README</a><br/>
|
||||||
|
<a href="#top">⬆️ Go back to top</a></p>
|
||||||
|
|
||||||
|
<p class="foot">Copyright © 2013-2026 Christian Hesse <mail@eworm.de></p>
|
||||||
|
|
||||||
|
</body></html>
|
||||||
|
|
|
||||||
|
|
@ -1,36 +0,0 @@
|
||||||
body {
|
|
||||||
font-family: fira-sans, sans-serif;
|
|
||||||
font-size: 10pt;
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
div.notification {
|
|
||||||
position: relative;
|
|
||||||
float: right;
|
|
||||||
width: 600px;
|
|
||||||
border: 3px outset #6c5d53;
|
|
||||||
/* border-radius: 5px; */
|
|
||||||
padding: 10px;
|
|
||||||
background-color: #e6e6e6;
|
|
||||||
}
|
|
||||||
div.content {
|
|
||||||
padding-left: 60px;
|
|
||||||
}
|
|
||||||
img.logo {
|
|
||||||
float: left;
|
|
||||||
border-radius: 50%;
|
|
||||||
}
|
|
||||||
p.heading {
|
|
||||||
margin: 0px;
|
|
||||||
font-weight: bold;
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
p.hint {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
pre {
|
|
||||||
font-family: fira-mono, monospace;
|
|
||||||
white-space: pre-wrap;
|
|
||||||
}
|
|
||||||
span.link {
|
|
||||||
color: #863600;
|
|
||||||
}
|
|
||||||
|
|
@ -1,35 +1,57 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html><html lang="en">
|
||||||
<html lang="en">
|
<!-- static html //-->
|
||||||
<head>
|
<head><meta http-equiv="content-type" content="text/html; charset=UTF-8">
|
||||||
<meta charset="UTF-8">
|
<title>RouterOS Scripts :: Notification Generator</title>
|
||||||
<title>RouterOS-Scripts Notification Generator</title>
|
<link rel="stylesheet" type="text/css" href="../general/style.css">
|
||||||
<link rel="stylesheet" type="text/css" href="notification.d/style.css">
|
<link rel="icon" type="image/png" href="../logo.png">
|
||||||
<script src="notification.d/script.js"></script>
|
<script src="notification.d/script.js"></script>
|
||||||
</head>
|
</head><body>
|
||||||
<body>
|
|
||||||
|
|
||||||
<h1>RouterOS-Scripts Notification Generator</h1>
|
<table><tr>
|
||||||
|
<td><img src="../general/eworm-meadow.avif" alt="eworm on meadow" /></td>
|
||||||
|
<td><img src="../general/qr-code.png" alt="QR code: rsc.eworm.de" /></td>
|
||||||
|
<td class="head"><span class="top">RouterOS Scripts</span><br />
|
||||||
|
<span class="bottom">a collection of scripts for MikroTik RouterOS</span></td>
|
||||||
|
</tr></table>
|
||||||
|
<hr />
|
||||||
|
|
||||||
|
<h1>Notification Generator</h1>
|
||||||
|
|
||||||
|
<!-- badges here //-->
|
||||||
|
|
||||||
|
<p><a href="../README.md">⬅️ Go back to main README</a></p>
|
||||||
|
|
||||||
|
<blockquote style="/* display */"><p>💡️ <strong>Hint</strong>: This site or links
|
||||||
|
on it may be broken on code hosting sites. Use
|
||||||
|
<a href="https://rsc.eworm.de/main/contrib/notification.html">Notification Generator</a>
|
||||||
|
instead.</p></blockquote>
|
||||||
|
|
||||||
<div class="notification">
|
<div class="notification">
|
||||||
<img src="../logo.svg" alt="logo" class="logo" width=48 height=48>
|
<img src="../logo.svg" alt="logo" class="logo" width=48 height=48>
|
||||||
<div class="content">
|
<div class="content">
|
||||||
<p id="heading" class="heading">[<span id="hostname">MikroTik</span>] <span id="subject">ℹ️ Subject</span></p>
|
<p id="heading" class="heading">[<span id="hostname">MikroTik</span>] <span id="subject">ℹ️ Subject</span></p>
|
||||||
<pre id="message">Message</pre>
|
<pre id="message">Message</pre>
|
||||||
<p id="link" class="hint">🔗 <span id="link-text" class="link">https://eworm.de/</span></p>
|
<p id="link" class="hint">🔗 <span id="link-text" class="link">https://rsc.eworm.de/</span></p>
|
||||||
<p id="queued" class="hint">⏰ This message was queued since <span id="queued-since">oct/18/2022 18:30:48</span> and may be obsolete.</p>
|
<p id="queued" class="hint">⏰ This message was queued since <i><span id="queued-since">2025-10-29 16:06:18</span></i> and may be obsolete.</p>
|
||||||
<p id="cut" class="hint">✂️ The message was too long and has been truncated, cut off <span id="cut-percent">13</span>%!</p>
|
<p id="cut" class="hint">✂️ The message was too long and has been truncated, cut off <i><span id="cut-percent">13</span>%</i>!</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<p>Hostname: <input type="text" value="MikroTik" onchange="update(this, 'hostname')"></p>
|
<p>Hostname: <input type="text" value="MikroTik" onchange="update(this, 'hostname')"></p>
|
||||||
<p>Subject: <input type="text" size=50 value="ℹ️ Subject" onchange="update(this, 'subject')"></p>
|
<p>Subject: <input type="text" size=50 value="ℹ️ Subject" onchange="update(this, 'subject')"></p>
|
||||||
<p>Message: <textarea id="w3review" name="w3review" rows="4" cols="50" onchange="update(this, 'message')">Message</textarea></p>
|
<p>Message: <textarea id="w3review" name="w3review" rows="4" cols="50" onchange="update(this, 'message')">Message</textarea></p>
|
||||||
<p><input type="checkbox" onclick="visible(this, 'link')"> Show link: <input type="text" value="https://eworm.de/" onchange="update(this, 'link-text')"></p>
|
<p><input type="checkbox" onclick="visible(this, 'link')"> Show link: <input type="text" value="https://rsc.eworm.de/" onchange="update(this, 'link-text')"></p>
|
||||||
<p><input type="checkbox" onclick="visible(this, 'queued')"> Queued since <input type="text" value="oct/18/2022 18:30:48" onchange="update(this, 'queued-since')"></p>
|
<p><input type="checkbox" onclick="visible(this, 'queued')"> Queued since <input type="text" value="2025-10-29 16:06:18" onchange="update(this, 'queued-since')"></p>
|
||||||
<p><input type="checkbox" onclick="visible(this, 'cut')"> Cut-off with <input type="number" min=1 max=99 value=13 onchange="update(this, 'cut-percent')"> percent</p>
|
<p><input type="checkbox" onclick="visible(this, 'cut')"> Cut-off with <input type="number" min=1 max=99 value=13 onchange="update(this, 'cut-percent')"> percent</p>
|
||||||
|
|
||||||
<p>Then right-click, click "<i>Take Screenshot</i>" and finally select the
|
<p>Then right-click, click "<i>Take Screenshot</i>" and finally select the
|
||||||
notification and download it.</p>
|
notification and download it.</p>
|
||||||
|
|
||||||
</body>
|
<hr />
|
||||||
</html>
|
|
||||||
|
<p><a href="../README.md">⬅️ Go back to main README</a><br/>
|
||||||
|
<a href="#top">⬆️ Go back to top</a></p>
|
||||||
|
|
||||||
|
<p class="foot">Copyright © 2013-2026 Christian Hesse <mail@eworm.de></p>
|
||||||
|
|
||||||
|
</body></html>
|
||||||
|
|
|
||||||
10
contrib/static-html.sh
Executable file
|
|
@ -0,0 +1,10 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
sed -i \
|
||||||
|
-e '/href=/s|\.md|\.html|' \
|
||||||
|
-e '/blockquote/s|/\* display \*/|display: none;|' \
|
||||||
|
-e '/<!-- badges here \/\/-->/r badges.html' \
|
||||||
|
-e '/<!-- badges here \/\/-->/d' \
|
||||||
|
"${@}"
|
||||||
274
contrib/telegram.md
Normal file
|
|
@ -0,0 +1,274 @@
|
||||||
|
Telegram
|
||||||
|
========
|
||||||
|
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/stargazers)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/network)
|
||||||
|
[](https://github.com/eworm-de/routeros-scripts/watchers)
|
||||||
|
[](https://mikrotik.com/download/changelogs/)
|
||||||
|
[](https://t.me/routeros_scripts)
|
||||||
|
[](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=A4ZXBD6YS2W8J)
|
||||||
|
|
||||||
|
[⬅️ Go back to main README](../README.md)
|
||||||
|
|
||||||
|
We have [Miss Rose Bot ↗️](https://t.me/MissRose_bot) in our
|
||||||
|
[RouterOS-Scripts ↗️](https://t.me/routeros_scripts) Telegram group,
|
||||||
|
always kind and ready to help moderate.
|
||||||
|
|
||||||
|
Notes
|
||||||
|
-----
|
||||||
|
|
||||||
|
### README
|
||||||
|
|
||||||
|
/save readme Please read the [main README](https://rsc.eworm.de/) to understand how things work and to get the base installation right.
|
||||||
|
|
||||||
|
### Available scripts
|
||||||
|
|
||||||
|
#### accesslist-duplicates
|
||||||
|
|
||||||
|
/save accesslist-duplicates Find and remove access list duplicates with [accesslist-duplicates](https://rsc.eworm.de/doc/accesslist-duplicates.md).
|
||||||
|
|
||||||
|
#### backup-cloud
|
||||||
|
|
||||||
|
/save backup-cloud Upload backup to Mikrotik cloud with [backup-cloud](https://rsc.eworm.de/doc/backup-cloud.md).
|
||||||
|
|
||||||
|
#### backup-email
|
||||||
|
|
||||||
|
/save backup-email Send backup via e-mail with [backup-email](https://rsc.eworm.de/doc/backup-email.md).
|
||||||
|
|
||||||
|
#### backup-partition
|
||||||
|
|
||||||
|
/save backup-partition Save configuration to fallback partition with [backup-partition](https://rsc.eworm.de/doc/backup-partition.md).
|
||||||
|
|
||||||
|
#### backup-upload
|
||||||
|
|
||||||
|
/save backup-upload Upload backup to server with [backup-upload](https://rsc.eworm.de/doc/backup-upload.md).
|
||||||
|
|
||||||
|
#### capsman-download-packages
|
||||||
|
|
||||||
|
/save capsman-download-packages Download packages for CAP upgrade from CAPsMAN with [capsman-download-packages](https://rsc.eworm.de/doc/capsman-download-packages.md).
|
||||||
|
|
||||||
|
#### capsman-rolling-upgrade
|
||||||
|
|
||||||
|
/save capsman-rolling-upgrade Run rolling CAP upgrades from CAPsMAN with [capsman-rolling-upgrade](https://rsc.eworm.de/doc/capsman-rolling-upgrade.md).
|
||||||
|
|
||||||
|
#### certificate-renew-issued
|
||||||
|
|
||||||
|
/save certificate-renew-issued Renew locally issued certificates with [certificate-renew-issued](https://rsc.eworm.de/doc/certificate-renew-issued.md).
|
||||||
|
|
||||||
|
#### check-certificates
|
||||||
|
|
||||||
|
/save check-certificates Renew certificates and notify on expiration with [check-certificates](https://rsc.eworm.de/doc/check-certificates.md).
|
||||||
|
|
||||||
|
#### check-health
|
||||||
|
|
||||||
|
/save check-health Notify about health state with [check-health](https://rsc.eworm.de/doc/check-health.md).
|
||||||
|
|
||||||
|
#### check-lte-firmware-upgrade
|
||||||
|
|
||||||
|
/save check-lte-firmware-upgrade Notify on LTE firmware upgrade with [check-lte-firmware-upgrade](https://rsc.eworm.de/doc/check-lte-firmware-upgrade.md).
|
||||||
|
|
||||||
|
#### check-perpetual-license
|
||||||
|
|
||||||
|
/save check-perpetual-license Check perpetual license on CHR with [check-perpetual-license](https://rsc.eworm.de/doc/check-perpetual-license.md).
|
||||||
|
|
||||||
|
#### check-routeros-update
|
||||||
|
|
||||||
|
/save check-routeros-update Notify on RouterOS update with [check-routeros-update](https://rsc.eworm.de/doc/check-routeros-update.md).
|
||||||
|
|
||||||
|
#### collect-wireless-mac
|
||||||
|
|
||||||
|
/save collect-wireless-mac Collect MAC addresses in wireless access list with [collect-wireless-mac](https://rsc.eworm.de/doc/collect-wireless-mac.md).
|
||||||
|
|
||||||
|
#### daily-psk
|
||||||
|
|
||||||
|
/save daily-psk Use wireless network with [daily-psk](https://rsc.eworm.de/doc/daily-psk.md).
|
||||||
|
|
||||||
|
#### dhcp-lease-comment
|
||||||
|
|
||||||
|
/save dhcp-lease-comment Comment DHCP leases with [dhcp-lease-comment](https://rsc.eworm.de/doc/dhcp-lease-comment.md).
|
||||||
|
|
||||||
|
#### dhcp-to-dns
|
||||||
|
|
||||||
|
/save dhcp-to-dns Create DNS records for DHCP leases with [dhcp-to-dns](https://rsc.eworm.de/doc/dhcp-to-dns.md).
|
||||||
|
|
||||||
|
#### firmware-upgrade-reboot
|
||||||
|
|
||||||
|
/save firmware-upgrade-reboot Automatically upgrade firmware and reboot with [firmware-upgrade-reboot](https://rsc.eworm.de/doc/firmware-upgrade-reboot.md).
|
||||||
|
|
||||||
|
#### fw-addr-lists
|
||||||
|
|
||||||
|
/save fw-addr-lists Download, import and update firewall address-lists with [fw-addr-lists](https://rsc.eworm.de/doc/fw-addr-lists.md).
|
||||||
|
|
||||||
|
#### global-wait
|
||||||
|
|
||||||
|
/save global-wait Wait for global functions und modules with [global-wait](https://rsc.eworm.de/doc/global-wait.md).
|
||||||
|
|
||||||
|
#### gps-track
|
||||||
|
|
||||||
|
/save gps-track Send GPS position to server with [gps-track](https://rsc.eworm.de/doc/gps-track.md).
|
||||||
|
|
||||||
|
#### hotspot-to-wpa
|
||||||
|
|
||||||
|
/save hotspot-to-wpa Use WPA network with [hotspot-to-wpa](https://rsc.eworm.de/doc/hotspot-to-wpa.md).
|
||||||
|
|
||||||
|
#### ipsec-to-dns
|
||||||
|
|
||||||
|
/save ipsec-to-dns Create DNS records for IPSec peers with [ipsec-to-dns](https://rsc.eworm.de/doc/ipsec-to-dns.md).
|
||||||
|
|
||||||
|
#### ipv6-update
|
||||||
|
|
||||||
|
/save ipv6-update Update configuration on IPv6 prefix change with [ipv6-update](https://rsc.eworm.de/doc/ipv6-update.md).
|
||||||
|
|
||||||
|
#### ip-addr-bridge
|
||||||
|
|
||||||
|
/save ip-addr-bridge Manage IP addresses with [ip-addr-bridge](https://rsc.eworm.de/doc/ip-addr-bridge.md).
|
||||||
|
|
||||||
|
#### lease-script
|
||||||
|
|
||||||
|
/save lease-script Run other scripts on DHCP lease with [lease-script](https://rsc.eworm.de/doc/lease-script.md).
|
||||||
|
|
||||||
|
#### leds-mode
|
||||||
|
|
||||||
|
/save leds-mode Manage LEDs dark mode with [leds-mode](https://rsc.eworm.de/doc/leds-mode.md).
|
||||||
|
|
||||||
|
#### log-forward
|
||||||
|
|
||||||
|
/save log-forward Forward log messages via notification with [log-forward](https://rsc.eworm.de/doc/log-forward.md).
|
||||||
|
|
||||||
|
#### mode-button
|
||||||
|
|
||||||
|
/save mode-button Mode button with [mode-button](https://rsc.eworm.de/doc/mode-button.md).
|
||||||
|
|
||||||
|
#### netwatch-dns
|
||||||
|
|
||||||
|
/save netwatch-dns Manage DNS and DoH servers from netwatch with [netwatch-dns](https://rsc.eworm.de/doc/netwatch-dns.md).
|
||||||
|
|
||||||
|
#### netwatch-notify
|
||||||
|
|
||||||
|
/save netwatch-notify Notify on host up and down with [netwatch-notify](https://rsc.eworm.de/doc/netwatch-notify.md).
|
||||||
|
|
||||||
|
#### ospf-to-leds
|
||||||
|
|
||||||
|
/save ospf-to-leds Visualize OSPF state via LEDs with [ospf-to-leds](https://rsc.eworm.de/doc/ospf-to-leds.md).
|
||||||
|
|
||||||
|
#### packages-update
|
||||||
|
|
||||||
|
/save packages-update Manage system update with [packages-update](https://rsc.eworm.de/doc/packages-update.md).
|
||||||
|
|
||||||
|
#### ppp-on-up
|
||||||
|
|
||||||
|
/save ppp-on-up Run scripts on ppp connection with [ppp-on-up](https://rsc.eworm.de/doc/ppp-on-up.md).
|
||||||
|
|
||||||
|
#### sms-action
|
||||||
|
|
||||||
|
/save sms-action Act on received SMS with [sms-action](https://rsc.eworm.de/doc/sms-action.md).
|
||||||
|
|
||||||
|
#### sms-forward
|
||||||
|
|
||||||
|
/save sms-forward Forward received SMS with [sms-forward](https://rsc.eworm.de/doc/sms-forward.md).
|
||||||
|
|
||||||
|
#### super-mario-theme
|
||||||
|
|
||||||
|
/save super-mario-theme Play Super Mario theme with [super-mario-theme](https://rsc.eworm.de/doc/super-mario-theme.md).
|
||||||
|
|
||||||
|
#### telegram-chat
|
||||||
|
|
||||||
|
/save telegram-chat Chat with [telegram-chat](https://rsc.eworm.de/doc/telegram-chat.md).
|
||||||
|
|
||||||
|
#### unattended-lte-firmware-upgrade
|
||||||
|
|
||||||
|
/save unattended-lte-firmware-upgrade Install LTE firmware upgrade with [unattended-lte-firmware-upgrade](https://rsc.eworm.de/doc/unattended-lte-firmware-upgrade.md).
|
||||||
|
|
||||||
|
#### update-gre-address
|
||||||
|
|
||||||
|
/save update-gre-address Update GRE configuration with [update-gre-address](https://rsc.eworm.de/doc/update-gre-address.md).
|
||||||
|
|
||||||
|
#### update-tunnelbroker
|
||||||
|
|
||||||
|
/save update-tunnelbroker Update tunnelbroker configuration with [update-tunnelbroker](https://rsc.eworm.de/doc/update-tunnelbroker.md).
|
||||||
|
|
||||||
|
### Available modules
|
||||||
|
|
||||||
|
#### mod/bridge-port-to
|
||||||
|
|
||||||
|
/save mod/bridge-port-to Manage ports in bridge with [mod/bridge-port-to](https://rsc.eworm.de/doc/mod/bridge-port-to.md).
|
||||||
|
|
||||||
|
#### mod/bridge-port-vlan
|
||||||
|
|
||||||
|
/save mod/bridge-port-vlan Manage VLANs on bridge ports with [mod/bridge-port-vlan](https://rsc.eworm.de/doc/mod/bridge-port-vlan.md).
|
||||||
|
|
||||||
|
#### mod/inspectvar
|
||||||
|
|
||||||
|
/save mod/inspectvar Inspect variables with [mod/inspectvar](https://rsc.eworm.de/doc/mod/inspectvar.md).
|
||||||
|
|
||||||
|
#### mod/ipcalc
|
||||||
|
|
||||||
|
/save mod/ipcalc IP address calculation with [mod/ipcalc](https://rsc.eworm.de/doc/mod/ipcalc.md).
|
||||||
|
|
||||||
|
#### mod/notification-email
|
||||||
|
|
||||||
|
/save mod/notification-email Send notifications via e-mail with [mod/notification-email](https://rsc.eworm.de/doc/mod/notification-email.md).
|
||||||
|
|
||||||
|
#### mod/notification-gotify
|
||||||
|
|
||||||
|
/save mod/notification-gotify Send notifications via Gotify with [mod/notification-gotify](https://rsc.eworm.de/doc/mod/notification-gotify.md).
|
||||||
|
|
||||||
|
#### mod/notification-matrix
|
||||||
|
|
||||||
|
/save mod/notification-matrix Send notifications via Matrix with [mod/notification-matrix](https://rsc.eworm.de/doc/mod/notification-matrix.md).
|
||||||
|
|
||||||
|
#### mod/notification-ntfy
|
||||||
|
|
||||||
|
/save mod/notification-ntfy Send notifications via Ntfy with [mod/notification-ntfy](https://rsc.eworm.de/doc/mod/notification-ntfy.md).
|
||||||
|
|
||||||
|
#### mod/notification-telegram
|
||||||
|
|
||||||
|
/save mod/notification-telegram Send notifications via Telegram with [mod/notification-telegram](https://rsc.eworm.de/doc/mod/notification-telegram.md).
|
||||||
|
|
||||||
|
#### mod/scriptrunonce
|
||||||
|
|
||||||
|
/save mod/scriptrunonce Download script and run it once with [mod/scriptrunonce](https://rsc.eworm.de/doc/mod/scriptrunonce.md).
|
||||||
|
|
||||||
|
#### mod/ssh-keys-import
|
||||||
|
|
||||||
|
/save mod/ssh-keys-import Import ssh keys for public key authentication with [mod/ssh-keys-import](https://rsc.eworm.de/doc/mod/ssh-keys-import.md).
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
#### Installing from branches
|
||||||
|
|
||||||
|
/save branches Living on the edge or testing new features? Learn how to [switch specific scripts or the complete installation to different branches](https://rsc.eworm.de/BRANCHES.md).
|
||||||
|
|
||||||
|
#### Certificate name from browser
|
||||||
|
|
||||||
|
/save certificate-name-from-browser Running or accessing a custom service and looking for the CA certificate? Get the [certificate name from browser](https://rsc.eworm.de/CERTIFICATES.md).
|
||||||
|
|
||||||
|
#### Debug output and logs
|
||||||
|
|
||||||
|
/save debug Enable [debug output and logs](https://rsc.eworm.de/DEBUG.md) for more information on what happens.
|
||||||
|
|
||||||
|
#### Donate
|
||||||
|
|
||||||
|
/save donate This project is developed in private spare time and usage is free of charge for you. If you like the scripts and think this is of value for you or your business [please consider a donation](https://rsc.eworm.de/#donate). Thanks!
|
||||||
|
|
||||||
|
#### Fix existing installation
|
||||||
|
|
||||||
|
/save fix-installation [Fix existing installation] Your installation broke and you do not know back and forth? See how to [fix an existing installation](https://rsc.eworm.de/INITIAL-COMMANDS.md#fix-existing-installation).
|
||||||
|
|
||||||
|
#### Next!
|
||||||
|
|
||||||
|
/save next Another satisfied user. 😊 Next, please!
|
||||||
|
|
||||||
|
#### Off-topic
|
||||||
|
|
||||||
|
/save off-topic Please note this group is not about MikroTik RouterOS in general, but [RouterOS Scripts](https://rsc.eworm.de/). Your request is not about scripting at all, so please discuss somewhere else. See the [MikroTik RouterOS users (english)](https://t.me/RouterOS_users_english) group or official Mikrotik forums (https://forum.mikrotik.com/).
|
||||||
|
|
||||||
|
Greeting
|
||||||
|
--------
|
||||||
|
|
||||||
|
/setwelcome Hello {mention} and welcome to {chatname}!
|
||||||
|
Please note this group is not about RouterOS in general, but [RouterOS Scripts](https://rsc.eworm.de/). Also pay attention to [rules](https://t.me/routeros_scripts/4), thanks!
|
||||||
|
|
||||||
|
---
|
||||||
|
[⬅️ Go back to main README](../README.md)
|
||||||
|
[⬆️ Go back to top](#top)
|
||||||
11
contrib/template-capsman.sh
Executable file
|
|
@ -0,0 +1,11 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
sed \
|
||||||
|
-e '/\/interface\/wifi\//d' \
|
||||||
|
-e '/\/interface\/wireless\//d' \
|
||||||
|
-e 's|%TEMPL%|.capsman|' \
|
||||||
|
-e '/^# NOT \/caps-man\/ #$/,/^# NOT \/caps-man\/ #$/d' \
|
||||||
|
-e '/^# !!/,/^# !!/c # !! Do not edit this file, it is generated from template!' \
|
||||||
|
< "${1}"
|
||||||
11
contrib/template-local.sh
Executable file
|
|
@ -0,0 +1,11 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
sed \
|
||||||
|
-e '/\/caps-man\//d' \
|
||||||
|
-e '/\/interface\/wifi\//d' \
|
||||||
|
-e 's|%TEMPL%|.local|' \
|
||||||
|
-e '/^# NOT \/interface\/wireless\/ #$/,/^# NOT \/interface\/wireless\/ #$/d' \
|
||||||
|
-e '/^# !!/,/^# !!/c # !! Do not edit this file, it is generated from template!' \
|
||||||
|
< "${1}"
|
||||||
11
contrib/template-wifi.sh
Executable file
|
|
@ -0,0 +1,11 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
sed \
|
||||||
|
-e '/\/caps-man\//d' \
|
||||||
|
-e '/\/interface\/wireless\//d' \
|
||||||
|
-e 's|%TEMPL%|.wifi|' \
|
||||||
|
-e '/^# NOT \/interface\/wifi\/ #$/,/^# NOT \/interface\/wifi\/ #$/d' \
|
||||||
|
-e '/^# !!/,/^# !!/c # !! Do not edit this file, it is generated from template!' \
|
||||||
|
< "${1}"
|
||||||
|
|
@ -1,28 +1,29 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: daily-psk.capsman
|
# RouterOS script: daily-psk.capsman
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# update daily PSK (pre shared key)
|
# update daily PSK (pre shared key)
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/daily-psk.md
|
# https://rsc.eworm.de/doc/daily-psk.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global DailyPskMatchComment;
|
:global DailyPskMatchComment;
|
||||||
:global DailyPskQrCodeUrl;
|
:global DailyPskQrCodeUrl;
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
@ -31,7 +32,8 @@
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
|
|
@ -68,27 +70,27 @@
|
||||||
:local Skip 0;
|
:local Skip 0;
|
||||||
|
|
||||||
:if ($NewPsk != $OldPsk) do={
|
:if ($NewPsk != $OldPsk) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Updating daily PSK for " . $Ssid . " to " . $NewPsk . " (was " . $OldPsk . ")") false;
|
$LogPrint info $ScriptName ("Updating daily PSK for '" . $Ssid . "' to '" . $NewPsk . "' (was '" . $OldPsk . "')");
|
||||||
/caps-man/access-list/set $AccList private-passphrase=$NewPsk;
|
/caps-man/access-list/set $AccList private-passphrase=$NewPsk;
|
||||||
|
|
||||||
:if ([ :len [ /caps-man/actual-interface-configuration/find where configuration.ssid=$Ssid !disabled ] ] > 0) do={
|
:if ([ :len [ /caps-man/actual-interface-configuration/find where configuration.ssid=$Ssid !disabled ] ] > 0) do={
|
||||||
:if ($Seen->$Ssid = 1) do={
|
:if ($Seen->$Ssid = 1) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("Already sent a mail for SSID " . $Ssid . ", skipping.") false;
|
$LogPrint debug $ScriptName ("Already sent a mail for SSID " . $Ssid . ", skipping.");
|
||||||
} else={
|
} else={
|
||||||
:local Link ($DailyPskQrCodeUrl . \
|
:local Link ($DailyPskQrCodeUrl . \
|
||||||
"?scale=8&level=1&ssid=" . [ $UrlEncode $Ssid ] . "&pass=" . [ $UrlEncode $NewPsk ]);
|
"?scale=8&level=1&ssid=" . [ $UrlEncode $Ssid ] . "&pass=" . [ $UrlEncode $NewPsk ]);
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "calendar" ] . "daily PSK " . $Ssid); \
|
subject=([ $SymbolForNotification "calendar" ] . "daily PSK " . $Ssid); \
|
||||||
message=("This is the daily PSK on " . $Identity . ":\n\n" . \
|
message=("This is the daily PSK on " . $Identity . ":\n\n" . \
|
||||||
[ $FormatLine "SSID" $Ssid ] . "\n" . \
|
[ $FormatLine "SSID" $Ssid 8 ] . "\n" . \
|
||||||
[ $FormatLine "PSK" $NewPsk ] . "\n" . \
|
[ $FormatLine "PSK" $NewPsk 8 ] . "\n" . \
|
||||||
[ $FormatLine "Date" $Date ] . "\n\n" . \
|
[ $FormatLine "Date" $Date 8 ] . "\n\n" . \
|
||||||
"A client device specific rule must not exist!"); link=$Link });
|
"A client device specific rule must not exist!"); link=$Link });
|
||||||
:set ($Seen->$Ssid) 1;
|
:set ($Seen->$Ssid) 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,28 +1,29 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: daily-psk.local
|
# RouterOS script: daily-psk.local
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# update daily PSK (pre shared key)
|
# update daily PSK (pre shared key)
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/daily-psk.md
|
# https://rsc.eworm.de/doc/daily-psk.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global DailyPskMatchComment;
|
:global DailyPskMatchComment;
|
||||||
:global DailyPskQrCodeUrl;
|
:global DailyPskQrCodeUrl;
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
@ -31,7 +32,8 @@
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
|
|
@ -67,27 +69,27 @@
|
||||||
:local Skip 0;
|
:local Skip 0;
|
||||||
|
|
||||||
:if ($NewPsk != $OldPsk) do={
|
:if ($NewPsk != $OldPsk) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Updating daily PSK for " . $Ssid . " to " . $NewPsk . " (was " . $OldPsk . ")") false;
|
$LogPrint info $ScriptName ("Updating daily PSK for '" . $Ssid . "' to '" . $NewPsk . "' (was '" . $OldPsk . "')");
|
||||||
/interface/wireless/access-list/set $AccList private-pre-shared-key=$NewPsk;
|
/interface/wireless/access-list/set $AccList private-pre-shared-key=$NewPsk;
|
||||||
|
|
||||||
:if ([ :len [ /interface/wireless/find where name=$IntName !disabled ] ] = 1) do={
|
:if ([ :len [ /interface/wireless/find where name=$IntName !disabled ] ] = 1) do={
|
||||||
:if ($Seen->$Ssid = 1) do={
|
:if ($Seen->$Ssid = 1) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("Already sent a mail for SSID " . $Ssid . ", skipping.") false;
|
$LogPrint debug $ScriptName ("Already sent a mail for SSID " . $Ssid . ", skipping.");
|
||||||
} else={
|
} else={
|
||||||
:local Link ($DailyPskQrCodeUrl . \
|
:local Link ($DailyPskQrCodeUrl . \
|
||||||
"?scale=8&level=1&ssid=" . [ $UrlEncode $Ssid ] . "&pass=" . [ $UrlEncode $NewPsk ]);
|
"?scale=8&level=1&ssid=" . [ $UrlEncode $Ssid ] . "&pass=" . [ $UrlEncode $NewPsk ]);
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "calendar" ] . "daily PSK " . $Ssid); \
|
subject=([ $SymbolForNotification "calendar" ] . "daily PSK " . $Ssid); \
|
||||||
message=("This is the daily PSK on " . $Identity . ":\n\n" . \
|
message=("This is the daily PSK on " . $Identity . ":\n\n" . \
|
||||||
[ $FormatLine "SSID" $Ssid ] . "\n" . \
|
[ $FormatLine "SSID" $Ssid 8 ] . "\n" . \
|
||||||
[ $FormatLine "PSK" $NewPsk ] . "\n" . \
|
[ $FormatLine "PSK" $NewPsk 8 ] . "\n" . \
|
||||||
[ $FormatLine "Date" $Date ] . "\n\n" . \
|
[ $FormatLine "Date" $Date 8 ] . "\n\n" . \
|
||||||
"A client device specific rule must not exist!"); link=$Link });
|
"A client device specific rule must not exist!"); link=$Link });
|
||||||
:set ($Seen->$Ssid) 1;
|
:set ($Seen->$Ssid) 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,29 +1,30 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: daily-psk%TEMPL%
|
# RouterOS script: daily-psk%TEMPL%
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# update daily PSK (pre shared key)
|
# update daily PSK (pre shared key)
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/daily-psk.md
|
# https://rsc.eworm.de/doc/daily-psk.md
|
||||||
#
|
#
|
||||||
# !! This is just a template to generate the real script!
|
# !! This is just a template to generate the real script!
|
||||||
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global DailyPskMatchComment;
|
:global DailyPskMatchComment;
|
||||||
:global DailyPskQrCodeUrl;
|
:global DailyPskQrCodeUrl;
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
@ -32,7 +33,8 @@
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
|
|
@ -79,31 +81,31 @@
|
||||||
:local Skip 0;
|
:local Skip 0;
|
||||||
|
|
||||||
:if ($NewPsk != $OldPsk) do={
|
:if ($NewPsk != $OldPsk) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Updating daily PSK for " . $Ssid . " to " . $NewPsk . " (was " . $OldPsk . ")") false;
|
$LogPrint info $ScriptName ("Updating daily PSK for '" . $Ssid . "' to '" . $NewPsk . "' (was '" . $OldPsk . "')");
|
||||||
/caps-man/access-list/set $AccList private-passphrase=$NewPsk;
|
/caps-man/access-list/set $AccList private-passphrase=$NewPsk;
|
||||||
/interface/wifi/access-list/set $AccList passphrase=$NewPsk;
|
/interface/wifi/access-list/set $AccList passphrase=$NewPsk;
|
||||||
/interface/wireless/access-list/set $AccList private-pre-shared-key=$NewPsk;
|
/interface/wireless/access-list/set $AccList private-pre-shared-key=$NewPsk;
|
||||||
|
|
||||||
:if ([ :len [ /caps-man/actual-interface-configuration/find where configuration.ssid=$Ssid !disabled ] ] > 0) do={
|
:if ([ :len [ /caps-man/actual-interface-configuration/find where configuration.ssid=$Ssid !disabled ] ] > 0) do={
|
||||||
:if ([ :len [ /interface/wifi/actual-configuration/find where configuration.ssid=$Ssid ] ] > 0) do={
|
:if ([ :len [ /interface/wifi/find where configuration.ssid=$Ssid !disabled ] ] > 0) do={
|
||||||
:if ([ :len [ /interface/wireless/find where name=$IntName !disabled ] ] = 1) do={
|
:if ([ :len [ /interface/wireless/find where name=$IntName !disabled ] ] = 1) do={
|
||||||
:if ($Seen->$Ssid = 1) do={
|
:if ($Seen->$Ssid = 1) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("Already sent a mail for SSID " . $Ssid . ", skipping.") false;
|
$LogPrint debug $ScriptName ("Already sent a mail for SSID " . $Ssid . ", skipping.");
|
||||||
} else={
|
} else={
|
||||||
:local Link ($DailyPskQrCodeUrl . \
|
:local Link ($DailyPskQrCodeUrl . \
|
||||||
"?scale=8&level=1&ssid=" . [ $UrlEncode $Ssid ] . "&pass=" . [ $UrlEncode $NewPsk ]);
|
"?scale=8&level=1&ssid=" . [ $UrlEncode $Ssid ] . "&pass=" . [ $UrlEncode $NewPsk ]);
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "calendar" ] . "daily PSK " . $Ssid); \
|
subject=([ $SymbolForNotification "calendar" ] . "daily PSK " . $Ssid); \
|
||||||
message=("This is the daily PSK on " . $Identity . ":\n\n" . \
|
message=("This is the daily PSK on " . $Identity . ":\n\n" . \
|
||||||
[ $FormatLine "SSID" $Ssid ] . "\n" . \
|
[ $FormatLine "SSID" $Ssid 8 ] . "\n" . \
|
||||||
[ $FormatLine "PSK" $NewPsk ] . "\n" . \
|
[ $FormatLine "PSK" $NewPsk 8 ] . "\n" . \
|
||||||
[ $FormatLine "Date" $Date ] . "\n\n" . \
|
[ $FormatLine "Date" $Date 8 ] . "\n\n" . \
|
||||||
"A client device specific rule must not exist!"); link=$Link });
|
"A client device specific rule must not exist!"); link=$Link });
|
||||||
:set ($Seen->$Ssid) 1;
|
:set ($Seen->$Ssid) 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,28 +1,29 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: daily-psk.wifi
|
# RouterOS script: daily-psk.wifi
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# Michael Gisbers <michael@gisbers.de>
|
# Michael Gisbers <michael@gisbers.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# update daily PSK (pre shared key)
|
# update daily PSK (pre shared key)
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/daily-psk.md
|
# https://rsc.eworm.de/doc/daily-psk.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
:local Main do={
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
:local ScriptName [ :tostr $1 ];
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:global DailyPskMatchComment;
|
:global DailyPskMatchComment;
|
||||||
:global DailyPskQrCodeUrl;
|
:global DailyPskQrCodeUrl;
|
||||||
:global Identity;
|
:global Identity;
|
||||||
|
|
||||||
:global FormatLine;
|
:global FormatLine;
|
||||||
:global LogPrintExit2;
|
:global LogPrint;
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
:global SendNotification2;
|
:global SendNotification2;
|
||||||
:global SymbolForNotification;
|
:global SymbolForNotification;
|
||||||
|
|
@ -31,7 +32,8 @@
|
||||||
:global WaitFullyConnected;
|
:global WaitFullyConnected;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
$WaitFullyConnected;
|
$WaitFullyConnected;
|
||||||
|
|
||||||
|
|
@ -68,27 +70,27 @@
|
||||||
:local Skip 0;
|
:local Skip 0;
|
||||||
|
|
||||||
:if ($NewPsk != $OldPsk) do={
|
:if ($NewPsk != $OldPsk) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Updating daily PSK for " . $Ssid . " to " . $NewPsk . " (was " . $OldPsk . ")") false;
|
$LogPrint info $ScriptName ("Updating daily PSK for '" . $Ssid . "' to '" . $NewPsk . "' (was '" . $OldPsk . "')");
|
||||||
/interface/wifi/access-list/set $AccList passphrase=$NewPsk;
|
/interface/wifi/access-list/set $AccList passphrase=$NewPsk;
|
||||||
|
|
||||||
:if ([ :len [ /interface/wifi/actual-configuration/find where configuration.ssid=$Ssid ] ] > 0) do={
|
:if ([ :len [ /interface/wifi/find where configuration.ssid=$Ssid !disabled ] ] > 0) do={
|
||||||
:if ($Seen->$Ssid = 1) do={
|
:if ($Seen->$Ssid = 1) do={
|
||||||
$LogPrintExit2 debug $ScriptName ("Already sent a mail for SSID " . $Ssid . ", skipping.") false;
|
$LogPrint debug $ScriptName ("Already sent a mail for SSID " . $Ssid . ", skipping.");
|
||||||
} else={
|
} else={
|
||||||
:local Link ($DailyPskQrCodeUrl . \
|
:local Link ($DailyPskQrCodeUrl . \
|
||||||
"?scale=8&level=1&ssid=" . [ $UrlEncode $Ssid ] . "&pass=" . [ $UrlEncode $NewPsk ]);
|
"?scale=8&level=1&ssid=" . [ $UrlEncode $Ssid ] . "&pass=" . [ $UrlEncode $NewPsk ]);
|
||||||
$SendNotification2 ({ origin=$ScriptName; \
|
$SendNotification2 ({ origin=$ScriptName; \
|
||||||
subject=([ $SymbolForNotification "calendar" ] . "daily PSK " . $Ssid); \
|
subject=([ $SymbolForNotification "calendar" ] . "daily PSK " . $Ssid); \
|
||||||
message=("This is the daily PSK on " . $Identity . ":\n\n" . \
|
message=("This is the daily PSK on " . $Identity . ":\n\n" . \
|
||||||
[ $FormatLine "SSID" $Ssid ] . "\n" . \
|
[ $FormatLine "SSID" $Ssid 8 ] . "\n" . \
|
||||||
[ $FormatLine "PSK" $NewPsk ] . "\n" . \
|
[ $FormatLine "PSK" $NewPsk 8 ] . "\n" . \
|
||||||
[ $FormatLine "Date" $Date ] . "\n\n" . \
|
[ $FormatLine "Date" $Date 8 ] . "\n\n" . \
|
||||||
"A client device specific rule must not exist!"); link=$Link });
|
"A client device specific rule must not exist!"); link=$Link });
|
||||||
:set ($Seen->$Ssid) 1;
|
:set ($Seen->$Ssid) 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,27 +1,29 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: dhcp-lease-comment.capsman
|
# RouterOS script: dhcp-lease-comment.capsman
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: lease-script, order=60
|
# provides: lease-script, order=60
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# update dhcp-server lease comment with infos from access-list
|
# update dhcp-server lease comment with infos from access-list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/dhcp-lease-comment.md
|
# https://rsc.eworm.de/doc/dhcp-lease-comment.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Main do={
|
:global LogPrint;
|
||||||
:local ScriptName [ :tostr $1 ];
|
|
||||||
|
|
||||||
:global LogPrintExit2;
|
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Lease in=[ /ip/dhcp-server/lease/find where dynamic=yes status=bound ] do={
|
:foreach Lease in=[ /ip/dhcp-server/lease/find where dynamic=yes status=bound ] do={
|
||||||
|
|
@ -32,10 +34,10 @@
|
||||||
:set NewComment [ /caps-man/access-list/get $AccessList comment ];
|
:set NewComment [ /caps-man/access-list/get $AccessList comment ];
|
||||||
}
|
}
|
||||||
:if ([ :len $NewComment ] != 0 && $LeaseVal->"comment" != $NewComment) do={
|
:if ([ :len $NewComment ] != 0 && $LeaseVal->"comment" != $NewComment) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Updating comment for DHCP lease " . $LeaseVal->"active-mac-address" . ": " . $NewComment) false;
|
$LogPrint info $ScriptName ("Updating comment for DHCP lease " . $LeaseVal->"active-mac-address" . ": " . $NewComment);
|
||||||
/ip/dhcp-server/lease/set comment=$NewComment $Lease;
|
/ip/dhcp-server/lease/set comment=$NewComment $Lease;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,27 +1,29 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: dhcp-lease-comment.local
|
# RouterOS script: dhcp-lease-comment.local
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: lease-script, order=60
|
# provides: lease-script, order=60
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# update dhcp-server lease comment with infos from access-list
|
# update dhcp-server lease comment with infos from access-list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/dhcp-lease-comment.md
|
# https://rsc.eworm.de/doc/dhcp-lease-comment.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Main do={
|
:global LogPrint;
|
||||||
:local ScriptName [ :tostr $1 ];
|
|
||||||
|
|
||||||
:global LogPrintExit2;
|
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Lease in=[ /ip/dhcp-server/lease/find where dynamic=yes status=bound ] do={
|
:foreach Lease in=[ /ip/dhcp-server/lease/find where dynamic=yes status=bound ] do={
|
||||||
|
|
@ -32,10 +34,10 @@
|
||||||
:set NewComment [ /interface/wireless/access-list/get $AccessList comment ];
|
:set NewComment [ /interface/wireless/access-list/get $AccessList comment ];
|
||||||
}
|
}
|
||||||
:if ([ :len $NewComment ] != 0 && $LeaseVal->"comment" != $NewComment) do={
|
:if ([ :len $NewComment ] != 0 && $LeaseVal->"comment" != $NewComment) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Updating comment for DHCP lease " . $LeaseVal->"active-mac-address" . ": " . $NewComment) false;
|
$LogPrint info $ScriptName ("Updating comment for DHCP lease " . $LeaseVal->"active-mac-address" . ": " . $NewComment);
|
||||||
/ip/dhcp-server/lease/set comment=$NewComment $Lease;
|
/ip/dhcp-server/lease/set comment=$NewComment $Lease;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,28 +1,30 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: dhcp-lease-comment%TEMPL%
|
# RouterOS script: dhcp-lease-comment%TEMPL%
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: lease-script, order=60
|
# provides: lease-script, order=60
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# update dhcp-server lease comment with infos from access-list
|
# update dhcp-server lease comment with infos from access-list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/dhcp-lease-comment.md
|
# https://rsc.eworm.de/doc/dhcp-lease-comment.md
|
||||||
#
|
#
|
||||||
# !! This is just a template to generate the real script!
|
# !! This is just a template to generate the real script!
|
||||||
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
# !! Pattern '%TEMPL%' is replaced, paths are filtered.
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Main do={
|
:global LogPrint;
|
||||||
:local ScriptName [ :tostr $1 ];
|
|
||||||
|
|
||||||
:global LogPrintExit2;
|
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Lease in=[ /ip/dhcp-server/lease/find where dynamic=yes status=bound ] do={
|
:foreach Lease in=[ /ip/dhcp-server/lease/find where dynamic=yes status=bound ] do={
|
||||||
|
|
@ -37,10 +39,10 @@
|
||||||
:set NewComment [ /interface/wireless/access-list/get $AccessList comment ];
|
:set NewComment [ /interface/wireless/access-list/get $AccessList comment ];
|
||||||
}
|
}
|
||||||
:if ([ :len $NewComment ] != 0 && $LeaseVal->"comment" != $NewComment) do={
|
:if ([ :len $NewComment ] != 0 && $LeaseVal->"comment" != $NewComment) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Updating comment for DHCP lease " . $LeaseVal->"active-mac-address" . ": " . $NewComment) false;
|
$LogPrint info $ScriptName ("Updating comment for DHCP lease " . $LeaseVal->"active-mac-address" . ": " . $NewComment);
|
||||||
/ip/dhcp-server/lease/set comment=$NewComment $Lease;
|
/ip/dhcp-server/lease/set comment=$NewComment $Lease;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||
|
|
@ -1,27 +1,29 @@
|
||||||
#!rsc by RouterOS
|
#!rsc by RouterOS
|
||||||
# RouterOS script: dhcp-lease-comment.wifi
|
# RouterOS script: dhcp-lease-comment.wifi
|
||||||
# Copyright (c) 2013-2024 Christian Hesse <mail@eworm.de>
|
# Copyright (c) 2013-2026 Christian Hesse <mail@eworm.de>
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/COPYING.md
|
# https://rsc.eworm.de/COPYING.md
|
||||||
#
|
#
|
||||||
# provides: lease-script, order=60
|
# provides: lease-script, order=60
|
||||||
# requires RouterOS, version=7.12
|
# requires RouterOS, version=7.15
|
||||||
#
|
#
|
||||||
# update dhcp-server lease comment with infos from access-list
|
# update dhcp-server lease comment with infos from access-list
|
||||||
# https://git.eworm.de/cgit/routeros-scripts/about/doc/dhcp-lease-comment.md
|
# https://rsc.eworm.de/doc/dhcp-lease-comment.md
|
||||||
#
|
#
|
||||||
# !! Do not edit this file, it is generated from template!
|
# !! Do not edit this file, it is generated from template!
|
||||||
|
|
||||||
:global GlobalFunctionsReady;
|
:local ExitOK false;
|
||||||
:while ($GlobalFunctionsReady != true) do={ :delay 500ms; }
|
:onerror Err {
|
||||||
|
:global GlobalConfigReady; :global GlobalFunctionsReady;
|
||||||
|
:retry { :if ($GlobalConfigReady != true || $GlobalFunctionsReady != true) \
|
||||||
|
do={ :error ("Global config and/or functions not ready."); }; } delay=500ms max=50;
|
||||||
|
:local ScriptName [ :jobname ];
|
||||||
|
|
||||||
:local Main do={
|
:global LogPrint;
|
||||||
:local ScriptName [ :tostr $1 ];
|
|
||||||
|
|
||||||
:global LogPrintExit2;
|
|
||||||
:global ScriptLock;
|
:global ScriptLock;
|
||||||
|
|
||||||
:if ([ $ScriptLock $ScriptName ] = false) do={
|
:if ([ $ScriptLock $ScriptName ] = false) do={
|
||||||
:return false;
|
:set ExitOK true;
|
||||||
|
:error false;
|
||||||
}
|
}
|
||||||
|
|
||||||
:foreach Lease in=[ /ip/dhcp-server/lease/find where dynamic=yes status=bound ] do={
|
:foreach Lease in=[ /ip/dhcp-server/lease/find where dynamic=yes status=bound ] do={
|
||||||
|
|
@ -32,10 +34,10 @@
|
||||||
:set NewComment [ /interface/wifi/access-list/get $AccessList comment ];
|
:set NewComment [ /interface/wifi/access-list/get $AccessList comment ];
|
||||||
}
|
}
|
||||||
:if ([ :len $NewComment ] != 0 && $LeaseVal->"comment" != $NewComment) do={
|
:if ([ :len $NewComment ] != 0 && $LeaseVal->"comment" != $NewComment) do={
|
||||||
$LogPrintExit2 info $ScriptName ("Updating comment for DHCP lease " . $LeaseVal->"active-mac-address" . ": " . $NewComment) false;
|
$LogPrint info $ScriptName ("Updating comment for DHCP lease " . $LeaseVal->"active-mac-address" . ": " . $NewComment);
|
||||||
/ip/dhcp-server/lease/set comment=$NewComment $Lease;
|
/ip/dhcp-server/lease/set comment=$NewComment $Lease;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} do={
|
||||||
|
:global ExitError; $ExitError $ExitOK [ :jobname ] $Err;
|
||||||
}
|
}
|
||||||
|
|
||||||
$Main [ :jobname ];
|
|
||||||
|
|
|
||||||