@pejulian/simple-route53-ddns v0.0.18
Simple Route53 Dynamic DNS
This node module offers a script that allows you to create/update a record set in your Route53 Hosted Zone with your current IP address.
A use case for this script is to have it invoked via a scheduled task (i.e. crontab) to keep your FQDN updated with the correct and active IP address of your non static IP server.
This effectively gives you a simple Dynamic DNS service that you can use to ensure that your domain/host is always pointing to the correct
Credits
This script is a NodeJS adaptation of a script provided by Anthony Heddings.
Prerequisites
- AWS CLI installed and available on your prompt (This script doesn't directly use the CLI, but the CLI is required for setting up your AWS profile configuration on your machine: aws configure)
- An iamprofile configured that has relevant access to the Route53 service to add/update record sets in a given Hosted Zone
- npminstalled and available on your path
- An active Hosted Zone in AWS Route53
Usage
The easiest way to invoke scripts in this module is via npx.
update-record-set
Gets the current public ip address of your network and creates or updates a record set in the specified Hosted Zone in Route53.
npx @pejulian/simple-route53-ddns update-record-set -h YOUR_HOSTED_ZONE_ID -d YOUR_DOMAIN_NAME_1 YOUR_DOMAIN_NAME_2 [-t RECORD_SET_TYPE -l TTL -p YOUR_IAM_PROFILE -r YOUR_AWS_REGION]| Option | Required | Description | 
|---|---|---|
| -h --hosted-zone-id | :heavy_check_mark: | The hosted zone in Route53 where the record set will be created/updated | 
| -d --domain | :heavy_check_mark: | The domain name. Must be a FQDN or subdomain of the root FQDN. | 
| -i --ip | :x: | The IP address to set as the value of the record set created (NOTE: Setting this will override the internal IP lookup mechanism) | 
| -t --type | :x: | The DNS record set type to create/update (optional, will use Aif not set) | 
| -l --ttl | :x: | The TTL (optional, will default to 60seconds if not set) | 
| -p --profile | :x: | The IAM profile that is configured for use to interact with the target AWS account (optional, will use defaultif not set) | 
| -r --region | :x: | The region that the AWS SDK should operate in when running commands (optional, will use ap-southeast-1if not set) | 
The Route53 AWS SDK has a hard limit of 5 concurrent/bulk operations per second per account. Consider running this command in batches if you have more than 5 domains to be updated.