feat(vmware): adding vmware support
This commit is contained in:
parent
d02e96d4f1
commit
0293e76708
|
@ -0,0 +1,92 @@
|
||||||
|
variable "vms" {
|
||||||
|
type = map(object(
|
||||||
|
{
|
||||||
|
domain = string
|
||||||
|
cpu = number
|
||||||
|
ram = number
|
||||||
|
guest_id = string
|
||||||
|
disks = map(object({
|
||||||
|
size = string
|
||||||
|
}))
|
||||||
|
network_interfaces = map(object(
|
||||||
|
{
|
||||||
|
name = string
|
||||||
|
mac = string
|
||||||
|
}
|
||||||
|
))
|
||||||
|
folder = string
|
||||||
|
}
|
||||||
|
))
|
||||||
|
description = "Virtual Machines description"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable "cluster" {
|
||||||
|
type = object({
|
||||||
|
datacenter_name = string
|
||||||
|
datastore_name = string
|
||||||
|
resource_pool_name = string
|
||||||
|
folder = string
|
||||||
|
}
|
||||||
|
)
|
||||||
|
description = "vSphere cluster definition"
|
||||||
|
}
|
||||||
|
|
||||||
|
locals {
|
||||||
|
vnets = flatten([
|
||||||
|
for vm_key, vm in var.vms : [
|
||||||
|
for vnet in vm.network_interfaces : {
|
||||||
|
vm_key = "${vm_key}.${vm.domain}"
|
||||||
|
name = vnet.name
|
||||||
|
mac = vnet.mac
|
||||||
|
}
|
||||||
|
]
|
||||||
|
])
|
||||||
|
}
|
||||||
|
|
||||||
|
data "vsphere_datacenter" "datacenter" {
|
||||||
|
name = var.cluster.datacenter_name
|
||||||
|
}
|
||||||
|
|
||||||
|
data "vsphere_datastore" "datastore" {
|
||||||
|
name = var.cluster.datastore_name
|
||||||
|
datacenter_id = data.vsphere_datacenter.datacenter.id
|
||||||
|
}
|
||||||
|
|
||||||
|
data "vsphere_resource_pool" "pool" {
|
||||||
|
name = var.cluster.resource_pool_name
|
||||||
|
datacenter_id = data.vsphere_datacenter.datacenter.id
|
||||||
|
}
|
||||||
|
|
||||||
|
data "vsphere_network" "network" {
|
||||||
|
count = length(local.vnets)
|
||||||
|
|
||||||
|
name = local.vnets[count.index].name
|
||||||
|
datacenter_id = data.vsphere_datacenter.datacenter.id
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "vsphere_virtual_machine" "vm" {
|
||||||
|
for_each = var.vms
|
||||||
|
name = "${each.key}.${each.value.domain}"
|
||||||
|
resource_pool_id = data.vsphere_resource_pool.pool.id
|
||||||
|
datastore_id = data.vsphere_datastore.datastore.id
|
||||||
|
folder = each.value.folder
|
||||||
|
num_cpus = each.value.cpu
|
||||||
|
memory = each.value.ram
|
||||||
|
guest_id = each.value.guest_id
|
||||||
|
|
||||||
|
dynamic "network_interface" {
|
||||||
|
for_each = { for idx, vnet in data.vsphere_network.network : idx => vnet }
|
||||||
|
content {
|
||||||
|
network_id = network_interface.value.id
|
||||||
|
mac_address = local.vnets[network_interface.key].mac
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
dynamic "disk" {
|
||||||
|
for_each = each.value.disks
|
||||||
|
content {
|
||||||
|
label = disk.key
|
||||||
|
size = disk.value.size
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
output "shortnames" {
|
||||||
|
value = keys(var.vms)
|
||||||
|
}
|
||||||
|
|
||||||
|
output "vnets" {
|
||||||
|
value = local.vnets
|
||||||
|
|
||||||
|
}
|
||||||
|
//output "virtual_machines" {
|
||||||
|
// value = vsphere.virtual_machine.vm //template_nic[0].computed_mac)
|
||||||
|
//}
|
|
@ -0,0 +1,8 @@
|
||||||
|
terraform {
|
||||||
|
required_providers {
|
||||||
|
vsphere = {
|
||||||
|
source = "hashicorp/vsphere"
|
||||||
|
version = "~> 2.4.0"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue