Skip to content

Long-running dynamic DNS daemon for DigitalOcean

Notifications You must be signed in to change notification settings

T0astBread/dddd

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

dddd

Tests npm version badge

is the DigitalOcean Dynamic DNS Daemon.

It's a small tool to keep your A records on DigitalOcean updated with your server's IP address if your ISP doesn't give you a static address. At the moment it can only handle IPv4 and A records.

Installation

npm i -g @t0ast/dddd

Usage

dddd <config-file>

Where config-file is a JSON file of the following format:

{
	"checkInterval": 5,
	"records": [
		{
			"domain": "example.com",
			"names": [
				"@",
				"www",
				"whatever"
			]
		}
	]
}

checkInterval is the time dddd waits after an update has been completed and before a new update is started. The time is specified in minutes but it can be a floating point number if desired.

records contains the DNS records you want to have updated. Existing records not listed here are not touched. Nonexistent records will be created.

records.*.domain is the domain you have added to your DigitalOcean project (without any subdomains).

records.*.names are the subdomains to be updated.

Additionally the DO_API_TOKEN environment variable needs to be set to a read/write DigitalOcean API token. You can generate one on the Manage > API > Tokens/Keys page at cloud.digitalocean.com.

Note that, despite the name, the program does not daemonize. Usually, something else will do that for you (like an init system). The name only contains "daemon" because it sounds cooler that way.