X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-web.git/blobdiff_plain/8f7f618a72a975abf592788212301fc315c21d55..1adbd730e54e17845e3f41b03d774f1a1d9b8255:/code/main.fcgi diff --git a/code/main.fcgi b/code/main.fcgi index ac34a64..fa2681a 100755 --- a/code/main.fcgi +++ b/code/main.fcgi @@ -4,19 +4,44 @@ import cherrypy import os import sys -from main import InvirtWeb +from main import InvirtWeb, InvirtUnauthWeb dev = False base_dir = os.path.dirname(__file__) -if __name__=="__main__": +def usage(): + print >>sys.stderr, """%s [config] + +Run server as FastCGI, with CherryPy config from "main.conf". + +With `config`, run standalone with CherryPy config from `config`. +""" % sys.argv[0] + sys.exit(2) + +if __name__ == "__main__": + static_dir = os.path.join(base_dir, 'static') + + if len(sys.argv) > 2: + usage() if len(sys.argv) > 1: + if sys.argv[1] in ('-h', '--help'): + usage() conf_file = sys.argv[1] dev = True else: conf_file = os.path.join(base_dir, 'main.conf') - app = cherrypy.tree.mount(InvirtWeb(), '/' if dev else '/main.fcgi') + app = cherrypy.tree.mount(InvirtWeb(), + '/', + {'/': {'tools.staticdir.root': static_dir, + 'tools.invirtwebstate.on': True}, + '/static': {'tools.staticdir.on': True, + 'tools.staticdir.dir': static_dir} + }) app.merge(conf_file) + unauthApp = cherrypy.tree.mount(InvirtUnauthWeb(), + '/unauth', + {'/': {'tools.invirtwebstate.on': True}}) + unauthApp.merge(conf_file) cherrypy.config.update(conf_file) if dev: @@ -26,5 +51,5 @@ if __name__=="__main__": else: cherrypy.engine.start(blocking=False) from flup.server.fcgi import WSGIServer - server = WSGIServer(app) + server = WSGIServer(cherrypy.tree) server.run()