From 8ab05d70a8e079c845d3897802e52884e609b800 Mon Sep 17 00:00:00 2001 From: Muhammad Atif Ali Date: Wed, 20 Sep 2023 16:48:42 +0300 Subject: [PATCH] wip --- aws-regions/README.md | 22 +++++ aws-regions/main.tf | 215 ++++++++++++++++++++++++++++++++++++++++++ aws-regions/update.sh | 34 +++++++ gcp-regions/README.md | 2 +- gcp-regions/main.tf | 16 ++-- gcp-regions/update.sh | 56 +++++++++++ 6 files changed, 336 insertions(+), 9 deletions(-) create mode 100644 aws-regions/README.md create mode 100644 aws-regions/main.tf create mode 100644 aws-regions/update.sh create mode 100644 gcp-regions/update.sh diff --git a/aws-regions/README.md b/aws-regions/README.md new file mode 100644 index 0000000..6690c42 --- /dev/null +++ b/aws-regions/README.md @@ -0,0 +1,22 @@ +--- +display_name: AWS Regions +description: Add Amazon Web Services regions to your Coder template. +icon: ../.icons/aws.svg +maintainer_github: coder +verified: true +tags: [aws, regions, zones] +--- +# Amazon Web Services Regions + +This module adds Amazon Web Services regions to your Coder template. + +## How to use this module + +To use this module, add the following snippet to your template manifest: + +```hcl +module "aws_regions" { + source = "https://registry.coder.com/modules/aws-regions" + gcp_regions = ["us-west-1", "us-west-2"] # Add your desired regions here, use ["all"] for all regions +} +``` diff --git a/aws-regions/main.tf b/aws-regions/main.tf new file mode 100644 index 0000000..20b18e1 --- /dev/null +++ b/aws-regions/main.tf @@ -0,0 +1,215 @@ +terraform { + required_version = ">= 1.0" + + required_providers { + coder = { + source = "coder/coder" + version = ">= 0.11" + } + } +} + +variable "gcp_regions" { + description = "List of GCP regions to include." + type = list(string) + default = [] + validation { + condition = length(var.gcp_regions) > 0 + error_message = "At least one region must be selected." + } + validation { + condition = can(regexall("^[a-z0-9-]+$", var.gcp_regions)) + error_message = "All regions must be valid names." + } +} + +locals { + all_zones = [ + # US Central + { zone = "us-central1-a", location = "Council Bluffs, Iowa, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-central1-b", location = "Council Bluffs, Iowa, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-central1-c", location = "Council Bluffs, Iowa, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-central1-f", location = "Council Bluffs, Iowa, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + # US East + { zone = "us-east1-b", location = "Moncks Corner, S. Carolina, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-east1-c", location = "Moncks Corner, S. Carolina, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-east1-d", location = "Moncks Corner, S. Carolina, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + { zone = "us-east4-a", location = "Ashburn, Virginia, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-east4-b", location = "Ashburn, Virginia, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-east4-c", location = "Ashburn, Virginia, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + { zone = "us-east5-a", location = "Columbus, Ohio, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-east5-b", location = "Columbus, Ohio, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-east5-c", location = "Columbus, Ohio, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + # Us West + { zone = "us-west1-a", location = "The Dalles, Oregon, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-west1-b", location = "The Dalles, Oregon, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-west1-c", location = "The Dalles, Oregon, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + { zone = "us-west2-a", location = "Los Angeles, California, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-west2-b", location = "Los Angeles, California, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-west2-c", location = "Los Angeles, California, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + { zone = "us-west3-a", location = "Salt Lake City, Utah, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-west3-b", location = "Salt Lake City, Utah, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-west3-c", location = "Salt Lake City, Utah, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + { zone = "us-west4-a", location = "Las Vegas, Nevada, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-west4-b", location = "Las Vegas, Nevada, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-west4-c", location = "Las Vegas, Nevada, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + # US South + { zone = "us-south1-a", location = "Dallas, Texas, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-south1-b", location = "Dallas, Texas, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + { zone = "us-south1-c", location = "Dallas, Texas, USA", icon = "/emojis/1f1fa-1f1f8.png" }, + + # Canada + { zone = "northamerica-northeast1-a", location = "Montréal, Québec, Canada", icon = "/emojis/1f1e8-1f1f6.png" }, + { zone = "northamerica-northeast1-b", location = "Montréal, Québec, Canada", icon = "/emojis/1f1e8-1f1f6.png" }, + { zone = "northamerica-northeast1-c", location = "Montréal, Québec, Canada", icon = "/emojis/1f1e8-1f1f6.png" }, + + { zone = "northamerica-northeast2-a", location = "Toronto, Ontario, Canada", icon = "/emojis/1f1e8-1f1f6.png" }, + { zone = "northamerica-northeast2-b", location = "Toronto, Ontario, Canada", icon = "/emojis/1f1e8-1f1f6.png" }, + { zone = "northamerica-northeast2-c", location = "Toronto, Ontario, Canada", icon = "/emojis/1f1e8-1f1f6.png" }, + + # South America East (Brazil, Chile) + { zone = "southamerica-east1-a", location = "Osasco, São Paulo, Brazil", icon = "/emojis/1f1e7-1f1f7.png" }, + { zone = "southamerica-east1-b", location = "Osasco, São Paulo, Brazil", icon = "/emojis/1f1e7-1f1f7.png" }, + { zone = "southamerica-east1-c", location = "Osasco, São Paulo, Brazil", icon = "/emojis/1f1e7-1f1f7.png" }, + + { zone = "southamerica-west1-a", location = "Santiago, Chile", icon = "/emojis/1f1e8-1f1f1.png" }, + { zone = "southamerica-west1-b", location = "Santiago, Chile", icon = "/emojis/1f1e8-1f1f1.png" }, + { zone = "southamerica-west1-c", location = "Santiago, Chile", icon = "/emojis/1f1e8-1f1f1.png" }, + + # Europe North (Finland) + { zone = "europe-north1-a", location = "Hamina, Finland", icon = "/emojis/1f1e7-1f1ee.png" }, + { zone = "europe-north1-b", location = "Hamina, Finland", icon = "/emojis/1f1e7-1f1ee.png" }, + { zone = "europe-north1-c", location = "Hamina, Finland", icon = "/emojis/1f1e7-1f1ee.png" }, + + # Europe Central (Poland) + { zone = "europe-central2-a", location = "Warsaw, Poland", icon = "/emojis/1f1f5-1f1f1.png" }, + { zone = "europe-central2-b", location = "Warsaw, Poland", icon = "/emojis/1f1f5-1f1f1.png" }, + { zone = "europe-central2-c", location = "Warsaw, Poland", icon = "/emojis/1f1f5-1f1f1.png" }, + + # Europe Southwest (Spain) + { zone = "europe-southwest1-a", location = "Madrid, Spain", icon = "/emojis/1f1ea-1f1f8.png" }, + { zone = "europe-southwest1-b", location = "Madrid, Spain", icon = "/emojis/1f1ea-1f1f8.png" }, + { zone = "europe-southwest1-c", location = "Madrid, Spain", icon = "/emojis/1f1ea-1f1f8.png" }, + + # Europe West + { zone = "europe-west1-b", location = "St. Ghislain, Belgium", icon = "/emojis/1f1e7-1f1ea.png" }, + { zone = "europe-west1-c", location = "St. Ghislain, Belgium", icon = "/emojis/1f1e7-1f1ea.png" }, + { zone = "europe-west1-d", location = "St. Ghislain, Belgium", icon = "/emojis/1f1e7-1f1ea.png" }, + + { zone = "europe-west2-a", location = "London, England", icon = "/emojis/1f173–1f1ff.png" }, + { zone = "europe-west2-b", location = "London, England", icon = "/emojis/1f173–1f1ff.png" }, + { zone = "europe-west2-c", location = "London, England", icon = "/emojis/1f173–1f1ff.png" }, + + { zone = "europe-west3-b", location = "Frankfurt, Germany", icon = "/emojis/1f1e9-1f1ea.png" }, + { zone = "europe-west3-c", location = "Frankfurt, Germany", icon = "/emojis/1f1e9-1f1ea.png" }, + { zone = "europe-west3-d", location = "Frankfurt, Germany", icon = "/emojis/1f1e9-1f1ea.png" }, + + { zone = "europe-west4-a", location = "Eemshaven, Netherlands", icon = "/emojis/1f1f3-1f1f1.png" }, + { zone = "europe-west4-b", location = "Eemshaven, Netherlands", icon = "/emojis/1f1f3-1f1f1.png" }, + { zone = "europe-west4-c", location = "Eemshaven, Netherlands", icon = "/emojis/1f1f3-1f1f1.png" }, + + { zone = "europe-west6-a", location = "Zurich, Switzerland", icon = "/emojis/1f1e8-1f1ed.png" }, + { zone = "europe-west6-b", location = "Zurich, Switzerland", icon = "/emojis/1f1e8-1f1ed.png" }, + { zone = "europe-west6-c", location = "Zurich, Switzerland", icon = "/emojis/1f1e8-1f1ed.png" }, + + { zone = "europe-west8-a", location = "Milan, Italy", icon = "/emojis/1f1ee-1f1f9.png" }, + { zone = "europe-west8-b", location = "Milan, Italy", icon = "/emojis/1f1ee-1f1f9.png" }, + { zone = "europe-west8-c", location = "Milan, Italy", icon = "/emojis/1f1ee-1f1f9.png" }, + + { zone = "europe-west9-a", location = "Paris, France", icon = "/emojis/1f1eb-1f1f7.png" }, + { zone = "europe-west9-b", location = "Paris, France", icon = "/emojis/1f1eb-1f1f7.png" }, + { zone = "europe-west9-c", location = "Paris, France", icon = "/emojis/1f1eb-1f1f7.png" }, + + { zone = "europe-west10-a", location = "Berlin, Germany", icon = "/emojis/1f1e9-1f1ea.png" }, + { zone = "europe-west10-b", location = "Berlin, Germany", icon = "/emojis/1f1e9-1f1ea.png" }, + { zone = "europe-west10-c", location = "Berlin, Germany", icon = "/emojis/1f1e9-1f1ea.png" }, + + { zone = "europe-west12-a", location = "Turin, Italy", icon = "/emojis/1f1ee-1f1f9.png" }, + { zone = "europe-west12-b", location = "Turin, Italy", icon = "/emojis/1f1ee-1f1f9.png" }, + { zone = "europe-west12-c", location = "Turin, Italy", icon = "/emojis/1f1ee-1f1f9.png" }, + + # Middleeast Central (Qatar, Saudi Arabia) + { zone = "me-central1-a ", location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, + { zone = "me-central1-b ", location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, + { zone = "me-central1-c ", location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, + + { zone = "me-central2-a ", location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, + { zone = "me-central2-b ", location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, + { zone = "me-central2-c ", location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, + + # Middleeast West (Israel) + { zone = "me-west1-a", location = "Tel Aviv, Israel", icon = "/emojis/1f1ee-1f1f1.png" }, + { zone = "me-west1-b", location = "Tel Aviv, Israel", icon = "/emojis/1f1ee-1f1f1.png" }, + { zone = "me-west1-c", location = "Tel Aviv, Israel", icon = "/emojis/1f1ee-1f1f1.png" }, + + # Asia East (Taiwan, Hong Kong) + { zone = "asia-east1-a", location = "Changhua County, Taiwan", icon = "/emojis/1f1f9-1f1fc.png" }, + { zone = "asia-east1-b", location = "Changhua County, Taiwan", icon = "/emojis/1f1f9-1f1fc.png" }, + { zone = "asia-east1-c", location = "Changhua County, Taiwan", icon = "/emojis/1f1f9-1f1fc.png" }, + + { zone = "asia-east2-a", location = "Hong Kong", icon = "/emojis/1f1ed-1f1f0.png" }, + { zone = "asia-east2-b", location = "Hong Kong", icon = "/emojis/1f1ed-1f1f0.png" }, + { zone = "asia-east2-c", location = "Hong Kong", icon = "/emojis/1f1ed-1f1f0.png" }, + + # Asia Northeast (Japan, South Korea) + { zone = "asia-northeast1-a", location = "Tokyo, Japan", icon = "/emojis/1f1ef-1f1f5.png" }, + { zone = "asia-northeast1-b", location = "Tokyo, Japan", icon = "/emojis/1f1ef-1f1f5.png" }, + { zone = "asia-northeast1-c", location = "Tokyo, Japan", icon = "/emojis/1f1ef-1f1f5.png" }, + { zone = "asia-northeast2-a", location = "Osaka, Japan", icon = "/emojis/1f1ef-1f1f5.png" }, + { zone = "asia-northeast2-b", location = "Osaka, Japan", icon = "/emojis/1f1ef-1f1f5.png" }, + { zone = "asia-northeast2-c", location = "Osaka, Japan", icon = "/emojis/1f1ef-1f1f5.png" }, + { zone = "asia-northeast3-a", location = "Seoul, South Korea", icon = "/emojis/1f1f0-1f1f7.png" }, + { zone = "asia-northeast3-b", location = "Seoul, South Korea", icon = "/emojis/1f1f0-1f1f7.png" }, + { zone = "asia-northeast3-c", location = "Seoul, South Korea", icon = "/emojis/1f1f0-1f1f7.png" }, + + # Asia South (India) + { zone = "asia-south1-a", location = "Mumbai, India", icon = "/emojis/1f1ee-1f1f3.png" }, + { zone = "asia-south1-b", location = "Mumbai, India", icon = "/emojis/1f1ee-1f1f3.png" }, + { zone = "asia-south1-c", location = "Mumbai, India", icon = "/emojis/1f1ee-1f1f3.png" }, + { zone = "asia-south2-a", location = "Delhi, India", icon = "/emojis/1f1ee-1f1f3.png" }, + { zone = "asia-south2-b", location = "Delhi, India", icon = "/emojis/1f1ee-1f1f3.png" }, + { zone = "asia-south2-c", location = "Delhi, India", icon = "/emojis/1f1ee-1f1f3.png" }, + + # Asia Southeast (Singapore, Indonesia) + { zone = "asia-southeast1-a", location = "Jurong West, Singapore", icon = "/emojis/1f1f8-1f1ec.png" }, + { zone = "asia-southeast1-b", location = "Jurong West, Singapore", icon = "/emojis/1f1f8-1f1ec.png" }, + { zone = "asia-southeast1-c", location = "Jurong West, Singapore", icon = "/emojis/1f1f8-1f1ec.png" }, + { zone = "asia-southeast2-a", location = "Jakarta, Indonesia", icon = "/emojis/1f1ee-1f1e9.png" }, + { zone = "asia-southeast2-b", location = "Jakarta, Indonesia", icon = "/emojis/1f1ee-1f1e9.png" }, + { zone = "asia-southeast2-c", location = "Jakarta, Indonesia", icon = "/emojis/1f1ee-1f1e9.png" }, + + # Australia (Sydney, Melbourne) + { zone = "australia-southeast1-a", location = "Sydney, Australia", icon = "/emojis/1f1e6-1f1fa.png" }, + { zone = "australia-southeast1-b", location = "Sydney, Australia", icon = "/emojis/1f1e6-1f1fa.png" }, + { zone = "australia-southeast1-c", location = "Sydney, Australia", icon = "/emojis/1f1e6-1f1fa.png" }, + { zone = "australia-southeast2-a", location = "Melbourne, Australia", icon = "/emojis/1f1e6-1f1fa.png" }, + { zone = "australia-southeast2-b", location = "Melbourne, Australia", icon = "/emojis/1f1e6-1f1fa.png" }, + { zone = "australia-southeast2-c", location = "Melbourne, Australia", icon = "/emojis/1f1e6-1f1fa.png" }, + ] +} + +data "coder_parameter" "aws_zones" { + type = "list(string)" + name = "aws_zones" + display_name = "AWS Zones" + icon = "/icon/aws.svg" + mutable = false + + dynamic "option" { + for_each = [for z in local.all_zones : z if contains(var.aws_regions, substr(z.zone, 0, index(z.zone, "-")))] + content { + icon = option.value.icon + name = option.value.location + description = option.value.zone + value = option.value.zone + } + } +} diff --git a/aws-regions/update.sh b/aws-regions/update.sh new file mode 100644 index 0000000..9701495 --- /dev/null +++ b/aws-regions/update.sh @@ -0,0 +1,34 @@ +#!/bin/bash + +# Function to fetch AWS zones based on regions in `gcp_regions` variable in Terraform +fetch_aws_zones() { + for region in $(awk -F\" '/var\.aws_regions/{flag=1; next} flag && /],/{flag=0} flag' your_terraform_file.tf); do + aws ec2 describe-availability-zones --region "$region" --query 'AvailabilityZones[].ZoneName' --output text | tr '\t' '\n' | while read -r zone; do + location="AWS $region" # Adjust this as needed + icon="/emojis/1f1fa-1f1f8.png" # Adjust this as needed + + # Format the Terraform entry for this zone + echo " { zone = \"${zone}\", location = \"${location}\", icon = \"${icon}\" }," + done + done +} + +# Temporary file to store the updated Terraform content +temp_file=$(mktemp) + +# Print everything before the AWS zones list +awk '/locals {/,/aws_zones = \[/{print; exit}' your_terraform_file.tf > "$temp_file" + +# Fetch and format the AWS zones, appending them to the temporary file +echo " aws_zones = [" >> "$temp_file" +fetch_aws_zones >> "$temp_file" +echo " ]" >> "$temp_file" + +# Print everything after the AWS zones list +awk '/\],/{flag=1; next} flag' your_terraform_file.tf >> "$temp_file" + +# Replace the original Terraform file with the updated one +mv "$temp_file" your_terraform_file.tf + +# Clean up +rm -f "$temp_file" diff --git a/gcp-regions/README.md b/gcp-regions/README.md index 46941b9..292efc7 100644 --- a/gcp-regions/README.md +++ b/gcp-regions/README.md @@ -18,6 +18,6 @@ To use this module, add the following snippet to your template manifest: module "gcp_regions" { source = "https://registry.coder.com/modules/gcp-regions" gcp_regions = ["us-west1", "us-west2", "us-west3"] # Add your desired regions here, use ["all"] for all regions - gpu_only = true + gpu_only = true } ``` diff --git a/gcp-regions/main.tf b/gcp-regions/main.tf index 0a0b451..cb0ae02 100644 --- a/gcp-regions/main.tf +++ b/gcp-regions/main.tf @@ -143,13 +143,13 @@ locals { { zone = "europe-west12-c", has_gpu = false, location = "Turin, Italy", icon = "/emojis/1f1ee-1f1f9.png" }, # Middleeast Central (Qatar, Saudi Arabia) - { zone = "me-central1-a ", has_gpu = false, location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, - { zone = "me-central1-b ", has_gpu = false, location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, - { zone = "me-central1-c ", has_gpu = false, location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, + { zone = "me-central1-a", has_gpu = false, location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, + { zone = "me-central1-b", has_gpu = false, location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, + { zone = "me-central1-c", has_gpu = false, location = "Doha, Qatar", icon = "/emojis/1f1f6-1f1e6.png" }, - { zone = "me-central2-a ", has_gpu = false, location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, - { zone = "me-central2-b ", has_gpu = false, location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, - { zone = "me-central2-c ", has_gpu = false, location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, + { zone = "me-central2-a", has_gpu = false, location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, + { zone = "me-central2-b", has_gpu = false, location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, + { zone = "me-central2-c", has_gpu = false, location = "Dammam, Saudi Arabia", icon = "/emojis/1f1f8-1f1e6.png" }, # Middleeast West (Israel) { zone = "me-west1-a", has_gpu = false, location = "Tel Aviv, Israel", icon = "/emojis/1f1ee-1f1f1.png" }, @@ -202,11 +202,11 @@ locals { ] } -data "coder_parameter" "gcp-zones" { +data "coder_parameter" "gcp_zones" { type = "list(string)" name = "gcp_zones" display_name = "GCP Zones" - icon = "/icon/gcp/svg" + icon = "/icon/gcp.svg" mutable = true dynamic "option" { diff --git a/gcp-regions/update.sh b/gcp-regions/update.sh new file mode 100644 index 0000000..31d4802 --- /dev/null +++ b/gcp-regions/update.sh @@ -0,0 +1,56 @@ +#!/bin/bash + +declare -A zone_to_location=( + ["us-central1"]="Council Bluffs, Iowa, USA" + ["us-east1"]="Moncks Corner, S. Carolina, USA" +) + +declare -A zone_to_emoji=( + ["us-central1"]="/emojis/1f1fa-1f1f8.png" + ["us-east1"]="/emojis/1f1fa-1f1f8.png" + # ... Add other mappings here +) + +# Function to check if a zone has a GPU +has_gpu() { + local zone=$1 + gcloud compute machine-types list --filter="zone:($zone) AND guestCpus:>=0" --format="csv[no-heading](name)" | grep -q "gpu" +} + +# Function to fetch zones from GCP and format them for Terraform +fetch_zones() { + gcloud compute zones list --format="csv[no-heading](name,region)" | while IFS=',' read -r zone region; do + # Check if the zone has a GPU + gpu_status=false + if has_gpu "$zone"; then + gpu_status=true + fi + + # Fetch location and emoji from the mapping + location=${zone_to_location[${zone%-*}]:-"TODO: Add Location"} + emoji=${zone_to_emoji[${zone%-*}]:-"/emojis/TODO: Add Emoji"} + + # Format the Terraform entry for this zone + echo " { zone = \"${zone}\", has_gpu = ${gpu_status}, location = \"${location}\", icon = \"${emoji}\" }," + done +} + +# Temporary file to store the updated Terraform content +temp_file=$(mktemp) + +# Print everything before the zone list +awk '/locals {/,/all_zones = \[/{print; exit}' your_terraform_file.tf > "$temp_file" + +# Fetch and format the zones, appending them to the temporary file +echo " all_zones = [" >> "$temp_file" +fetch_zones >> "$temp_file" +echo " ]" >> "$temp_file" + +# Print everything after the zone list +awk '/\],/{flag=1; next} flag' your_terraform_file.tf >> "$temp_file" + +# Replace the original Terraform file with the updated one +mv "$temp_file" your_terraform_file.tf + +# Clean up +rm -f "$temp_file"