Skip to content
/ dawg Public

Set up a Wireguard VPN on Digital Ocean with one command

Notifications You must be signed in to change notification settings

boosh/dawg

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

40 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Dawg - Wireguard on Digital Ocean

With a single command, this repo will create a Digital Ocean droplet (server) and configure it as Wireguard server, optionally importing previously created client configs. This means you can destroy and recreate the server and it will come back up without needing to reconfigure your clients. E.g. you could do this on a cron to shut the server down when you're usually asleep and bring it up before you wake up to save money.

Features

  • Create a Digital Ocean server configured with Wireguard
  • Optionally import existing client configs when the server is created
  • Commands to create new clients and download their configs or import existing configs
  • Display downloaded configs as QR codes to easily configure mobile devices (requires qrencode)
  • Optionally snapshot the server and restore from a snapshot to speed up reprovisioning

Quickstart

  1. Download Terraform or asdf & qrencode (with e.g. brew install asdf qrencode if on a Mac)
  2. Sign up for a Digital Ocean account. Get an API key and write it to ~/.digitalocean/token. Create an SSH key in Digital Ocean.
  3. Sign up with ydns.io. Get an API key and write it to ~/.ydns in the form <username>:<password/key>
  4. Clone this repo locally
  5. Edit terraform/terraform.tfvars:
    1. Add your Digital Ocean SSH key ID (you can find this with make ssh-list)
    2. Set ydns_url to whatever your YDNS URL is
    3. Set clients to {}
  6. Run make deploy

This will launch a Digital Ocean droplet, apply updates, enable automated security updates, enable the UFW firewall and configure Wireguard. If clients in terraform/terraform.tfvars is not empty, those clients will be automatically imported into the Wireguard config.

The server's private keys are downloaded to ~/.dawg-server-keys. Don't share this with anyone. If this is deleted you'll need to reconfigure all your clients if you destroy and recreate the server.

Create a new client

Run make new-client name=<name> where <name> is how you'd like to identify this client (e.g. laptop, phone, etc). This is only used in strings and can be anything.

The config will be downloaded to ~/Downloads/wg-<name>.conf. You can then import it into your desktop Wireguard client (make sure to rename the file to wg0.conf on linux first), or create a QR code with make qr name=<name>.

Make sure to copy the relevant details into terraform.tfvars. For the public key, use the value under the Interface section of the downloaded config file (the line starts # Note: PublicKey = ???).

Add existing clients

Run make add-client and enter the details the help message tells you to.

Destroy and recreate

If you want to destroy the server, just run make destroy. You can recreate it again with make deploy.

This uses Terraform - if the terraform.tfstate file is deleted, make destroy won't work. But this only creates a single Digital Ocean droplet, so in that case just log into your account and manually delete the droplet.

Snapshots

To speed up reprovisioning you can take a snapshot once the server is configured. Just run make snapshot. This will create a snapshot called dawg.

To restore from a snapshot, set use_snapshot = true in your terraform.tfvars file. The next time the server is deployed it will be from this snapshot.

Note: No command is provided to delete any snapshots. You'll need to do that manually through the DO console/CLI

Other commands

Run make for a list of commands that can be run. There are commands to e.g. SSH to the server, check the status, etc.

About

Set up a Wireguard VPN on Digital Ocean with one command

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published