certificate.tf 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. #----------------------------------------------------------------------------
  2. # Public DNS Certificate
  3. #----------------------------------------------------------------------------
  4. resource "aws_acm_certificate" "cert_private" {
  5. domain_name = "phantom.${var.dns_info["private"]["zone"]}"
  6. validation_method = "DNS"
  7. lifecycle {
  8. create_before_destroy = true
  9. }
  10. tags = merge(var.standard_tags, var.tags)
  11. }
  12. resource "aws_acm_certificate_validation" "cert_private" {
  13. certificate_arn = aws_acm_certificate.cert_private.arn
  14. validation_record_fqdns = [for record in aws_route53_record.cert_validation_private: record.fqdn]
  15. }
  16. resource "aws_route53_record" "cert_validation_private" {
  17. provider = aws.mdr-common-services-commercial
  18. for_each = {
  19. for dvo in aws_acm_certificate.cert_private.domain_validation_options : dvo.domain_name => {
  20. name = dvo.resource_record_name
  21. record = dvo.resource_record_value
  22. type = dvo.resource_record_type
  23. }
  24. }
  25. allow_overwrite = true
  26. name = each.value.name
  27. records = [each.value.record]
  28. ttl = 60
  29. type = each.value.type
  30. zone_id = var.dns_info["public"]["zone_id"] # private zones sitll use public dns for validation
  31. }