Source code for

#!/usr/bin/env python
#! -*- coding: utf-8 -*-

# Copyright (c) Rice University 2012-13
# This software is subject to
# the provisions of the GNU Affero General
# Public License version 3 (AGPLv3).
# See LICENCE.txt for details.

""" - Launch the repo app.

This is the suggested method for running a WSGI Server - we instantiate the repo
app, and pass it to the waitress server (To be replaced by gunicorn)::

  python --config=../../testing.ini

.. todo::
   Michaels solution to include a sererate standalone module was much better.
   Replicate it and pull much of the URLMap code out of here.

def make_app(name, confd):
    an attempt at an app_factory
    open("/tmp/log", "a").write("APPFACTORYCALLED\n")
    app = Flask(name)
    app.add_url_rule("/", view_func=index)
    app.add_url_rule("/favicon", view_func=favicon)
    app.add_url_rule("/cms/<path:path>", view_func=cms)        
    return app


from rhaptos2.repo import make_app, sessioncache
from rhaptos2.repo.configuration import Configuration
from optparse import OptionParser
import os
from paste.urlmap import URLMap
from paste.urlparser import StaticURLParser, make_static
from waitress import serve

def main():
    opts, args = parse_args()
    config = Configuration.from_file(opts.conf)
    app = get_app(opts, args, config, 
                  as_standalone = opts.devserver, 
                  with_testuser = opts.testuser)

    wsgi_run(app, opts, args)

[docs]def get_app(opts, args, config, as_standalone = False, with_testuser = False): """ creates and sets up the app, *but does not run it through flask server unless told to* This intends to return a valid WSGI app to later be called by say gunicorn todo: I would like to use @pumazi approach of only importing _standalone server as needed returns a Flask app.wsgi_app, which can be passed into wsgi chain """ app = make_app(config) app.debug = True sessioncache.set_config(config) if as_standalone: if not os.path.isdir(opts.jslocation): raise IOError( "dir to serve static files (%s) does not exist" % opts.jslocation) ### Creating a mapping of URLS to file locations ### TODO: simplify this - proabbly need change atc and this ### may want to consider a config list of dirs, or grab ### list of dirs from FS (at jslocation) at startup time sloc = opts.jslocation stat = StaticURLParser(sloc) stat_config = StaticURLParser(os.path.join(sloc, "config")) stat_lib = StaticURLParser(os.path.join(sloc, "lib")) stat_bookish = StaticURLParser(os.path.join(sloc, "bookish")) stat_helpers = StaticURLParser(os.path.join(sloc, "helpers")) stat_node_modules = StaticURLParser(os.path.join(sloc, "node_modules")) ### give repo a simple response - /api/ will get rewritten ### todo: can I force URLMap not to adjust PATH info etc? mymaps = {"/": app.wsgi_app, "/js/": stat, "/js/config/": stat_config, "/js/lib/": stat_lib, "/js/bookish/": stat_bookish, "/js/helpers/": stat_helpers, "/js/node_modules/": stat_node_modules} urlmap = URLMap() urlmap.update(mymaps) # Need a fake user for testing, especially in the standalone case wrappedapp = urlmap else: wrappedapp = app.wsgi_app if with_testuser: wrappedapp = AddTestUser(wrappedapp) return wrappedapp
[docs]class AddTestUser(object): """ We are faking a user header to avoid onerous logins via openid for test situations """ def __init__(self, app): = app def __call__(self, environ, start_response): environ['HTTP_X-REMOTEAUTHID'] = '' # Call the wrapped application onwards return, start_response)
[docs]def wsgi_run(app, opts, args): """ """ serve(app,, port=opts.port )
def parse_args(): parser = OptionParser() parser.add_option("--host", dest="host", default="", help="hostname to listen on") parser.add_option("--port", dest="port", default="8000", help="port to listen on", type="int") parser.add_option("--debug", dest="debug", action="store_true", help="debug on.", default=False) parser.add_option("--config", dest="conf", help="Path to config file.") parser.add_option("--devserver", dest="devserver", action="store_true", default=False, help="run as devserver.") parser.add_option("--testuser", dest="testuser", action="store_true", default=False, help="Add a fake openid authenticated testuser") parser.add_option("--jslocation", dest="jslocation", help="Path to config file.") (options, args) = parser.parse_args() return (options, args)
[docs]def initialize_database(): """Initialize the database tables.""" opts, args = parse_args() config = Configuration.from_file(opts.conf) from rhaptos2.repo.backend import initdb initdb(config)
if __name__ == '__main__': main()

Project Versions

This Page