Compare commits

..

No commits in common. "main" and "v0.1.1" have entirely different histories.
main ... v0.1.1

5 changed files with 14 additions and 35 deletions

View File

@ -16,9 +16,9 @@ steps:
commands: commands:
- tflint --color - tflint --color
- name: tofu - name: terraform
image: quay.io/thegeeklab/wp-opentofu image: docker.io/jmccann/drone-terraform:8
settings: settings:
action: actions:
- validate - validate
tofu_version: 1.6.1 tf_version: 1.5.0

25
main.tf
View File

@ -1,21 +1,3 @@
locals {
ipv4_addresses = {
for server_key, server in var.server : server.name => flatten([
for k, v in try(proxmox_virtual_environment_vm.server[server.name].ipv4_addresses, []) :
v if length(regexall(try(server.netif_filter, var.server_netif_filter), proxmox_virtual_environment_vm.server[server.name].network_interface_names[k])) > 0
])
}
}
locals {
ipv6_addresses = {
for server_key, server in var.server : server.name => flatten([
for k, v in try(proxmox_virtual_environment_vm.server[server.name].ipv6_addresses, []) :
v if length(regexall(try(server.netif_filter, var.server_netif_filter), proxmox_virtual_environment_vm.server[server.name].network_interface_names[k])) > 0
])
}
}
resource "proxmox_virtual_environment_vm" "server" { resource "proxmox_virtual_environment_vm" "server" {
for_each = { for row in var.server : row.name => row } for_each = { for row in var.server : row.name => row }
@ -113,7 +95,12 @@ resource "restapi_object" "ucs_server" {
"position" : var.ucs_zones[try(each.value.dns_zone, var.server_dns_zone)], "position" : var.ucs_zones[try(each.value.dns_zone, var.server_dns_zone)],
"properties" : { "properties" : {
"name" : each.value.name, "name" : each.value.name,
"a" : concat(local.ipv4_addresses[each.key]), "a" : concat(
[
for k, v in flatten(coalesce(proxmox_virtual_environment_vm.server[each.value.name].ipv4_addresses, [])) :
v if k != try(index(proxmox_virtual_environment_vm.server[each.value.name].network_interface_names, "lo"), -1)
],
),
} }
}) })
} }

View File

@ -1,8 +1,5 @@
output "output" { output "output" {
value = { value = {
for server_key, server in proxmox_virtual_environment_vm.server : server_key => merge( for server_key, server in proxmox_virtual_environment_vm.server : server_key => server
server,
{ ipv4_addresses = local.ipv4_addresses[server_key] },
)
} }
} }

View File

@ -43,8 +43,3 @@ variable "server_guest_agent" {
type = bool type = bool
default = false default = false
} }
variable "server_netif_filter" {
type = string
default = "^(eth|ens|enp).+"
}

View File

@ -1,13 +1,13 @@
terraform { terraform {
required_providers { required_providers {
cloudflare = { cloudflare = {
source = "registry.opentofu.org/cloudflare/cloudflare" source = "cloudflare/cloudflare"
} }
proxmox = { proxmox = {
source = "registry.opentofu.org/bpg/proxmox" source = "bpg/proxmox"
} }
restapi = { restapi = {
source = "registry.opentofu.org/thegeeklab/restapi" source = "mastercard/restapi"
} }
} }
} }