terragrunt.hcl 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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/s3_bucket_writer_role?ref=v5.0.0"
  16. }
  17. # Include all settings from the root terragrunt.hcl file
  18. include {
  19. path = find_in_parent_folders()
  20. }
  21. dependencies {
  22. paths = [
  23. "../008-xdr-binaries",
  24. "../../../../prod/aws/mdr-prod-c2/072-salt-master-inventory-role",
  25. "../../../../test/aws/mdr-test-c2/072-salt-master-inventory-role",
  26. ]
  27. }
  28. dependency "prod-salt-master" {
  29. config_path = "../../../../prod/aws-us-gov/mdr-prod-c2/071-instance-salt-master"
  30. }
  31. dependency "test-salt-master" {
  32. config_path = "../../../../test/aws-us-gov/mdr-test-c2/071-instance-salt-master"
  33. }
  34. dependency "bucket" {
  35. config_path = "../008-xdr-binaries"
  36. }
  37. dependency "prod-user" {
  38. config_path = "../../../../prod/aws/mdr-prod-c2/072-salt-master-inventory-role"
  39. }
  40. dependency "test-user" {
  41. config_path = "../../../../test/aws/mdr-test-c2/072-salt-master-inventory-role"
  42. }
  43. # These are the variables we have to pass in to use the module specified in the terragrunt source above
  44. inputs = {
  45. # All of the inputs from the inherited hcl files are available automatically
  46. # (via the `inputs` section of the root `terragrunt.hcl`). However, modules
  47. # will be more flexible if you specify particular input values.
  48. tags = {
  49. Purpose = "Read/Write access to afsxdr-binaries s3 bucket"
  50. Terraform = "aws/${basename(get_parent_terragrunt_dir())}/${path_relative_to_include()}/"
  51. }
  52. bucket = dependency.bucket.outputs.arn
  53. name = "afsxdr-binaries_writers"
  54. description = "Write access to the s3 bucket for afsxdr-binaries"
  55. trusted_arns = [
  56. "arn:aws:iam::477548533976:role/salt-master-instance-role", # Legacy prod salt master
  57. "arn:aws:iam::527700175026:role/salt-master-instance-role", # Legacy test salt master
  58. dependency.test-user.outputs.salt-master-c2-commercial-user-arn,
  59. dependency.prod-user.outputs.salt-master-c2-commercial-user-arn,
  60. ]
  61. kms_key_ids = [
  62. dependency.bucket.outputs.kms_key_arn
  63. ]
  64. }
  65. terraform_version_constraint = "= 1.1.6"
  66. terragrunt_version_constraint = "= 0.36.2"