116 lines
2.9 KiB
HCL
116 lines
2.9 KiB
HCL
# Terraform configuration for the GCP project 'tazjins-infrastructure'
|
|
|
|
provider "google" {
|
|
project = "tazjins-infrastructure"
|
|
region = "europe-north1"
|
|
version = "~> 2.20"
|
|
}
|
|
|
|
# Configure a storage bucket in which to keep Terraform state and
|
|
# other data, such as Nixery's layers.
|
|
resource "google_storage_bucket" "tazjins-data" {
|
|
name = "tazjins-data"
|
|
location = "EU"
|
|
}
|
|
|
|
terraform {
|
|
backend "gcs" {
|
|
bucket = "tazjins-data"
|
|
prefix = "terraform"
|
|
}
|
|
}
|
|
|
|
# Configure enabled APIs
|
|
resource "google_project_services" "primary" {
|
|
project = "tazjins-infrastructure"
|
|
services = [
|
|
"bigquery-json.googleapis.com",
|
|
"bigquerystorage.googleapis.com",
|
|
"cloudapis.googleapis.com",
|
|
"cloudbuild.googleapis.com",
|
|
"clouddebugger.googleapis.com",
|
|
"cloudfunctions.googleapis.com",
|
|
"cloudkms.googleapis.com",
|
|
"cloudtrace.googleapis.com",
|
|
"compute.googleapis.com",
|
|
"container.googleapis.com",
|
|
"containerregistry.googleapis.com",
|
|
"datastore.googleapis.com",
|
|
"distance-matrix-backend.googleapis.com",
|
|
"dns.googleapis.com",
|
|
"gmail.googleapis.com",
|
|
"iam.googleapis.com",
|
|
"iamcredentials.googleapis.com",
|
|
"logging.googleapis.com",
|
|
"monitoring.googleapis.com",
|
|
"oslogin.googleapis.com",
|
|
"pubsub.googleapis.com",
|
|
"run.googleapis.com",
|
|
"secretmanager.googleapis.com",
|
|
"servicemanagement.googleapis.com",
|
|
"serviceusage.googleapis.com",
|
|
"sourcerepo.googleapis.com",
|
|
"sql-component.googleapis.com",
|
|
"storage-api.googleapis.com",
|
|
"storage-component.googleapis.com",
|
|
]
|
|
}
|
|
|
|
|
|
# Configure the main Kubernetes cluster in which services are deployed
|
|
resource "google_container_cluster" "primary" {
|
|
name = "tazjin-cluster"
|
|
location = "europe-north1"
|
|
|
|
remove_default_node_pool = true
|
|
initial_node_count = 1
|
|
}
|
|
|
|
resource "google_container_node_pool" "primary_nodes" {
|
|
name = "primary-nodes"
|
|
location = "europe-north1"
|
|
cluster = google_container_cluster.primary.name
|
|
node_count = 1
|
|
|
|
node_config {
|
|
preemptible = true
|
|
machine_type = "n1-standard-2"
|
|
|
|
oauth_scopes = [
|
|
"storage-rw",
|
|
"logging-write",
|
|
"monitoring",
|
|
"https://www.googleapis.com/auth/source.read_only",
|
|
]
|
|
}
|
|
}
|
|
|
|
# Configure a service account for which GCS URL signing keys can be created.
|
|
resource "google_service_account" "nixery" {
|
|
account_id = "nixery"
|
|
display_name = "Nixery service account"
|
|
}
|
|
|
|
# Configure Cloud KMS for secret encryption
|
|
resource "google_kms_key_ring" "tazjins_keys" {
|
|
name = "tazjins-keys"
|
|
location = "europe-north1"
|
|
|
|
lifecycle {
|
|
prevent_destroy = true
|
|
}
|
|
}
|
|
|
|
resource "google_kms_crypto_key" "kontemplate_key" {
|
|
name = "kontemplate-key"
|
|
key_ring = google_kms_key_ring.tazjins_keys.id
|
|
|
|
lifecycle {
|
|
prevent_destroy = true
|
|
}
|
|
}
|
|
|
|
# Configure the git repository that contains everything.
|
|
resource "google_sourcerepo_repository" "depot" {
|
|
name = "depot"
|
|
}
|