mirror of
https://github.com/Blockstream/satellite-api.git
synced 2025-02-22 05:41:37 +01:00
187 lines
6 KiB
HCL
187 lines
6 KiB
HCL
terraform {
|
|
required_providers {
|
|
google = {
|
|
source = "hashicorp/google"
|
|
}
|
|
google-beta = {
|
|
source = "hashicorp/google-beta"
|
|
}
|
|
}
|
|
required_version = ">= 0.15"
|
|
|
|
backend "gcs" {
|
|
bucket = "terraform-bs-source"
|
|
prefix = "satellite-api"
|
|
}
|
|
}
|
|
|
|
provider "google" {
|
|
project = var.project
|
|
}
|
|
|
|
provider "google-beta" {
|
|
project = var.project
|
|
}
|
|
|
|
module "blc-mainnet" {
|
|
source = "./modules/blc"
|
|
|
|
project = var.project
|
|
name = "satellite-api"
|
|
network = "default"
|
|
lightning_docker = var.lightning_docker
|
|
charge_docker = var.charge_docker
|
|
ionosphere_docker = var.ionosphere_docker
|
|
ionosphere_sse_docker = var.ionosphere_sse_docker
|
|
node_exporter_docker = var.node_exporter_docker
|
|
autossh_docker = var.autossh_docker
|
|
certbot_docker = var.certbot_docker
|
|
net = "mainnet"
|
|
env = local.env
|
|
lb_svc_acct = module.lb.lb_svc_acct
|
|
ssh_key_net = ""
|
|
lightning_cmd = "--mainnet --conf=/root/.lightning/bitcoin/lightning.conf"
|
|
|
|
create_resources = local.create_mainnet
|
|
|
|
# CI vars
|
|
region = var.region
|
|
zone = var.zone
|
|
instance_type = var.instance_type[1]
|
|
timeout = var.timeout
|
|
prom_service_acct = var.prom_service_acct
|
|
opsgenie_key = var.opsgenie_key
|
|
rpcpass = var.rpcpass
|
|
charge_token = var.charge_token
|
|
k8s_autossh_lb = var.k8s_autossh_lb
|
|
private_bucket = var.private_bucket
|
|
}
|
|
|
|
module "blc-testnet" {
|
|
source = "./modules/blc"
|
|
|
|
project = var.project
|
|
name = "satellite-api"
|
|
network = "default"
|
|
lightning_docker = var.lightning_docker
|
|
charge_docker = var.charge_docker
|
|
ionosphere_docker = var.ionosphere_docker
|
|
ionosphere_sse_docker = var.ionosphere_sse_docker
|
|
node_exporter_docker = var.node_exporter_docker
|
|
autossh_docker = var.autossh_docker
|
|
certbot_docker = var.certbot_docker
|
|
net = "testnet"
|
|
env = local.env
|
|
lb_svc_acct = length(data.terraform_remote_state.blc-mainnet.outputs) > 1 ? data.terraform_remote_state.blc-mainnet.outputs.lb_svc_acct : ""
|
|
ssh_key_net = "_testnet"
|
|
lightning_cmd = "--testnet --conf=/root/.lightning/testnet/lightning.conf"
|
|
|
|
create_resources = local.create_testnet
|
|
|
|
# CI vars
|
|
region = var.region
|
|
zone = var.zone
|
|
instance_type = var.instance_type[1]
|
|
timeout = var.timeout
|
|
prom_service_acct = var.prom_service_acct
|
|
opsgenie_key = var.opsgenie_key
|
|
rpcpass = var.rpcpass
|
|
charge_token = var.charge_token
|
|
k8s_autossh_lb = var.k8s_autossh_lb
|
|
private_bucket = var.private_bucket
|
|
}
|
|
|
|
module "lb" {
|
|
source = "./modules/lb"
|
|
|
|
project = var.project
|
|
name = "satellite-api-lb"
|
|
network = "default"
|
|
certbot_docker = var.certbot_docker
|
|
node_exporter_docker = var.node_exporter_docker
|
|
env = local.env
|
|
internal_ip_mainnet = module.blc-mainnet.internal_ip
|
|
internal_ip_testnet = local.env == "staging" ? "" : data.terraform_remote_state.blc-testnet.outputs.blc_internal_ip_testnet
|
|
internal_ip_gossip = local.env == "staging" ? "" : data.terraform_remote_state.gossip-prod.outputs.gossip_internal_ip
|
|
internal_ip_auth = local.env == "staging" ? "" : data.terraform_remote_state.auth-prod.outputs.auth_internal_ip
|
|
internal_ip_btc_src = local.env == "staging" ? "" : data.terraform_remote_state.btc-src-prod.outputs.btc_src_internal_ip
|
|
target_pool = length(google_compute_target_pool.lb-pool) > 0 ? google_compute_target_pool.lb-pool[0].self_link : ""
|
|
health_check = length(google_compute_http_health_check.lb-health) > 0 ? google_compute_http_health_check.lb-health[0].self_link : ""
|
|
|
|
create_resources = local.create_mainnet
|
|
|
|
# CI vars
|
|
region = var.region
|
|
zone = var.zone
|
|
instance_type = var.instance_type[0]
|
|
host = var.host
|
|
timeout = var.timeout
|
|
prom_service_acct = var.prom_service_acct
|
|
letsencrypt_email = var.letsencrypt_email
|
|
public_bucket_url = var.public_bucket_url
|
|
station1 = var.station1
|
|
station2 = var.station2
|
|
}
|
|
|
|
module "tor" {
|
|
source = "./modules/tor"
|
|
|
|
project = var.project
|
|
network = "default"
|
|
name = "satapi-tor"
|
|
gcloud_docker = var.gcloud_docker
|
|
tor_docker = var.tor_docker
|
|
node_exporter_docker = var.node_exporter_docker
|
|
kms_key = element(concat(google_kms_crypto_key.tor-crypto-key.*.name, [""]), 0)
|
|
kms_key_ring = element(concat(google_kms_key_ring.tor-key-ring.*.name, [""]), 0)
|
|
kms_key_link = element(
|
|
concat(google_kms_crypto_key.tor-crypto-key.*.self_link, [""]),
|
|
0,
|
|
)
|
|
tor_lb = element(
|
|
concat(google_compute_global_address.tor-lb.*.address, [""]),
|
|
0,
|
|
)
|
|
|
|
create_resources = local.create_misc
|
|
|
|
# CI vars
|
|
region = var.region
|
|
zone = var.zone
|
|
instance_type = var.instance_type[0]
|
|
onion_host = var.onion_host
|
|
prom_service_acct = var.prom_service_acct
|
|
}
|
|
|
|
module "prometheus" {
|
|
source = "./modules/prometheus"
|
|
|
|
project = var.project
|
|
network = "default"
|
|
name = "satapi-prometheus"
|
|
prom_docker = var.prom_docker
|
|
node_exporter_docker = var.node_exporter_docker
|
|
|
|
create_resources = local.create_misc
|
|
|
|
# CI vars
|
|
region = var.region
|
|
zone = var.zone
|
|
instance_type = var.instance_type[1]
|
|
prom_allowed_source_ip = var.prom_allowed_source_ip
|
|
prom_service_acct = var.prom_service_acct
|
|
}
|
|
|
|
module "dns" {
|
|
source = "./modules/dns"
|
|
|
|
project = var.project
|
|
|
|
create_resources = local.create_misc
|
|
|
|
# CI vars
|
|
satellite_lb = var.satellite_lb
|
|
satellite_api_lb = var.satellite_api_lb
|
|
satellite_api_lb_staging = var.satellite_api_lb_staging
|
|
blocksat_monitoring = var.blocksat_monitoring
|
|
}
|