#!/bin/sh set -e # Author: Daniel Kahn Gillmor # Date: 2011-01-26 # License: GPL v3+ ## expect to pull these values from the environment: # VMNAME=snapper # OWNER=jrollins # TAP=tap0 # RAM=512 # MAC=52:54:00:12:34:56 # HDA=/path/to/disk0 # optional # HDB=/path/to/disk1 # optional # HDC=/path/to/disk2 # optional # HDD=/path/to/disk3 # optional if [ -z "$VMNAME" ] ; then exit 1 fi ################### OWNERGROUP=$(groups "$OWNER" | cut -f1 -d\ ) OWNERHOME=$(getent passwd "$OWNER" | cut -f6 -d: ) up() { # bring up the network tap: modprobe -v tun tunctl -u "$OWNER" -t "$TAP" ip link set "$TAP" up brctl addif br0 "$TAP" chpst -u "$OWNER:$OWNERGROUP" mkdir -p "$OWNERHOME/vms/$VMNAME" CDISO="$OWNERHOME/vms/$VMNAME/cd.iso" NETBOOT="$OWNERHOME/vms/$VMNAME/netboot" KVMARGS= BOOTCHOICE=c if [ -e "$NETBOOT" ] ; then BOOTCHOICE=n elif [ -e "$CDISO" ] && [ -e $(readlink -f "$CDISO") ] ; then KVMARGS="-cdrom $CDISO" BOOTCHOICE=d fi for disk in "$HDA" "$HDB" "HDC" "HDD"; do if printf "%s" "$disk" | grep '^/dev/mapper/'; then mappername=$(printf "%s" "$disk" | sed 's!^/dev/mapper/!!') udevadm trigger --subsystem-match=block --attr-match=dm/name="$mappername" fi done # set up the disks, if needed: [ -z "$HDA" ] || KVMARGS="$KVMARGS -drive file=$HDA,if=virtio,id=hda,boot=on,format=raw" [ -z "$HDB" ] || KVMARGS="$KVMARGS -drive file=$HDB,if=virtio,id=hdb,format=raw" [ -z "$HDC" ] || KVMARGS="$KVMARGS -drive file=$HDC,if=virtio,id=hdc,format=raw" [ -z "$HDD" ] || KVMARGS="$KVMARGS -drive file=$HDD,if=virtio,id=hdd,format=raw" LOGNAME="$OWNERHOME/vms/$VMNAME/console" ln -sfT "$LOGNAME" ./servicelog if [ -e "$LOGNAME" ] ; then chpst -u "$OWNER" mv "$LOGNAME" "$LOGNAME".$(date +%F_%T%z|tr : .) fi MONITORNAME="$OWNERHOME/vms/$VMNAME/monitor.socket" CONSOLENAME="$OWNERHOME/vms/$VMNAME/console.socket" kvmsend() { socat STDIO "UNIX:$MONITORNAME" <&2 exit 1 ;; esac