# 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='', 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='', 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='', default=utils.env( 'RSD_USERNAME', default='admin'), help='User account with admin access (Env: RSD_USERNAME)') parser.add_argument( '--rsd-password', metavar='', default=utils.env( 'RSD_PASSWORD', default='admin'), help='User account password (Env: RSD_PASSWORD)') parser.add_argument( '--rsd-verify', metavar='', 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