-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathmain.tf
55 lines (46 loc) · 2.12 KB
/
main.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
44
45
46
47
48
49
50
51
52
53
54
55
resource "null_resource" "create-endpoint" {
provisioner "local-exec" {
command = "aws route53resolver create-resolver-endpoint --creator-request-id ${var.creator-request-id} --security-group-ids ${local.security-groups} --direction ${var.direction} --ip-addresses ${local.list-ip-template} --name ${var.endpoint-name} --tags ${var.tags} --profile ${var.aws-profile} > ${data.template_file.log_name.rendered}"
}
}
resource "null_resource" "output-id" {
provisioner "local-exec" {
command = "aws route53resolver list-resolver-endpoints --profile ${var.aws-profile} --output text --query 'ResolverEndpoints[?Name==`${var.endpoint-name}`].Id' > ${data.template_file.endpoint-id.rendered}"
}
depends_on = ["null_resource.create-endpoint"]
}
resource "null_resource" "deleteEndpoint" {
count = "${var.delete != "false" ? 1 :0}"
provisioner "local-exec" {
command = "aws route53resolver delete-resolver-endpoint resolver-endpoint-id ${trimspace(data.local_file.readId.content)} --profile ${var.aws-profile} > ${data.template_file.log_name.rendered}"
}
depends_on = ["null_resource.create-endpoint"]
}
# ------------------------------------------------------------
data "template_file" "log_name" {
template = "${path.module}/output.log"
}
data "template_file" "endpoint-id" {
template = "${path.module}/id.log"
}
data "local_file" "create-endpoint" {
filename = "${data.template_file.log_name.rendered}"
depends_on = ["null_resource.create-endpoint"]
}
data "local_file" "readId" {
filename = "${data.template_file.endpoint-id.rendered}"
depends_on = ["null_resource.output-id"]
}
data "template_file" "ip-template" {
count = "${length(var.subnet-ids)}"
template = "SubnetId=${var.subnet-ids[count.index]},Ip=${var.ip_addresses[count.index]} "
}
data "template_file" "security-groups" {
count = "${length(var.security-groups)}"
template = "${var.security-groups[count.index]} "
}
#------------------------------------------------------------------
locals {
list-ip-template = "${join(" ",data.template_file.ip-template.*.rendered)}"
security-groups = "${join(" ",data.template_file.security-groups.*.rendered)}"
}