From e0e7814e58df1dc0342e3f88e7bcfad4ed483079 Mon Sep 17 00:00:00 2001 From: Eric Price <ecprice@mit.edu> Date: Mon, 8 Oct 2007 03:37:59 -0400 Subject: [PATCH 1/1] Help! svn path=/trunk/web/; revision=139 --- templates/help.tmpl | 16 +++++++++++++++ templates/list.tmpl | 2 +- templates/main.py | 52 +++++++++++++++++++++++++++++++++++++---------- templates/skeleton.py | 51 +++++++++++++++++++++++++++++++++++----------- templates/skeleton.tmpl | 28 ++++++++++++++++++++++++- 5 files changed, 124 insertions(+), 25 deletions(-) create mode 100644 templates/help.tmpl diff --git a/templates/help.tmpl b/templates/help.tmpl new file mode 100644 index 0000000..9998922 --- /dev/null +++ b/templates/help.tmpl @@ -0,0 +1,16 @@ +#from skeleton import skeleton +#extends skeleton + +#def title +Help +#end def + + +#def body +#if not $simple +<h1>Help</h1> +#end if +#for $subject in $subjects +<p>$mapping[$subject]</p> +#end for +#end def diff --git a/templates/list.tmpl b/templates/list.tmpl index 7dd0da0..19b108e 100644 --- a/templates/list.tmpl +++ b/templates/list.tmpl @@ -79,7 +79,7 @@ $has_vnc.get($machine.name) <td><input type="text" name="disk" value="$maxdisk" size=3/> gigabytes ($maxdisk max)</td> </tr> <tr> - <td>HVM/ParaVM</td> + <td>HVM/ParaVM$helppopup('hvm_paravm')</td> <td> <input checked type="radio" name="vmtype" value="hvm">HVM</input> <input type="radio" name="vmtype" value="paravm">ParaVM</input> diff --git a/templates/main.py b/templates/main.py index 4a50e43..b528b3e 100755 --- a/templates/main.py +++ b/templates/main.py @@ -24,6 +24,14 @@ import random class MyException(Exception): pass +def helppopup(subj): + return '<span class="helplink"><a href="help?subject='+subj+'&simple=true" target="_blank" onclick="return helppopup(\''+subj+'\')">(?)</a></span>' + + +global_dict = {} +global_dict['helppopup'] = helppopup + + # ... and stolen from xend/uuid.py def randomUUID(): """Generate a random UUID.""" @@ -47,7 +55,7 @@ def haveAccess(user, machine): def error(op, user, fields, err): d = dict(op=op, user=user, errorMessage=str(err)) - print Template(file='error.tmpl', searchList=d); + print Template(file='error.tmpl', searchList=[d, global_dict]); def validMachineName(name): """Check that name is valid for a machine name""" @@ -267,7 +275,7 @@ def create(user, fields): d = dict(user=user, machine=machine) print Template(file='create.tmpl', - searchList=d); + searchList=[d, global_dict]); def listVms(user, fields): machines = [m for m in Machine.select() if haveAccess(user, m)] @@ -281,8 +289,7 @@ def listVms(user, fields): elif m.type.hvm: has_vnc[m.name] = True else: - help_name = 'paravm_console' - has_vnc[m.name] = 'ParaVM <span class="helplink"><a href="help?subject=%s&simple=true" target="_blank" onclick="return helppopup(\'%s\')">(?)</a></span>' % (help_name, help_name) + has_vnc[m.name] = "ParaVM"+helppopup("paravm_console") # for m in machines: # status = statusInfo(m) # on[m.name] = status is not None @@ -294,7 +301,7 @@ def listVms(user, fields): has_vnc=has_vnc, uptimes=uptimes, cdroms=CDROM.select()) - print Template(file='list.tmpl', searchList=d) + print Template(file='list.tmpl', searchList=[d, global_dict]) def testMachineId(user, machineId, exists=True): if machineId is None: @@ -345,7 +352,7 @@ def vnc(user, fields): hostname=os.environ.get('SERVER_NAME', 'localhost'), authtoken=token) print Template(file='vnc.tmpl', - searchList=d) + searchList=[d, global_dict]) def getNicInfo(data_dict, machine): data_dict['num_nics'] = len(machine.nics) @@ -420,11 +427,32 @@ def command(user, fields): d = dict(user=user, command=action, machine=machine) - print Template(file="command.tmpl", searchList=d) + print Template(file="command.tmpl", searchList=[d, global_dict]) def modify(user, fields): machine = testMachineId(user, fields.getfirst('machine_id')) +def help(user, fields): + simple = fields.getfirst('simple') + subjects = fields.getlist('subject') + + mapping = dict(paravm_console=""" +ParaVM machines do not support console access over VNC. To access +these machines, you either need to boot with a liveCD and ssh in or +hope that the sipb-xen maintainers add support for serial consoles.""", + hvm_paravm=""" +HVM machines use the virtualization features of the processor, while +ParaVM machines use Xen's emulation of virtualization features. You +want an HVM virtualized machine.""", + cpu_weight="""Don't ask us! We're as mystified as you are.""") + + d = dict(user=user, + simple=simple, + subjects=subjects, + mapping=mapping) + + print Template(file="help.tmpl", searchList=[d, global_dict]) + def info(user, fields): machine = testMachineId(user, fields.getfirst('machine_id')) @@ -451,7 +479,7 @@ def info(user, fields): ('memory', 'RAM'), 'DISK_INFO', ('state', 'state (xen format)'), - ('cpu_weight', 'CPU weight'), + ('cpu_weight', 'CPU weight'+helppopup('cpu_weight')), ('on_reboot', 'Action on VM reboot'), ('on_poweroff', 'Action on VM poweroff'), ('on_crash', 'Action on VM crash'), @@ -496,14 +524,15 @@ def info(user, fields): maxdisk=maxDisk(user, machine), fields = fields) print Template(file='info.tmpl', - searchList=d) + searchList=[d, global_dict]) mapping = dict(list=listVms, vnc=vnc, command=command, modify=modify, info=info, - create=create) + create=create, + help=help) if __name__ == '__main__': start_time = time.time() @@ -512,7 +541,6 @@ if __name__ == '__main__': username = "moo" email = 'moo@cow.com' u = User() - connect('postgres://sipb-xen@sipb-xen-dev/sipb_xen') operation = os.environ.get('PATH_INFO', '') if not operation: pass @@ -527,6 +555,8 @@ if __name__ == '__main__': lambda u, e: error(operation, u, e, "Invalid operation '%s'" % operation)) + if fun not in (help, ): + connect('postgres://sipb-xen@sipb-xen-dev/sipb_xen') try: fun(u, fields) except MyException, err: diff --git a/templates/skeleton.py b/templates/skeleton.py index 01debf9..09409a5 100644 --- a/templates/skeleton.py +++ b/templates/skeleton.py @@ -33,10 +33,10 @@ VFN=valueForName currentTime=time.time __CHEETAH_version__ = '2.0rc8' __CHEETAH_versionTuple__ = (2, 0, 0, 'candidate', 8) -__CHEETAH_genTime__ = 1191718104.9039481 -__CHEETAH_genTimestamp__ = 'Sat Oct 6 20:48:24 2007' +__CHEETAH_genTime__ = 1191828896.641397 +__CHEETAH_genTimestamp__ = 'Mon Oct 8 03:34:56 2007' __CHEETAH_src__ = 'skeleton.tmpl' -__CHEETAH_srcLastModified__ = 'Sat Oct 6 20:18:06 2007' +__CHEETAH_srcLastModified__ = 'Mon Oct 8 03:34:52 2007' __CHEETAH_docstring__ = 'Autogenerated by CHEETAH: The Python-Powered Template Engine' if __CHEETAH_versionTuple__ < RequiredCheetahVersionTuple: @@ -87,19 +87,46 @@ class skeleton(Template): <head><title>''') _v = VFFSL(SL,"title",True) # '$title' on line 2, col 14 if _v is not None: write(_filter(_v, rawExpr='$title')) # from line 2, col 14. - write('''</title></head> + write('''</title> + <link href="/static/favicon.ico" type="image/x-icon" rel="shortcut icon"> + <style media="screen" type="text/css"> + @import "static/css/all.css"; + </style> + <script type="text/javascript"> +var helpWin = null; +function closeWin(){ +\tif (helpWin != null){ +\t\tif(!helpWin.closed) +\t\t\thelpWin.close(); +\t} +} + +function helppopup(name){ + closeWin() + helpWin = window.open("help?simple=true&subject="+encodeURIComponent(name), "HMMTHelp", +"status, height = 300, width = 400"); + if (window.focus){helpWin.focus();} + return false; +} +</script> +</head> <body> -<p>[You are logged in as ''') - _v = VFFSL(SL,"user.username",True) # '$user.username' on line 4, col 26 - if _v is not None: write(_filter(_v, rawExpr='$user.username')) # from line 4, col 26. - write('''.]</p> ''') - _v = VFFSL(SL,"body",True) # '$body' on line 5, col 1 - if _v is not None: write(_filter(_v, rawExpr='$body')) # from line 5, col 1. + if not VFFSL(SL,"varExists",False)('simple') or not VFFSL(SL,"simple",True): # generated from line 26, col 1 + write('''<p>[You are logged in as ''') + _v = VFFSL(SL,"user.username",True) # '$user.username' on line 27, col 26 + if _v is not None: write(_filter(_v, rawExpr='$user.username')) # from line 27, col 26. + write('''.]</p> +''') + _v = VFFSL(SL,"body",True) # '$body' on line 29, col 1 + if _v is not None: write(_filter(_v, rawExpr='$body')) # from line 29, col 1. write(''' -<hr /> +''') + if not VFFSL(SL,"varExists",False)('simple') or not VFFSL(SL,"simple",True): # generated from line 30, col 1 + write('''<hr /> Questions? Contact <a href="mailto:sipb-xen-dev@mit.edu">sipb-xen-dev@mit.edu</a>. -</body> +''') + write('''</body> </html> ''') diff --git a/templates/skeleton.tmpl b/templates/skeleton.tmpl index 9c1c891..3a5b8e2 100644 --- a/templates/skeleton.tmpl +++ b/templates/skeleton.tmpl @@ -1,9 +1,35 @@ <html> -<head><title>$title</title></head> +<head><title>$title</title> + <link href="/static/favicon.ico" type="image/x-icon" rel="shortcut icon"> + <style media="screen" type="text/css"> + @import "static/css/all.css"; + </style> + <script type="text/javascript"> +var helpWin = null; +function closeWin(){ + if (helpWin != null){ + if(!helpWin.closed) + helpWin.close(); + } +} + +function helppopup(name){ + closeWin() + helpWin = window.open("help?simple=true&subject="+encodeURIComponent(name), "HMMTHelp", +"status, height = 300, width = 400"); + if (window.focus){helpWin.focus();} + return false; +} +</script> +</head> <body> +#if not $varExists('simple') or not $simple <p>[You are logged in as $user.username.]</p> +#end if $body +#if not $varExists('simple') or not $simple <hr /> Questions? Contact <a href="mailto:sipb-xen-dev@mit.edu">sipb-xen-dev@mit.edu</a>. +#end if </body> </html> -- 1.7.9.5