Remove unneeded methods from OS_Config class

These are in the minimum required version of osc-lib (1.2.0).

A few methods remain that need to be released in osc-lib, expect them
in the 1.3.0 release soon.

Change-Id: I2333946da9a73e73377b646e4c06e99597990945
This commit is contained in:
Dean Troyer 2017-01-04 11:30:17 -06:00
parent e6e3cd295c
commit c6aceb78b7

View File

@ -15,10 +15,8 @@
import logging import logging
from os_client_config import config
from os_client_config import exceptions as occ_exceptions from os_client_config import exceptions as occ_exceptions
from oslo_utils import strutils from osc_lib.cli import client_config
import six
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
@ -26,7 +24,7 @@ LOG = logging.getLogger(__name__)
# Sublcass OpenStackConfig in order to munge config values # Sublcass OpenStackConfig in order to munge config values
# before auth plugins are loaded # before auth plugins are loaded
class OSC_Config(config.OpenStackConfig): class OSC_Config(client_config.OSC_Config):
# TODO(dtroyer): Once os-client-config with pw_func argument is in # TODO(dtroyer): Once os-client-config with pw_func argument is in
# global-requirements we can remove __init()__ # global-requirements we can remove __init()__
@ -62,75 +60,8 @@ class OSC_Config(config.OpenStackConfig):
return ret return ret
def _auth_select_default_plugin(self, config): # TODO(dtroyer): Remove _auth_default_domain when the v3otp fix is
"""Select a default plugin based on supplied arguments # backported to osc-lib, should be in release 1.3.0
Migrated from auth.select_auth_plugin()
"""
identity_version = config.get('identity_api_version', '')
if config.get('username', None) and not config.get('auth_type', None):
if identity_version == '3':
config['auth_type'] = 'v3password'
elif identity_version.startswith('2'):
config['auth_type'] = 'v2password'
else:
# let keystoneauth figure it out itself
config['auth_type'] = 'password'
elif config.get('token', None) and not config.get('auth_type', None):
if identity_version == '3':
config['auth_type'] = 'v3token'
elif identity_version.startswith('2'):
config['auth_type'] = 'v2token'
else:
# let keystoneauth figure it out itself
config['auth_type'] = 'token'
else:
# The ultimate default is similar to the original behaviour,
# but this time with version discovery
if not config.get('auth_type', None):
config['auth_type'] = 'password'
LOG.debug("Auth plugin %s selected" % config['auth_type'])
return config
def _auth_v2_arguments(self, config):
"""Set up v2-required arguments from v3 info
Migrated from auth.build_auth_params()
"""
if ('auth_type' in config and config['auth_type'].startswith("v2")):
if 'project_id' in config['auth']:
config['auth']['tenant_id'] = config['auth']['project_id']
if 'project_name' in config['auth']:
config['auth']['tenant_name'] = config['auth']['project_name']
return config
def _auth_v2_ignore_v3(self, config):
"""Remove v3 arguemnts if present for v2 plugin
Migrated from clientmanager.setup_auth()
"""
# NOTE(hieulq): If USER_DOMAIN_NAME, USER_DOMAIN_ID, PROJECT_DOMAIN_ID
# or PROJECT_DOMAIN_NAME is present and API_VERSION is 2.0, then
# ignore all domain related configs.
if (config.get('identity_api_version', '').startswith('2') and
config.get('auth_type', None).endswith('password')):
domain_props = [
'project_domain_id',
'project_domain_name',
'user_domain_id',
'user_domain_name',
]
for prop in domain_props:
if config['auth'].pop(prop, None) is not None:
LOG.warning("Ignoring domain related config " +
prop + " because identity API version is 2.0")
return config
def _auth_default_domain(self, config): def _auth_default_domain(self, config):
"""Set a default domain from available arguments """Set a default domain from available arguments
@ -171,23 +102,6 @@ class OSC_Config(config.OpenStackConfig):
config['auth']['user_domain_id'] = default_domain config['auth']['user_domain_id'] = default_domain
return config return config
def auth_config_hook(self, config):
"""Allow examination of config values before loading auth plugin
OpenStackClient will override this to perform additional chacks
on auth_type.
"""
config = self._auth_select_default_plugin(config)
config = self._auth_v2_arguments(config)
config = self._auth_v2_ignore_v3(config)
config = self._auth_default_domain(config)
if LOG.isEnabledFor(logging.DEBUG):
LOG.debug("auth_config_hook(): %s",
strutils.mask_password(six.text_type(config)))
return config
def load_auth_plugin(self, config): def load_auth_plugin(self, config):
"""Get auth plugin and validate args""" """Get auth plugin and validate args"""
@ -196,10 +110,12 @@ class OSC_Config(config.OpenStackConfig):
auth_plugin = loader.load_from_options(**config['auth']) auth_plugin = loader.load_from_options(**config['auth'])
return auth_plugin return auth_plugin
# TODO(dtroyer): Remove _validate_auth_ksc when it is in osc-lib 1.3.0
def _validate_auth_ksc(self, config, cloud, fixed_argparse=None): def _validate_auth_ksc(self, config, cloud, fixed_argparse=None):
"""Old compatibility hack for OSC, no longer needed/wanted""" """Old compatibility hack for OSC, no longer needed/wanted"""
return config return config
# TODO(dtroyer): Remove _validate_auth when it is in osc-lib 1.3.0
def _validate_auth(self, config, loader, fixed_argparse=None): def _validate_auth(self, config, loader, fixed_argparse=None):
"""Validate auth plugin arguments""" """Validate auth plugin arguments"""
# May throw a keystoneauth1.exceptions.NoMatchingPlugin # May throw a keystoneauth1.exceptions.NoMatchingPlugin