112 lines
3.6 KiB
Python
112 lines
3.6 KiB
Python
"""ProxmoxVE provider, Ansible powered with Python"""
|
|
|
|
import pulumi
|
|
import pulumi_proxmoxve as proxmox
|
|
import pulumi_command as command
|
|
from pvewrapper import PveWrapper
|
|
import additional_config
|
|
|
|
# Check pulumi configuration
|
|
config = pulumi.Config()
|
|
|
|
username = config.require("pveTokenName").split("!")[0]
|
|
tokenname = config.require("pveTokenName").split("!")[1]
|
|
pvehostname = config.require("pveHostname")
|
|
pvenodename = config.require("pveNodeName")
|
|
pveURL=f"https://{pvehostname}:8006/"
|
|
verify = True if config.get_int("pveVerifySSL") == 1 else False
|
|
pvedefaultstorage = config.require("pveDefaultStorage")
|
|
vm_name: str = config.require("hostname")
|
|
vm_username: str = config.require("cloudUsername")
|
|
tokenvalue = config.require_secret("pveTokenValue")
|
|
|
|
provider = proxmox.Provider(pvehostname,
|
|
endpoint=pveURL,
|
|
insecure=not verify,
|
|
api_token=tokenvalue.apply(lambda x: f"{username}!{tokenname}={x}")
|
|
)
|
|
|
|
pve = PveWrapper(pvehostname,
|
|
username=username,
|
|
token_name=tokenname,
|
|
token_value=tokenvalue.apply(lambda v: f"{v}"),
|
|
nodename=pvenodename,
|
|
verify_ssl=verify
|
|
)
|
|
|
|
vm = proxmox.vm.VirtualMachine(vm_name,
|
|
name = vm_name,
|
|
node_name = pvenodename,
|
|
agent = proxmox.vm.VirtualMachineAgentArgs(
|
|
enabled=True,
|
|
type="virtio",
|
|
timeout="2m",
|
|
),
|
|
cpu = proxmox.vm.VirtualMachineCpuArgs(
|
|
cores = config.get_int("vmSockets"),
|
|
sockets = config.get_int("vmCores")
|
|
),
|
|
memory = proxmox.vm.VirtualMachineMemoryArgs(dedicated = config.get_int("vmRAM")),
|
|
clone = proxmox.vm.VirtualMachineCloneArgs(
|
|
node_name = pvenodename,
|
|
vm_id = additional_config.os_to_template[config.require("vmTemplate")],
|
|
full = False
|
|
),
|
|
disks = [
|
|
proxmox.vm.VirtualMachineDiskArgs(
|
|
interface = "virtio0",
|
|
datastore_id = pvedefaultstorage,
|
|
size = config.get_int("vmDiskSize"),
|
|
file_format = "raw"
|
|
)
|
|
],
|
|
network_devices = [
|
|
proxmox.vm.VirtualMachineNetworkDeviceArgs(
|
|
bridge = "vmbr0",
|
|
model = "virtio"
|
|
)
|
|
],
|
|
operating_system = proxmox.vm.VirtualMachineOperatingSystemArgs(
|
|
type = "l26"
|
|
),
|
|
initialization = proxmox.vm.VirtualMachineInitializationArgs(
|
|
type = "nocloud",
|
|
datastore_id = pvedefaultstorage,
|
|
user_account = proxmox.vm.VirtualMachineInitializationUserAccountArgs(
|
|
username = vm_username,
|
|
password = config.require_secret("cloudPassword"),
|
|
keys = additional_config.sshkeys
|
|
),
|
|
vendor_data_file_id = "cloud-init/qemu-guest-agent_deb.yml"
|
|
),
|
|
opts = pulumi.ResourceOptions(
|
|
provider = provider,
|
|
custom_timeouts=pulumi.CustomTimeouts(create="3m")
|
|
)
|
|
)
|
|
|
|
ipv4_addresses = vm.id.apply(lambda id: pve.ipv4_addresses(f"{id}"))
|
|
|
|
# Creating the inventory file
|
|
inventory = command.local.Command("a-inventory",
|
|
create = ipv4_addresses.apply(lambda ipaddr:
|
|
f"echo '{vm_name} ansible_host={ipaddr[0]['address']} ansible_user={vm_username}' >./inventory"
|
|
),
|
|
delete = "rm -f ./inventory",
|
|
opts = pulumi.ResourceOptions(depends_on = [ vm, ipv4_addresses ])
|
|
)
|
|
|
|
# Applying the command
|
|
for playbook in additional_config.playbooks:
|
|
shortname: str = playbook.split(".")[0]
|
|
command.local.Command(f"ap-{shortname}",
|
|
create = vm.ipv4_addresses.apply(
|
|
lambda run: f"ansible-playbook {run[0]['ipv4_address']}"
|
|
),
|
|
delete = "rm -f ./ansible.log",
|
|
opts = pulumi.ResourceOptions(depends_on = [ inventory ])
|
|
)
|
|
|
|
# Outputs
|
|
pulumi.export("ipv4_addresses", vm.ipv4_addresses)
|