-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathvariables.tf
238 lines (203 loc) · 6.39 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
variable "ami_id" {
type = string
description = "ID of the Spacelift AMI. If left empty, the latest Spacelift AMI will be used."
default = ""
}
variable "configuration" {
type = string
description = <<EOF
User configuration. This allows you to decide how you want to pass your token
and private key to the environment - be that directly, or using SSM Parameter
Store, Vault etc. Ultimately, here you need to export SPACELIFT_TOKEN and
SPACELIFT_POOL_PRIVATE_KEY to the environment.
EOF
}
variable "disable_container_credentials" {
type = bool
description = <<EOF
If true, the run container will not be able to access the instance profile
credentials by talking to the EC2 metadata endpoint. This is done by setting
the number of hops in IMDSv2 to 1. Since the Docker container goes through an
extra NAT step, this still allows the launcher to talk to the endpoint, but
prevents the container from doing so.
EOF
default = false
}
variable "autoscaling_group_arn" {
type = string
description = "autoscaling group ARN. Required for autoscaler"
}
variable "domain_name" {
type = string
description = "Top-level domain name to use for pulling the launcher binary"
default = "spacelift.io"
}
variable "ec2_instance_type" {
type = string
description = "EC2 instance type for the workers. If an arm64-based AMI is used, this must be an arm64-based instance type."
default = "t3.micro"
}
variable "enabled_metrics" {
type = list(string)
description = "List of CloudWatch metrics enabled on the ASG"
default = [
"GroupDesiredCapacity",
"GroupInServiceInstances",
"GroupMaxSize",
"GroupMinSize",
"GroupPendingInstances",
"GroupStandbyInstances",
"GroupTerminatingInstances",
"GroupTotalInstances",
]
}
variable "custom_iam_role_name" {
description = "Name of an existing IAM to use. Used `when create_iam_role` = `false`"
type = string
default = ""
}
variable "create_iam_role" {
description = "Determines whether an IAM role is created or to use an existing IAM role"
type = bool
default = true
}
variable "min_size" {
type = number
description = "Minimum numbers of workers to spin up"
default = 0
}
variable "max_size" {
type = number
description = "Maximum number of workers to spin up"
default = 10
}
variable "poweroff_delay" {
type = number
description = "Number of seconds to wait before powering the EC2 instance off after the Spacelift launcher stopped"
default = 15
}
variable "security_groups" {
type = list(string)
description = "List of security groups to use"
}
variable "additional_tags" {
type = map(string)
description = "Additional tags to set on the resources"
default = {}
}
variable "tag_specifications" {
description = "Tag specifications to set on the launch template, which will apply to the instances at launch"
type = list(object({
resource_type = string
tags = optional(map(string), {})
}))
default = []
}
variable "volume_encryption" {
type = bool
default = false
description = "Whether to encrypt the EBS volume"
}
variable "volume_size" {
type = number
default = 40
description = "Size of instance EBS volume"
}
variable "vpc_subnets" {
type = list(string)
description = "List of VPC subnets to use"
}
variable "worker_pool_id" {
type = string
description = "ID (ULID) of the the worker pool."
validation {
condition = can(regex("^[0-9A-HJKMNP-TV-Z]+$", var.worker_pool_id))
error_message = "The worker pool ID must be a valid ULID (eg 01HCC6QZ932J7WDF4FTVM9QMEP)."
}
}
variable "base_name" {
type = string
description = "Base name for resources. If unset, it defaults to `sp5ft-$${var.worker_pool_id}`."
nullable = true
default = null
}
variable "enable_monitoring" {
description = "Enables/disables detailed monitoring"
type = bool
default = true
}
variable "instance_refresh" {
description = "If this block is configured, start an Instance Refresh when this Auto Scaling Group is updated based on instance refresh configration."
type = any
default = {}
}
variable "enable_autoscaling" {
default = true
description = "Determines whether to create the Lambda Autoscaler function and dependent resources or not"
type = bool
}
variable "autoscaler_version" {
description = "Version of the autoscaler to deploy"
type = string
default = "latest"
nullable = false
}
variable "autoscaler_architecture" {
type = string
description = "Instruction set architecture of the autoscaler to use"
default = "amd64"
}
variable "spacelift_api_key_id" {
type = string
description = "ID of the Spacelift API key to use"
default = null
}
variable "spacelift_api_key_secret" {
type = string
sensitive = true
description = "Secret corresponding to the Spacelift API key to use"
default = null
}
variable "spacelift_api_key_endpoint" {
type = string
description = "Full URL of the Spacelift API endpoint to use, eg. https://demo.app.spacelift.io"
default = null
}
variable "schedule_expression" {
type = string
description = "Autoscaler scheduling expression"
default = "rate(1 minute)"
}
variable "volume_encryption_kms_key_id" {
description = "KMS key ID to use for encrypting the EBS volume"
type = string
default = null
}
variable "autoscaling_max_create" {
description = "The maximum number of instances the utility is allowed to create in a single run"
type = number
default = 1
}
variable "autoscaling_max_terminate" {
description = "The maximum number of instances the utility is allowed to terminate in a single run"
type = number
default = 1
}
variable "autoscaling_timeout" {
type = number
description = "Timeout (in seconds) for a single autoscaling run. The more instances you have, the higher this should be."
default = 30
}
variable "autoscaler_s3_package" {
type = object({
bucket = string
key = string
object_version = optional(string)
})
description = "Configuration to retrieve autoscaler lambda package from s3 bucket"
default = null
}
variable "region" {
type = string
description = "AWS region to deploy to"
}