You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Dan Buch
c1a57ba5d1
Many updates! terraform 0.14 formatting, nginx compat, error handling
3 years ago
.github/ workflows
Modernizing many things
4 years ago
.gitignore
Modernizing many things
4 years ago
LICENSE
Initial commit
4 years ago
Makefile
Now with less trailing space
4 years ago
README.md
Run terraform 0.13upgrade
4 years ago
main.tf
Many updates! terraform 0.14 formatting, nginx compat, error handling
3 years ago
nginx-sites-default.conf.tpl
Use cert bits from home directory
4 years ago
spoke-app-provision
Many updates! terraform 0.14 formatting, nginx compat, error handling
3 years ago
spoke-app-provision-wrapper
Many updates! terraform 0.14 formatting, nginx compat, error handling
3 years ago
spoke-app-run
Many updates! terraform 0.14 formatting, nginx compat, error handling
3 years ago
spoke.service
Porting over most of the things
4 years ago
versions.tf
Run terraform 0.13upgrade
4 years ago
tf_digitalocean_spoke
This is a terraform module that provisions a
Spoke instance at DigitalOcean.
Terraform versions
This module is compatible with Terraform version 0.13+
.
Usage
A typical production deployment that uses PASSPORT_STRATEGY=auth0
,
DEFAULT_SERVICE=twilio
, and a direct SMTP connection for email might look
like this:
module "digitalocean_spoke" {
source = "github.com/meatballhat/tf_digitalocean_spoke"
server_name = "spoke.example.org"
base_url = "https://spoke.example.org"
resource_prefix = "example-spoke-"
region = "nyc1"
ssh_keys = [ file ( "path/to/id_rsa.pub" )]
cert_private_key = file ( "path/to/cert.key" )
cert_certificate = file ( "path/to/cert.crt" )
env = {
AUTH0_CLIENT_ID = "8570285697946a0cc03f8049b9309d7e"
AUTH0_CLIENT_SECRET = "1194435d32479ab99ed51a0a5f244cd5"
AUTH0_DOMAIN = "example.auth0.com"
EMAIL_FROM = "admin@example.org"
EMAIL_HOST = "mail.example.org"
EMAIL_HOST_PASSWORD = "b5090d80c82e608a1acd2f59ac366083"
EMAIL_HOST_PORT = "123"
EMAIL_HOST_SECURE = "true"
EMAIL_HOST_USER = "admin"
DEFAULT_SERVICE = "twilio" ,
PASSPORT_STRATEGY = "auth0" ,
PHONE_NUMBER_COUNTRY = "US" ,
SUPPRESS_SELF_INVITE = "true" ,
TWILIO_API_KEY = "6babd5fa8226c66406edcce7390675b3"
TWILIO_APPLICATION_SID = "be2d8e141ab5b45287d06ee649c48b82"
TWILIO_AUTH_TOKEN = "17381f485e35f89608b88b45f5a00873"
TWILIO_MESSAGE_SERVICE_SID = "b2b551ca3228aa8d130b5739e1a20cdd"
TWILIO_STATUS_CALLBACK_URL = "https://callback.example.org"
}
}
Requirements
Name
Version
terraform
>= 0.13
digitalocean
>= 1.22
Providers
Name
Version
digitalocean
>= 1.22
null
n/a
random
n/a
Inputs
Name
Description
Type
Default
Required
base_url
Fully qualified https URL of the app
string
n/a
yes
cert_certificate
Certificate with leaf and intermediates to pass to nginx
string
n/a
yes
cert_private_key
Certificate key to pass to nginx
string
n/a
yes
droplet_image
Image to use when provisioning app droplet
string
"ubuntu-20-04-x64"
no
droplet_size
Size value passed when provisioning app droplet
string
"s-1vcpu-1gb"
no
env
Arbitrary additional environment variables passed at build time and run time
map(string)
{}
no
node_env
Value defined at build time and run time as NODE_ENV
string
"production"
no
node_options
Value defined at build time and run time as NODE_OPTIONS
string
"--max_old_space_size=8192"
no
port
TCP port used to communicate between droplet and nginx
string
"3000"
no
region
Region in which all resources will be provisioned
string
"nyc1"
no
resource_prefix
Prefix prepended to resource names
string
"spoke-"
no
server_name
Server name used in nginx config
string
n/a
yes
spoke_version
Git ref of MoveOnOrg/Spoke to deploy
string
"v8.0"
no
ssh_keys
List of ssh public keys to pass to droplet provisioning
list(string)
n/a
yes
Outputs
Name
Description
droplet_ipv4_address
ipv4 address of the droplet
droplet_urn
urn of the droplet suitable for adding to project resources
floating_ip_address
floating IP address assigned to the droplet suitable for creating a DNS A record
floating_ip_urn
urn of the floating IP address assigned to the droplet suitable for adding to project resources