1
0
digitalocean-dynamic-dns-ip/README.md

94 lines
4.1 KiB
Markdown
Raw Permalink Normal View History

2021-10-22 11:03:59 -07:00
# DIGITAL OCEAN DYNAMIC IP API CLIENT
2019-10-29 04:37:49 -07:00
A simple script in Go language to automatically update Digital ocean DNS records if you have a dynamic IP. Since it can be compiled on any platform, you can use it along with raspberrypi etc.
To find your Dynamic IP, this program will call out to https://api.ipify.org/ for ipv4 addresses and https://api64.ipify.org/ for ipv6 addresses. This is to support dual-stack environments. (These URLs can be customized; see Usage, below.)
## Requirements
2019-10-29 04:37:49 -07:00
2019-10-29 04:45:53 -07:00
- The record must already exist in DigitalOcean's DNS so that it can be updated.
(manually find your IP and add it to DO's DNS it will later be updated)
- A Digital Ocean API key that can be created at https://cloud.digitalocean.com/account/api/tokens.
2019-10-29 04:45:53 -07:00
## Installation
2019-10-29 04:45:53 -07:00
Download the prebuilt binaries from [releases](https://github.com/anaganisk/digitalocean-dynamic-dns-ip/releases),
2019-10-29 04:45:53 -07:00
or Build from source
2019-10-29 04:37:49 -07:00
```bash
2019-10-29 04:45:53 -07:00
# Requires Git, Go 1.8+(GO 1.11 if you want to use GO111MODULE=on).
# clone the repo in ~/go/src/github.com/anaganisk:
git clone https://github.com/anaganisk/digitalocean-dynamic-dns-ip.git
2019-10-29 04:37:49 -07:00
# Skip to next step, if you have GO111MODULE=on in your environment it is fetched automatically
go get github.com/mitchellh/go-homedir
# build the project
go build
```
## Usage
2019-10-29 04:37:49 -07:00
2019-09-26 10:45:03 -07:00
Create a file `.digitalocean-dynamic-ip.json` (dot prefix to hide the file) and place it in your home directory. Add the following JSON (or refer to the sample configuration file, `digitalocean-dynamic-ip.sample.json`):
```json
{
"interval": "30m",
"apikey": "samplekeydasjkdhaskjdhrwofihsamplekey",
"doPageSize": 20,
2019-07-20 20:26:15 -07:00
"useIPv4": true,
"useIPv6": false,
2019-07-20 22:13:34 -07:00
"allowIPv4InIPv6": false,
"ipv4CheckUrl": "https://api.ipify.org/?format=text",
2017-11-12 05:46:49 -08:00
"domains": [
{
2017-11-12 05:46:49 -08:00
"domain": "example.com",
"records": [
{
"name": "subdomainOrRecord",
"type": "A"
}
]
},
{
"domain": "example2.com",
"records": [
{
"name": "subdomainOrRecord2",
"type": "A",
"TTL": 30
2017-11-12 05:46:49 -08:00
}
]
}
]
}
```
2019-09-26 10:45:03 -07:00
The TTL can optionally be updated if passed in the configuration. Digital Ocean has a minimum TTL of 30 seconds. The `type` and the `name` must match existing records in the Digital Ocean DNS configuration. Only `types` of `A` and `AAAA` allowed at the moment. Use the `name` of `"@"` to update a the top level domain record itself instead of a sub domain.
2019-07-20 22:13:34 -07:00
If you want to reduce the number of calls made to the digital ocean API and have more than 20 DNS records in your domain, you can adjust the `doPageSize` parameter. By default, Digital Ocean returns 20 records per page. Digital Ocean has a max page size of 200 items.
2019-07-20 20:26:15 -07:00
By default, the configuration checks both IPv4 and IPv6 addresses assuming your provider set up your connection as dual stack. If you know you only have ipv4 or ipv6 you can disable using one or the other in the config. To disable one or the other, set the `useIPv4` or `useIPv6` settings to `false`. If the options aren't present, or are set to `null`, then the configuration assumes a value of `true`.
2019-07-20 22:13:34 -07:00
The `allowIPv4InIPv6` configuration option will allow adding an IPv4 address to be used in a AAAA record for IPv6 lookups.
The `ipv4CheckUrl` and `ipv6CheckUrl` configuration settings are optional. If set, they must be URLs which respond to a GET request, with a plaintext response containing only your IP address. If unset, they default to `https://api.ipify.org/?format=text` and `https://api64.ipify.org/?format=text` respectively.
2019-09-26 10:45:03 -07:00
```bash
2019-09-26 10:45:03 -07:00
# after running `go build digitalocean-dynamic-ip.go`, run:
./digitalocean-dynamic-ip
```
Configuration file location must be specified as a positional argument:
2019-09-26 10:45:03 -07:00
2019-08-05 07:07:13 -07:00
```bash
2019-09-26 10:45:03 -07:00
#run:
2019-08-05 07:07:13 -07:00
./digitalocean-dynamic-ip /path/to/my/config.json
```
2021-12-31 07:55:03 -08:00
By default the tool will not output anything on success. If you wish to see debug messages, you can use the `-d` or `-debug` command flags. All debug messages will be printed to *Standard Out*, while warnings and fatal errors will be printed to *Standard Error*. Warnings and Error messages are always printed regardless of the `-d`/`-debug` flag usage.
```bash
#run:
./digitalocean-dynamic-ip -debug /path/to/my/config.json
```