oslo.limit/oslo_limit/opts.py
Takashi Kajinami 9575a24796 Query endpoint id from keystone
Endpoint id is not predictable so users can't configure the endpoint_id
option until keystone endpoints are created. This requires redundant
steps in deployment. For example both keystone and glance are run by
httpd + mod_wsgi then you first have to deploy keystone and then create
glance endpoints, until you can install glance and restart httpd.

This introduces a few new options to look up the target endpoint from
Keystone. All these options accept predictable values.

Closes-bug: #1931875
Change-Id: I0411d4aa6abd86cb38bf3c1999f2bae213983078
2024-09-05 11:08:12 +09:00

79 lines
2.6 KiB
Python

# 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 copy
from keystoneauth1 import loading
from oslo_config import cfg
from oslo_limit._i18n import _
__all__ = [
'list_opts',
'register_opts',
]
CONF = cfg.CONF
_options = [
cfg.StrOpt(
'endpoint_id',
help=_("The service's endpoint id which is registered in Keystone.")),
cfg.StrOpt(
'endpoint_service_name',
help=_("Service name for endpoint discovery")),
cfg.StrOpt(
'endpoint_service_type',
help=_("Service type for endpoint discovery")),
cfg.StrOpt(
'endpoint_region_name',
help=_("Region to which the endpoint belongs")),
cfg.StrOpt(
'endpoint_interface',
default='publicURL',
choices=['public', 'publicURL', 'internal', 'internalURL',
'admin', 'adminURL'],
help=_("The interface for endpoint discovery")),
]
_option_group = 'oslo_limit'
def list_opts():
"""Return a list of oslo.config options available in the library.
:returns: a list of (group_name, opts) tuples
"""
return [(_option_group,
copy.deepcopy(_options) +
loading.get_session_conf_options() +
loading.get_auth_plugin_conf_options('password') +
loading.get_auth_plugin_conf_options('v2password') +
loading.get_auth_plugin_conf_options('v3password') +
loading.get_adapter_conf_options(include_deprecated=False)
)]
def register_opts(conf):
loading.register_session_conf_options(CONF, _option_group)
loading.register_adapter_conf_options(CONF, _option_group,
include_deprecated=False)
loading.register_auth_conf_options(CONF, _option_group)
plugin_name = CONF.oslo_limit.auth_type
if plugin_name:
plugin_loader = loading.get_plugin_loader(plugin_name)
plugin_opts = loading.get_auth_plugin_conf_options(plugin_loader)
CONF.register_opts(plugin_opts, group=_option_group)
conf.register_opts(_options, group=_option_group)