# Copyright Ericsson AB 2014. All rights reserved # # Authors: Balazs Gibizer # Ildiko Vancsa # # 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 ceilometerclient import client as ceiloclient from ceilometerclient.v2 import alarms from ceilometerclient.v2 import capabilities from ceilometerclient.v2 import event_types from ceilometerclient.v2 import events from ceilometerclient.v2 import meters from ceilometerclient.v2 import query from ceilometerclient.v2 import resources from ceilometerclient.v2 import samples from ceilometerclient.v2 import statistics from ceilometerclient.v2 import trait_descriptions from ceilometerclient.v2 import traits from keystoneclient import exceptions class Client(object): """Client for the Ceilometer v2 API. :param session: a keystoneauth/keystoneclient session object :type session: keystoneclient.session.Session :param str service_type: The default service_type for URL discovery :param str service_name: The default service_name for URL discovery :param str interface: The default interface for URL discovery (Default: public) :param str region_name: The default region_name for URL discovery :param str endpoint_override: Always use this endpoint URL for requests :param for this ceiloclient :param auth: An auth plugin to use instead of the session one :type auth: keystoneclient.auth.base.BaseAuthPlugin :param str user_agent: The User-Agent string to set (Default is python-ceilometer-client) :param int connect_retries: the maximum number of retries that should be attempted for connection errors :param logger: A logging object :type logger: logging.Logger """ def __init__(self, *args, **kwargs): """Initialize a new client for the Ceilometer v2 API.""" if not kwargs.get('auth_plugin'): kwargs['auth_plugin'] = ceiloclient.get_auth_plugin(*args, **kwargs) self.auth_plugin = kwargs.get('auth_plugin') self.http_client = ceiloclient._construct_http_client(**kwargs) self.alarm_client, aodh_enabled = self._get_alarm_client(**kwargs) self.meters = meters.MeterManager(self.http_client) self.samples = samples.OldSampleManager(self.http_client) self.new_samples = samples.SampleManager(self.http_client) self.statistics = statistics.StatisticsManager(self.http_client) self.resources = resources.ResourceManager(self.http_client) self.alarms = alarms.AlarmManager(self.alarm_client, aodh_enabled) self.events = events.EventManager(self.http_client) self.event_types = event_types.EventTypeManager(self.http_client) self.traits = traits.TraitManager(self.http_client) self.trait_descriptions = trait_descriptions.\ TraitDescriptionManager(self.http_client) self.query_samples = query.QuerySamplesManager( self.http_client) self.query_alarms = query.QueryAlarmsManager(self.alarm_client) self.query_alarm_history = query.QueryAlarmHistoryManager( self.alarm_client) self.capabilities = capabilities.CapabilitiesManager(self.http_client) def _get_alarm_client(self, **kwargs): """Get client for alarm manager that redirect to aodh.""" kwargs = copy.deepcopy(kwargs) self.alarm_auth_plugin = kwargs.get('auth_plugin') aodh_endpoint = kwargs.get('aodh_endpoint') if kwargs.get('session') is not None: if aodh_endpoint: kwargs['endpoint_override'] = aodh_endpoint else: kwargs["service_type"] = "alarming" try: return ceiloclient._construct_http_client(**kwargs), True except exceptions.EndpointNotFound: return self.http_client, False else: if aodh_endpoint: kwargs["auth_plugin"].opts['endpoint'] = aodh_endpoint elif not kwargs.get('auth_url'): # Users may just provided ceilometer endpoint and token, and no # auth_url, in this case, we need 'aodh_endpoint' also # provided, otherwise we cannot get aodh endpoint from # keystone, and assume aodh is unavailable. return self.http_client, False else: try: # NOTE(liusheng): Getting the aodh's endpoint to rewrite # the endpoint of alarm auth_plugin. kwargs["auth_plugin"].redirect_to_aodh_endpoint( kwargs.get('timeout')) except exceptions.EndpointNotFound: return self.http_client, False return ceiloclient._construct_http_client(**kwargs), True