summaryrefslogtreecommitdiffstats
path: root/nova/utils.py
diff options
context:
space:
mode:
authorDavanum Srinivas <dims@linux.vnet.ibm.com>2013-01-21 21:18:34 -0500
committerDavanum Srinivas <dims@linux.vnet.ibm.com>2013-01-21 21:18:34 -0500
commit52bee33eca1719bc01318cdef5f95c2b48992c0a (patch)
treef309ff294bf2dd3c9c53a25ab20f1afcfb43794b /nova/utils.py
parenta4d608fa33b328d7ed77c7f9c40ffbb43c0ade6b (diff)
downloadnova-52bee33eca1719bc01318cdef5f95c2b48992c0a.tar.gz
nova-52bee33eca1719bc01318cdef5f95c2b48992c0a.tar.xz
nova-52bee33eca1719bc01318cdef5f95c2b48992c0a.zip
Add support for Option Groups in LazyPluggable
Use @markmc's suggestion to enhance LazyPluggable with an optional config group. Also fix the baremetal database backend option to use the "baremetal" config group. Fixes LP #1093043 Change-Id: I28cf51a2962f516fcef4ced19e30c985220e86dc
Diffstat (limited to 'nova/utils.py')
-rw-r--r--nova/utils.py8
1 files changed, 6 insertions, 2 deletions
diff --git a/nova/utils.py b/nova/utils.py
index 75cba0a7c..f9e08fd80 100644
--- a/nova/utils.py
+++ b/nova/utils.py
@@ -507,14 +507,18 @@ def str_dict_replace(s, mapping):
class LazyPluggable(object):
"""A pluggable backend loaded lazily based on some value."""
- def __init__(self, pivot, **backends):
+ def __init__(self, pivot, config_group=None, **backends):
self.__backends = backends
self.__pivot = pivot
self.__backend = None
+ self.__config_group = config_group
def __get_backend(self):
if not self.__backend:
- backend_name = CONF[self.__pivot]
+ if self.__config_group is None:
+ backend_name = CONF[self.__pivot]
+ else:
+ backend_name = CONF[self.__config_group][self.__pivot]
if backend_name not in self.__backends:
msg = _('Invalid backend: %s') % backend_name
raise exception.NovaException(msg)