A Cloudflare Worker script that exposes a UniFi-compatible DDNS API to dynamically update the IP address of a DNS A record.
I have a UniFi Dream Machine Pro (UDM-Pro), and I want to update my Cloudflare domain name DNS records when my public IP address changes. Unfortunately, UniFi does not come pre-configured to support Cloudflare as one of its DDNS providers.
You must have a Cloudflare account and your domain must be configured to point to the Cloudflare nameservers before you continue.
- Deploy the Worker:
- Navigate to the Cloudflare Workers dashboard
- Once the deployment is complete, take note of it's
\*.workers.dev
route. More on routes for Cloudflare Workers here. - Create an API token so the Worker can update your DNS records. Go to https://dash.cloudflare.com/profile/api-tokens and select "Create token". On the next page, scroll down and click the "Get Started" button next to the "Create Custom Token" label. Select Zone:DNS:Edit for the "Permissions" drop-down, and include your target zone under the "Zone Resources" drop-down. Copy your API Key - you will need it later when configuring your UniFi OS Controller.
- Clone or download this project
- Ensure you have the Wrangler CLI installed on your system
- Log in with wrangler, and run
wrangler deploy
. - Once you have created the worker, take note of it's
\*.workers.dev
route. More on routes for Cloudflare Workers here. - Create an API token so the Worker can update your DNS records. Go to https://dash.cloudflare.com/profile/api-tokens and select "Create token". On the next page, scroll down and click the "Get Started" button next to the "Create Custom Token" label. Select Zone:DNS:Edit for the "Permissions" drop-down, and include your target zone under the "Zone Resources" drop-down. Copy your API Key - you will need it later when configuring your UniFi OS Controller.
- Log on to your UniFi OS Controller
- Navigate to Settings > Internet > WAN and scroll down to Dynamic DNS.
- Click Create New Dynamic DNS and enter the following information:
Service
: you must choosedyndns
Hostname
: the full subdomain and hostname of the record you want to update (e.g.subdomain.mydomain.com
,mydomain.com
for root domain)Username
: the domain name containing the record (e.g.mydomain.com
)Password
: the Cloudflare API Token you created earlierServer
: the Cloudflare Worker route<worker-name>.<worker-subdomain>.workers.dev/update?ip=%i&hostname=%h
- On UniFi devices older than the UDM the
Server
value should be configured with no URL path:<worker-name>.<worker-subdomain>.workers.dev
. - Many UniFi devices do not handle the
https://
prefix in the URL for theServer
value. You should remove it, using<worker-name>.<worker-subdomain>.workers.dev
instead ofhttps://<worker-name>.<worker-subdomain>.workers.dev
.
- On UniFi devices older than the UDM the
To test the configuration and force an update:
- Ssh into your UniFi device
- Run
ps aux | grep inadyn
- Note the configuration file path referenced by the running inadyn process e.g.
/run/ddns-eth4-inadyn.conf
. - Run
inadyn -n -1 --force -f <config-path>
e.g.inadyn -n -1 --force -f /run/ddns-eth4-inadyn.conf
Also check /var/log/messages
for error messages related to inadyn
.
- If you are attempting to update a subdomain (
sub.example.com
), you must manually create an A record for it first in your Cloudflare dashboard. - If you receive a log message on your Unifi device like
inadyn[2173778]: Failed resolving hostname https: Name or service not known
, removehttps://
from theServer
field as described the Configuring section.