acd70e5641
Bug 1223524 Change-Id: Ic0d53fd1d5b3b7a587d33dc230e9ff200782ad4f
137 lines
4.3 KiB
Python
137 lines
4.3 KiB
Python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
|
|
# Copyright 2012 OpenStack Foundation
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
import functools
|
|
import routes
|
|
|
|
from keystone import assignment
|
|
from keystone import auth
|
|
from keystone import catalog
|
|
from keystone.common import cache
|
|
from keystone.common import dependency
|
|
from keystone.common import wsgi
|
|
from keystone import config
|
|
from keystone.contrib import endpoint_filter
|
|
from keystone import controllers
|
|
from keystone import credential
|
|
from keystone import identity
|
|
from keystone.openstack.common import log as logging
|
|
from keystone import policy
|
|
from keystone import routers
|
|
from keystone import token
|
|
from keystone import trust
|
|
|
|
|
|
CONF = config.CONF
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
# Ensure the cache is configured and built before we instantiate the managers
|
|
cache.configure_cache_region(cache.REGION)
|
|
|
|
# Ensure that the identity driver is created before the assignment manager.
|
|
# The default assignment driver is determined by the identity driver, so the
|
|
# identity driver must be available to the assignment manager.
|
|
_IDENTITY_API = identity.Manager()
|
|
|
|
DRIVERS = dict(
|
|
assignment_api=assignment.Manager(),
|
|
catalog_api=catalog.Manager(),
|
|
credentials_api=credential.Manager(),
|
|
endpoint_filter_api=endpoint_filter.Manager(),
|
|
identity_api=_IDENTITY_API,
|
|
policy_api=policy.Manager(),
|
|
token_api=token.Manager(),
|
|
trust_api=trust.Manager(),
|
|
token_provider_api=token.provider.Manager())
|
|
|
|
dependency.resolve_future_dependencies()
|
|
|
|
|
|
def fail_gracefully(f):
|
|
"""Logs exceptions and aborts."""
|
|
@functools.wraps(f)
|
|
def wrapper(*args, **kw):
|
|
try:
|
|
return f(*args, **kw)
|
|
except Exception as e:
|
|
LOG.debug(e, exc_info=True)
|
|
|
|
# exception message is printed to all logs
|
|
LOG.critical(e)
|
|
|
|
exit(1)
|
|
return wrapper
|
|
|
|
|
|
@fail_gracefully
|
|
def public_app_factory(global_conf, **local_conf):
|
|
controllers.register_version('v2.0')
|
|
conf = global_conf.copy()
|
|
conf.update(local_conf)
|
|
return wsgi.ComposingRouter(routes.Mapper(),
|
|
[identity.routers.Public(),
|
|
token.routers.Router(),
|
|
routers.VersionV2('public'),
|
|
routers.Extension(False)])
|
|
|
|
|
|
@fail_gracefully
|
|
def admin_app_factory(global_conf, **local_conf):
|
|
conf = global_conf.copy()
|
|
conf.update(local_conf)
|
|
return wsgi.ComposingRouter(routes.Mapper(),
|
|
[identity.routers.Admin(),
|
|
token.routers.Router(),
|
|
routers.VersionV2('admin'),
|
|
routers.Extension()])
|
|
|
|
|
|
@fail_gracefully
|
|
def public_version_app_factory(global_conf, **local_conf):
|
|
conf = global_conf.copy()
|
|
conf.update(local_conf)
|
|
return wsgi.ComposingRouter(routes.Mapper(),
|
|
[routers.Versions('public')])
|
|
|
|
|
|
@fail_gracefully
|
|
def admin_version_app_factory(global_conf, **local_conf):
|
|
conf = global_conf.copy()
|
|
conf.update(local_conf)
|
|
return wsgi.ComposingRouter(routes.Mapper(),
|
|
[routers.Versions('admin')])
|
|
|
|
|
|
@fail_gracefully
|
|
def v3_app_factory(global_conf, **local_conf):
|
|
controllers.register_version('v3')
|
|
conf = global_conf.copy()
|
|
conf.update(local_conf)
|
|
mapper = routes.Mapper()
|
|
v3routers = []
|
|
for module in [auth, catalog, credential, identity, policy]:
|
|
module.routers.append_v3_routers(mapper, v3routers)
|
|
|
|
if CONF.trust.enabled:
|
|
trust.routers.append_v3_routers(mapper, v3routers)
|
|
|
|
# Add in the v3 version api
|
|
v3routers.append(routers.VersionV3('admin'))
|
|
v3routers.append(routers.VersionV3('public'))
|
|
# TODO(ayoung): put token routes here
|
|
return wsgi.ComposingRouter(mapper, v3routers)
|