Allow the uri passed to various entrypoints to itself contain most of the configuration for that entrypoint by using the RFC 3986 uri format to allow for additional parameters to be used in configuring and selecting those entrypoints. Also bring over network_utils from oslo since it provides a more compliant url splitting support. Part of blueprint persistence-uris Change-Id: I8e5d8584d2cac4f9b338fa155f220cdfd52bb7d9
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# -*- coding: utf-8 -*-
 | 
						|
 | 
						|
#    Copyright (C) 2014 Yahoo! Inc. All Rights Reserved.
 | 
						|
#
 | 
						|
#    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 logging
 | 
						|
 | 
						|
import six
 | 
						|
from stevedore import driver
 | 
						|
 | 
						|
from taskflow import exceptions as exc
 | 
						|
from taskflow.utils import misc
 | 
						|
 | 
						|
 | 
						|
# NOTE(harlowja): this is the entrypoint namespace, not the module namespace.
 | 
						|
BACKEND_NAMESPACE = 'taskflow.jobboards'
 | 
						|
 | 
						|
LOG = logging.getLogger(__name__)
 | 
						|
 | 
						|
 | 
						|
def fetch(name, conf, namespace=BACKEND_NAMESPACE, **kwargs):
 | 
						|
    """Fetch a jobboard backend with the given configuration (and any board
 | 
						|
    specific kwargs) in the given entrypoint namespace and create it with the
 | 
						|
    given name.
 | 
						|
    """
 | 
						|
    if isinstance(conf, six.string_types):
 | 
						|
        conf = {'board': conf}
 | 
						|
    board = conf['board']
 | 
						|
    try:
 | 
						|
        pieces = misc.parse_uri(board)
 | 
						|
    except (TypeError, ValueError):
 | 
						|
        pass
 | 
						|
    else:
 | 
						|
        board = pieces['scheme']
 | 
						|
        conf = misc.merge_uri(pieces, conf.copy())
 | 
						|
    LOG.debug('Looking for %r jobboard driver in %r', board, namespace)
 | 
						|
    try:
 | 
						|
        mgr = driver.DriverManager(namespace, board,
 | 
						|
                                   invoke_on_load=True,
 | 
						|
                                   invoke_args=(name, conf),
 | 
						|
                                   invoke_kwds=kwargs)
 | 
						|
        return mgr.driver
 | 
						|
    except RuntimeError as e:
 | 
						|
        raise exc.NotFound("Could not find jobboard %s" % (board), e)
 |