Cloudflare DNS Updater written in Rust. Works for IPv4 and IPv6 alike.
Neshura
9b8377cba9
All checks were successful
Run Tests on Code / run-tests (push) Successful in 35s
Build and release binary file and packages / test (push) Successful in 25s
Build and release binary file and packages / build (push) Successful in 41s
Build and release binary file and packages / upload-generic-package (push) Successful in 3s
Build and release binary file and packages / upload-debian-package (push) Successful in 10s
Build and release binary file and packages / create-release (push) Successful in 15s
|
||
---|---|---|
.forgejo/workflows | ||
debian | ||
src | ||
.gitignore | ||
Cargo.lock | ||
Cargo.toml | ||
COPYING | ||
README.md |
Cloudflare DNS Updater
Using the application
The application necessarily requires a valid Cloudflare API Token. Further the application must be located in the same network as the configured zones.
The actual configuration happens in three or more files located in ~/.config/cloudflare-dns-updater/
:
config.toml
contains general configuration parameters for the application
interfaces.toml
contains all IPv6 interfaces available/used by the zone config files.
.toml
files in zones.d
contain settings for individual zones.
Example:
config.toml
cf_api_token = "0123456789abcdef0123456789abcdef01234" # Cloudflare API Token
check_interval_seconds = 30 # Defaults to 60 if missing
uptime_url = "https://example.org/uptime/id12" # Post Endpoint for a Uptime Monitor
interfaces.toml
host_address = "::edcb:a098:7654:3210"
[interfaces]
example-interface = "::0123:4567:890a:bcde" # static part of the IP, the rest will be dynamically generated using the host
zones.d/example.org.toml
email = "owner@example.org" # Email of User owning the Zone
zone = "example.org" # Zone Name
id = "01234567890abcdefghijklmnopqrstu" # Zone ID
[[entry]]
name = "example.org" # "@" Symbol is not currently supported
type = ["AAAA", "A"] # Options are: "A" (IPv4/A Record) and/or "AAAA" (IPv6/AAAA Record)
interface = "example-interface" # Only required on type values 6 and 10
Debian Repository
Currently supported:
- Debian 12 'Bookworm'
Includes systemd system and user unit files
For more details see the package registry