svn path=/trunk/packages/sipb-xen-www/; revision=863
-from sipb_xen_database import *
+from invirt.database import *
import sys
import getafsgroups
import subprocess
import sys
import getafsgroups
import subprocess
raise
if __name__ == '__main__':
raise
if __name__ == '__main__':
- connect('postgres://sipb-xen@sipb-xen-dev/sipb_xen')
Functions to perform remctls.
"""
Functions to perform remctls.
"""
-from sipb_xen_database import Machine, Disk, Type, NIC, CDROM, ctx, meta
import validation
from webcommon import CodeError, InvalidInput
import random
import validation
from webcommon import CodeError, InvalidInput
import random
import cache_acls
import yaml
import cache_acls
import yaml
+from invirt.config import structs as config
+from invirt.database import Machine, Disk, Type, NIC, CDROM, ctx, meta
+
# ... and stolen from xend/uuid.py
def randomUUID():
"""Generate a random UUID."""
# ... and stolen from xend/uuid.py
def randomUUID():
"""Generate a random UUID."""
"%02x" * 6]) % tuple(u)
# end stolen code
"%02x" * 6]) % tuple(u)
# end stolen code
-def kinit(username = 'daemon/sipb-xen.mit.edu', keytab = '/etc/sipb-xen.keytab'):
"""Kinit with a given username and keytab"""
"""Kinit with a given username and keytab"""
-
- p = subprocess.Popen(['kinit', "-k", "-t", keytab, username],
+ p = subprocess.Popen(['kinit', "-k", "-t", '/etc/invirt/keytab',
+ 'daemon/'+config.web.hostname],
stderr=subprocess.PIPE)
e = p.wait()
if e:
stderr=subprocess.PIPE)
e = p.wait()
if e:
kinits if necessary, and outputs errors to stderr.
"""
checkKinit()
kinits if necessary, and outputs errors to stderr.
"""
checkKinit()
- p = subprocess.Popen(['remctl', 'remote.mit.edu']
+ p = subprocess.Popen(['remctl', config.remote.hostname]
+ list(args),
stdout=subprocess.PIPE,
stderr=subprocess.PIPE)
+ list(args),
stdout=subprocess.PIPE,
stderr=subprocess.PIPE)
import templates
from Cheetah.Template import Template
import templates
from Cheetah.Template import Template
-import sipb_xen_database
-from sipb_xen_database import Machine, CDROM, ctx, connect, MachineAccess, Type, Autoinstall
import validation
import cache_acls
from webcommon import InvalidInput, CodeError, State
import controls
from getafsgroups import getAfsGroupMembers
import validation
import cache_acls
from webcommon import InvalidInput, CodeError, State
import controls
from getafsgroups import getAfsGroupMembers
-import invirt.config
-invirt_config = invirt.config.load()
+import sipb_xen_database
+from invirt import database
+from sipb_xen_database import Machine, CDROM, ctx, connect, MachineAccess, Type, Autoinstall
+from invirt.config import structs as config
def pathSplit(path):
if path.startswith('/'):
def pathSplit(path):
if path.startswith('/'):
token = base64.urlsafe_b64encode(token)
host = controls.listHost(machine)
if host:
token = base64.urlsafe_b64encode(token)
host = controls.listHost(machine)
if host:
- port = 10003 + [config_host["hostname"] for config_host in invirt_config["hosts"]
- ].index(host)
+ port = 10003 + [h.hostname for h in config.hosts].index(host)
else:
port = 5900 # dummy
else:
port = 5900 # dummy
if nic.hostname and '.' in nic.hostname:
return nic.hostname
elif nic.machine:
if nic.hostname and '.' in nic.hostname:
return nic.hostname
elif nic.machine:
- return nic.machine.name + '.xvm.mit.edu'
+ return nic.machine.name + '.' + config.dns.domains[0]
help_mapping = {'ParaVM Console': """
ParaVM machines do not support local console access over VNC. To
access the serial console of these machines, you can SSH with Kerberos
help_mapping = {'ParaVM Console': """
ParaVM machines do not support local console access over VNC. To
access the serial console of these machines, you can SSH with Kerberos
-to console.xvm.mit.edu, using the name of the machine as your
-username.""",
+to console.%s, using the name of the machine as your
+username.""" % config.dns.domains[0],
'HVM/ParaVM': """
HVM machines use the virtualization features of the processor, while
ParaVM machines use Xen's emulation of virtualization features. You
'HVM/ParaVM': """
HVM machines use the virtualization features of the processor, while
ParaVM machines use Xen's emulation of virtualization features. You
def send_error_mail(subject, body):
import subprocess
def send_error_mail(subject, body):
import subprocess
+ to = config.web.errormail
-""" % (to, subject, body)
+""" % (to, config.web.hostname, subject, body)
p = subprocess.Popen(['/usr/sbin/sendmail', to], stdin=subprocess.PIPE)
p.stdin.write(mail)
p.stdin.close()
p = subprocess.Popen(['/usr/sbin/sendmail', to], stdin=subprocess.PIPE)
p.stdin.write(mail)
p.stdin.close()
yield '<pre>%s</pre>' % cgi.escape(str(checkpoint))
def constructor():
yield '<pre>%s</pre>' % cgi.escape(str(checkpoint))
def constructor():
- connect('postgres://sipb-xen@sipb-xen-dev.mit.edu/sipb_xen')