| Crates.io | teleddns |
| lib.rs | teleddns |
| version | 0.2.0 |
| created_at | 2025-02-03 00:01:49.054799+00 |
| updated_at | 2025-12-15 19:37:51.768535+00 |
| description | Advanced DDNS client with Netlink support for efficient address change detection |
| homepage | https://github.com/tmshlvck/teleddns |
| repository | https://github.com/tmshlvck/teleddns |
| max_upload_size | |
| id | 1539970 |
| size | 149,248 |
Advanced DDNS client with daemonization (as systemd service), or one-shot running capability and compatibility for teleddns-server.
When the TeleDDNS runs in daemonized mode it listens for Netlink messages and pools the updates to minimize both the DDNS convergence time and resource usage.
curl -s -L https://raw.githubusercontent.com/tmshlvck/teleddns/master/deploy.sh | bash -s <URL> <domainname>
Where URL is the API URL including the username and password in https://user:pass@host.domain.tld/ddns/update form and domainname is the FQDN of the host (example: testhost.d.telephant.eu).
The deploy script automatically detects your distribution and installs using the best available method:
| Distribution | Installation Method |
|---|---|
| Debian, Ubuntu, Pop!_OS, Mint, etc. | APT repository (apt.telephant.eu) |
| Fedora | COPR repository |
| Other Linux | Binary download from GitHub releases |
| Fallback (if binary unavailable) | cargo install from crates.io |
The script will:
/etc/teleddns/teleddns.yaml (if not already present)After installation, check status with:
sudo systemctl status teleddns
sudo journalctl -u teleddns -f
cargo install teleddns
curl -fsSL https://apt.telephant.eu/teleddns/pubkey.gpg | sudo gpg --dearmor -o /usr/share/keyrings/teleddns.gpg
echo "deb [signed-by=/usr/share/keyrings/teleddns.gpg] https://apt.telephant.eu/teleddns/ stable main" | sudo tee /etc/apt/sources.list.d/teleddns.list
sudo apt update
sudo apt install teleddns
sudo dnf copr enable tmshlvck/teleddns
sudo dnf install teleddns
Pre-compiled binaries for amd64, arm64, armhf, and riscv64 are available on GitHub Releases.
Then edit and install teleddns.service.
Clone this repo, build and install the software:
git clone https://github.com/tmshlvck/teleddns.git
cd teleddns
cargo install --root /usr/local --path .
Then edit and install teleddns.service.
Create configuration file (modify the following example):
sudo mkdir /etc/teleddns/
sudo bash -c 'cat <<EOF >/etc/teleddns/teleddns.yaml
---
debug: False
ddns_url: 'https://USERNAME:PASSWORD@ddns-server.domain.tld/ddns/update'
hostname: 'myhostname.ddns.domain.tld'
enable_ipv6: True
enable_ipv4: False
interfaces:
- '*'
hooks:
- nft_sets_outfile: "/etc/nftables.d/00-localnets.rules"
shell: "nft -f /etc/nftables.conf"
EOF'
Test the client:
teleddns -o
The exected output should look like this:
[2025-02-02T23:16:05Z INFO teleddns] Read config file /etc/teleddns/teleddns.yaml finished
[2025-02-02T23:16:05Z INFO teleddns] Set log level Info
[2025-02-02T23:16:05Z INFO teleddns] Main loop now waiting for the oneshot run to finish
[2025-02-02T23:16:05Z INFO teleddns] Trigger the first update
[2025-02-02T23:16:35Z INFO teleddns] Sending DDNS: 2a02:aa11:380:300:ef1a:78c9:f995:e73d
[2025-02-02T23:16:36Z INFO teleddns] DDNS GET to URL https://th:<PASSWORD>@slon.telephant.eu/ddns/update?myip=2a02%3Aaa11%3A380%3A300%3Aef1a%3A78c9%3Af995%3Ae73d&hostname=tapir.d.telephant.eu succeeded with code: 200 OK, text: Ok("{\"detail\":\"DDNS noop AAAA label='tapir' zone.origin='d.telephant.eu.' -> 2a02:aa11:380:300:ef1a:78c9:f995:e73d\"}")
[2025-02-02T23:16:36Z INFO teleddns] Sucessfully shutdown