Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dlecan/generic-dns-update
Cross-platform tool to update DNS such as Gandi.net with your dynamic IP address
https://github.com/dlecan/generic-dns-update
Last synced: 3 months ago
JSON representation
Cross-platform tool to update DNS such as Gandi.net with your dynamic IP address
- Host: GitHub
- URL: https://github.com/dlecan/generic-dns-update
- Owner: dlecan
- License: mit
- Archived: true
- Created: 2015-11-29T21:20:49.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2022-01-20T17:17:31.000Z (almost 3 years ago)
- Last Synced: 2024-10-07T20:18:06.831Z (3 months ago)
- Language: Rust
- Homepage:
- Size: 110 KB
- Stars: 10
- Watchers: 3
- Forks: 8
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-rust - dlecan/generic-dns-update - ci.org/dlecan/generic-dns-update.svg?branch=master">](https://travis-ci.org/dlecan/generic-dns-update) (Applications)
- awesome-rust-zh - dlecan/generic-dns-update - 使用您的 IP 地址,更新 DNS 区域文件的工具[<img src="https://api.travis-ci.org/dlecan/generic-dns-update.svg?branch=master">](https://travis-ci.org/dlecan/generic-dns-update) (应用 / 贡献)
- awesome-rust-cn - dlecan/generic-dns-update
- awesome-rust - dlecan/generic-dns-update - ci.org/dlecan/generic-dns-update.svg?branch=master">](https://travis-ci.org/dlecan/generic-dns-update) (应用 Applications)
README
# GDU | Generic DNS Update
This project is not maintained anymore.
I decided to replace it by combining Terraform and the Gandi Go providerSee:
- https://medium.com/@matzhouse/dynamic-dns-with-terraform-and-route53-3fafe7c68970
- https://registry.terraform.io/providers/go-gandi/gandi/latest/docs# Legacy description
A cross-platform tool to update DNS zonefiles (such as Gandi.net) when you have a dynamic public IP address.
It's a DynDNS or equivalent alternative, available for several OS and configured by command line parameters.
For developpers, it's written in Rust and can be easily extended to add new DNS providers or new ways to detect your public IP address.
## Features
- [x] Detect your public IP address
- [x] By HTTP
- [ ] By DNS lookup- Create or update your DNS provider zonefiles to associate to public IP address with an A or AAAA DNS record.
- [x] Gandi.net
- [ ] Other providers- Run on several OS:
- [x] Linux x86_64
- [x] Linux ARMv6 and more, such as Raspberry PI all models, including PI2
- [x] Windows 32/64 bits
- [ ] OS X## Command line usage
```
$ gdu --helpUSAGE:
gdu [FLAGS] [OPTIONS]FLAGS:
-n, --dry-run Dry run, don't really update Gandi zone file
-f, --force Force new zonefile creation even if IP address isn't modified
-h, --help Prints help information
-V, --version Prints version information
-v Verbose modeOPTIONS:
-a, --apikey Your API key provided by Gandi
-d, --domain The domain name whose active zonefile will be updated, e.g. "domain.com"
-i, --ip-provider IP address provider to use to get your own IP address.
Available values for :
opendns : OpenDNS
- : read IP address from stdin
sfrlaboxfibre : French 'SFR Labox Fibre' subscribers
-r, --record-name Name of the A record to update or create (without domain)```
## Installation
### On Linux: Fedora, Debian, Ubuntu, Raspbian ...
GDU is available as a native package (rpm/deb) for your distribution through package.io.
Go to [package.io project page](https://packagecloud.io/dlecan/generic-dns-update/install) for installation instructions.Then
```
sudo apt-get install generic-dns-update
```#### Linux cron configuration
You can configure GDU to check hourly if your IP address as been updated with cron.
Edit as root or sudo the file `/etc/cron.hourly/gdu`, with the following content:
```bash
#!/bin/bashgdu -a YOUR_GANDI_KEY -d YOUR_DOMAIN -r YOUR_RECORD -i opendns >> /var/log/gdu.log 2>&1
```
## Inspiration
- https://github.com/brianpcurran/gandi-automatic-dns
- https://github.com/Chralu/gandyn
- https://github.com/jasontbradshaw/gandi-dyndns
- https://github.com/lembregtse/gandi-dyndns