DDNS Daemon
data:image/s3,"s3://crabby-images/29652/2965296f8fc062fab599c84b94b8342bbca2940a" alt="Go Report Card"
OVH DynHost self-hosted daemon. Multiple hosts supported!
How it works
It's fetching your IP address from ifconfig.co API then updating all your OVH
DynHost hosts based on the configuration file.
Config
By default config.yml
is expected to be in the same directory but you can customize
it with --config-filepath
param.
hosts:
first_host:
host: first.host.dynhost.ovh
user: firstHostUsername
pass: firstHostPassword
second_host:
host: second.host.dynhost.ovh
user: secondHostUsername
pass: secondHostPassword
...
Quick setup
Production
- Download latest executable
- Prepare yaml config file
- Configure the daemon (eg. service - sample config below) or run it manually (eg. screen)
Ubuntu (system.d service)
# /etc/systemd/system/ddns-daemon.service
[Unit]
Description=DDNS daemon
[Service]
ExecStart=/usr/local/bin/ddns-daemon daemon --config-filepath=/etc/ddns-daemon/config.yml
User=user
Restart=on-failure
RestartSec=5
[Install]
WantedBy=multi-user.target
# reload daemon and check service status
systemctl daemon-reload
service ddns-daemon status
Development
Run it with or without Docker.
- Clone the repository
- Create
.env
file based on .env.dist
- Prepare yaml config file
- Build docker image and run Golang environment
- Contribute, build binary, run daemon
License
MIT License