2010-12-09 06:59:11 -06:00
|
|
|
# Authors:
|
|
|
|
# Rob Crittenden <rcritten@redhat.com>
|
|
|
|
# Jason Gerard DeRose <jderose@redhat.com>
|
|
|
|
#
|
|
|
|
# Copyright (C) 2010 Red Hat
|
|
|
|
# see file 'COPYING' for use and warranty information
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program 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 General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
|
2010-02-24 12:29:23 -06:00
|
|
|
"""
|
|
|
|
WSGI appliction for IPA server.
|
|
|
|
"""
|
|
|
|
from ipalib import api
|
2010-08-10 09:00:35 -05:00
|
|
|
from ipalib.config import Env
|
|
|
|
from ipalib.constants import DEFAULT_CONFIG
|
|
|
|
|
|
|
|
# Determine what debug level is configured. We can only do this
|
|
|
|
# by reading in the configuration file(s). The server always reads
|
|
|
|
# default.conf and will also read in `context'.conf.
|
|
|
|
env = Env()
|
|
|
|
env._bootstrap(context='server', log=None)
|
|
|
|
env._finalize_core(**dict(DEFAULT_CONFIG))
|
|
|
|
|
|
|
|
# Initialize the API with the proper debug level
|
|
|
|
api.bootstrap(context='server', debug=env.debug, log=None)
|
2010-06-25 12:37:27 -05:00
|
|
|
try:
|
|
|
|
api.finalize()
|
|
|
|
except StandardError, e:
|
|
|
|
api.log.error('Failed to start IPA: %s' % e)
|
|
|
|
else:
|
|
|
|
api.log.info('*** PROCESS START ***')
|
2010-02-24 12:29:23 -06:00
|
|
|
|
2010-06-25 12:37:27 -05:00
|
|
|
# This is the WSGI callable:
|
2010-11-08 03:58:29 -06:00
|
|
|
def application(environ, start_response):
|
|
|
|
if not environ['wsgi.multithread']:
|
|
|
|
return api.Backend.session(environ, start_response)
|
|
|
|
else:
|
|
|
|
api.log.error("IPA does not work with the threaded MPM, use the pre-fork MPM")
|