From 5f2b695baf01e6f0b6b35751cea28c02b91c7ec1 Mon Sep 17 00:00:00 2001 From: Ole Langbehn <ole.langbehn@inoio.de> Date: Fri, 12 Jul 2024 21:55:42 +0200 Subject: [PATCH] NOISSUE refactor default region code, unify file structure --- .gitlab-ci.yml | 2 +- terraform/common/init.tf | 4 ++-- terraform/common/vars.tf | 3 +++ terraform/environments/deployment.tf | 2 +- terraform/environments/init.tf | 4 ++-- terraform/environments/scripts/get-api-domain.sh | 8 -------- terraform/environments/scripts/get-output.sh | 10 ++++++++++ terraform/environments/vars.tf | 2 ++ 8 files changed, 21 insertions(+), 14 deletions(-) create mode 100644 terraform/common/vars.tf delete mode 100755 terraform/environments/scripts/get-api-domain.sh create mode 100755 terraform/environments/scripts/get-output.sh diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 9a786e6..83a11c3 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -29,7 +29,7 @@ variables: script: - export GOOGLE_APPLICATION_CREDENTIALS=${GOOGLE_CLOUD_SERVICE_ACCOUNT} - terraform/environments/scripts/create-or-update-env.sh $ENVIRONMENT_ID $CI_COMMIT_SHA - - echo "$(terraform/environments/scripts/get-api-domain.sh)" > $API_DOMAIN_PATH + - echo "$(terraform/environments/scripts/get-output.sh api_domain)" > $API_DOMAIN_PATH resource_group: $ENVIRONMENT_ID # never execute terraform in parallel on the same environment interruptible: false diff --git a/terraform/common/init.tf b/terraform/common/init.tf index 93d6ec7..817551e 100644 --- a/terraform/common/init.tf +++ b/terraform/common/init.tf @@ -15,9 +15,9 @@ data "terraform_remote_state" "holi_infra_state" { # provider google including beta features provider "google" { - region = "europe-north1" + region = local.default_region } provider "google-beta" { - region = "europe-north1" + region = local.default_region } diff --git a/terraform/common/vars.tf b/terraform/common/vars.tf new file mode 100644 index 0000000..1c12ce4 --- /dev/null +++ b/terraform/common/vars.tf @@ -0,0 +1,3 @@ +locals { + default_region = data.terraform_remote_state.holi_infra_state.outputs.default_region +} diff --git a/terraform/environments/deployment.tf b/terraform/environments/deployment.tf index ae1416c..db00dbe 100644 --- a/terraform/environments/deployment.tf +++ b/terraform/environments/deployment.tf @@ -33,7 +33,7 @@ variable "image_tag" { resource "google_cloud_run_service" "geo_api" { project = data.terraform_remote_state.holi_infra_state.outputs.shared_project_id name = random_id.main.hex - location = "europe-north1" # finland, low CO2 emissions + location = local.default_region # finland, low CO2 emissions # https://github.com/hashicorp/terraform-provider-google/issues/5898 autogenerate_revision_name = true diff --git a/terraform/environments/init.tf b/terraform/environments/init.tf index 3e00eea..bfce857 100644 --- a/terraform/environments/init.tf +++ b/terraform/environments/init.tf @@ -23,9 +23,9 @@ data "terraform_remote_state" "holi_geo_api_common_state" { # provider google including beta features provider "google" { - region = "europe-north1" + region = local.default_region } provider "google-beta" { - region = "europe-north1" + region = local.default_region } diff --git a/terraform/environments/scripts/get-api-domain.sh b/terraform/environments/scripts/get-api-domain.sh deleted file mode 100755 index 63451fc..0000000 --- a/terraform/environments/scripts/get-api-domain.sh +++ /dev/null @@ -1,8 +0,0 @@ -#!/usr/bin/env sh - -# exit when any command fails -set -ex - -cd terraform/environments > /dev/null - -terraform output -raw api_domain diff --git a/terraform/environments/scripts/get-output.sh b/terraform/environments/scripts/get-output.sh new file mode 100755 index 0000000..2e1d9b6 --- /dev/null +++ b/terraform/environments/scripts/get-output.sh @@ -0,0 +1,10 @@ +#!/usr/bin/env sh + +# exit when any command fails +set -ex + +: "${1?"Usage: $0 OUTPUT_NAME"}" + +cd "$(dirname "$0")"/.. > /dev/null + +terraform output -raw "$1" diff --git a/terraform/environments/vars.tf b/terraform/environments/vars.tf index 750dfce..f7e2e18 100644 --- a/terraform/environments/vars.tf +++ b/terraform/environments/vars.tf @@ -5,4 +5,6 @@ locals { # the dns name can be at most 64 chars in total dns_name = "${trimsuffix(substr(local.environment, 0, 34), ".-")}.${data.terraform_remote_state.holi_geo_api_common_state.outputs.dns_geo_api_domain}" + + default_region = data.terraform_remote_state.holi_infra_state.outputs.default_region } -- GitLab