forked from jan/debianmemberportfolio
95 lines
3.3 KiB
Python
95 lines
3.3 KiB
Python
# -*- python -*-
|
|
# -*- coding: utf-8 -*-
|
|
#
|
|
# Debian Member Portfolio Service middleware configuration
|
|
#
|
|
# Copyright © 2009-2014 Jan Dittberner <jan@dittberner.info>
|
|
#
|
|
# This file is part of the Debian Member Portfolio Service.
|
|
#
|
|
# Debian Member Portfolio Service is free software: you can redistribute it
|
|
# and/or modify it under the terms of the GNU Affero General Public License as
|
|
# published by the Free Software Foundation, either version 3 of the License,
|
|
# or (at your option) any later version.
|
|
#
|
|
# Debian Member Portfolio Service is distributed in the hope that it will be
|
|
# useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero
|
|
# General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
#
|
|
"""
|
|
Pylons middleware initialization
|
|
|
|
"""
|
|
|
|
from beaker.middleware import SessionMiddleware
|
|
from paste.cascade import Cascade
|
|
from paste.registry import RegistryManager
|
|
from paste.urlparser import StaticURLParser
|
|
from paste.deploy.converters import asbool
|
|
from pylons.middleware import ErrorHandler, StatusCodeRedirect
|
|
from pylons.wsgiapp import PylonsApp
|
|
from routes.middleware import RoutesMiddleware
|
|
|
|
from debianmemberportfolio.config.environment import load_environment
|
|
|
|
|
|
def make_app(global_conf, full_stack=True, static_files=True, **app_conf):
|
|
"""
|
|
Create a Pylons WSGI application and return it
|
|
|
|
``global_conf``
|
|
The inherited configuration for this application. Normally from
|
|
the [DEFAULT] section of the Paste ini file.
|
|
|
|
``full_stack``
|
|
Whether this application provides a full WSGI stack (by default,
|
|
meaning it handles its own exceptions and errors). Disable
|
|
full_stack when this application is "managed" by another WSGI
|
|
middleware.
|
|
|
|
``static_files``
|
|
Whether this application serves its own static files; disable
|
|
when another web server is responsible for serving them.
|
|
|
|
``app_conf``
|
|
The application's local configuration. Normally specified in
|
|
the [app:<name>] section of the Paste ini file (where <name>
|
|
defaults to main).
|
|
|
|
"""
|
|
# Configure the Pylons environment
|
|
config = load_environment(global_conf, app_conf)
|
|
|
|
# The Pylons WSGI app
|
|
app = PylonsApp(config=config)
|
|
|
|
# Routing/Session/Cache Middleware
|
|
app = RoutesMiddleware(app, config['routes.map'])
|
|
app = SessionMiddleware(app, config)
|
|
|
|
# CUSTOM MIDDLEWARE HERE (filtered by error handling middlewares)
|
|
|
|
if asbool(full_stack):
|
|
# Handle Python exceptions
|
|
app = ErrorHandler(app, global_conf, **config['pylons.errorware'])
|
|
|
|
# Display error documents for 401, 403, 404 status codes (and
|
|
# 500 when debug is disabled)
|
|
if asbool(config['debug']):
|
|
app = StatusCodeRedirect(app)
|
|
else:
|
|
app = StatusCodeRedirect(app, [400, 401, 403, 404, 500])
|
|
|
|
# Establish the Registry for this application
|
|
app = RegistryManager(app)
|
|
|
|
if asbool(static_files):
|
|
# Serve static files
|
|
static_app = StaticURLParser(config['pylons.paths']['static_files'])
|
|
app = Cascade([static_app, app])
|
|
app.config = config
|
|
return app
|