forked from chime/terraform-aws-alternat
-
Notifications
You must be signed in to change notification settings - Fork 0
/
variables.tf
273 lines (230 loc) · 8.4 KB
/
variables.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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
variable "additional_instance_policies" {
description = "Additional policies for the Alternat instance IAM role."
type = list(object({
policy_name = string
policy_json = string
}))
default = []
}
variable "alternat_image_tag" {
description = "The tag of the container image for the Alternat Lambda functions."
type = string
default = "latest"
}
variable "alternat_image_uri" {
description = "The URI of the container image for the Alternat Lambda functions."
type = string
default = ""
}
variable "architecture" {
description = "Architecture of the NAT instance image. Must be compatible with nat_instance_type."
type = string
default = "arm64"
}
variable "autoscaling_hook_function_name" {
description = "The name to use for the autoscaling hook Lambda function."
type = string
default = "alternat-autoscaling-hook"
}
variable "create_nat_gateways" {
description = "Whether to create the NAT Gateway and the NAT Gateway EIP in this module. If false, you must create and manage NAT Gateways separately."
type = bool
default = true
}
variable "connectivity_test_check_urls" {
description = "List of URLs to check with the connectivity tester function."
type = list(string)
default = ["https://www.example.com", "https://www.google.com"]
}
variable "connectivity_test_event_rule_name" {
description = "The name to use for the event rule that invokes the connectivity test Lambda function."
type = string
default = "alternat-test-every-minute"
}
variable "connectivity_tester_function_name" {
description = "The prefix to use for the name of the connectivity tester Lambda function. Because there is a function created in each ASG, the name will be suffixed with an index."
type = string
default = "alternat-connectivity-tester"
}
variable "enable_ec2_endpoint" {
description = "Whether to create a VPC endpoint to EC2 for Internet Connectivity testing."
type = bool
default = true
}
variable "enable_ssm" {
description = "Whether to enable SSM on the Alternat instances."
type = bool
default = true
}
variable "ingress_security_group_ids" {
description = "A list of security group IDs that are allowed by the NAT instance."
type = list(string)
default = []
}
variable "ingress_security_group_cidr_blocks" {
description = "A list of CIDR blocks that are allowed by the NAT instance."
type = list(string)
default = []
}
variable "ingress_security_group_ipv6_cidr_blocks" {
description = "A list of IPv6 CIDR blocks that are allowed by the NAT instance."
type = list(string)
default = []
}
variable "lifecycle_heartbeat_timeout" {
description = "The length of time, in seconds, that autoscaled NAT instances should wait in the terminate state before being fully terminated."
type = number
default = 180
}
variable "max_instance_lifetime" {
description = "Max instance life in seconds. Defaults to 14 days. Set to 0 to disable."
type = number
default = 1209600
}
variable "nat_ami" {
description = "The AMI to use for the NAT instance. Defaults to the latest Amazon Linux 2 AMI."
type = string
default = ""
}
variable "nat_instance_block_devices" {
description = "Optional custom EBS volume settings for the NAT instance."
type = any
default = {}
}
variable "nat_instance_iam_profile_name" {
description = "Name to use for the IAM profile used by the NAT instance. Must be globally unique in this AWS account. Defaults to alternat-instance- as a prefix."
type = string
default = ""
}
variable "nat_instance_iam_role_name" {
description = "Name to use for the IAM role used by the NAT instance. Must be globally unique in this AWS account. Defaults to alternat-instance- as a prefix."
type = string
default = ""
}
variable "nat_instance_key_name" {
description = "The name of the key pair to use for the NAT instance. This is primarily used for testing."
type = string
default = ""
}
variable "nat_instance_lifecycle_hook_role_name" {
description = "Name to use for the IAM role used by the NAT instance lifecycle hook. Must be globally unique in this AWS account. Defaults to alternat-lifecycle-hook as a prefix."
type = string
default = ""
}
variable "nat_instance_name_prefix" {
description = "Prefix for the NAT Auto Scaling Group and instance names. Because there is an instance created in each ASG, the name will be suffixed with an index."
type = string
default = "alternat-"
}
variable "nat_instance_sg_name_prefix" {
description = "Prefix for the NAT instance security group name."
type = string
default = "alternat-instance"
}
variable "nat_lambda_function_role_name" {
description = "Name to use for the IAM role used by the replace-route Lambda function. Must be globally unique in this AWS account."
type = string
default = ""
}
variable "nat_instance_type" {
description = "Instance type to use for NAT instances."
type = string
default = "c6gn.8xlarge"
}
variable "nat_instance_eip_ids" {
description = <<-EOT
Allocation IDs of Elastic IPs to associate with the NAT instances. If not specified, EIPs will be created.
Note: if the number of EIPs does not match the number of subnets specified in `vpc_public_subnet_ids`, this variable will be ignored.
EOT
type = list(string)
default = []
}
variable "nat_instance_user_data_pre_install" {
description = "Pre-install shell script to run at boot before configuring alternat."
type = string
default = ""
}
variable "nat_instance_user_data_post_install" {
description = "Post-install shell script to run at boot after configuring alternat."
type = string
default = ""
}
variable "tags" {
description = "A map of tags to add to all supported resources managed by the module."
type = map(string)
default = {}
}
variable "vpc_az_maps" {
description = "A map of az to private route tables that the NAT instances will manage."
type = list(object({
az = string
private_subnet_ids = list(string)
public_subnet_id = string
route_table_ids = list(string)
}))
}
variable "nat_gateway_id" {
description = "NAT Gateway ID to use for fallback. If not provided, the gateway in the same subnet as relevant NAT instance is selected."
type = string
default = ""
}
variable "vpc_id" {
description = "The ID of the VPC."
type = string
}
variable "lambda_package_type" {
description = "The lambda deployment package type. Valid values are \"Zip\" and \"Image\". Defaults to \"Image\"."
type = string
default = "Image"
nullable = false
validation {
condition = contains(["Zip", "Image"], var.lambda_package_type)
error_message = "Must be a supported package type: \"Zip\" or \"Image\"."
}
}
variable "lambda_memory_size" {
description = "Amount of memory in MB your Lambda Function can use at runtime. Defaults to 256."
type = number
default = 256
}
variable "lambda_timeout" {
description = "Amount of time your Lambda Function has to run in seconds. Defaults to 300."
type = number
default = 300
}
variable "lambda_handlers" {
description = "Lambda handlers."
type = object({
connectivity_tester = string,
alternat_autoscaling_hook = string,
})
default = {
connectivity_tester = "app.connectivity_test_handler",
alternat_autoscaling_hook = "app.handler"
}
}
variable "lambda_environment_variables" {
description = "Environment variables to be provided to the lambda function."
type = map(string)
default = null
}
variable "lambda_has_ipv6" {
description = "Controls whether or not the lambda function can use IPv6."
type = bool
default = true
}
variable "lambda_zip_path" {
description = "The location where the generated zip file should be stored. Required when `lambda_package_type` is \"Zip\"."
type = string
default = "/tmp/alternat-lambda.zip"
}
variable "lambda_function_architectures" {
description = "CPU architecture(s) to use for the lambda functions."
type = list(string)
default = ["x86_64"]
}
variable "lambda_layer_arns" {
type = list(string)
description = "List of Lambda layers ARN that will be added to functions"
default = null
}