-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.tf
65 lines (58 loc) · 1.45 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
56
57
58
59
60
61
62
63
64
65
locals {
metadata = {
package = "terraform-aws-ipam"
version = trimspace(file("${path.module}/../../VERSION"))
module = basename(path.module)
name = var.name
}
module_tags = var.module_tags_enabled ? {
"module.terraform.io/package" = local.metadata.package
"module.terraform.io/version" = local.metadata.version
"module.terraform.io/name" = local.metadata.module
"module.terraform.io/full-name" = "${local.metadata.package}/${local.metadata.module}"
"module.terraform.io/instance" = local.metadata.name
} : {}
}
###################################################
# Elastic IP
###################################################
# TODO: customer_owned_ipv4_pool
# INFO: Not supported attributes
# - `associate_with_private_ip`
# - `instance`
# - `network_interface`
# - `vpc`
resource "aws_eip" "this" {
domain = "vpc"
network_border_group = (var.type == "AMAZON"
? var.network_border_group
: null
)
public_ipv4_pool = (var.type == "IPAM_POOL"
? var.ipam_pool.id
: "amazon"
)
address = (var.type == "IPAM_POOL"
? var.ipam_pool.address
: null
)
timeouts {
read = var.timeouts.read
update = var.timeouts.update
delete = var.timeouts.delete
}
tags = merge(
{
"Name" = local.metadata.name
},
local.module_tags,
var.tags,
)
lifecycle {
ignore_changes = [
associate_with_private_ip,
instance,
network_interface,
]
}
}