terragrunt.hcl 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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/keycloak-configuration?ref=v1.25.0"
  16. }
  17. generate "required_providers" {
  18. path = "required_provider.tf"
  19. if_exists = "overwrite_terragrunt"
  20. contents = <<EOF
  21. terraform {
  22. required_providers {
  23. aws = {
  24. source = "hashicorp/aws"
  25. version = "= 3.37.0" # 2021-04-29: upgrade from 2.66
  26. }
  27. template = {
  28. source = "hashicorp/template"
  29. version = "= 2.2.0" # 2021-04-29: ugprade from 2.1.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. keycloak = {
  40. source = "mrparkers/keycloak"
  41. version = "= 3.0.1"
  42. }
  43. }
  44. }
  45. EOF
  46. }
  47. generate "provider-keycloak" {
  48. path = "provider-keycloak.tf"
  49. if_exists = "overwrite_terragrunt"
  50. contents = <<EOF
  51. provider "keycloak" {
  52. client_id = "terraform"
  53. # Specify the secret in the environment variable KEYCLOAK_CLIENT_SECRET
  54. #client_secret = blahblahblah
  55. # Specify the url in the environment variable KEYCLOAK_URL
  56. #url = "http://keycloak-0.pvt.xdrtest.accenturefederalcyber.com:8443"
  57. tls_insecure_skip_verify = true # Should probably specify the CA
  58. }
  59. EOF
  60. }
  61. # Include all settings from the root terragrunt.hcl file
  62. include {
  63. path = find_in_parent_folders()
  64. }
  65. # These are the variables we have to pass in to use the module specified in the terragrunt source above
  66. inputs = {
  67. # All of the inputs from the inherited hcl files are available automatically
  68. # (via the `inputs` section of the root `terragrunt.hcl`). However, modules
  69. # will be more flexible if you specify particular input values.
  70. tags = {
  71. Purpose = "Identity Provider Configuration",
  72. Terraform = "aws/${basename(get_parent_terragrunt_dir())}/${path_relative_to_include()}/"
  73. }
  74. }
  75. terraform_version_constraint = "= 0.15.1"
  76. terragrunt_version_constraint = ">= 0.29, < 0.30"