|
| 1 | +locals { |
| 2 | + acm_certificate_validation_records = [ |
| 3 | + for record in aws_acm_certificate.this.domain_validation_options : |
| 4 | + { |
| 5 | + name = record.resource_record_name |
| 6 | + type = record.resource_record_type |
| 7 | + value = record.resource_record_value |
| 8 | + domain = record.domain_name |
| 9 | + } |
| 10 | + ] |
| 11 | +} |
| 12 | + |
1 | 13 | ################################################################################ |
2 | | -# ACM Amazon issued certificates |
| 14 | +# ACM Certificate |
3 | 15 | ################################################################################ |
4 | 16 |
|
5 | | -resource "aws_acm_certificate" "amazon_issued" { |
6 | | - for_each = var.amazon_issued_certificates |
7 | | - |
8 | | - domain_name = try(each.value.domain_name, null) |
9 | | - subject_alternative_names = try(each.value.subject_alternative_names, null) |
10 | | - validation_method = try(each.value.validation_method, null) |
11 | | - key_algorithm = try(each.value.key_algorithm, null) |
| 17 | +resource "aws_acm_certificate" "this" { |
| 18 | + domain_name = var.certificate_domain_name |
| 19 | + subject_alternative_names = try(var.certificate_subject_alternative_names, null) |
| 20 | + validation_method = try(var.certificate_validation_method, null) |
| 21 | + key_algorithm = try(var.certificate_key_algorithm, null) |
12 | 22 |
|
13 | 23 | dynamic "validation_option" { |
14 | | - for_each = try(each.value.validation_option, null) != null ? [1] : [] |
| 24 | + for_each = try(var.certificate_validation_option, null) != null ? [1] : [] |
15 | 25 |
|
16 | 26 | content { |
17 | | - domain_name = each.value.validation_option.domain_name |
18 | | - validation_domain = each.value.validation_option.validation_domain |
| 27 | + domain_name = var.certificate_validation_option.domain_name |
| 28 | + validation_domain = var.certificate_validation_option.validation_domain |
19 | 29 | } |
20 | 30 | } |
21 | 31 |
|
22 | 32 | lifecycle { |
23 | 33 | create_before_destroy = true |
24 | 34 | } |
25 | 35 |
|
26 | | - tags = merge(var.tags, each.value.tags) |
| 36 | + tags = var.tags |
| 37 | +} |
| 38 | + |
| 39 | +################################################################################ |
| 40 | +# ACM Validation |
| 41 | +################################################################################ |
| 42 | + |
| 43 | +resource "aws_route53_record" "this" { |
| 44 | + for_each = local.acm_certificate_validation_records |
| 45 | + |
| 46 | + zone_id = var.record_zone_id |
| 47 | + name = each.value.name |
| 48 | + type = each.value.type |
| 49 | + records = [each.value.value] |
| 50 | + ttl = 60 |
| 51 | + allow_overwrite = var.record_allow_overwrite |
| 52 | +} |
| 53 | + |
| 54 | +resource "aws_acm_certificate_validation" "this" { |
| 55 | + certificate_arn = aws_acm_certificate.this.arn |
| 56 | + validation_record_fqdns = [for route53_record in aws_route53_record.this : route53_record.fqdn] |
27 | 57 | } |
0 commit comments