forked from oracle-terraform-modules/terraform-oci-oke
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.tf
430 lines (343 loc) · 14 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
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
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
# Copyright 2017, 2022 Oracle Corporation and/or affiliates.
# Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl
module "vcn" {
source = "oracle-terraform-modules/vcn/oci"
version = "3.5.3"
# general oci parameters
compartment_id = local.compartment_id
label_prefix = var.label_prefix
# gateways
create_internet_gateway = var.load_balancers == "internal" && var.create_bastion_host == false && var.control_plane_type == "private" ? false : true
create_nat_gateway = var.worker_type == "private" || var.create_operator == true || (var.load_balancers == "internal" || var.load_balancers == "both") ? true : false
create_service_gateway = true
nat_gateway_public_ip_id = var.nat_gateway_public_ip_id
attached_drg_id = var.drg_id != null ? var.drg_id : (var.create_drg ? module.drg[0].drg_id : null)
# lpgs
local_peering_gateways = var.local_peering_gateways
# tags
freeform_tags = var.freeform_tags["vcn"]
defined_tags = var.defined_tags["vcn"]
# vcn
vcn_cidrs = var.vcn_cidrs
vcn_dns_label = var.assign_dns ? var.vcn_dns_label : null
vcn_name = var.vcn_name
lockdown_default_seclist = var.lockdown_default_seclist
internet_gateway_route_rules = var.internet_gateway_route_rules
nat_gateway_route_rules = var.nat_gateway_route_rules
count = var.create_vcn == true ? 1 : 0
}
module "drg" {
source = "oracle-terraform-modules/drg/oci"
version = "1.0.3"
# general oci parameters
compartment_id = local.compartment_id
label_prefix = var.label_prefix
# drg parameters
drg_display_name = var.drg_display_name
drg_vcn_attachments = { for k, v in module.vcn : k => {
# gets the vcn_id values dynamically from the vcn module
vcn_id : v.vcn_id
vcn_transit_routing_rt_id : null
drg_route_table_id : null
}
}
# var.drg_id can either contain an existing DRG ID or be null.
drg_id = var.drg_id
count = var.create_drg || var.drg_id != null ? 1 : 0
}
module "bastion" {
source = "oracle-terraform-modules/bastion/oci"
version = "3.1.5"
tenancy_id = local.tenancy_id
compartment_id = local.compartment_id
label_prefix = var.label_prefix
# networking
assign_dns = var.assign_dns
availability_domain = var.availability_domains["bastion"]
bastion_access = var.bastion_access
ig_route_id = local.ig_route_id
netnum = lookup(var.subnets["bastion"], "netnum")
newbits = lookup(var.subnets["bastion"], "newbits")
vcn_id = local.vcn_id
# bastion host parameters
bastion_image_id = var.bastion_image_id
bastion_os_version = var.bastion_os_version
bastion_shape = var.bastion_shape
bastion_state = var.bastion_state
bastion_timezone = var.bastion_timezone
bastion_type = var.bastion_type
ssh_public_key = var.ssh_public_key
ssh_public_key_path = var.ssh_public_key_path
upgrade_bastion = var.upgrade_bastion
# bastion notification
enable_bastion_notification = var.enable_bastion_notification && var.create_policies
bastion_notification_endpoint = var.bastion_notification_endpoint
bastion_notification_protocol = var.bastion_notification_protocol
bastion_notification_topic = var.bastion_notification_topic
# tags
freeform_tags = var.freeform_tags["bastion"]
providers = {
oci.home = oci.home
}
depends_on = [
module.vcn
]
count = var.create_bastion_host == true ? 1 : 0
}
module "operator" {
source = "oracle-terraform-modules/operator/oci"
version = "3.1.5"
# general oci parameters
tenancy_id = local.tenancy_id
compartment_id = local.compartment_id
label_prefix = var.label_prefix
# networking
assign_dns = var.assign_dns
availability_domain = var.availability_domains["operator"]
nat_route_id = local.nat_route_id
netnum = lookup(var.subnets["operator"], "netnum")
newbits = lookup(var.subnets["operator"], "newbits")
nsg_ids = var.operator_nsg_ids
vcn_id = local.vcn_id
# operator host parameters
operator_image_id = var.operator_image_id
enable_operator_instance_principal = var.enable_operator_instance_principal && var.create_policies
enable_pv_encryption_in_transit = var.enable_operator_pv_encryption_in_transit
operator_os_version = var.operator_os_version
operator_shape = var.operator_shape
operator_state = var.operator_state
operator_timezone = var.operator_timezone
ssh_public_key = var.ssh_public_key
ssh_public_key_path = var.ssh_public_key_path
upgrade_operator = var.upgrade_operator
boot_volume_encryption_key = var.operator_volume_kms_id
# operator notification
enable_operator_notification = var.enable_operator_notification
operator_notification_endpoint = var.operator_notification_endpoint
operator_notification_protocol = var.operator_notification_protocol
operator_notification_topic = var.operator_notification_topic
# tags
freeform_tags = var.freeform_tags["operator"]
providers = {
oci.home = oci.home
}
depends_on = [
module.vcn
]
count = var.create_operator == true ? 1 : 0
}
module "bastionsvc" {
source = "./modules/bastionsvc"
# general oci parameters
compartment_id = local.compartment_id
label_prefix = var.label_prefix
# bastion service parameters
bastion_service_access = var.bastion_service_access
bastion_service_name = var.bastion_service_name
bastion_service_target_subnet = var.bastion_service_target_subnet
vcn_id = local.vcn_id
depends_on = [
module.operator
]
count = var.create_bastion_service == true ? 1 : 0
}
# additional networking for oke
module "network" {
source = "./modules/network"
# general oci parameters
compartment_id = local.compartment_id
label_prefix = var.label_prefix
# oke networking parameters
assign_dns = var.assign_dns
ig_route_id = local.ig_route_id
nat_route_id = local.nat_route_id
subnets = var.subnets
vcn_id = local.vcn_id
# control plane endpoint parameters
cni_type = var.cni_type
control_plane_type = var.control_plane_type
control_plane_allowed_cidrs = var.control_plane_allowed_cidrs
# oke worker network parameters
allow_node_port_access = var.allow_node_port_access
allow_worker_internet_access = var.allow_worker_internet_access
allow_pod_internet_access = var.allow_pod_internet_access
allow_worker_ssh_access = var.allow_worker_ssh_access
worker_type = var.worker_type
# oke load balancer network parameters
load_balancers = var.load_balancers
# oke internal load balancer
internal_lb_allowed_cidrs = var.internal_lb_allowed_cidrs
internal_lb_allowed_ports = var.internal_lb_allowed_ports
# oke public load balancer
public_lb_allowed_cidrs = var.public_lb_allowed_cidrs
public_lb_allowed_ports = var.public_lb_allowed_ports
# waf integration
enable_waf = var.enable_waf
# fss integration
create_fss = var.create_fss
depends_on = [
module.vcn
]
}
# # cluster creation for oke
module "oke" {
source = "./modules/oke"
# provider
tenancy_id = local.tenancy_id
# general oci parameters
compartment_id = local.compartment_id
label_prefix = var.label_prefix
# ssh keys
ssh_public_key = var.ssh_public_key
ssh_public_key_path = var.ssh_public_key_path
# oke cluster parameters
cluster_kubernetes_version = var.kubernetes_version
control_plane_type = var.control_plane_type
control_plane_nsgs = concat(var.control_plane_nsgs, [module.network.control_plane_nsg_id])
cluster_name = var.cluster_name
cluster_options_add_ons_is_kubernetes_dashboard_enabled = var.dashboard_enabled
cluster_options_kubernetes_network_config_pods_cidr = var.pods_cidr
cluster_options_kubernetes_network_config_services_cidr = var.services_cidr
cluster_subnets = module.network.subnet_ids
cni_type = var.cni_type
vcn_id = local.vcn_id
use_cluster_encryption = var.use_cluster_encryption
cluster_kms_key_id = var.cluster_kms_key_id
create_policies = var.create_policies
use_signed_images = var.use_signed_images
image_signing_keys = var.image_signing_keys
admission_controller_options = var.admission_controller_options
# oke node pool parameters
kubeproxy_mode = var.kubeproxy_mode
max_pods_per_node = var.max_pods_per_node
node_pools = var.node_pools
node_pool_name_prefix = var.node_pool_name_prefix
node_pool_image_id = var.node_pool_image_id
node_pool_image_type = var.node_pool_image_type
node_pool_os = var.node_pool_os
node_pool_os_version = var.node_pool_os_version
node_pool_timezone = var.node_pool_timezone
enable_pv_encryption_in_transit = var.enable_pv_encryption_in_transit
use_node_pool_volume_encryption = var.use_node_pool_volume_encryption
node_pool_volume_kms_key_id = var.node_pool_volume_kms_key_id
cloudinit_nodepool = var.cloudinit_nodepool
cloudinit_nodepool_common = var.cloudinit_nodepool_common
# oke load balancer parameters
preferred_load_balancer = var.preferred_load_balancer
# nsgs
pod_nsgs = concat(module.network.pod_nsg_id)
worker_nsgs = concat(var.worker_nsgs, [module.network.worker_nsg_id])
# tags
freeform_tags = var.freeform_tags["oke"]
defined_tags = var.defined_tags["oke"]
depends_on = [
module.network
]
providers = {
oci.home = oci.home
}
}
#fss
module "storage" {
source = "./modules/storage"
# general oci parameters
tenancy_id = local.tenancy_id
compartment_id = local.compartment_id
availability_domain = var.availability_domains["fss"]
label_prefix = var.label_prefix
# FSS network information
subnets = var.subnets
assign_dns = var.assign_dns
vcn_id = local.vcn_id
nat_route_id = local.nat_route_id
fss_mount_path = var.fss_mount_path
# Export set configuration
max_fs_stat_bytes = var.max_fs_stat_bytes
max_fs_stat_files = var.max_fs_stat_files
providers = {
oci.home = oci.home
}
count = var.create_fss == true ? 1 : 0
}
# extensions to oke
module "extensions" {
source = "./modules/extensions"
# provider
tenancy_id = local.tenancy_id
# general oci parameters
compartment_id = local.compartment_id
label_prefix = var.label_prefix
# region parameters
region = var.region
# ssh keys
ssh_private_key = var.ssh_private_key
ssh_private_key_path = var.ssh_private_key_path
ssh_public_key = var.ssh_public_key
ssh_public_key_path = var.ssh_public_key_path
# bastion
create_bastion_host = var.create_bastion_host
bastion_public_ip = local.bastion_public_ip
bastion_user = var.bastion_user
bastion_state = var.bastion_state
# operator details
create_operator = var.create_operator
operator_private_ip = local.operator_private_ip
operator_user = var.operator_user
operator_state = var.operator_state
operator_dynamic_group = local.operator_instance_principal_group_name
enable_operator_instance_principal = var.enable_operator_instance_principal
operator_os_version = var.operator_os_version
# oke cluster parameters
cluster_id = module.oke.cluster_id
cluster_name = var.cluster_name
pods_cidr = var.pods_cidr
use_cluster_encryption = var.use_cluster_encryption
cluster_kms_key_id = var.cluster_kms_key_id
cluster_kms_dynamic_group_id = module.oke.cluster_kms_dynamic_group_id
create_policies = var.create_policies
# ocir parameters
email_address = var.email_address
secret_id = var.secret_id
secret_name = var.secret_name
secret_namespace = var.secret_namespace
username = var.username
# calico parameters
install_calico = var.enable_calico
calico_version = var.calico_version
calico_mode = var.calico_mode
cni_type = var.cni_type
calico_mtu = var.calico_mtu
calico_url = var.calico_url
calico_apiserver_enabled = var.calico_apiserver_enabled
calico_staging_dir = var.calico_staging_dir
typha_enabled = var.typha_enabled
typha_replicas = var.typha_replicas
# metric server
enable_metric_server = var.enable_metric_server
enable_vpa = var.enable_vpa
vpa_version = var.vpa_version
#Gatekeeper
enable_gatekeeper = var.enable_gatekeeper
gatekeeper_version = var.gatekeeper_version
# service account
create_service_account = var.create_service_account
service_account_name = var.service_account_name
service_account_namespace = var.service_account_namespace
service_account_cluster_role_binding = var.service_account_cluster_role_binding
#check worker nodes are active
check_node_active = var.check_node_active
# oke upgrade
upgrade_nodepool = var.upgrade_nodepool
nodepool_upgrade_method = var.nodepool_upgrade_method
node_pools_to_drain = var.node_pools_to_drain
debug_mode = var.debug_mode
depends_on = [
module.bastion,
module.network,
module.operator,
module.oke
]
providers = {
oci.home = oci.home
}
}