aboutsummaryrefslogtreecommitdiffstats
#!rsc
# RouterOS script: ipv6-update
# Copyright (c) 2013-2019 Christian Hesse <mail@eworm.de>
#
# update firewall and dns settings on IPv6 prefix change

:local PdPrefix $"pd-prefix";

:if ([ :typeof $PdPrefix ] = "nothing") do={
  :log error "This script is supposed to run from ipv6 dhcp-client.";
  :error "Error: See log for details.";
}

:local Pool [ / ipv6 pool get [ find where prefix=$PdPrefix ] name ];
:local AddrList [ / ipv6 firewall address-list find where comment=("ipv6-pool-" . $Pool) ];
:local OldPrefix [ / ipv6 firewall address-list get $AddrList address ];

# give the interfaces a moment to receive their addresses
:delay 2s;

if ($OldPrefix != $PdPrefix) do={
  :log info ("Updating IPv6 address list with new IPv6 prefix " . $PdPrefix);
  / ipv6 firewall address-list set address=$PdPrefix $AddrList;

  :foreach Record in=[ / ip dns static find where comment~("ipv6-pool-" . $Pool) ] do={
    :local Comment [ :toarray [ / ip dns static get $Record comment ] ];
    :local IntName [ :pick ($Comment->1) 10 99 ];
    :local Suffix [ :pick ($Comment->2) 7 99 ];

    :local Prefix [ / ipv6 address get [ find where interface=$IntName from-pool=$Pool global ] address ];
    :set Prefix [ :pick $Prefix 0 [ :find $Prefix "::/64" ] ];
    :if ($Prefix~"^[0-9a-f]+:[0-9a-f]+:[0-9a-f]+:") do={ } else={
      :set Prefix ($Prefix . ":");
    }

    :local Name [ / ip dns static get $Record name ];
    :if ([ :len $Name ] = 0) do={
      :set Name [ / ip dns static get $Record regex ];
    }

    :log info ("Updating DNS record for " . $Name . " to " . $Prefix . ":" . $Suffix);
    / ip dns static set address=($Prefix . ":" . $Suffix) $Record;
  }
}