forked from aws-ia/terraform-aws-polygon-technology-edge
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.tf
162 lines (129 loc) · 4.81 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
module "vpc" {
source = "aws-ia/vpc/aws"
version = "= 1.4.1"
name = var.vpc_name
cidr_block = var.vpc_cidr_block
az_count = 4
subnets = {
public = {
netmask = 24
nat_gateway_configuration = "all_azs"
}
private = {
netmask = 24
route_to_nat = true
}
}
vpc_flow_logs = {
log_destination_type = "cloud-watch-logs"
retention_in_days = 180
}
}
locals {
package_url = var.lambda_function_zip
downloaded = basename(var.lambda_function_zip)
azs = slice(data.aws_availability_zones.current.names, 0, 4)
private_subnets = [for _, value in module.vpc.private_subnet_attributes_by_az : value.id]
private_azs = {
for idx, az_name in local.azs : idx => az_name
}
}
module "s3" {
source = "terraform-aws-modules/s3-bucket/aws"
version = ">= 3.3.0"
bucket_prefix = var.s3_bucket_prefix
acl = "private"
force_destroy = var.s3_force_destroy
}
module "security" {
source = "./modules/security"
vpc_id = module.vpc.vpc_attributes.id
account_id = data.aws_caller_identity.current.account_id
s3_shared_bucket_name = module.s3.s3_bucket_id
ssm_parameter_id = var.ssm_parameter_id
region = data.aws_region.current.name
internal_sec_gr_name_tag = var.internal_sec_gr_name_tag
alb_sec_gr_name_tag = var.alb_sec_gr_name_tag
lambda_function_name = var.lambda_function_name
}
module "instances" {
source = "./modules/instances"
for_each = local.private_azs
internal_subnet = local.private_subnets[each.key]
internal_sec_groups = [module.security.internal_sec_group_id]
user_data_base64 = module.user_data[each.key].polygon_edge_node
instance_iam_role = module.security.ec2_to_assm_iam_policy_id
az = each.value
instance_type = var.instance_type
instance_name = var.instance_name
ebs_root_name_tag = var.ebs_root_name_tag
instance_interface_name_tag = var.instance_interface_name_tag
chain_data_ebs_volume_size = var.chain_data_ebs_volume_size
chain_data_ebs_name_tag = var.chain_data_ebs_name_tag
depends_on = [module.lambda]
}
module "user_data" {
source = "./modules/user-data"
for_each = local.private_azs
node_name = "${var.node_name_prefix}-${each.value}"
assm_path = var.ssm_parameter_id
assm_region = data.aws_region.current.name
s3_bucket_name = module.s3.s3_bucket_id
s3_key_name = var.s3_key_name
total_nodes = length(module.vpc.private_subnet_attributes_by_az)
polygon_edge_dir = var.polygon_edge_dir
ebs_device = var.ebs_device
# Server configuration
max_slots = var.max_slots
block_time = var.block_time
prometheus_address = var.prometheus_address
block_gas_target = var.block_gas_target
nat_address = var.nat_address
dns_name = var.dns_name
price_limit = var.price_limit
# # Chain configuration
premine = var.premine
chain_name = var.chain_name
chain_id = var.chain_id
block_gas_limit = var.block_gas_limit
epoch_size = var.epoch_size
consensus = var.consensus
lambda_function_name = var.lambda_function_name
max_validator_count = var.max_validator_count
min_validator_count = var.min_validator_count
pos = var.pos
}
module "alb" {
source = "./modules/alb"
public_subnets = [for _, value in module.vpc.public_subnet_attributes_by_az : value.id]
alb_sec_group = module.security.jsonrpc_sec_group_id
vpc_id = module.vpc.vpc_attributes.id
node_ids = [for _, instance in module.instances : instance.instance_id]
alb_ssl_certificate = var.alb_ssl_certificate
nodes_alb_name_prefix = var.nodes_alb_name_prefix
nodes_alb_name_tag = var.nodes_alb_name_tag
nodes_alb_targetgroup_name_prefix = var.nodes_alb_targetgroup_name_prefix
}
resource "null_resource" "download_package" {
triggers = {
downloaded = local.downloaded
}
provisioner "local-exec" {
command = "curl -L -o ${local.downloaded} ${local.package_url}"
}
}
module "lambda" {
source = "terraform-aws-modules/lambda/aws"
version = ">=3.3.1"
function_name = var.lambda_function_name
description = "Lambda function used to initialize chain and generate genesis.json"
handler = "main"
runtime = "go1.x"
timeout = 20
memory_size = 256
create_package = false
local_existing_package = data.null_data_source.downloaded_package.outputs["filename"]
attach_policy_jsons = true
number_of_policy_jsons = 2
policy_jsons = [data.aws_iam_policy_document.genesis_s3.json, data.aws_iam_policy_document.genesis_ssm.json]
}