Terraform

If you are in an environment where resources are provisioned using Terraform, you can use the provisioned Terraform module to generate a Solidblocks cloud-init based user data script.

main.tf



resource "hcloud_volume" "example" {
  name     = "example"
  size     = 16
  format   = "ext4"
  location = var.location
}

resource "hcloud_volume_attachment" "example" {
  server_id = hcloud_server.example.id
  volume_id = hcloud_volume.example.id
}

module "example" {
  source  = "github.com/pellepelster/terraform-null-solidblocks-cloud-init?ref=0.3.0"

  storage = [
    { linux_device = hcloud_volume.example.linux_device, mount_path = "/data1" },
  ]

  acme_ssl = {
    path         = "/data1/ssl"
    email        = "contact@blcks.de"
    domains      = ["example.blcks.de"]
    acme_server  = "https://acme-staging-v02.api.letsencrypt.org/directory"
    dns_provider = "hetzner"
    variables = {
      HETZNER_API_KEY : var.hetzner_dns_api_token
      HETZNER_HTTP_TIMEOUT : "30"
      HETZNER_PROPAGATION_TIMEOUT : "300"
    }
  }
}

resource "hcloud_server" "example" {
  name        = "test"
  image       = "debian-11"
  server_type = "cx22"
  location    = var.location
  ssh_keys    = [hcloud_ssh_key.ssh_key.id]
  user_data   = <<EOT
${module.example.user_data}

# do something with the generated certificate
ls -lsa /data1/ssl/certificates/example.blcks.de.crt
EOT
}

variables.tf



variable "hetzner_dns_api_token" {
  type = string
}

variable "location" {
  type    = string
  default = "nbg1"
}

versions.tf



variable "hetzner_dns_api_token" {
  type = string
}

variable "location" {
  type    = string
  default = "nbg1"
}