This Mikrotik RouterOS 7 script for updating DNS entries via Hetzner's DNS API.
The script is currently only compatible with RouterOS 7!
RouterOS 6 is currently not supported.
The scripts checks the defined interfaces' IP's for the configured FQDN's.
This is achieved via plain DNS.
If the IP from the interface differs from the IP configures in the DNS record, the DNS record will be updated accordingly to the interfaces' IP.
- Dependencies
- This script requires Winand's mikrotik-json-parser.
- Create a new Script
System -> Scripts
- Name:
ddns-hetzner
- Policy:
read
,write
,test
, uncheck everything else - Source: Copy the script here
- Name:
- Create a API token for Hetzner's DNS API
- Configure the script to your needs, check the description in the script or below for information how to configure it
- Create another new script
- Name:
JParseFunctions
- Policy:
read
,write
,test
uncheck everything else - Source: The content of mikrotik-json-parser
- Name:
- Create a new Schedule
System -> Schedule
- Name:
ddns-hetzner
- Start Date: leave it as it is
- Start Time: leave it as it is
- Interval:
00:05:00
- Policy:
read
,write
,test
uncheck everything else - On Event:
ddns-hetzner
- Name:
Variable name | Data type | Example | Description |
---|---|---|---|
apiKey |
string |
:local apiKey "3su1OLc0gUhUdwxn1bmKFss5V19mBhBx"; |
This variable requires a valid API token for the Hetzner DNS API. You can create an API token here. |
domainEntryConfig |
array s of string s |
:local domainEntryConfig {{"pppoe-out1";"";"domain.com";"A";"@";"300";};{"pppoe-out1";"pool-ipv6";"domain.com";"AAAA";"@";"300";};}; |
See below how to format the arrays correctly. |
The domainEntryConfig
array consists of multiple arrays. Each of the is configuring a DNS record for a given domain in a zone.
The data sheet below describes the formatting of the DNS records arrays.
Array index | Data | Data type | Example | Description |
---|---|---|---|---|
0 |
interface |
string |
"pppoe-out1" |
Name of the interface where the IP which is currently configured is fetched from. |
1 |
pool |
string |
"pool-ipv6" |
The prefix delegation pool which is used to automatically setup the IPv6 interface IP. Use "" when you don't use a pool to set your interface ip or for a type A record. |
2 |
zone |
string |
"domain.com" |
Zone which should be used to set a record to. |
3 |
record type |
string |
"A" |
Valid values A , AAAA . The type of record which will be set. Also determines which IP (v4/v6) will be fetched. |
4 |
record name |
string |
"@" |
The record name which should be updated. Use @ for the root of your domain. |
5 |
record TTL |
string |
"300" |
TTL value of the record in seconds, for a dynamic entry a short lifetime like 300 is recommended. |
Configuration example:
:local domainEntryConfig {
{
"pppoe-out1";
"";
"domain.com";
"A";
"@";
"300";
};
{"pppoe-out1";"pool-ipv6";"domain.com";"AAAA";"@";"300";};
{"pppoe-out1";"";"example.de";"A";"ddns";"300";};
{"pppoe-out1";"pool-ipv6";"abc.xzy";"AAAA";"ddns";"300";};
};
This example will create & update those DNS records:
- domain.com
- IPv4
- IPv6
- example.de
- IPv4
- abc.xzy
- IPv6