Routing either V1 or V2 using a Facade. By default, V1 is enabled but can be deactivated by a confflag. Pecan controller for Lease created using WSME i/o validation Implements blueprint: pecan-wsme Change-Id: I9047abece78632daa13fdebfea9fb8aaa3c60981
		
			
				
	
	
		
			68 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# Copyright (c) 2014 Bull.
 | 
						|
#
 | 
						|
# 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.
 | 
						|
 | 
						|
from oslo.config import cfg
 | 
						|
from pecan import hooks
 | 
						|
 | 
						|
from climate.api import context
 | 
						|
from climate.db import api as dbapi
 | 
						|
from climate.manager.oshosts import rpcapi as hosts_rpcapi
 | 
						|
from climate.manager import rpcapi
 | 
						|
 | 
						|
from climate.openstack.common import log as logging
 | 
						|
 | 
						|
LOG = logging.getLogger(__name__)
 | 
						|
 | 
						|
 | 
						|
class ConfigHook(hooks.PecanHook):
 | 
						|
    """Attach the configuration object to the request
 | 
						|
    so controllers can get to it.
 | 
						|
    """
 | 
						|
 | 
						|
    def before(self, state):
 | 
						|
        state.request.cfg = cfg.CONF
 | 
						|
 | 
						|
 | 
						|
class DBHook(hooks.PecanHook):
 | 
						|
    """Attach the dbapi object to the request so controllers can get to it."""
 | 
						|
 | 
						|
    def before(self, state):
 | 
						|
        state.request.dbapi = dbapi.get_instance()
 | 
						|
 | 
						|
 | 
						|
class ContextHook(hooks.PecanHook):
 | 
						|
    """Configures a request context and attaches it to the request."""
 | 
						|
 | 
						|
    def before(self, state):
 | 
						|
        state.request.context = context.ctx_from_headers(state.request.headers)
 | 
						|
        state.request.context.__enter__()
 | 
						|
 | 
						|
    # NOTE(sbauza): on_error() can be fired before after() if the original
 | 
						|
    #               exception is not catched by WSME. That's necessary to not
 | 
						|
    #               handle context.__exit__() within on_error() as it could
 | 
						|
    #               lead to pop the stack twice for the same request
 | 
						|
    def after(self, state):
 | 
						|
        # If no API extensions are loaded, context is empty
 | 
						|
        if state.request.context:
 | 
						|
            state.request.context.__exit__(None, None, None)
 | 
						|
 | 
						|
 | 
						|
class RPCHook(hooks.PecanHook):
 | 
						|
    """Attach the rpcapi object to the request so controllers can get to it."""
 | 
						|
 | 
						|
    def before(self, state):
 | 
						|
        state.request.rpcapi = rpcapi.ManagerRPCAPI()
 | 
						|
        state.request.hosts_rpcapi = hosts_rpcapi.ManagerRPCAPI()
 |