forked from zoitech/terraform-aws-alb
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhttps_target_groups.tf
43 lines (36 loc) · 2.52 KB
/
https_target_groups.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
43
#### Create https target group(s) ####
resource "aws_lb_target_group" "tg_https" {
# Check the number of https target group names matches the number of https target group ports.
# If check is ok creates the number of https target group resources based on the number of https target group names
count = "${var.lb_https_listener ? "${length(var.https_target_group_names) == "${length(var.https_target_group_ports)}" ? "${length(var.https_target_group_names)}" : 0}" :0}"
### Required Arguments ###
name = "${var.prefix}${element(var.https_target_group_names, count.index)}${var.suffix}" # default prefix/suffix = "". Default target group name = ["https-target-group"] N.B. 32 Character limit with prefix/suffix
port = "${element(var.https_target_group_ports, count.index)}" # default = [443]
protocol = "HTTPS"
vpc_id = "${var.vpc_id}"
health_check {
interval = "${var.https_health_check_interval}" #default = 30
path = "${var.https_health_check_path}" #default = "/"
port = "${var.https_health_check_port}" #default = "traffic-port"
protocol = "HTTPS"
timeout = "${var.https_health_check_timeout}" #default = 5
healthy_threshold = "${var.https_health_check_healthy_threshold}" #default = 3
unhealthy_threshold = "${var.https_health_check_unhealthy_threshold}" #default = 3
matcher = "${var.https_health_check_matcher}" #default = 200
}
target_type = "instance"
### Optional Arguments ###
deregistration_delay = "${var.https_target_group_deregistration_delay}" # default = 300.
stickiness {
enabled = "${var.https_target_group_stickiness_enabled}" # default set to false
type = "lb_cookie" # default = lb_cookie. Only possible value for applicatoin load balancer
cookie_duration = "${var.https_target_group_stickiness_cookie_duration}" # default 8640 seconds (1 day).
}
}
# Attach target to https target group(s)
resource "aws_lb_target_group_attachment" "attach_https_tg" {
count = "${var.lb_https_listener ? "${length(var.https_target_group_names) == "${length(var.https_target_group_ports)}" ? "${length(var.https_target_group_names)}" : 0}" :0}"
target_group_arn = "${element(aws_lb_target_group.tg_https.*.arn, count.index)}"
target_id = "${var.target_id}"
port = "${element(var.https_target_group_ports, count.index)}"
}