2022-10-03 02:19:24 +00:00
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
# Name: vm-libvirt-arch-minimal
|
|
|
|
# Desc: Create a minimal Arch Linux VM install on a libvirt/kvm hypervisor.
|
|
|
|
# -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#--------------------
|
|
|
|
# Requirements block.
|
|
|
|
#--------------------
|
|
|
|
|
|
|
|
packer {
|
|
|
|
required_plugins {
|
|
|
|
libvirt = {
|
|
|
|
version = ">= 0.3.4"
|
|
|
|
source = "github.com/thomasklein94/libvirt"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# ----------------
|
|
|
|
# Variables block.
|
|
|
|
# ----------------
|
|
|
|
|
|
|
|
data "http" "image_checksum" {
|
|
|
|
url = var.checksum_url
|
|
|
|
}
|
|
|
|
|
|
|
|
locals {
|
2022-10-03 13:47:03 +00:00
|
|
|
image_checksum = split(" ",data.http.image_checksum.body)[0]
|
|
|
|
libvirt_uri = "qemu+ssh://${var.host_ssh_user}@${var.host_ssh_address}/system?keyfile=${var.host_ssh_private_key}&no_verify=1"
|
2022-10-03 02:19:24 +00:00
|
|
|
nvram_path = "${var.nvram_path_base}/${var.guest_hostname}_VARS.fd"
|
|
|
|
cidata_name = "${var.volume_name}_cidata"
|
|
|
|
}
|
|
|
|
|
|
|
|
#---------------
|
|
|
|
# Sources block.
|
|
|
|
#---------------
|
|
|
|
|
|
|
|
source "libvirt" "arch-minimal" {
|
|
|
|
libvirt_uri = local.libvirt_uri
|
|
|
|
domain_name = var.guest_hostname
|
|
|
|
vcpu = var.cpu_count
|
|
|
|
memory = var.memory
|
|
|
|
boot_devices = ["hd"]
|
|
|
|
shutdown_mode = "guest"
|
|
|
|
domain_type = var.domain_type
|
|
|
|
arch = var.arch
|
|
|
|
chipset = var.chipset
|
|
|
|
loader_type = var.loader_type
|
|
|
|
loader_path = var.loader_path
|
2022-10-03 13:47:03 +00:00
|
|
|
// nvram_template = var.nvram_template
|
|
|
|
// nvram_path = local.nvram_path
|
|
|
|
nvram_template = local.nvram_path
|
|
|
|
nvram_path = var.nvram_template
|
2022-10-03 11:11:25 +00:00
|
|
|
secure_boot = var.secure_boot
|
2022-10-03 02:19:24 +00:00
|
|
|
|
|
|
|
volume {
|
|
|
|
alias = "artifact"
|
2022-10-03 02:30:22 +00:00
|
|
|
name = var.volume_name
|
2022-10-03 02:19:24 +00:00
|
|
|
pool = var.volume_pool
|
|
|
|
readonly = false
|
|
|
|
target_dev = "vda"
|
|
|
|
bus = "virtio"
|
|
|
|
format = "qcow2"
|
|
|
|
size = "2G"
|
|
|
|
capacity = var.volume_capacity
|
|
|
|
source {
|
|
|
|
type = "external"
|
|
|
|
urls = [var.image_url]
|
|
|
|
checksum = local.image_checksum
|
2022-10-03 13:47:03 +00:00
|
|
|
// checksum = "f237ada9ba61431f6aebb066d2b3f0b5b432ea21da6034d98248725df1417545"
|
2022-10-03 02:19:24 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
volume {
|
|
|
|
alias = "cidata"
|
|
|
|
name = local.cidata_name
|
|
|
|
pool = var.volume_pool
|
|
|
|
readonly = true
|
|
|
|
source {
|
|
|
|
type = "cloud-init"
|
|
|
|
|
|
|
|
meta_data = jsonencode({
|
2022-10-03 13:47:03 +00:00
|
|
|
"instance-id" = "${var.guest_hostname}"
|
|
|
|
"hostname" = "${var.guest_hostname}"
|
2022-10-03 02:19:24 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
user_data = format("#cloud-config\n%s", jsonencode({
|
2022-10-03 13:47:03 +00:00
|
|
|
"packages" = [
|
2022-10-03 02:19:24 +00:00
|
|
|
"qemu-guest-agent",
|
|
|
|
"ufw"
|
|
|
|
]
|
2022-10-03 13:47:03 +00:00
|
|
|
"runcmd" = [
|
2022-10-03 02:19:24 +00:00
|
|
|
["systemctl", "enable", "--now", "qemu-guest-agent"],
|
|
|
|
["ufw", "enable"],
|
2022-10-03 13:47:03 +00:00
|
|
|
["ufw", "allow", "from", "${var.ssh_source}", "to", "port", "22", "proto", "tcp"],
|
2022-10-03 02:19:24 +00:00
|
|
|
["systemctl", "enable", "--now", "ufw"]
|
|
|
|
]
|
|
|
|
}))
|
|
|
|
|
|
|
|
network_config = jsonencode({
|
2022-10-03 11:11:25 +00:00
|
|
|
renderer = "networkd"
|
2022-10-03 02:19:24 +00:00
|
|
|
version = 2
|
|
|
|
ethernets = {
|
2022-10-03 11:11:25 +00:00
|
|
|
eth0 = {
|
2022-10-03 02:19:24 +00:00
|
|
|
match = {
|
|
|
|
name = "en*"
|
|
|
|
}
|
2022-10-03 11:11:25 +00:00
|
|
|
dhcp4 = false
|
2022-10-03 13:47:03 +00:00
|
|
|
addresses = ["${var.network_address}"]
|
|
|
|
gateway4 = "${var.network_gateway}"
|
2022-10-03 11:11:25 +00:00
|
|
|
nameservers = {
|
2022-10-03 13:47:03 +00:00
|
|
|
addresses = ["${var.network_nameserver}"]
|
|
|
|
search = ["${var.network_domain}"]
|
2022-10-03 11:11:25 +00:00
|
|
|
}
|
2022-10-03 02:19:24 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
artifact_volume_alias = "artifact"
|
|
|
|
|
|
|
|
network_interface {
|
|
|
|
type = "bridge"
|
|
|
|
bridge = var.bridge_name
|
|
|
|
model = "virtio"
|
|
|
|
alias = "default-network"
|
|
|
|
}
|
|
|
|
network_address_source = "agent"
|
|
|
|
|
|
|
|
graphics {
|
2022-10-03 13:47:03 +00:00
|
|
|
type = "vnc"
|
|
|
|
port = 5902
|
2022-10-03 02:19:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
communicator {
|
2022-10-03 13:47:03 +00:00
|
|
|
ssh_username = var.guest_ssh_user
|
|
|
|
ssh_port = var.guest_ssh_port
|
|
|
|
ssh_private_key_file = var.guest_ssh_private_key
|
2022-10-03 02:19:24 +00:00
|
|
|
}
|
|
|
|
communicator_interface = "default-network"
|
|
|
|
}
|
|
|
|
|
|
|
|
#-------------
|
|
|
|
# Build block.
|
|
|
|
#-------------
|
|
|
|
|
|
|
|
build {
|
|
|
|
sources = ["source.libvirt.arch-minimal"]
|
|
|
|
}
|