Source code for ecl.telemetry.v2.sample

# 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.

from ecl import resource
from ecl.telemetry import telemetry_service


[docs]class Sample(resource.Resource): """.. caution:: This API is a work in progress and is subject to change.""" id_attribute = 'sample_id' base_path = '/meters/%(counter_name)s' service = telemetry_service.TelemetryService() # Supported Operations allow_create = True allow_list = True # Properties #: The meter name this sample is for counter_name = resource.prop('meter', alias='counter_name') #: When the sample has been generated. generated_at = resource.prop('timestamp') #: Arbitrary metadata associated with the sample metadata = resource.prop('metadata', alias='resource_metadata') #: The ID of the project this sample was taken for project_id = resource.prop('project_id') #: When the sample has been recorded. recorded_at = resource.prop('recorded_at') #: The ID of the resource this sample was taken for resource_id = resource.prop('resource_id') #: The name of the source that identifies where the sample comes from source = resource.prop('source') #: The meter type type = resource.prop('type', alias='counter_type') #: The unit of measure unit = resource.prop('unit', alias='counter_unit') #: The ID of the user this sample was taken for user_id = resource.prop('user_id') #: The metered value volume = resource.prop('volume', alias='counter_volume') @classmethod
[docs] def list(cls, session, limit=None, marker=None, path_args=None, paginated=False, **params): url = cls._get_url(path_args) resp = session.get(url, endpoint_filter=cls.service, params=params) for item in resp.json(): yield cls.existing(**item)
[docs] def create(self, session): url = self._get_url(self) # telemetry expects a list of samples attrs = self._attrs.copy() attrs.pop('meter', None) resp = session.post(url, endpoint_filter=self.service, json=[attrs]) resp = resp.json() self.update_attrs(**resp.pop()) self._reset_dirty() return self