mirror of https://github.com/coder/coder.git
211 lines
4.5 KiB
HCL
211 lines
4.5 KiB
HCL
terraform {
|
|
required_providers {
|
|
coder = {
|
|
source = "coder/coder"
|
|
}
|
|
aws = {
|
|
source = "hashicorp/aws"
|
|
}
|
|
}
|
|
}
|
|
|
|
# Last updated 2023-03-14
|
|
# aws ec2 describe-regions | jq -r '[.Regions[].RegionName] | sort'
|
|
data "coder_parameter" "region" {
|
|
name = "region"
|
|
display_name = "Region"
|
|
description = "The region to deploy the workspace in."
|
|
default = "us-east-1"
|
|
mutable = false
|
|
option {
|
|
name = "Asia Pacific (Tokyo)"
|
|
value = "ap-northeast-1"
|
|
icon = "/emojis/1f1ef-1f1f5.png"
|
|
}
|
|
option {
|
|
name = "Asia Pacific (Seoul)"
|
|
value = "ap-northeast-2"
|
|
icon = "/emojis/1f1f0-1f1f7.png"
|
|
}
|
|
option {
|
|
name = "Asia Pacific (Osaka-Local)"
|
|
value = "ap-northeast-3"
|
|
icon = "/emojis/1f1f0-1f1f7.png"
|
|
}
|
|
option {
|
|
name = "Asia Pacific (Mumbai)"
|
|
value = "ap-south-1"
|
|
icon = "/emojis/1f1f0-1f1f7.png"
|
|
}
|
|
option {
|
|
name = "Asia Pacific (Singapore)"
|
|
value = "ap-southeast-1"
|
|
icon = "/emojis/1f1f0-1f1f7.png"
|
|
}
|
|
option {
|
|
name = "Asia Pacific (Sydney)"
|
|
value = "ap-southeast-2"
|
|
icon = "/emojis/1f1f0-1f1f7.png"
|
|
}
|
|
option {
|
|
name = "Canada (Central)"
|
|
value = "ca-central-1"
|
|
icon = "/emojis/1f1e8-1f1e6.png"
|
|
}
|
|
option {
|
|
name = "EU (Frankfurt)"
|
|
value = "eu-central-1"
|
|
icon = "/emojis/1f1ea-1f1fa.png"
|
|
}
|
|
option {
|
|
name = "EU (Stockholm)"
|
|
value = "eu-north-1"
|
|
icon = "/emojis/1f1ea-1f1fa.png"
|
|
}
|
|
option {
|
|
name = "EU (Ireland)"
|
|
value = "eu-west-1"
|
|
icon = "/emojis/1f1ea-1f1fa.png"
|
|
}
|
|
option {
|
|
name = "EU (London)"
|
|
value = "eu-west-2"
|
|
icon = "/emojis/1f1ea-1f1fa.png"
|
|
}
|
|
option {
|
|
name = "EU (Paris)"
|
|
value = "eu-west-3"
|
|
icon = "/emojis/1f1ea-1f1fa.png"
|
|
}
|
|
option {
|
|
name = "South America (São Paulo)"
|
|
value = "sa-east-1"
|
|
icon = "/emojis/1f1e7-1f1f7.png"
|
|
}
|
|
option {
|
|
name = "US East (N. Virginia)"
|
|
value = "us-east-1"
|
|
icon = "/emojis/1f1fa-1f1f8.png"
|
|
}
|
|
option {
|
|
name = "US East (Ohio)"
|
|
value = "us-east-2"
|
|
icon = "/emojis/1f1fa-1f1f8.png"
|
|
}
|
|
option {
|
|
name = "US West (N. California)"
|
|
value = "us-west-1"
|
|
icon = "/emojis/1f1fa-1f1f8.png"
|
|
}
|
|
option {
|
|
name = "US West (Oregon)"
|
|
value = "us-west-2"
|
|
icon = "/emojis/1f1fa-1f1f8.png"
|
|
}
|
|
}
|
|
|
|
data "coder_parameter" "instance_type" {
|
|
name = "instance_type"
|
|
display_name = "Instance type"
|
|
description = "What instance type should your workspace use?"
|
|
default = "t3.micro"
|
|
mutable = false
|
|
option {
|
|
name = "2 vCPU, 1 GiB RAM"
|
|
value = "t3.micro"
|
|
}
|
|
option {
|
|
name = "2 vCPU, 2 GiB RAM"
|
|
value = "t3.small"
|
|
}
|
|
option {
|
|
name = "2 vCPU, 4 GiB RAM"
|
|
value = "t3.medium"
|
|
}
|
|
option {
|
|
name = "2 vCPU, 8 GiB RAM"
|
|
value = "t3.large"
|
|
}
|
|
option {
|
|
name = "4 vCPU, 16 GiB RAM"
|
|
value = "t3.xlarge"
|
|
}
|
|
option {
|
|
name = "8 vCPU, 32 GiB RAM"
|
|
value = "t3.2xlarge"
|
|
}
|
|
}
|
|
|
|
provider "aws" {
|
|
region = data.coder_parameter.region.value
|
|
}
|
|
|
|
data "coder_workspace" "me" {
|
|
}
|
|
|
|
data "aws_ami" "windows" {
|
|
most_recent = true
|
|
owners = ["amazon"]
|
|
|
|
filter {
|
|
name = "name"
|
|
values = ["Windows_Server-2019-English-Full-Base-*"]
|
|
}
|
|
}
|
|
|
|
resource "coder_agent" "main" {
|
|
arch = "amd64"
|
|
auth = "aws-instance-identity"
|
|
os = "windows"
|
|
}
|
|
|
|
locals {
|
|
|
|
# User data is used to stop/start AWS instances. See:
|
|
# https://github.com/hashicorp/terraform-provider-aws/issues/22
|
|
|
|
user_data_start = <<EOT
|
|
<powershell>
|
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
|
|
${coder_agent.main.init_script}
|
|
</powershell>
|
|
<persist>true</persist>
|
|
EOT
|
|
|
|
user_data_end = <<EOT
|
|
<powershell>
|
|
shutdown /s
|
|
</powershell>
|
|
<persist>true</persist>
|
|
EOT
|
|
}
|
|
|
|
resource "aws_instance" "dev" {
|
|
ami = data.aws_ami.windows.id
|
|
availability_zone = "${data.coder_parameter.region.value}a"
|
|
instance_type = data.coder_parameter.instance_type.value
|
|
|
|
user_data = data.coder_workspace.me.transition == "start" ? local.user_data_start : local.user_data_end
|
|
tags = {
|
|
Name = "coder-${data.coder_workspace.me.owner}-${data.coder_workspace.me.name}"
|
|
# Required if you are using our example policy, see template README
|
|
Coder_Provisioned = "true"
|
|
}
|
|
}
|
|
|
|
resource "coder_metadata" "workspace_info" {
|
|
resource_id = aws_instance.dev.id
|
|
item {
|
|
key = "region"
|
|
value = data.coder_parameter.region.value
|
|
}
|
|
item {
|
|
key = "instance type"
|
|
value = aws_instance.dev.instance_type
|
|
}
|
|
item {
|
|
key = "disk"
|
|
value = "${aws_instance.dev.root_block_device[0].volume_size} GiB"
|
|
}
|
|
}
|