sdlc/
├─ main.tf # Main Terraform config file
├─ variables.tf # Variable declarations
├─ terraform.tfvars # Variable assigned
├─ outputs.tf # Output definitions
├─ provider.tf # Provider-specific config
├─ terraform.tfstate # Terraform state file
├─ academia.auto.tfvars # User Sensitive Data
├─ dev.tf # Dev Env config for development
├─ prod.tf # Prod Env config for production
├─ modules/ # Directory for custom modules
│ ├─ module1/ # Custom module 1
│ │ ├─ main.tf # Module-specific Terraform config
│ │ ├─ variables.tf # Module-specific variables
│ │ └─ outputs.tf # Module-specific outputs
│ └─ module2/ # Custom module 2
│ ├─ main.tf
│ ├─ variables.tf
│ └─ outputs.tf
├─ environments/ # Directory for env
│ ├─ dev/ # Development env
│ │ ├─ main.tf # Env specific Terraform config
│ │ ├─ variables.tf
│ │ └─ outputs.tf
│ └─ prod/ # Production env
│ ├─ main.tf
│ ├─ variables.tf
│ └─ outputs.tf
├─ scripts/ # Scripts or utility for IaC
└── README.md
cat << HCL | tee -a ./variables.tf >/dev/null
variable "backend_http_tfstate_repository_unlock" {
type = string
description = "Terraform State Repository Unlock"
}
variable "backend_http_tfstate_repository_lock" {
type = string
description = "Terraform State Repository Lock"
}
variable "backend_http_tfstate_repository_base" {
type = string
description = "Terraform State Repository Base"
}
variable "backend_http_username" {
type = string
description = "Terraform State Repository Username"
}
variable "backend_http_password" {
type = string
description = "Terraform State Repository Password"
}
HCL
cat << HCL | tee -a ./backend.tf >/dev/null
terraform {
backend "http" {
unlock_address = var.backend_http_tfstate_repository_unlock
lock_address = var.backend_http_tfstate_repository_lock
address = var.backend_http_tfstate_repository_base
username = var.backend_http_username
password = var.backend_http_password
unlock_method = DELETE
lock_method = POST
retry_wait_min = 5
}
}
HCL
cat << HCL | tee -a ./{terraform,academia.auto}.tfvars >/dev/null
backend_http_tfstate_repository_unlock = "https://gitlab.chorke.org/api/v4/projects/123/terraform/state/aws-chorke/unlock"
backend_http_tfstate_repository_lock = "https://gitlab.chorke.org/api/v4/projects/123/terraform/state/aws-chorke/lock"
backend_http_tfstate_repository_base = "https://gitlab.chorke.org/api/v4/projects/123/terraform/state/aws-chorke"
backend_http_username = "academia"
backend_http_password = "sadaqah!"
HCL
cat << HCL | tee -a ./{terraform,academia.auto}.tfvars >/dev/null
backend_http_tfstate_repository_unlock = "https://nexus.chorke.org/repository/terraform/chorke-sdlc/state/aws-chorke/unlock"
backend_http_tfstate_repository_lock = "https://nexus.chorke.org/repository/terraform/chorke-sdlc/state/aws-chorke/lock"
backend_http_tfstate_repository_base = "https://nexus.chorke.org/repository/terraform/chorke-sdlc/state/aws-chorke"
backend_http_username = "[email protected]"
backend_http_password = "sadaqah!"
HCL