main.tf 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. # Sadly, this would be far easier if we could use for_each in a module. We can't, so we're cutting and pasting
  2. # code from submodules/dns/private_A_record
  3. locals {
  4. # For reverse dns:
  5. # 1) Split the ip addresses into 4 octets
  6. private_octets = { for name, address in var.legacy_private_dns: name => regex("^(\\d+)\\.(\\d+)\\.(\\d+)\\.(\\d+)$", address) }
  7. # 2) Reverse them, but only if the first octet is 10 (maybe handle 192.168 and 172.16 later), and if enabled
  8. private_reverse_addresses = { for name, octets in local.private_octets: name => join(".", reverse(slice(octets, 1, 4))) if octets[0] == "10" }
  9. }
  10. # Private
  11. resource "aws_route53_record" "private" {
  12. for_each = var.legacy_private_dns
  13. name = each.key
  14. type = "A"
  15. ttl = 300
  16. zone_id = var.dns_info["private"]["zone_id"]
  17. records = [ each.value ]
  18. provider = aws.c2
  19. }
  20. # Reverse
  21. resource "aws_route53_record" "reverse_dns" {
  22. for_each = local.private_reverse_addresses
  23. name = each.value
  24. type = "PTR"
  25. ttl = 300
  26. zone_id = var.dns_info["reverse"]["zone_id"]
  27. records = [ "${each.key}.${var.dns_info["private"]["zone"]}." ]
  28. provider = aws.c2
  29. }
  30. # Public
  31. resource "aws_route53_record" "public" {
  32. for_each = var.legacy_public_dns
  33. name = each.key
  34. type = "A"
  35. ttl = 300
  36. zone_id = var.dns_info["public"]["zone_id"]
  37. records = [ each.value ]
  38. provider = aws.mdr-common-services-commercial
  39. }
  40. # Public cname
  41. resource "aws_route53_record" "public_cname" {
  42. for_each = var.legacy_public_cname_dns
  43. name = each.key
  44. type = "CNAME"
  45. ttl = 300
  46. zone_id = var.dns_info["public"]["zone_id"]
  47. records = [ each.value ]
  48. provider = aws.mdr-common-services-commercial
  49. }