mirror of
https://github.com/eworm-de/routeros-scripts.git
synced 2024-05-11 05:55:19 +00:00
update-gre-address: remove settings from global-config
Instead read infos from gre interface comment.
This commit is contained in:
@ -37,11 +37,6 @@
|
|||||||
# This controls what configuration is activated by bridge-port-to-default.
|
# This controls what configuration is activated by bridge-port-to-default.
|
||||||
:global "bridge-port-to" "default";
|
:global "bridge-port-to" "default";
|
||||||
|
|
||||||
# These settings are used to update gre interface settings based on
|
|
||||||
# remote peer configuration.
|
|
||||||
:global "gre-cert-prefix" "ikev2-";
|
|
||||||
:global "gre-int-prefix" "gre-";
|
|
||||||
|
|
||||||
# Access-list entries matching this comment are updated
|
# Access-list entries matching this comment are updated
|
||||||
# with daily pseudo-random PSK.
|
# with daily pseudo-random PSK.
|
||||||
:global "daily-psk-match-comment" "Daily PSK";
|
:global "daily-psk-match-comment" "Daily PSK";
|
||||||
|
@ -5,22 +5,16 @@
|
|||||||
# update gre interface remote address with dynamic address from
|
# update gre interface remote address with dynamic address from
|
||||||
# ipsec remote peer
|
# ipsec remote peer
|
||||||
|
|
||||||
:global "gre-cert-prefix";
|
|
||||||
:global "gre-int-prefix";
|
|
||||||
|
|
||||||
/ interface gre set remote-address=0.0.0.0 disabled=yes [ find where !running !disabled ];
|
/ interface gre set remote-address=0.0.0.0 disabled=yes [ find where !running !disabled ];
|
||||||
|
|
||||||
:foreach peer in=[ / ip ipsec remote-peers find ] do={
|
:foreach peer in=[ / ip ipsec remote-peers find ] do={
|
||||||
:local id [ / ip ipsec remote-peers get $peer id ];
|
:local id [ / ip ipsec remote-peers get $peer id ];
|
||||||
|
:local greint [ / interface gre find where comment=$id ];
|
||||||
:if ([ :pick $id 0 [ :len $"gre-cert-prefix" ] ] = $"gre-cert-prefix") do={
|
|
||||||
:local name [ :pick $id [ :len $"gre-cert-prefix" ] [ :len $id ] ];
|
|
||||||
:local addrnew [ / ip ipsec remote-peers get $peer dynamic-address ];
|
|
||||||
:local grename ($"gre-int-prefix" . $name);
|
|
||||||
:local greint [ / interface gre find where name=$grename ];
|
|
||||||
:if ([ :len $greint ] > 0) do={
|
:if ([ :len $greint ] > 0) do={
|
||||||
|
:local grename [ / interface gre get $greint name ];
|
||||||
:local addrold [ / interface gre get $greint remote-address ];
|
:local addrold [ / interface gre get $greint remote-address ];
|
||||||
:local disabled [ / interface gre get $greint disabled ];
|
:local disabled [ / interface gre get $greint disabled ];
|
||||||
|
:local addrnew [ / ip ipsec remote-peers get $peer dynamic-address ];
|
||||||
:if ($addrnew != $addrold || $disabled = true) do={
|
:if ($addrnew != $addrold || $disabled = true) do={
|
||||||
:log info ("Update remote address for interface " . $grename . " to " . $addrnew);
|
:log info ("Update remote address for interface " . $grename . " to " . $addrnew);
|
||||||
/ interface gre set remote-address=0.0.0.0 disabled=yes [ find where remote-address=$addrnew name!=$grename ];
|
/ interface gre set remote-address=0.0.0.0 disabled=yes [ find where remote-address=$addrnew name!=$grename ];
|
||||||
@ -28,4 +22,3 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
Reference in New Issue
Block a user