forked from dgozalo/terraform-eks-jx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.tf
160 lines (149 loc) · 7.45 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
// ----------------------------------------------------------------------------
// Configure providers
// ----------------------------------------------------------------------------
provider "helm" {
kubernetes {
host = module.cluster.cluster_host
cluster_ca_certificate = module.cluster.cluster_ca_certificate
token = module.cluster.cluster_token
}
}
resource "random_string" "suffix" {
length = 8
special = false
}
resource "random_pet" "current" {
prefix = "tf-jx"
separator = "-"
keepers = {
# Keep the name consistent on executions
cluster_name = var.cluster_name
}
}
data "aws_caller_identity" "current" {}
// ----------------------------------------------------------------------------
// Setup all required AWS resources as well as the EKS cluster and any k8s resources
// See https://www.terraform.io/docs/providers/aws/r/vpc.html
// See https://www.terraform.io/docs/providers/aws/r/eks_cluster.html
// ----------------------------------------------------------------------------
module "cluster" {
source = "./modules/cluster"
region = var.region
create_eks = var.create_eks
create_vpc = var.create_vpc
vpc_id = var.vpc_id
subnets = var.subnets
cluster_name = local.cluster_name
cluster_version = var.cluster_version
desired_node_count = var.desired_node_count
min_node_count = var.min_node_count
max_node_count = var.max_node_count
node_machine_type = var.node_machine_type
node_groups = var.node_groups_managed
spot_price = var.spot_price
encrypt_volume_self = var.encrypt_volume_self
vpc_name = var.vpc_name
public_subnets = var.public_subnets
private_subnets = var.private_subnets
vpc_cidr_block = var.vpc_cidr_block
enable_nat_gateway = var.enable_nat_gateway
single_nat_gateway = var.single_nat_gateway
force_destroy = var.force_destroy
enable_spot_instances = var.enable_spot_instances
node_group_disk_size = var.node_group_disk_size
enable_worker_group = var.enable_worker_group
cluster_in_private_subnet = var.cluster_in_private_subnet
map_accounts = var.map_accounts
map_roles = var.map_roles
map_users = var.map_users
enable_key_name = var.enable_key_name
key_name = var.key_name
volume_type = var.volume_type
volume_size = var.volume_size
iops = var.iops
use_kms_s3 = var.use_kms_s3
s3_kms_arn = var.s3_kms_arn
is_jx2 = var.is_jx2
content = local.content
cluster_endpoint_public_access = var.cluster_endpoint_public_access
cluster_endpoint_public_access_cidrs = var.cluster_endpoint_public_access_cidrs
cluster_endpoint_private_access = var.cluster_endpoint_private_access
cluster_endpoint_private_access_cidrs = var.cluster_endpoint_private_access_cidrs
enable_worker_groups_launch_template = var.enable_worker_groups_launch_template
allowed_spot_instance_types = var.allowed_spot_instance_types
lt_desired_nodes_per_subnet = var.lt_desired_nodes_per_subnet
lt_min_nodes_per_subnet = var.lt_min_nodes_per_subnet
lt_max_nodes_per_subnet = var.lt_max_nodes_per_subnet
jx_git_url = var.jx_git_url
jx_bot_username = var.jx_bot_username
jx_bot_token = var.jx_bot_token
cluster_encryption_config = var.cluster_encryption_config
create_autoscaler_role = var.create_autoscaler_role
create_bucketrepo_role = var.create_bucketrepo_role
create_cm_role = var.create_cm_role
create_cmcainjector_role = var.create_cmcainjector_role
create_ctrlb_role = var.create_ctrlb_role
create_exdns_role = var.create_exdns_role
create_pipeline_vis_role = var.create_pipeline_vis_role
create_asm_role = var.create_asm_role
create_ssm_role = var.create_ssm_role
create_tekton_role = var.create_tekton_role
additional_tekton_role_policy_arns = var.additional_tekton_role_policy_arns
tls_cert = var.tls_cert
tls_key = var.tls_key
}
// ----------------------------------------------------------------------------
// Setup all required resources for using the bank-vaults operator
// See https://github.com/banzaicloud/bank-vaults
// ----------------------------------------------------------------------------
module "vault" {
source = "./modules/vault"
cluster_name = local.cluster_name
vault_user = var.vault_user
force_destroy = var.force_destroy
external_vault = local.external_vault
use_vault = var.use_vault
region = var.region
}
// ----------------------------------------------------------------------------
// Setup all required resources for using Velero for cluster backups
// ----------------------------------------------------------------------------
module "backup" {
source = "./modules/backup"
enable_backup = var.enable_backup
cluster_name = local.cluster_name
force_destroy = var.force_destroy
velero_username = var.velero_username
create_velero_role = var.create_velero_role
}
// ----------------------------------------------------------------------------
// Setup all required Route 53 resources if External DNS / Cert Manager is enabled
// ----------------------------------------------------------------------------
module "dns" {
source = "./modules/dns"
apex_domain = var.apex_domain
subdomain = var.subdomain
tls_email = var.tls_email
enable_external_dns = var.enable_external_dns
create_and_configure_subdomain = var.create_and_configure_subdomain
force_destroy_subdomain = var.force_destroy_subdomain
enable_tls = var.enable_tls
production_letsencrypt = var.production_letsencrypt
manage_apex_domain = var.manage_apex_domain
manage_subdomain = var.manage_subdomain
}
module "health" {
source = "./modules/health"
is_jx2 = var.is_jx2
install_kuberhealthy = var.install_kuberhealthy
}
module "nginx" {
source = "./modules/nginx"
is_jx2 = var.is_jx2
create_nginx = var.create_nginx
nginx_release_name = var.nginx_release_name
nginx_namespace = var.nginx_namespace
nginx_chart_version = var.nginx_chart_version
create_nginx_namespace = var.create_nginx_namespace
nginx_values_file = var.nginx_values_file
}