2017-08-16 17:55:01 +00:00
gandi-live-dns
2017-08-14 21:45:08 +00:00
----
This is a simple dynamic DNS updater for the
2017-08-15 16:01:15 +00:00
[Gandi ](https://www.gandi.net ) registrar. It uses their [LiveDNS REST API ](http://doc.livedns.gandi.net/ ) to update the zone file for a subdomain of a domain to point at the external IPv4 address of the computer it has been run from.
2017-08-14 21:45:08 +00:00
2019-12-09 11:05:06 +00:00
~~It has been developed on Debian 8 Jessie and tested on Debian 9 Stretch GNU/Linux using Python 2.7.~~
2020-01-21 11:26:55 +00:00
This has been update to work with Python 3 (Python 3.6 at Ubuntu 18.04). This will not work with Python 2 since it ~~will be deprecated in~~ is deprecated since 2020-01-01.
2017-08-14 21:45:08 +00:00
2017-08-15 16:01:15 +00:00
With the new v5 Website, Gandi has also launched a new REST API which makes it easier to communicate via bash/curl or python/requests.
2017-08-14 21:45:08 +00:00
2017-08-15 15:54:18 +00:00
### Goal
2017-08-14 21:45:08 +00:00
2017-08-15 16:25:55 +00:00
You want your homeserver to be always available at `dynamic_subdomain.mydomain.tld` .
2017-08-14 21:45:08 +00:00
2017-08-15 16:01:15 +00:00
### Debian Package Requirements
`apt-get update && apt-get upgrade && apt-get install unzip python-requests python-args python-simplejson`
2017-08-14 21:45:08 +00:00
#### API Key
2017-08-15 12:42:51 +00:00
First, you must apply for an API key with Gandi. Visit
https://account.gandi.net/en/ and apply for (at least) the production API
2017-08-14 21:45:08 +00:00
key by following their directions.
2017-08-15 15:54:18 +00:00
#### A DNS Record
2019-12-09 11:05:06 +00:00
Create the DNS A Records in the GANDI Webinterface which you want to update if your IPv4 changes.
#### AAAA DNS Record (only needed if ipv6 is in use)
Create the DNS AAAA Records for ipv6 in the GANDI Webinterface which you want to update if your IPv6 changes.
2017-08-14 21:45:08 +00:00
2017-08-15 12:42:51 +00:00
#### Git Clone or Download the Script
2017-08-16 17:55:01 +00:00
Download the Script from here as [zip ](https://github.com/cavebeat/gandi-live-dns/archive/master.zip )/[tar.gz](https://github.com/cavebeat/gandi-live-dns/archive/master.tar.gz) and extract it.
2017-08-15 15:54:18 +00:00
2017-08-15 16:25:55 +00:00
or clone from git
2017-08-15 15:54:18 +00:00
2017-08-16 17:55:01 +00:00
`git clone https://github.com/cavebeat/gandi-live-dns.git`
2017-08-15 12:42:51 +00:00
2017-08-14 21:45:08 +00:00
#### Script Configuration
2017-08-15 12:42:51 +00:00
Then you'd need to configure the script in the src directory.
2017-08-15 15:54:18 +00:00
Copy `example.config.py` to `config.py` , and put it in the same directory as the script.
Edit the config file to fit your needs.
##### api_secret
Start by retrieving your API Key from the "Security" section in new [Gandi Account admin panel ](https://account.gandi.net/ ) to be able to make authenticated requests to the API.
api_secret = '---my_secret_API_KEY----'
##### api_endpoint
Gandiv5 LiveDNS API Location
http://doc.livedns.gandi.net/#api-endpoint
2017-08-15 16:01:15 +00:00
```
2017-11-17 13:26:16 +00:00
api_endpoint = 'https://dns.api.gandi.net/api/v5'
2017-08-15 16:01:15 +00:00
```
2017-08-15 15:54:18 +00:00
##### domain
2017-08-15 16:01:15 +00:00
Your domain for the subdomains to be updated
2017-08-15 15:54:18 +00:00
##### subdomains
2017-08-15 16:01:15 +00:00
All subdomains which should be updated. They get created if they do not yet exist.
2017-08-14 21:45:08 +00:00
2019-12-09 11:05:06 +00:00
* `subdomains` for ipv4
* `subdomains6` for ipv6
2017-08-15 16:01:15 +00:00
```
subdomains = ["subdomain1", "subdomain2", "subdomain3"]
2019-12-09 11:05:06 +00:00
subdomains6 = ["subdomain1v6", "subdomain2v6", "subdomain3v6"]
2017-08-15 16:01:15 +00:00
```
2019-12-09 11:05:06 +00:00
The first subdomain is used to find out the actual IP in the Zone Records.
If the returnded ip from is ipv6, it will use the first from subdomains6.
2017-08-14 21:45:08 +00:00
2017-08-15 12:42:51 +00:00
#### Run the script
2017-08-15 15:54:18 +00:00
And run the script:
2017-08-15 16:01:15 +00:00
```
2017-08-16 17:55:01 +00:00
root@dyndns:~/gandi-live-dns-master/src# ./gandi-live-dns.py
2017-08-15 15:54:18 +00:00
Checking dynamic IP: 127.0.0.1
Checking IP from DNS Record subdomain1: 127.0.0.1
IP Address Match - no further action
2017-08-15 16:01:15 +00:00
```
2017-08-15 15:54:18 +00:00
If your IP has changed, it will be detected and the update will be triggered.
2017-08-15 12:42:51 +00:00
2017-08-15 16:01:15 +00:00
```
2017-08-16 17:55:01 +00:00
root@dyndns:~/gandi-live-dns-master/src# ./gandi-live-dns.py
2017-08-15 15:54:18 +00:00
Checking dynamic IP: 127.0.0.2
Checking IP from DNS Record subdomain1: 127.0.0.1
IP Address Mismatch - going to update the DNS Records for the subdomains with new IP 127.0.0.2
Status Code: 201 , DNS Record Created , IP updated for subdomain1
Status Code: 201 , DNS Record Created , IP updated for subdomain2
Status Code: 201 , DNS Record Created , IP updated for subdomain3
2017-08-15 16:01:15 +00:00
```
2017-08-15 15:54:18 +00:00
#### Command Line Arguments
2017-08-15 16:01:15 +00:00
```
2017-08-16 17:55:01 +00:00
root@dyndns:~/gandi-live-dns-master/src# ./gandi-live-dns.py -h
2019-12-09 16:07:43 +00:00
usage: gandi-live-dns.py [-h] [-f] [-v] [-r]
2017-08-15 15:54:18 +00:00
optional arguments:
2019-12-09 16:07:43 +00:00
-h, --help show this help message and exit
-v, --verbose increase output verbosity
-f, --force force an update/create
-r REPEAT, --repeat REPEAT
keep running and repeat every N seconds
2017-08-15 16:01:15 +00:00
```
2017-08-15 12:42:51 +00:00
2017-08-15 15:54:18 +00:00
The force option runs the script, even when no IP change has been detected.
It will update all subdomains and even create them if they are missing in the
Zone File/Zone UUID. This can be used if additional/new subdomains get appended to the conig file.
2017-08-15 16:25:55 +00:00
### IP address lookup service
There exist several providers for this case, but better is to run your own somewhere.
#### Poor Mans PHP Solution
2017-08-16 17:55:01 +00:00
On a LAMP Stack, place the file [index.php ](https://github.com/cavebeat/gandi-live-dns/blob/master/src/example-index.php ) in a directory /ip in your webroot.
2017-08-15 16:25:55 +00:00
```
root@laptop:~# curl https://blog.cavebeat.org/ip/
127.0.0.1
```
This should fit your personal needs and you still selfhost the whole thing.
2017-08-15 16:29:25 +00:00
#### IP address lookup service https://ifconfig.co
https://github.com/mpolden/ipd A simple service for looking up your IP address. This is the code that powers [https://ifconfig.co ](https://ifconfig.co )
2017-08-15 16:25:55 +00:00
#### use external services
choose one as described in the config file.
### Cron the script
2017-08-16 17:55:01 +00:00
Run the script every five minutes.
2017-08-15 16:25:55 +00:00
```
2017-08-16 17:55:01 +00:00
*/5 * * * * /root/gandi-live-dns-master/src/gandi-live-dns.py >/dev/null 2>& 1
2017-08-15 16:25:55 +00:00
```
2019-12-09 16:07:43 +00:00
### Run with Docker
Use the docker file to build the image. With docker, the script will run every 3600 seconds. (This value can be changed in the Dockerfile.
2017-08-16 17:55:01 +00:00
### Limitations
The XML-RPC API has a limit of 30 requests per 2 seconds, so i guess it's safe to update 25 subdomains at once with the REST API.
2017-08-15 16:25:55 +00:00
### Upcoming Features
2019-12-09 11:05:06 +00:00
* ~~command line Argument for verbose mode~~ Aditional verbosity implemented.
2017-08-15 16:25:55 +00:00
### Inspiration
2017-08-15 15:54:18 +00:00
2017-08-15 12:42:51 +00:00
This DynDNS updater is inspired by https://github.com/jasontbradshaw/gandi-dyndns which worked very well
2017-08-15 16:25:55 +00:00
with the classic DNS from Gandiv4 Website and their XML-RPC API.
Gandi has created a new API, i accidently switched to the new DNS Record System, so someone had to start a new updater.