infrastructure-ng/terraform/main.tf
2025-03-05 22:43:20 +01:00

96 lines
1.7 KiB
HCL

resource "hcloud_ssh_key" "main" {
for_each = var.ssh_keys
name = each.key
public_key = eeach.value
}
resource "hcloud_firewall" "main" {
name = "main"
# ICMP
rule {
direction = "in"
protocol = "icmp"
source_ips = [
"0.0.0.0/0",
"::/0"
]
}
# HTTPS
rule {
direction = "in"
protocol = "tcp"
port = "443"
source_ips = [
"0.0.0.0/0",
"::/0"
]
}
# SSH
rule {
direction = "in"
protocol = "tcp"
port = "22"
source_ips = [
"0.0.0.0/0",
"::/0"
]
}
}
resource "hcloud_server" "main" {
name = "id.tjo.space"
image = "ubuntu-24.04"
server_type = "cax11"
datacenter = "hel1-dc2"
public_net {
ipv4_enabled = true
ipv6_enabled = true
}
firewall_ids = [hcloud_firewall.main.id]
backups = true
ssh_keys = [for key in var.ssh_keys : hcloud_ssh_key.main[key].id]
user_data = <<-EOF
#cloud-config
hostname: id
fqdn: id.tjo.space
prefer_fqdn_over_hostname: true
packages:
- git
package_update: true
package_upgrade: true
power_state:
mode: reboot
swap:
filename: /swapfile
size: 512M
runcmd:
- su ubuntu -c "git clone --depth 1 git@github.com:tjo-space/infrastructure-ng.git /home/ubuntu/service"
- su ubuntu -c "/home/ubuntu/service/install.sh"
EOF
}
resource "dnsimple_zone_record" "a" {
zone_name = "tjo.space"
name = "id.tjo.space"
value = hcloud_server.main.ipv4_address
type = "A"
ttl = 300
}
resource "dnsimple_zone_record" "aaaa" {
zone_name = "tjo.space"
name = "id.tjo.space"
value = hcloud_server.main.ipv6_address
type = "AAAA"
ttl = 300
}