Skip to content

Script for servers with dynamic IPs that automatically updates Cloudflare DNS records whenever it changes.

License

Notifications You must be signed in to change notification settings

DaruZero/cloudflare-dns-auto-updater-go

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

81 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cloudflare DNS IP Updater - Go version

Go Report Card Docker Pulls Docker Image Size (tag)

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.

Requirements

  • 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)

Installation

  • 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

Environment variables

Required

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 or ZONE_NAME. If you specify both, ZONE_ID will be used.

Optional

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 and RECEIVER_ADDRESS can be the same.

Future implementation

  • 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

About

Script for servers with dynamic IPs that automatically updates Cloudflare DNS records whenever it changes.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published