infrastructure/main.tf

94 lines
2.3 KiB
Terraform
Raw Normal View History

2024-09-25 11:23:52 +00:00
terraform {
required_providers {
2024-09-28 12:14:09 +00:00
authentik = {
source = "goauthentik/authentik"
version = "~> 2024.8.0"
}
2024-09-25 11:23:52 +00:00
hcloud = {
source = "hetznercloud/hcloud"
2024-09-28 12:14:09 +00:00
version = "~> 1.45.0"
2024-09-25 11:23:52 +00:00
}
ovh = {
source = "ovh/ovh"
2024-09-28 12:14:09 +00:00
version = "~> 0.48.0"
2024-09-25 11:23:52 +00:00
}
2024-09-27 23:59:53 +00:00
postgresql = {
source = "cyrilgdn/postgresql"
2024-09-28 12:14:09 +00:00
version = "~> 1.23.0"
2024-09-27 23:59:53 +00:00
}
2024-09-25 11:23:52 +00:00
scaleway = {
source = "scaleway/scaleway"
2024-09-28 12:14:09 +00:00
version = "~> 2.43.0"
2024-09-25 11:23:52 +00:00
}
tailscale = {
source = "tailscale/tailscale"
2024-09-28 12:14:09 +00:00
version = "~> 0.16.0"
2024-09-25 11:23:52 +00:00
}
}
backend "s3" {
bucket = var.backend_bucket
access_key = var.backend_access_key
secret_key = var.backend_secret_key
key = "terraform.tfstate"
region = var.backend_region
encrypt = true
endpoints = {
s3 = var.backend_endpoint
}
# Disable AWS-specific features
skip_credentials_validation = true
skip_region_validation = true
skip_requesting_account_id = true
skip_s3_checksum = true
}
}
2024-09-28 12:14:09 +00:00
provider "authentik" {
url = "${var.authentik_url}"
token = "${var.authentik_token}"
}
2024-09-25 11:23:52 +00:00
provider "hcloud" {
token = "${var.hcloud_token}"
}
provider "ovh" {
endpoint = "ovh-eu"
application_key = "${var.ovh_application_key}"
application_secret = "${var.ovh_application_secret}"
consumer_key = "${var.ovh_consumer_key}"
}
2024-09-27 23:59:53 +00:00
provider "postgresql" {
host = "${var.postgresql_host}"
port = "${var.postgresql_port}"
database = "postgres"
username = "${var.postgresql_username}"
password = "${var.postgresql_password}"
sslmode = "verify-full"
connect_timeout = 15
}
2024-09-25 11:23:52 +00:00
provider "scaleway" {
organization_id = "${var.scaleway_organization_id}"
project_id = "${var.scaleway_project_id}"
access_key = "${var.scaleway_access_key}"
secret_key = "${var.scaleway_secret_key}"
region = "nl-ams"
zone = "nl-ams-1"
}
provider "tailscale" {
api_key = "${var.tailscale_api_key}"
tailnet = "${var.tailscale_tailnet}"
}
2024-09-28 12:14:09 +00:00
locals {
2024-09-28 16:24:07 +00:00
services_auth = {for key, val in var.services : key => val if val.auth}
services_database = {for key, val in var.services : key => val if val.database}
services_s3 = {for key, val in var.services : key => val if val.s3}
2024-09-28 12:14:09 +00:00
}