
Added how to set required environment variables and missing sub-command usage examples. Change-Id: Ib4ccd707b0bfe3f407923bf9629b91cfcb480065
97 lines
3.1 KiB
Python
97 lines
3.1 KiB
Python
# Copyright 2017 Intel, 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.
|
|
#
|
|
|
|
"""OpenStackClient plugin for RSD(Rack Scale Design)."""
|
|
|
|
import logging
|
|
|
|
from osc_lib import utils
|
|
|
|
from rsdclient.common import utils as rsdclient_utils
|
|
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
DEFAULT_API_VERSION = '1.2'
|
|
API_VERSION_OPTION = 'os_rsd_api_version'
|
|
API_NAME = 'rsd'
|
|
API_VERSIONS = {
|
|
'1.2': 'rsdclient.v1.client.Client',
|
|
}
|
|
|
|
|
|
def make_client(instance):
|
|
"""Returns a rsd client."""
|
|
rsd_client = utils.get_client_class(
|
|
API_NAME,
|
|
instance._api_version[API_NAME],
|
|
API_VERSIONS)
|
|
LOG.debug('Instantiating RSD client: %s', rsd_client)
|
|
|
|
client = rsd_client(
|
|
base_url=instance._cli_options.rsd_url,
|
|
username=instance._cli_options.rsd_username,
|
|
password=instance._cli_options.rsd_password,
|
|
verify=rsdclient_utils.str2boolean(instance._cli_options.rsd_verify))
|
|
return client
|
|
|
|
|
|
def build_option_parser(parser):
|
|
"""Hook to add global options"""
|
|
|
|
parser.add_argument(
|
|
'--rsd-api-version',
|
|
metavar='<rsd-api-version>',
|
|
default=utils.env(
|
|
'RSD_API_VERSION',
|
|
default=DEFAULT_API_VERSION),
|
|
help='RSD API version, default=' +
|
|
DEFAULT_API_VERSION +
|
|
' (Env: RSD_API_VERSION)')
|
|
parser.add_argument(
|
|
'--rsd-url',
|
|
metavar='<rsd-url>',
|
|
default=utils.env(
|
|
'RSD_URL',
|
|
default='https://localhost:8443/redfish/v1/'),
|
|
help='The base URL to RSD pod manager (Env: RSD_URL)')
|
|
parser.add_argument(
|
|
'--rsd-username',
|
|
metavar='<rsd-username>',
|
|
default=utils.env(
|
|
'RSD_USERNAME',
|
|
default='admin'),
|
|
help='User account with admin access (Env: RSD_USERNAME)')
|
|
parser.add_argument(
|
|
'--rsd-password',
|
|
metavar='<rsd-password>',
|
|
default=utils.env(
|
|
'RSD_PASSWORD',
|
|
default='admin'),
|
|
help='User account password (Env: RSD_PASSWORD)')
|
|
parser.add_argument(
|
|
'--rsd-verify',
|
|
metavar='<rsd-username>',
|
|
default=utils.env(
|
|
'RSD_VERIFY',
|
|
default='True'),
|
|
help='Either a boolean value, a path to a CA_BUNDLE file or directory'
|
|
' with certificates of trusted CAs. If set to True it will '
|
|
'verify the host certificates; if False it will ignore verifying'
|
|
' the SSL certificate; if it\'s a path the driver will use the '
|
|
'specified certificate or one of the certificates in the '
|
|
'directory. Defaults to True. (Env: RSD_VERIFY)')
|
|
return parser
|