terragrunt.hcl 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. locals {
  2. # If you want to use any of the variables in _this_ file, you have to load them here.
  3. # However, they will all be available as inputs to the module loaded in terraform.source
  4. # below.
  5. environment_vars = read_terragrunt_config(find_in_parent_folders("env.hcl"))
  6. partition_vars = read_terragrunt_config(find_in_parent_folders("partition.hcl"))
  7. region_vars = read_terragrunt_config(find_in_parent_folders("region.hcl"))
  8. account_vars = read_terragrunt_config(find_in_parent_folders("account.hcl"))
  9. global_vars = read_terragrunt_config(find_in_parent_folders("globals.hcl"))
  10. }
  11. # Terragrunt will copy the Terraform configurations specified by the source parameter, along with any files in the
  12. # working directory, into a temporary folder, and execute your Terraform commands in that folder.
  13. terraform {
  14. # Double slash is intentional and required to show root of modules
  15. source = "git@github.xdr.accenturefederalcyber.com:mdr-engineering/xdr-terraform-modules.git//base/codebuild_ecr_customer_portal?ref=v3.0.0"
  16. }
  17. dependency "codebuild-ecr-base" {
  18. config_path = "../075-codebuild-ecr-base"
  19. }
  20. #Github specific provider
  21. generate "required_providers" {
  22. path = "required_provider.tf"
  23. if_exists = "overwrite_terragrunt"
  24. contents = <<EOF
  25. terraform {
  26. required_providers {
  27. aws = {
  28. source = "hashicorp/aws"
  29. version = "= 3.59.0" # 2021-09-21: upgrade from 3.37.0
  30. }
  31. vault = {
  32. source = "hashicorp/vault"
  33. version = "= 2.19.1" # 2021-04-29: upgrade from 2.18.0
  34. }
  35. sensu = {
  36. source = "jtopjian/sensu"
  37. version = "= 0.10.5"
  38. }
  39. github = {
  40. source = "integrations/github"
  41. version = "4.2.0"
  42. }
  43. }
  44. }
  45. EOF
  46. }
  47. generate "github-provider" {
  48. path = "github-provider.tf"
  49. if_exists = "overwrite_terragrunt"
  50. contents = <<EOF
  51. #Provider block for Github engineering.
  52. #provider "github" {
  53. # organization = "mdr-engineering"
  54. # base_url = "https://github.xdr.accenturefederalcyber.com/"
  55. #}
  56. #Provider block for Github MDR Content.
  57. provider "github" {
  58. organization = "MDR-Content"
  59. base_url = "https://github.xdr.accenturefederalcyber.com/"
  60. }
  61. EOF
  62. }
  63. # Include all settings from the root terragrunt.hcl file
  64. include {
  65. path = find_in_parent_folders()
  66. }
  67. # These are the variables we have to pass in to use the module specified in the terragrunt source above
  68. inputs = {
  69. # All of the inputs from the inherited hcl files are available automatically
  70. # (via the `inputs` section of the root `terragrunt.hcl`). However, modules
  71. # will be more flexible if you specify particular input values.
  72. tags = {
  73. Purpose = "Build Docker Container with Codebuild"
  74. Terraform = "aws/${basename(get_parent_terragrunt_dir())}/${path_relative_to_include()}/"
  75. }
  76. name = "customer_portal"
  77. service_role = dependency.codebuild-ecr-base.outputs.service_role
  78. kms_key = dependency.codebuild-ecr-base.outputs.kms_key
  79. codebuild_image = "aws/codebuild/amazonlinux2-x86_64-standard:3.0"
  80. #codebuild_image = dependency.codebuild-ecr-base.outputs.codebuild_image_centos7
  81. #codebuild_image = dependency.codebuild-ecr-base.outputs.codebuild_image_rhel7
  82. artifact_s3_bucket = ""
  83. #artifact_s3_bucket = dependency.codebuild-ecr-base.outputs.artifact_s3_bucket
  84. webhook_branch_filter = "release/.*"
  85. }
  86. terraform_version_constraint = "= 1.0.7"
  87. terragrunt_version_constraint = "= 0.32.3"