Skip to content

Commit

Permalink
Domain migration prep and add Terrafile
Browse files Browse the repository at this point in the history
Prepare the configs for the migration
Add Terrafile support to DNS management
  • Loading branch information
smneal committed Aug 30, 2023
1 parent 3c8c906 commit 131b650
Show file tree
Hide file tree
Showing 18 changed files with 72 additions and 13 deletions.
12 changes: 6 additions & 6 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ dev:
.PHONY: development_aks ## For AKS
development_aks: aks ## Specify development aks environment
$(eval include global_config/development_aks.sh)

.PHONY: test
test:
$(eval DEPLOY_ENV=test)
Expand Down Expand Up @@ -240,15 +240,15 @@ set-key-vault-names:
$(eval KEY_VAULT_APPLICATION_NAME=$(AZURE_RESOURCE_PREFIX)-$(SERVICE_SHORT)-$(CONFIG_SHORT)-app-kv)
$(eval KEY_VAULT_INFRASTRUCTURE_NAME=$(AZURE_RESOURCE_PREFIX)-$(SERVICE_SHORT)-$(CONFIG_SHORT)-inf-kv)


domain-azure-resources: set-azure-account set-azure-template-tag set-azure-resource-group-tags ## deploy container to store terraform state for all dns resources -run validate first
$(if $(AUTO_APPROVE), , $(error can only run with AUTO_APPROVE))
az deployment sub create -l "UK South" --template-uri "https://raw.githubusercontent.com/DFE-Digital/tra-shared-services/${ARM_TEMPLATE_TAG}/azure/resourcedeploy.json" \
--name "${DNS_ZONE}domains-$(shell date +%Y%m%d%H%M%S)" --parameters "resourceGroupName=${RESOURCE_NAME_PREFIX}-${DNS_ZONE}domains-rg" 'tags=${RG_TAGS}' \
"tfStorageAccountName=${RESOURCE_NAME_PREFIX}${DNS_ZONE}domainstf" "tfStorageContainerName=${DNS_ZONE}domains-tf" "keyVaultName=${RESOURCE_NAME_PREFIX}-${DNS_ZONE}domains-kv" ${WHAT_IF}

domains-infra-init: bin/terrafile faltrn_domain set-azure-account ## make domains-infra-init - terraform init for dns core resources, eg Main FrontDoor resource
./bin/terrafile -p terraform/domains/infrastructure/vendor/modules -f terraform/domains/infrastructure/config/zones_Terrafile

domains-infra-init: faltrn_domain set-azure-account ## make domains-infra-init - terraform init for dns core resources, eg Main FrontDoor resource
terraform -chdir=terraform/domains/infrastructure init -reconfigure -upgrade

domains-infra-plan: domains-infra-init ## terraform plan for dns core resources
Expand All @@ -257,10 +257,11 @@ domains-infra-plan: domains-infra-init ## terraform plan for dns core resources
domains-infra-apply: domains-infra-init ## terraform apply for dns core resources
terraform -chdir=terraform/domains/infrastructure apply -var-file config/zones.tfvars.json ${AUTO_APPROVE}


######################################

domains-init: faltrn_domain set-azure-account ## terraform init for dns resources: make <env> domains-init
domains-init: bin/terrafile faltrn_domain set-azure-account ## terraform init for dns resources: make <env> domains-init
./bin/terrafile -p terraform/domains/environment_domains/vendor/modules -f terraform/domains/environment_domains/config/${CONFIG}_Terrafile

terraform -chdir=terraform/domains/environment_domains init -upgrade -reconfigure -backend-config=key=$(or $(DOMAINS_TERRAFORM_BACKEND_KEY),faltrndomains_$(DEPLOY_ENV).tfstate)

domains-plan: domains-init ## terraform plan for dns resources, eg dev.<domain_name> dns records and frontdoor routing
Expand All @@ -272,7 +273,6 @@ domains-apply: domains-init ## terraform apply for dns resources
domains-destroy: domains-init ## terraform destroy for dns resources
terraform -chdir=terraform/domains/environment_domains destroy -var-file config/$(DEPLOY_ENV).tfvars.json


arm-deployment: set-resource-group-name set-storage-account-name set-azure-template-tag set-azure-account set-azure-resource-group-tags set-key-vault-names ## deploy container/kv to store terraform state for each environment
az deployment sub create --name "resourcedeploy-tsc-$(shell date +%Y%m%d%H%M%S)" \
-l "UK South" --template-uri "https://raw.githubusercontent.com/DFE-Digital/tra-shared-services/${ARM_TEMPLATE_TAG}/azure/resourcedeploy.json" \
Expand Down
Empty file added bin/.gitkeep
Empty file.
1 change: 1 addition & 0 deletions terraform/domains/environment_domains/.terraform.lock.hcl

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
{
"domains": ["dev"],
"environment_short": "dev",
"cached_paths": ["/assets/*"],
"environment_short": "dv",
"environment_tag": "dev",
"origin_hostname": "find-a-lost-trn-development-web.test.teacherservices.cloud"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
domains:
source: "https://github.com/DFE-Digital/terraform-modules"
version: "testing"
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
{
"domains": ["preprod"],
"environment_short": "preprod",
"cached_paths": ["/assets/*"],
"environment_short": "pp",
"environment_tag": "pre-prod",
"origin_hostname": "find-a-lost-trn-preproduction-web.test.teacherservices.cloud"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
domains:
source: "https://github.com/DFE-Digital/terraform-modules"
version: "testing"
Original file line number Diff line number Diff line change
@@ -1,6 +1,19 @@
{
"domains": ["www", "apex"],
"domains": ["apex"],
"cached_paths": ["/assets/*"],
"environment_short": "pd",
"environment_tag": "Prod",
"origin_hostname": "find-a-lost-trn-production-web.teacherservices.cloud"
"origin_hostname": "find-a-lost-trn-production.london.cloudapps.digital",
"null_host_header": true,
"hosted_zone": {
"find-a-lost-trn.education.gov.uk": {
"resource_group_name": "s189p01-faltrndomains-rg",
"cnames": {
"_443ce8e523e08d5e5f44703bcffa0875": {
"target": "_680e92e9fa66938e47a0348221196c28.mntkzmhvxg.acm-validations.aws.",
"ttl": 86400
}
}
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
domains:
source: "https://github.com/DFE-Digital/terraform-modules"
version: "stable"
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
{
"domains": ["test"],
"environment_short": "test",
"cached_paths": ["/assets/*"],
"environment_short": "ts",
"environment_tag": "test",
"origin_hostname": "find-a-lost-trn-test-web.test.teacherservices.cloud"
}
3 changes: 3 additions & 0 deletions terraform/domains/environment_domains/config/test_Terrafile
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
domains:
source: "https://github.com/DFE-Digital/terraform-modules"
version: "testing"
10 changes: 9 additions & 1 deletion terraform/domains/environment_domains/main.tf
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
module "domains" {
source = "git::https://github.com/DFE-Digital/terraform-modules.git//domains/environment_domains?ref=stable"
source = "./vendor/modules/domains//domains/environment_domains"
zone = var.zone
front_door_name = var.front_door_name
resource_group_name = var.resource_group_name
domains = var.domains
environment = var.environment_short
host_name = var.origin_hostname
null_host_header = try(var.null_host_header, false)
cached_paths = try(var.cached_paths, [])
}

data "azurerm_cdn_frontdoor_profile" "main" {
Expand All @@ -17,3 +19,9 @@ data "azurerm_dns_zone" "main" {
name = var.zone
resource_group_name = var.resource_group_name
}

# Takes values from hosted_zone.domain_name.cnames (or txt_records, a-records). Use for domains which are not associated with front door.
module "dns_records" {
source = "./vendor/modules/domains//dns/records"
hosted_zone = var.hosted_zone
}
16 changes: 16 additions & 0 deletions terraform/domains/environment_domains/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -38,3 +38,19 @@ variable "origin_hostname" {
locals {
hostname = "${var.domains[0]}.${var.zone}"
}

variable "hosted_zone" {
type = map(any)
default = {}
}

variable "null_host_header" {
default = false
description = "The origin_host_header for the azurerm_cdn_frontdoor_origin resource will be var.host_name (if false) or null (if true). If null then the host name from the incoming request will be used."
}

variable "cached_paths" {
type = list(string)
default = []
description = "List of path patterns such as /assets/* that front door will cache"
}
Submodule domains added at 1c4ac5
1 change: 1 addition & 0 deletions terraform/domains/infrastructure/.terraform.lock.hcl

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 3 additions & 0 deletions terraform/domains/infrastructure/config/zones_Terrafile
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
domains:
source: "https://github.com/DFE-Digital/terraform-modules"
version: "stable"
2 changes: 1 addition & 1 deletion terraform/domains/infrastructure/main.tf
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
module "domains_infrastructure" {
source = "git::https://github.com/DFE-Digital/terraform-modules.git//domains/infrastructure?ref=stable"
source = "./vendor/modules/domains//domains/infrastructure"
hosted_zone = var.hosted_zone
tags = var.tags
deploy_default_records = var.deploy_default_records
Expand Down
1 change: 1 addition & 0 deletions terraform/domains/infrastructure/vendor/modules/domains
Submodule domains added at 1c4ac5

0 comments on commit 131b650

Please sign in to comment.