mirror of
https://github.com/outbackdingo/terraform-hcloud-talos.git
synced 2026-01-27 10:20:30 +00:00
Introduced conditional logic for enabling an alias IP for the control plane, improving network configuration flexibility. This change includes the addition of a new variable `enable_alias_ip` and updates to network and server configurations to conditionally assign the alias IP. Signed-off-by: Marcel Richter <mail@mrclrchtr.de>
107 lines
3.1 KiB
HCL
107 lines
3.1 KiB
HCL
data "hcloud_image" "arm" {
|
|
with_selector = "os=talos"
|
|
with_architecture = "arm"
|
|
most_recent = true
|
|
}
|
|
|
|
data "hcloud_image" "x86" {
|
|
with_selector = "os=talos"
|
|
with_architecture = "x86"
|
|
most_recent = true
|
|
}
|
|
|
|
locals {
|
|
control_plane_image_id = substr(var.control_plane_server_type, 0, 3) == "cax" ? data.hcloud_image.arm.id : data.hcloud_image.x86.id
|
|
worker_image_id = substr(var.worker_server_type, 0, 3) == "cax" ? data.hcloud_image.arm.id : data.hcloud_image.x86.id
|
|
}
|
|
|
|
resource "tls_private_key" "ssh_key" {
|
|
count = var.ssh_public_key == null ? 1 : 0
|
|
algorithm = "ED25519"
|
|
}
|
|
|
|
resource "hcloud_ssh_key" "this" {
|
|
name = "default"
|
|
public_key = coalesce(var.ssh_public_key, can(tls_private_key.ssh_key[0].public_key_openssh) ? tls_private_key.ssh_key[0].public_key_openssh : null)
|
|
}
|
|
|
|
resource "hcloud_server" "control_planes" {
|
|
count = var.control_plane_count
|
|
datacenter = data.hcloud_datacenter.this.name
|
|
name = "control-plane-${count.index + 1}"
|
|
image = local.control_plane_image_id
|
|
server_type = var.control_plane_server_type
|
|
user_data = data.talos_machine_configuration.control_plane[count.index].machine_configuration
|
|
ssh_keys = [hcloud_ssh_key.this.id]
|
|
placement_group_id = hcloud_placement_group.control_plane.id
|
|
|
|
labels = {
|
|
"role" = "control-plane"
|
|
}
|
|
|
|
firewall_ids = [
|
|
hcloud_firewall.this.id
|
|
]
|
|
|
|
public_net {
|
|
ipv4_enabled = true
|
|
ipv4 = hcloud_primary_ip.control_plane_ipv4[count.index].id
|
|
ipv6_enabled = var.enable_ipv6
|
|
ipv6 = var.enable_ipv6 ? hcloud_primary_ip.control_plane_ipv6[count.index].id : null
|
|
}
|
|
|
|
network {
|
|
network_id = hcloud_network_subnet.nodes.network_id
|
|
ip = local.control_plane_private_ipv4_list[count.index]
|
|
// only the first control plane gets the VIP
|
|
alias_ips = count.index == 0 && var.enable_alias_ip ? [local.control_plane_private_ipv4_vip] : []
|
|
}
|
|
|
|
depends_on = [
|
|
hcloud_network_subnet.nodes,
|
|
data.talos_machine_configuration.control_plane
|
|
]
|
|
}
|
|
|
|
resource "hcloud_server" "workers" {
|
|
count = var.worker_count
|
|
datacenter = data.hcloud_datacenter.this.name
|
|
name = "worker-${count.index + 1}"
|
|
image = local.worker_image_id
|
|
server_type = var.worker_server_type
|
|
user_data = data.talos_machine_configuration.worker[count.index].machine_configuration
|
|
ssh_keys = [hcloud_ssh_key.this.id]
|
|
placement_group_id = hcloud_placement_group.worker.id
|
|
|
|
labels = {
|
|
"role" = "worker"
|
|
}
|
|
|
|
firewall_ids = [
|
|
hcloud_firewall.this.id
|
|
]
|
|
|
|
public_net {
|
|
ipv4_enabled = true
|
|
ipv4 = hcloud_primary_ip.worker_ipv4[count.index].id
|
|
ipv6_enabled = var.enable_ipv6
|
|
ipv6 = var.enable_ipv6 ? hcloud_primary_ip.worker_ipv6[count.index].id : null
|
|
}
|
|
|
|
network {
|
|
network_id = hcloud_network_subnet.nodes.network_id
|
|
ip = local.worker_private_ipv4_list[count.index]
|
|
}
|
|
|
|
depends_on = [
|
|
hcloud_network_subnet.nodes,
|
|
data.talos_machine_configuration.worker
|
|
]
|
|
|
|
lifecycle {
|
|
ignore_changes = [
|
|
user_data
|
|
]
|
|
}
|
|
}
|