terragrunt.hcl 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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.mdr.defpoint.com:mdr-engineering/xdr-terraform-modules.git//base/splunk_servers/legacy_hec?ref=v1.10.17"
  16. }
  17. generate "provider-legacy" {
  18. path = "provider-legacy.tf"
  19. if_exists = "overwrite_terragrunt"
  20. contents = <<EOF
  21. provider "aws" {
  22. version = "~> 3.0"
  23. region = "us-east-1"
  24. assume_role {
  25. role_arn = "arn:aws:iam::${local.environment_vars.locals.legacy_account}:role/user/mdr_terraformer"
  26. session_name = "terraform-legacy"
  27. }
  28. profile = "commercial"
  29. alias = "legacy"
  30. # Only these AWS Account IDs may be operated on by this template
  31. allowed_account_ids = [ ${local.environment_vars.locals.legacy_account} ]
  32. }
  33. EOF
  34. }
  35. dependency "vpc" {
  36. config_path = "../010-vpc-splunk"
  37. }
  38. dependency "indexers" {
  39. config_path = "../160-splunk-indexer-cluster"
  40. }
  41. # Include all settings from the root terragrunt.hcl file
  42. include {
  43. path = find_in_parent_folders()
  44. }
  45. # These are the variables we have to pass in to use the module specified in the terragrunt source above
  46. inputs = {
  47. # All of the inputs from the inherited hcl files are available automatically
  48. # (via the `inputs` section of the root `terragrunt.hcl`). However, modules
  49. # will be more flexible if you specify particular input values.
  50. tags = {
  51. Purpose = "Legacy ELB for Splunk Migration"
  52. Terraform = "aws/${basename(get_parent_terragrunt_dir())}/${path_relative_to_include()}/"
  53. Schedule = "none"
  54. }
  55. prefix = local.account_vars.locals.splunk_prefix
  56. vpc_id = dependency.vpc.outputs.vpc_id
  57. vpc_cidr = local.account_vars.locals.vpc_info["vpc-splunk"]["cidr"]
  58. azs = dependency.vpc.outputs.azs
  59. public_subnets = dependency.vpc.outputs.public_subnets
  60. elb_attachments = dependency.indexers.outputs.elb_attachments
  61. }