mirror of
https://gitea.fenix-dev.com/fenix-gitea-admin/iac-opentofu-private.git
synced 2025-10-27 15:53:06 +00:00
Update proxmox.tf
This commit is contained in:
100
proxmox.tf
100
proxmox.tf
@ -30,28 +30,7 @@ resource "proxmox_virtual_environment_file" "cloud_init_yaml" {
|
|||||||
|
|
||||||
source_raw {
|
source_raw {
|
||||||
file_name = "user-data-cloud-config.yaml"
|
file_name = "user-data-cloud-config.yaml"
|
||||||
data = <<-EOF
|
data = yamldecode(file("${path.module}/cloud-init-base.yaml"))
|
||||||
locale: "pt_PT.UTF-8"
|
|
||||||
keyboard:
|
|
||||||
layout: "pt"
|
|
||||||
variant: "nodeadkeys"
|
|
||||||
|
|
||||||
#cloud-config
|
|
||||||
users:
|
|
||||||
- default
|
|
||||||
|
|
||||||
ssh_pwauth: true
|
|
||||||
|
|
||||||
package_update: true
|
|
||||||
packages:
|
|
||||||
- qemu-guest-agent
|
|
||||||
- net-tools
|
|
||||||
- curl
|
|
||||||
runcmd:
|
|
||||||
- systemctl enable qemu-guest-agent
|
|
||||||
- systemctl start qemu-guest-agent
|
|
||||||
- echo "done" > /tmp/cloud-config.done
|
|
||||||
EOF
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -59,47 +38,60 @@ resource "proxmox_virtual_environment_file" "cloud_init_yaml" {
|
|||||||
|
|
||||||
# Gerar um snippet cloud-init por VM
|
# Gerar um snippet cloud-init por VM
|
||||||
resource "proxmox_virtual_environment_file" "vm_user_data" {
|
resource "proxmox_virtual_environment_file" "vm_user_data" {
|
||||||
for_each = { for vm in var.proxmox_k8s_vms : vm.name => vm }
|
for_each = local.merged_cloudinit
|
||||||
|
|
||||||
node_name = "fenix"
|
node_name = "fenix"
|
||||||
datastore_id = "local-snippets"
|
datastore_id = "local-snippets"
|
||||||
content_type = "snippets"
|
content_type = "snippets"
|
||||||
|
|
||||||
source_raw {
|
source_raw {
|
||||||
file_name = "cloud-init-iac-k8s-${each.value.name}.yaml"
|
file_name = "cloud-init-iac-k8s-${each.key}.yaml"
|
||||||
data = <<-EOF
|
data = yamlencode(each.value)
|
||||||
#cloud-config
|
}
|
||||||
package_update: true
|
}
|
||||||
packages:
|
|
||||||
%{ for pkg in each.value.extra_packages ~}
|
|
||||||
- ${pkg}
|
|
||||||
%{ endfor ~}
|
|
||||||
|
|
||||||
users:
|
locals {
|
||||||
%{ if length(each.value.extra_users) > 0 ~}
|
# Lê o ficheiro base (que está no mesmo módulo)
|
||||||
|
base_cloudinit = yamldecode(file("${path.module}/cloud-init-base.yaml"))
|
||||||
%{ for u in each.value.extra_users ~}
|
|
||||||
- name: ${u.name}
|
|
||||||
groups: [${join(", ", u.groups)}]
|
|
||||||
shell: /bin/bash
|
|
||||||
sudo: ALL=(ALL) NOPASSWD:ALL
|
|
||||||
%{ endfor ~}
|
|
||||||
|
|
||||||
chpasswd:
|
# Renderiza cada ficheiro por VM
|
||||||
list: |
|
vm_cloudinits = {
|
||||||
%{ for u in each.value.extra_users ~}
|
for vm in var.proxmox_k8s_vms : vm.name => yamldecode(
|
||||||
${u.name}:${u.password}
|
templatefile("${path.module}/cloud-init-vm.yaml.tftpl", {
|
||||||
%{ endfor ~}
|
hostname = vm.hostname
|
||||||
expire: false
|
extra_packages = try(vm.extra_packages, [])
|
||||||
|
extra_users = try(vm.extra_users, [])
|
||||||
|
extra_runcmd = try(vm.extra_runcmd, [])
|
||||||
|
})
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
%{ endif ~}
|
# Função recursiva para deep merge
|
||||||
runcmd:
|
deep_merge = function("deep_merge", [map(string), map(string)], map(string), <<EOT
|
||||||
%{ if length(each.value.extra_runcmd) > 0 ~}
|
base, override = args
|
||||||
%{ for cmd in each.value.extra_runcmd ~}
|
result = {}
|
||||||
- ${cmd}
|
for k in setunion(keys(base), keys(override)) {
|
||||||
%{ endfor ~}
|
if can(base[k]) && can(override[k]) {
|
||||||
%{ endif ~}
|
if type(base[k]) == list && type(override[k]) == list {
|
||||||
EOF
|
result[k] = concat(base[k], override[k])
|
||||||
|
} else if type(base[k]) == map && type(override[k]) == map {
|
||||||
|
result[k] = deep_merge(base[k], override[k])
|
||||||
|
} else {
|
||||||
|
result[k] = override[k]
|
||||||
|
}
|
||||||
|
} else if can(override[k]) {
|
||||||
|
result[k] = override[k]
|
||||||
|
} else {
|
||||||
|
result[k] = base[k]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
EOT)
|
||||||
|
|
||||||
|
# Resultado final = deep merge do base + vm
|
||||||
|
merged_cloudinit = {
|
||||||
|
for vm_name, vm_cfg in local.vm_cloudinits :
|
||||||
|
vm_name => local.deep_merge(local.base_cloudinit, vm_cfg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user