forked from terraform-aws-modules/terraform-aws-opensearch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvariables.tf
318 lines (268 loc) · 9.68 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
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
variable "create" {
description = "Determines whether resources will be created (affects all resources)"
type = bool
default = true
}
variable "tags" {
description = "A map of tags to add to all resources"
type = map(string)
default = {}
}
################################################################################
# Domain
################################################################################
variable "advanced_options" {
description = "Key-value string pairs to specify advanced configuration options. Note that the values for these configuration options must be strings (wrapped in quotes) or they may be wrong and cause a perpetual diff, causing Terraform to want to recreate your Elasticsearch domain on every apply"
type = map(string)
default = {}
}
variable "advanced_security_options" {
description = "Configuration block for [fine-grained access control](https://docs.aws.amazon.com/elasticsearch-service/latest/developerguide/fgac.html)"
type = any
default = {
enabled = true
anonymous_auth_enabled = false
}
}
variable "auto_tune_options" {
description = "Configuration block for the Auto-Tune options of the domain"
type = any
default = {
desired_state = "ENABLED"
rollback_on_disable = "NO_ROLLBACK"
}
}
variable "cluster_config" {
description = "Configuration block for the cluster of the domain"
type = any
default = {
dedicated_master_enabled = true
}
}
variable "cognito_options" {
description = "Configuration block for authenticating Kibana with Cognito"
type = any
default = {}
}
variable "domain_endpoint_options" {
description = "Configuration block for domain endpoint HTTP(S) related options"
type = any
default = {
enforce_https = true
tls_security_policy = "Policy-Min-TLS-1-2-2019-07"
}
}
variable "domain_name" {
description = "Name of the domain"
type = string
default = ""
}
variable "ebs_options" {
description = "Configuration block for EBS related options, may be required based on chosen [instance size](https://aws.amazon.com/elasticsearch-service/pricing/)"
type = any
default = {
ebs_enabled = true
volume_size = 64
volume_type = "gp3"
}
}
variable "encrypt_at_rest" {
description = "Configuration block for encrypting at rest"
type = any
default = {
enabled = true
}
}
variable "engine_version" {
description = "Version of the OpenSearch engine to use"
type = string
default = null
}
variable "ip_address_type" {
description = "The IP address type for the endpoint. Valid values are ipv4 and dualstack"
type = string
default = null
}
variable "log_publishing_options" {
description = "Configuration block for publishing slow and application logs to CloudWatch Logs. This block can be declared multiple times, for each log_type, within the same resource"
type = any
default = [
{ log_type = "INDEX_SLOW_LOGS" },
{ log_type = "SEARCH_SLOW_LOGS" },
]
}
variable "node_to_node_encryption" {
description = "Configuration block for node-to-node encryption options"
type = any
default = {
enabled = true
}
}
variable "off_peak_window_options" {
description = "Configuration to add Off Peak update options"
type = any
default = {
enabled = true
off_peak_window = {
hours = 7
}
}
}
variable "software_update_options" {
description = "Software update options for the domain"
type = any
default = {
auto_software_update_enabled = true
}
}
variable "vpc_options" {
description = "Configuration block for VPC related options. Adding or removing this configuration forces a new resource ([documentation](https://docs.aws.amazon.com/elasticsearch-service/latest/developerguide/es-vpc.html#es-vpc-limitations))"
type = any
default = {}
}
variable "timeouts" {
description = "Create and delete timeout configurations for the domain"
type = map(string)
default = {}
}
################################################################################
# Package Association(s)
################################################################################
variable "package_associations" {
description = "Map of package association IDs to associate with the domain"
type = map(string)
default = {}
}
################################################################################
# VPC Endpoint(s)
################################################################################
variable "vpc_endpoints" {
description = "Map of VPC endpoints to create for the domain"
type = any
default = {}
}
################################################################################
# Access Policy
################################################################################
variable "enable_access_policy" {
description = "Determines whether an access policy will be applied to the domain"
type = bool
default = true
}
variable "create_access_policy" {
description = "Determines whether an access policy will be created"
type = bool
default = true
}
variable "access_policies" {
description = "IAM policy document specifying the access policies for the domain. Required if `create_access_policy` is `false`"
type = string
default = null
}
variable "access_policy_statements" {
description = "A map of IAM policy [statements](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/iam_policy_document#statement) for custom permission usage"
type = any
default = {}
}
variable "access_policy_source_policy_documents" {
description = "List of IAM policy documents that are merged together into the exported document. Statements must have unique `sid`s"
type = list(string)
default = []
}
variable "access_policy_override_policy_documents" {
description = "List of IAM policy documents that are merged together into the exported document. In merging, statements with non-blank `sid`s will override statements with the same `sid`"
type = list(string)
default = []
}
################################################################################
# SAML Options
################################################################################
variable "create_saml_options" {
description = "Determines whether SAML options will be created"
type = bool
default = false
}
variable "saml_options" {
description = "SAML authentication options for an AWS OpenSearch Domain"
type = any
default = {}
}
################################################################################
# Outbound Connections
################################################################################
variable "outbound_connections" {
description = "Map of AWS OpenSearch outbound connections to create"
type = any
default = {}
}
################################################################################
# CloudWatch Log Group
################################################################################
variable "create_cloudwatch_log_groups" {
description = "Determines whether log groups are created"
type = bool
default = true
}
variable "cloudwatch_log_group_retention_in_days" {
description = "Number of days to retain log events"
type = number
default = 60
}
variable "cloudwatch_log_group_kms_key_id" {
description = "If a KMS Key ARN is set, this key will be used to encrypt the corresponding log group. Please be sure that the KMS Key has an appropriate key policy (https://docs.aws.amazon.com/AmazonCloudWatch/latest/logs/encrypt-log-data-kms.html)"
type = string
default = null
}
variable "cloudwatch_log_group_skip_destroy" {
description = "Set to true if you do not wish the log group (and any logs it may contain) to be deleted at destroy time, and instead just remove the log group from the Terraform state"
type = bool
default = null
}
variable "cloudwatch_log_group_class" {
description = "Specified the log class of the log group. Possible values are: STANDARD or INFREQUENT_ACCESS"
type = string
default = null
}
variable "create_cloudwatch_log_resource_policy" {
description = "Determines whether a resource policy will be created for OpenSearch to log to CloudWatch"
type = bool
default = true
}
variable "cloudwatch_log_resource_policy_name" {
description = "Name of the resource policy for OpenSearch to log to CloudWatch"
type = string
default = null
}
################################################################################
# Security Group
################################################################################
variable "create_security_group" {
description = "Determines if a security group is created"
type = bool
default = true
}
variable "security_group_name" {
description = "Name to use on security group created"
type = string
default = null
}
variable "security_group_use_name_prefix" {
description = "Determines whether the security group name (`security_group_name`) is used as a prefix"
type = bool
default = true
}
variable "security_group_description" {
description = "Description of the security group created"
type = string
default = null
}
variable "security_group_rules" {
description = "Security group ingress and egress rules to add to the security group created"
type = any
default = {}
}
variable "security_group_tags" {
description = "A map of additional tags to add to the security group created"
type = map(string)
default = {}
}