Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add deployment configuration for Stun server #87

Merged
merged 15 commits into from
Sep 27, 2024
Merged
Show file tree
Hide file tree
Changes from 10 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
40 changes: 40 additions & 0 deletions stun_server/main.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
terraform {
klejejs marked this conversation as resolved.
Show resolved Hide resolved
cloud {
organization = "home_assistant"

workspaces {
name = "stun_server"
}
}
}

provider "aws" {
region = "us-east-1"
}

module "us_east_1" {
source = "./region"
klejejs marked this conversation as resolved.
Show resolved Hide resolved

region = "us-east-1"
domain_name = var.domain_name
subdomain = "stun"
image_tag = var.image_tag
}

module "eu_central_1" {
source = "./region"

region = "eu-central-1"
domain_name = var.domain_name
subdomain = "stun"
image_tag = var.image_tag
}

module "ap_southeast_1" {
source = "./region"

region = "ap-southeast-1"
domain_name = var.domain_name
subdomain = "stun"
klejejs marked this conversation as resolved.
Show resolved Hide resolved
image_tag = var.image_tag
}
14 changes: 14 additions & 0 deletions stun_server/outputs.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
output "stun_server_ip-us_east_1" {
klejejs marked this conversation as resolved.
Show resolved Hide resolved
description = "The public IP address of the stun server in us-east-1"
value = module.us_east_1.stun_server_ip
}

output "stun_server_ip-eu_central_1" {
description = "The public IP address of the stun server in eu-central-1"
value = module.eu_central_1.stun_server_ip
}

output "stun_server_ip-ap_southeast_1" {
description = "The public IP address of the stun server in ap-southeast-1"
value = module.ap_southeast_1.stun_server_ip
}
11 changes: 11 additions & 0 deletions stun_server/region/dns.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
data "cloudflare_zone" "dns_zone" {
name = var.domain_name
}

resource "cloudflare_record" "instance_dns" {
zone_id = data.cloudflare_zone.dns_zone.id
name = join("-", [var.subdomain, data.aws_region.current.name])
content = data.aws_network_interface.stun_server_interface.association[0].public_ip
klejejs marked this conversation as resolved.
Show resolved Hide resolved
type = "A"
proxied = true
}
34 changes: 34 additions & 0 deletions stun_server/region/ecs.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
resource "aws_ecs_service" "stun-server" {
ludeeus marked this conversation as resolved.
Show resolved Hide resolved
name = local.service_name
cluster = data.tfe_outputs.infrastructure.values[data.aws_region.current.name].ecs_cluster
task_definition = module.stun_server.task_definition
desired_count = 1
deployment_minimum_healthy_percent = 100
deployment_maximum_percent = 200
health_check_grace_period_seconds = 90
launch_type = local.launch_type

# Required to fetch the public IP address of the ECS service
enable_ecs_managed_tags = true
wait_for_steady_state = true

network_configuration {
assign_public_ip = true
security_groups = [aws_security_group.stun_sg.id]
subnets = [
data.tfe_outputs.infrastructure.values[data.aws_region.current.name].public_subnets[0],
data.tfe_outputs.infrastructure.values[data.aws_region.current.name].public_subnets[1]
]
}

tags = {
region = data.aws_region.current.name
}
}

data "aws_network_interface" "stun_server_interface" {
filter {
name = "tag:aws:ecs:serviceName"
values = [aws_ecs_service.stun-server.name]
}
}
42 changes: 42 additions & 0 deletions stun_server/region/module.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
locals {
klejejs marked this conversation as resolved.
Show resolved Hide resolved
service_name = "stun-server"
launch_type = "FARGATE"
klejejs marked this conversation as resolved.
Show resolved Hide resolved
}

provider "aws" {
region = var.region
}

data "tfe_outputs" "infrastructure" {
organization = "home_assistant"
workspace = "infrastructure"
}

data "aws_region" "current" {}

module "stun_server" {
source = "../../.modules/service"

service_name = local.service_name
container_image = "ghcr.io/home-assistant/stun"
container_version = var.image_tag
region = data.aws_region.current.name
ecs_cpu = 2048
ecs_memory = 4096
klejejs marked this conversation as resolved.
Show resolved Hide resolved
container_definitions = {
portMappings = [
{
containerPort = 3478
hostPort = 3478
protocol = "tcp"
},
{
containerPort = 3478
hostPort = 3478
protocol = "udp"
}
],
}
webservice = true
rolling_updates = true
klejejs marked this conversation as resolved.
Show resolved Hide resolved
}
30 changes: 30 additions & 0 deletions stun_server/region/network.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
resource "aws_security_group" "stun_sg" {
vpc_id = data.tfe_outputs.infrastructure.values[data.aws_region.current.name].network_id

egress {
from_port = 0
to_port = 0
protocol = "-1"
cidr_blocks = ["0.0.0.0/0"]
}

ingress {
description = "Allow STUN traffic TCP"
from_port = 3478
to_port = 3478
protocol = "tcp"
cidr_blocks = ["0.0.0.0/0"]
}

ingress {
description = "Allow STUN traffic UDF"
from_port = 3478
to_port = 3478
protocol = "udp"
cidr_blocks = ["0.0.0.0/0"]
}

tags = {
region = data.aws_region.current.name
}
}
4 changes: 4 additions & 0 deletions stun_server/region/outputs.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
output "stun_server_ip" {
description = "The public IP address of the stun server"
value = data.aws_network_interface.stun_server_interface.association[0].public_ip
}
18 changes: 18 additions & 0 deletions stun_server/region/variables.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
variable "region" {
description = "The region to deploy the STUN server to"
type = string
}

variable "domain_name" {
description = "The base domain name"
type = string
}

variable "subdomain" {
description = "The subdomain to use for the STUN server"
type = string
}
variable "image_tag" {
description = "Version of the Stun server to deploy"
type = string
}
19 changes: 19 additions & 0 deletions stun_server/region/versions.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
terraform {

required_providers {
aws = {
source = "hashicorp/aws"
version = "~> 4.0"
}

tfe = {
source = "hashicorp/tfe"
version = "~> 0.58.0"
}

cloudflare = {
source = "cloudflare/cloudflare"
version = "~> 4.0"
}
}
}
9 changes: 9 additions & 0 deletions stun_server/variables.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
variable "domain_name" {
description = "The base domain name"
type = string
}

variable "image_tag" {
description = "Version of the Stun server to deploy"
type = string
}
10 changes: 10 additions & 0 deletions stun_server/versions.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
terraform {
required_version = "= 1.9.6"

required_providers {
aws = {
source = "hashicorp/aws"
version = "~> 4.0"
}
}
}