-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathlocals.tf
42 lines (37 loc) · 1.98 KB
/
locals.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
data "aws_region" "current" {}
data "aws_caller_identity" "current" {}
data "aws_vpc" "default" {
count = local.use_default_subnets ? 1 : 0
default = true
}
data "aws_subnets" "default" {
count = local.use_default_subnets ? 1 : 0
filter {
name = "vpc-id"
values = [local.vpc_id]
}
}
data "aws_vpc" "other" {
count = local.is_internal && var.vpc_id != "" ? 1 : 0
id = var.vpc_id
}
locals {
region = data.aws_region.current.name
account_id = data.aws_caller_identity.current.account_id
vpc_id = var.vpc_id != "" ? var.vpc_id : data.aws_vpc.default[0].id
private_subnet_ids_provided = length(var.private_subnet_ids) > 0
public_subnet_ids_provided = length(var.public_subnet_ids) > 0
use_default_subnets = !local.private_subnet_ids_provided && !local.public_subnet_ids_provided
is_internal = local.private_subnet_ids_provided && !local.public_subnet_ids_provided
waf_global_identifier = length(var.global_waf_acl) != 0 ? var.global_waf_acl : var.global_waf_acl_id
waf_regional_identifier = length(var.regional_waf_acl) != 0 ? var.regional_waf_acl : var.regional_waf_acl_id
waf_regional = length(local.waf_regional_identifier) != 0
wafv1_regional = local.waf_regional && substr(local.waf_regional_identifier, 0, 4) != "arn:"
wafv2_regional = local.waf_regional && !local.wafv1_regional
certificate_arns = concat(var.certificate_arns, var.certificate_arn != "" ? [var.certificate_arn] : [])
cert_provided = length(local.certificate_arns) > 0
certs_provided = length(local.certificate_arns) > 1
additional_certificate_arns = try(slice(local.certificate_arns, 1, length(local.certificate_arns)), [])
additional_certificate_objs = [for cert in local.additional_certificate_arns : { cert_arn = cert, cert_name = regex("[^/]+$", cert) }]
listener_provided = length(var.listeners) > 0
}