-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathmain.tf
150 lines (137 loc) · 4.51 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
# Terraform setup stuff, required providers, where they are sourced from, and
# the provider's configuration requirements.
terraform {
required_providers {
hiera5 = {
source = "chriskuchin/hiera5"
version = "0.3.0"
}
google = {
source = "hashicorp/google"
version = "3.68.0"
}
random = {
source = "hashicorp/random"
version = "3.1.0"
}
}
}
# Sets the variables that'll be interpolated to determine where variables are
# located in the hierarchy
provider "hiera5" {
scope = {
architecture = var.architecture
replica = var.replica
profile = var.cluster_profile
}
}
# GCP region and project to operating within
provider "google" {
project = var.project
region = var.region
}
# hiera lookps
data "hiera5" "server_count" {
key = "server_count"
}
data "hiera5" "database_count" {
key = "database_count"
}
data "hiera5_bool" "has_compilers" {
key = "has_compilers"
}
data "hiera5" "compiler_type" {
key = "compiler_instance_type"
}
data "hiera5" "primary_type" {
key = "primary_instance_type"
}
data "hiera5" "database_type" {
key = "database_instance_type"
}
data "hiera5" "compiler_disk" {
key = "compiler_disk_size"
}
data "hiera5" "primary_disk" {
key = "primary_disk_size"
}
data "hiera5" "database_disk" {
key = "database_disk_size"
}
# Retrieve list of zones to deploy to prevent needing to know what they are for
# each region. Use count to trigger a no-op when Bolt runs a destroy plan.
data "google_compute_zones" "available" {
count = var.destroy ? 0 : 1
status = "UP"
}
# It is intended that multiple deployments can be launched easily without
# name collisions
resource "random_id" "deployment" {
byte_length = 3
}
# Collect some repeated values used by each major component module into one to
# make them easier to update
locals {
zones = try(data.google_compute_zones.available[0].names, ["a", "b", "c"])
allowed = concat(["10.128.0.0/9", "35.191.0.0/16", "130.211.0.0/22"], var.firewall_allow)
compiler_count = data.hiera5_bool.has_compilers.value ? var.compiler_count : 0
id = random_id.deployment.hex
network = coalesce(module.networking.network_link, try(data.google_compute_subnetwork.existing[0].network, null))
subnet = coalesce(module.networking.subnetwork_link, try(data.google_compute_subnetwork.existing[0].self_link, null))
create_network = var.subnet == null ? true : false
fetch_existing = var.subnet == null ? 0 : 1
has_lb = var.disable_lb ? false : data.hiera5_bool.has_compilers.value ? true : false
}
# If we didn't create a network then we need to know the network of our
# pre-existing, likely a shared subnetwork to associate resource with
data "google_compute_subnetwork" "existing" {
count = local.fetch_existing
name = var.subnet
region = var.region
project = var.subnet_project
}
# Contain all the networking configuration in a module for readability
module "networking" {
source = "./modules/networking"
id = local.id
allow = local.allowed
to_create = local.create_network
}
# Contain all the loadbalancer configuration in a module for readability
module "loadbalancer" {
source = "./modules/loadbalancer"
id = local.id
ports = ["8140", "8142"]
network = local.network
subnetwork = local.subnet
region = var.region
instances = module.instances.compilers
has_lb = local.has_lb
lb_ip_mode = var.lb_ip_mode
}
# Contain all the instances configuration in a module for readability
module "instances" {
source = "./modules/instances"
id = local.id
network = local.network
subnetwork = local.subnet
subnetwork_project = var.subnet_project
zones = local.zones
user = var.user
ssh_key = var.ssh_key
compiler_count = local.compiler_count
node_count = var.node_count
instance_image = var.instance_image
labels = var.labels
metadata = var.metadata
project = var.project
domain_name = var.domain_name
server_count = data.hiera5.server_count.value
database_count = data.hiera5.database_count.value
compiler_type = data.hiera5.compiler_type.value
primary_type = data.hiera5.primary_type.value
database_type = data.hiera5.database_type.value
compiler_disk = data.hiera5.compiler_disk.value
primary_disk = data.hiera5.primary_disk.value
database_disk = data.hiera5.database_disk.value
}