bd998017d5
Create host inventory services (api, conductor and agent) and python-inventoryclient. The inventory service collects the host resources and provides a REST API and client to expose the host resources. Create plugin for integration with system configuration (sysinv) service. This is the initial inventory service infratructure commit. Puppet configuration, SM integration and host integration with sysinv(systemconfig) changes are pending and planned to be delivered in future commits. Tests Performed: Verify the changes are inert on config_controller installation and provisioning. Puppet and spec changes are required in order to create keystone, database and activate inventory services. Unit tests performed (when puppet configuration for keystone, database is applied): Trigger host configure_check, configure signals into systemconfig(sysinv). Verify python-inventoryclient and api service: Disks and related storage resources are pending. inventory host-cpu-list/show inventory host-device-list/show/modify inventory host-ethernetport-list/show inventory host-lldp-neighbor-list inventory host-lldp-agent-list/show inventory host-memory-list/show inventory host-node-list/show inventory host-port-list/show Tox Unit tests: inventory: pep8 python-inventoryclient: py27, pep8, cover, pylint Change-Id: I744ac0de098608c55b9356abf180cc36601cfb8d Story: 2002950 Task: 22952 Signed-off-by: John Kung <john.kung@windriver.com>
50 lines
1.5 KiB
Python
50 lines
1.5 KiB
Python
#
|
|
# Copyright (c) 2018 Wind River Systems, Inc.
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
|
|
|
|
from cgtsclient.v1 import client as cgts_client
|
|
from inventory.api import config
|
|
from keystoneauth1 import loading as ks_loading
|
|
from oslo_config import cfg
|
|
from oslo_log import log
|
|
|
|
|
|
CONF = cfg.CONF
|
|
|
|
LOG = log.getLogger(__name__)
|
|
|
|
_SESSION = None
|
|
|
|
|
|
def cgtsclient(context, version=1, endpoint=None):
|
|
"""Constructs a cgts client object for making API requests.
|
|
|
|
:param context: The FM request context for auth.
|
|
:param version: API endpoint version.
|
|
:param endpoint: Optional If the endpoint is not available, it will be
|
|
retrieved from session
|
|
"""
|
|
global _SESSION
|
|
|
|
if not _SESSION:
|
|
_SESSION = ks_loading.load_session_from_conf_options(
|
|
CONF, config.sysinv_group.name)
|
|
|
|
auth_token = context.auth_token
|
|
if endpoint is None:
|
|
auth = context.get_auth_plugin()
|
|
service_type, service_name, interface = \
|
|
CONF.sysinv.catalog_info.split(':')
|
|
service_parameters = {'service_type': service_type,
|
|
'service_name': service_name,
|
|
'interface': interface,
|
|
'region_name': CONF.sysinv.os_region_name}
|
|
endpoint = _SESSION.get_endpoint(auth, **service_parameters)
|
|
|
|
return cgts_client.Client(version=version,
|
|
endpoint=endpoint,
|
|
token=auth_token)
|