1) reworking of lvm stuff into a single python script rather than a pile of shell...
[invirt/packages/invirt-database.git] / client / etc / xen / sipb-database
index daccd93..54c1b74 100644 (file)
@@ -1,15 +1,28 @@
+# -*- mode: python; -*-
 import sipb_xen_database.models as models
 from sipb_xen_database import connect
 import sipb_xen_database.models as models
 from sipb_xen_database import connect
+import re
 
 connect('postgres://sipb-xen@sipb-xen-dev.mit.edu/sipb_xen')
 
 connect('postgres://sipb-xen@sipb-xen-dev.mit.edu/sipb_xen')
-# `machine_name' should get passed in from the xm create call
+prefix = "d_"
+
+# 'machine_name', and optionally 'cdrom_image', should get passed in
+# from the xm create call
+
+def check(b):
+    if not b:
+        import sys
+        sys.exit(1)
 
 machine = models.Machine.get_by(name=machine_name)
 
 machine = models.Machine.get_by(name=machine_name)
+check(machine is not None)
 machine_type = models.Type.get_by(type_id=machine.type_id)
 
 memory = machine.memory
 maxmem = memory
 machine_type = models.Type.get_by(type_id=machine.type_id)
 
 memory = machine.memory
 maxmem = memory
-name = machine.name
+check(re.match('^[A-Za-z0-9][A-Za-z0-9._-]*$', machine.name))
+name = prefix + machine.name
+check(re.match('^[0-9a-f-]+$', machine.uuid))
 uuid = machine.uuid
 
 vcpus = machine.cpus
 uuid = machine.uuid
 
 vcpus = machine.cpus
@@ -19,12 +32,13 @@ viftype = ""
 
 if machine_type.hvm:
     ioemu = "ioemu:"
 
 if machine_type.hvm:
     ioemu = "ioemu:"
-    viftype = "type=ioemu"
+    viftype = "type=ioemu, "
 
     kernel = 'hvmloader'
     builder = 'hvm'
     vnc = 1
 
     kernel = 'hvmloader'
     builder = 'hvm'
     vnc = 1
-    device_model = 'qemu-dm'
+    vncpasswd = 'moocow'
+    device_model = '/usr/sbin/qemu-dm-sipb'
 else:
     kernel  = '/boot/vmlinuz-2.6.18-4-xen-amd64'
     ramdisk = '/boot/initrd.img-2.6.18-4-xen-amd64'
 else:
     kernel  = '/boot/vmlinuz-2.6.18-4-xen-amd64'
     ramdisk = '/boot/initrd.img-2.6.18-4-xen-amd64'
@@ -37,20 +51,25 @@ apic = machine_type.apic
 vif = []
 
 for n in machine.nics:
 vif = []
 
 for n in machine.nics:
-    d = '%s, mac=%s, ip=%s, bridge=xenbr0, script=vif-sipbroute' % (viftype, n.mac_addr, n.ip)
+    check(re.match('^[0-9a-fA-F:]+$', n.mac_addr) and re.match('^[0-9.]*$', n.ip))
+    d = '%smac=%s, ip=%s, bridge=xenbr0, script=vif-sipbroute' % (viftype, n.mac_addr, n.ip)
     vif.append(d)
 
 disk = []
 
 for d in machine.disks:
     vif.append(d)
 
 disk = []
 
 for d in machine.disks:
-    device = 'xenvg/' + machine.name + '_' + d.guest_device_name
+    check(re.match('^[A-Za-z0-9]+$', d.guest_device_name))
+    device = '/dev/xenvg/' + prefix + machine.name + '_' + d.guest_device_name
     dspec = 'phy:%s,%s%s,w' % (device, diskioemu, d.guest_device_name)
     disk.append(dspec)
 
     dspec = 'phy:%s,%s%s,w' % (device, diskioemu, d.guest_device_name)
     disk.append(dspec)
 
-restart = 'destroy'
-if machine.autorestart:
-    restart = 'restart'
+if 'cdrom_image' in locals():
+    check(re.match('^[A-Za-z0-9][A-Za-z0-9_.-]*$', cdrom_image))
+    disk.append('file:/srv/images/' + cdrom_image + '.iso,hdc:cdrom,r')
+    boot = 'd'
 
 on_poweroff = 'destroy'
 on_reboot = 'restart'
 
 on_poweroff = 'destroy'
 on_reboot = 'restart'
-on_crash = restart
+on_crash = 'destroy'
+if machine.autorestart:
+    on_crash = 'restart'