4faad94ced
This commit fixes up the initial import, correcting import paths, moving some code into a "private" module, updating requirements files, etc.
67 lines
2.3 KiB
Python
67 lines
2.3 KiB
Python
# Copyright 2013 Red Hat, Inc.
|
|
#
|
|
# 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.
|
|
|
|
"""Provides OpenStack Configuration Model
|
|
|
|
This module defines a class representing the data
|
|
model for :mod:`oslo_config` configuration options
|
|
"""
|
|
|
|
from oslo_reports.models import with_default_views as mwdv
|
|
from oslo_reports.views.text import generic as generic_text_views
|
|
|
|
|
|
class ConfigModel(mwdv.ModelWithDefaultViews):
|
|
"""A Configuration Options Model
|
|
|
|
This model holds data about a set of configuration options
|
|
from :mod:`oslo_config`. It supports both the default group
|
|
of options and named option groups.
|
|
|
|
:param conf_obj: a configuration object
|
|
:type conf_obj: :class:`oslo_config.cfg.ConfigOpts`
|
|
"""
|
|
|
|
def __init__(self, conf_obj):
|
|
kv_view = generic_text_views.KeyValueView(dict_sep=": ",
|
|
before_dict='')
|
|
super(ConfigModel, self).__init__(text_view=kv_view)
|
|
|
|
def opt_title(optname, co):
|
|
return co._opts[optname]['opt'].name
|
|
|
|
def opt_value(opt_obj, value):
|
|
if opt_obj['opt'].secret:
|
|
return '***'
|
|
else:
|
|
return value
|
|
|
|
self['default'] = dict(
|
|
(opt_title(optname, conf_obj),
|
|
opt_value(conf_obj._opts[optname], conf_obj[optname]))
|
|
for optname in conf_obj._opts
|
|
)
|
|
|
|
groups = {}
|
|
for groupname in conf_obj._groups:
|
|
group_obj = conf_obj._groups[groupname]
|
|
curr_group_opts = dict(
|
|
(opt_title(optname, group_obj),
|
|
opt_value(group_obj._opts[optname],
|
|
conf_obj[groupname][optname]))
|
|
for optname in group_obj._opts)
|
|
groups[group_obj.name] = curr_group_opts
|
|
|
|
self.update(groups)
|