X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-web.git/blobdiff_plain/3177530fc065d3bbb103e9b344cfd199fd6d2057..06d55379f8eaaffe42ca5a1ac59e1cb0633c12e9:/code/invirt.fcgi diff --git a/code/invirt.fcgi b/code/invirt.fcgi new file mode 100644 index 0000000..385b562 --- /dev/null +++ b/code/invirt.fcgi @@ -0,0 +1,61 @@ +#!/usr/bin/python +"""Main FastCGI entry point for web interface""" + +import cherrypy +import os +import sys + +import main + +dev = False +base_dir = os.path.dirname(__file__) + +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`. + +Run this script as either 'auth.fcgi' or 'unauth.fcgi', to get +the authenticated or unauthenticated site respectively. +""" % sys.argv[0] + sys.exit(2) + +if __name__ == "__main__": + 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_config = { + '/': { + 'tools.invirtwebstate.on': True, + }, + } + + if os.path.basename(sys.argv[0]).startswith('auth'): + root = InvirtWeb() + elif os.path.basename(sys.argv[0]).startswith('unauth'): + root = InvirtUnauthWeb() + else: + usage() + + app = cherrypy.tree.mount(root, '/', app_config) + app.merge(conf_file) + cherrypy.config.update(conf_file) + + if dev: + cherrypy.server.quickstart() + cherrypy.engine.start() + cherrypy.engine.block() + else: + cherrypy.engine.start(blocking=False) + from flup.server.fcgi import WSGIServer + server = WSGIServer(cherrypy.tree) + server.run()