If you have some self-hosted services exposed to the internet but not a static public IP, you certainly faced the annoying task to access the CloudFlare dashboard and manually change all your records with the new IP everytime it changes.
What if I tell you that it can be automated? With this simple application you just have to spin a Docker container and not worry about your IP changing anymore.
It will continuously run and fetch your public IP at a given interval, detecting if it changes and sending a request to the CloudFlare API to update you records. You can even choose to be notified by email when that happens.
This is based on the daruzero/cloudflare-dns-auto-updater python script, but it has been rewritten in Go.
⚠️ Be aware, this only works if you are using the Cloudflare DNS.
- A CloudFlare account
- Cloudflare Global API Key
- The domain name you want to change the record of
- (optional) The ID of the A record you want to change (how to)
-
Plain Docker
docker run -d \ -e EMAIL=<YOUR_CF_LOGIN_EMAIL> \ -e AUTH_KEY=<YOUR_API_KEY> \ -e ZONE_NAME=<YOUR_ZONE_NAME> \ daruzero/cfautoupdater-go:latest
-
Docker Compose (see
.env.example
for the env file)version: '3.8' services: app: image: daruzero/cfautoupdater-go:latest env_file: .env restart: unless-stopped
Variable | Example value | Description |
---|---|---|
EMAIL |
johndoe@example.com | Email address associated with your CloudFlare account |
AUTH_KEY |
c2547eb745079dac9320b638f5e225cf483cc5cfdda41 | Your CloudFlare Global API Key |
ZONE_NAME |
example.com | The domain name that you want to change the record of. You can update multiple domains separating them with a , (comma) |
ZONE_ID |
372e67954025e0ba6aaa6d586b9e0b59 | The ID of the zone you want to change a record of. You can update multiple domains separating them with a , (comma) |
Note:
- You only need to specify either
ZONE_ID
orZONE_NAME
. If you specify both,ZONE_ID
will be used.
Variable | Example value | Description | Default |
---|---|---|---|
RECORD_ID |
372e67954025e0ba6aaa6d586b9e0b59 | The ID of the record you want to change. Leave blank to update all records of the zone. | - |
CHECK_INTERVAL |
86400 | The amount of seconds the script should wait between checks | 86400 |
SENDER_ADDRESS |
johndoe@example.com | The address of the email sender. Must use Gmail SMTP server | - |
SENDER_PASSWORD |
supersecret | The password to authenticate the sender. Use an application password (tutorial) | - |
RECEIVER_ADDRESS |
johndoe@example.com | The address of the email receiver. Must use Gmail SMTP server | - |
Note:
SENDER_ADDRESS
andRECEIVER_ADDRESS
can be the same.
- Possibility to update multiple domains
- Support for other SMTP servers other than Google's
- Support for other notification systems
- SMS
- Telegram
- Discord
- Slack
- Support for other DNS services