Coder Social home page Coder Social logo

soerenschneider / dyndns Goto Github PK

View Code? Open in Web Editor NEW
0.0 3.0 0.0 672 KB

Automatically updates DNS records for internet connections that don't have a static IP

License: Apache License 2.0

Makefile 3.32% Go 86.75% Dockerfile 0.46% HCL 9.47%
aws route53 mqtt ed25519 dynamic-dns dyndns self-hosted golang dyndns-server dyndns-client vault-client dynamic-credentials sqs

dyndns's Introduction

dyndns

Go Report Card test-workflow release-workflow golangci-lint-workflow

Automatically updates DNS records for hosts that don't have a static IP

Features

๐Ÿ“ฃ Dynamically updates DNS records to match their public IP address
๐Ÿฐ Built-in resiliency for different failure scenarios
๐Ÿšข Server component supports running on AWS Lambda
๐Ÿš€ Dispatch update requests via AWS SQS, MQTT and/or HTTP API calls
๐Ÿš Detect public IP address by network interface's status or by calling HTTP APIs
๐ŸŽญ Runs in client / server mode to limit blast-radius of leaked credentials
๐Ÿ”ง Customizable list of HTTP APIs to detect IP updates
โค๏ธ Specify HTTP APIs that detect IP updates which are preferred over other API endpoints
๐Ÿ” Messages are cryptographically signed, therefore public MQTT brokers can be used
๐Ÿ”‘ Can use either dynamic credentials using Hashicorp Vault or static credentials
๐Ÿ”ญ Observability through Prometheus metrics

Why would I need it?

๐Ÿ“Œ You don't have a static public IP address but want to connect to your home network
๐Ÿคน Ideally, you have multiple endpoints you want to assign DNS records to

Installation

AWS Lambda

Run the lambda-server Makefile target to build an archive for the provided.al2 Lambda runtime and the arm64 architecture. Either create a Lambda function using AWS cli / Console or run the Terraform code to create an API Gateway instance and Lambda function.

$ make lambda-server # build the server component
$ terraform -chdir=deployment/terraform/envs/dev apply # this command will deploy a dyndns-server as a Lambda function which is reachable via a new API Gateway instance
$ terraform -chdir=deployment/terraform/envs/dev output -raw gateway-url # display the url of the API endpoint

Docker / Podman

$ docker pull ghcr.io/soerenschneider/dyndns-server:main
$ docker pull ghcr.io/soerenschneider/dyndns-client:main

Binaries

Head over to the prebuilt binaries and download the correct binary for your system.

From Source

As a prerequesite, you need to have Golang SDK installed. After that, you can install dyndns from source by invoking:

$ go install github.com/soerenschneider/dyndns@latest

Configuration

Head over to the configuration section to see more details.

Getting Started

First, you need to build a keypair. This is easily done

$ docker run ghcr.io/soerenschneider/dyndns-client -gen-keypair
{"public_key":"IyXH8z/+vRsIUEAldlGgKKFcVHoll8w2tzC6o9717m8=","private_key":"h7jrhYupN0LVPnVWqFun6sN+bWNr0B0mh7/mgRaKnhsjJcfzP/69GwhQQCV2UaAooVxUeiWXzDa3MLqj3vXubw=="}

Architecture

Client Internals

Client states and client failure scenarios and their remediation is found here.

Message format

Data sent over the wire is expected to have the following format, encoded as a JSON message.

UpdateRecordRequest reference

Field Name Description JSON Key Data Type Optional
PublicIp The resolved IP address. "public_ip" DnsRecord No
Signature The signature associated with the envelope. "signature" String No

DnsRecord reference

Field Name Description JSON Key Data Type Optional
IpV4 The IPv4 address (optional). "ipv4" String Yes
IpV6 The IPv6 address (optional). "ipv6" String Yes
Host The hostname associated with the resolved IP address. "host" String No
Timestamp The timestamp when the resolution occurred. "timestamp" Time No

Observability

Head over to the metrics to see more details.

Changelog

The changelog can be found here

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.