forked from cloudposse/terraform-aws-rds-db-proxy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvariables.tf
120 lines (102 loc) · 4.6 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
variable "debug_logging" {
type = bool
default = false
description = "Whether the proxy includes detailed information about SQL statements in its logs"
}
variable "engine_family" {
type = string
default = "MYSQL"
description = "The kinds of databases that the proxy can connect to. This value determines which database network protocol the proxy recognizes when it interprets network traffic to and from the database. The engine family applies to MySQL and PostgreSQL for both RDS and Aurora. Valid values are MYSQL and POSTGRESQL"
}
variable "idle_client_timeout" {
type = number
default = 1800
description = "The number of seconds that a connection to the proxy can be inactive before the proxy disconnects it"
}
variable "require_tls" {
type = bool
default = false
description = "A Boolean parameter that specifies whether Transport Layer Security (TLS) encryption is required for connections to the proxy. By enabling this setting, you can enforce encrypted TLS connections to the proxy"
}
variable "vpc_security_group_ids" {
type = set(string)
description = "One or more VPC security group IDs to associate with the proxy"
}
variable "vpc_subnet_ids" {
type = set(string)
description = "One or more VPC subnet IDs to associate with the proxy"
}
variable "auth" {
type = list(object({
auth_scheme = string
description = string
iam_auth = string
secret_arn = string
}))
description = "Configuration blocks with authorization mechanisms to connect to the associated database instances or clusters"
}
variable "db_instance_identifier" {
type = string
default = null
description = "DB instance identifier. Either `db_instance_identifier` or `db_cluster_identifier` should be specified and both should not be specified together"
}
variable "db_cluster_identifier" {
type = string
default = null
description = "DB cluster identifier. Either `db_instance_identifier` or `db_cluster_identifier` should be specified and both should not be specified together"
}
variable "connection_borrow_timeout" {
type = number
default = 120
description = "The number of seconds for a proxy to wait for a connection to become available in the connection pool. Only applies when the proxy has opened its maximum number of connections and all connections are busy with client sessions"
}
variable "init_query" {
type = string
default = null
description = "One or more SQL statements for the proxy to run when opening each new database connection"
}
variable "max_connections_percent" {
type = number
default = 100
description = "The maximum size of the connection pool for each target in a target group"
}
variable "max_idle_connections_percent" {
type = number
default = 50
description = "Controls how actively the proxy closes idle database connections in the connection pool. A high value enables the proxy to leave a high percentage of idle connections open. A low value causes the proxy to close idle client connections and return the underlying database connections to the connection pool"
}
variable "session_pinning_filters" {
type = list(string)
default = null
description = "Each item in the list represents a class of SQL operations that normally cause all later statements in a session using a proxy to be pinned to the same underlying database connection"
}
variable "iam_role_attributes" {
type = list(string)
default = null
description = "Additional attributes to add to the ID of the IAM role that the proxy uses to access secrets in AWS Secrets Manager"
}
variable "existing_iam_role_arn" {
type = string
default = null
description = "The ARN of an existing IAM role that the proxy can use to access secrets in AWS Secrets Manager. If not provided, the module will create a role to access secrets in Secrets Manager"
}
variable "kms_key_id" {
type = string
default = null
description = "The ARN or Id of the AWS KMS customer master key (CMK) to encrypt the secret values in the versions stored in secrets. If you don't specify this value, then Secrets Manager defaults to using the AWS account's default CMK (the one named `aws/secretsmanager`)"
}
variable "proxy_create_timeout" {
type = string
default = "30m"
description = "Proxy creation timeout"
}
variable "proxy_update_timeout" {
type = string
default = "30m"
description = "Proxy update timeout"
}
variable "proxy_delete_timeout" {
type = string
default = "60m"
description = "Proxy delete timeout"
}