174 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			174 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# Copyright 2016 Google Inc. All rights reserved.
 | 
						|
#
 | 
						|
# 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.
 | 
						|
 | 
						|
"""Define Logging API Metrics."""
 | 
						|
 | 
						|
from gcloud.exceptions import NotFound
 | 
						|
 | 
						|
 | 
						|
class Metric(object):
 | 
						|
    """Metrics represent named filters for log entries.
 | 
						|
 | 
						|
    See:
 | 
						|
    https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics
 | 
						|
 | 
						|
    :type name: string
 | 
						|
    :param name: the name of the metric
 | 
						|
 | 
						|
    :type filter_: string
 | 
						|
    :param filter_: the advanced logs filter expression defining the entries
 | 
						|
                   tracked by the metric.  If not passed, the instance should
 | 
						|
                   already exist, to be refreshed via :meth:`reload`.
 | 
						|
 | 
						|
    :type client: :class:`gcloud.logging.client.Client`
 | 
						|
    :param client: A client which holds credentials and project configuration
 | 
						|
                   for the metric (which requires a project).
 | 
						|
 | 
						|
    :type description: string
 | 
						|
    :param description: an optional description of the metric.
 | 
						|
    """
 | 
						|
    def __init__(self, name, filter_=None, client=None, description=''):
 | 
						|
        self.name = name
 | 
						|
        self._client = client
 | 
						|
        self.filter_ = filter_
 | 
						|
        self.description = description
 | 
						|
 | 
						|
    @property
 | 
						|
    def client(self):
 | 
						|
        """Clent bound to the logger."""
 | 
						|
        return self._client
 | 
						|
 | 
						|
    @property
 | 
						|
    def project(self):
 | 
						|
        """Project bound to the logger."""
 | 
						|
        return self._client.project
 | 
						|
 | 
						|
    @property
 | 
						|
    def full_name(self):
 | 
						|
        """Fully-qualified name used in metric APIs"""
 | 
						|
        return 'projects/%s/metrics/%s' % (self.project, self.name)
 | 
						|
 | 
						|
    @property
 | 
						|
    def path(self):
 | 
						|
        """URL path for the metric's APIs"""
 | 
						|
        return '/%s' % (self.full_name,)
 | 
						|
 | 
						|
    @classmethod
 | 
						|
    def from_api_repr(cls, resource, client):
 | 
						|
        """Factory:  construct a metric given its API representation
 | 
						|
 | 
						|
        :type resource: dict
 | 
						|
        :param resource: metric resource representation returned from the API
 | 
						|
 | 
						|
        :type client: :class:`gcloud.logging.client.Client`
 | 
						|
        :param client: Client which holds credentials and project
 | 
						|
                       configuration for the metric.
 | 
						|
 | 
						|
        :rtype: :class:`gcloud.logging.metric.Metric`
 | 
						|
        :returns: Metric parsed from ``resource``.
 | 
						|
        """
 | 
						|
        metric_name = resource['name']
 | 
						|
        filter_ = resource['filter']
 | 
						|
        description = resource.get('description', '')
 | 
						|
        return cls(metric_name, filter_, client=client,
 | 
						|
                   description=description)
 | 
						|
 | 
						|
    def _require_client(self, client):
 | 
						|
        """Check client or verify over-ride.
 | 
						|
 | 
						|
        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
 | 
						|
        :param client: the client to use.  If not passed, falls back to the
 | 
						|
                       ``client`` stored on the current metric.
 | 
						|
 | 
						|
        :rtype: :class:`gcloud.logging.client.Client`
 | 
						|
        :returns: The client passed in or the currently bound client.
 | 
						|
        """
 | 
						|
        if client is None:
 | 
						|
            client = self._client
 | 
						|
        return client
 | 
						|
 | 
						|
    def create(self, client=None):
 | 
						|
        """API call:  create the metric via a PUT request
 | 
						|
 | 
						|
        See:
 | 
						|
        https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/create
 | 
						|
 | 
						|
        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
 | 
						|
        :param client: the client to use.  If not passed, falls back to the
 | 
						|
                       ``client`` stored on the current metric.
 | 
						|
        """
 | 
						|
        client = self._require_client(client)
 | 
						|
        client.metrics_api.metric_create(
 | 
						|
            self.project, self.name, self.filter_, self.description)
 | 
						|
 | 
						|
    def exists(self, client=None):
 | 
						|
        """API call:  test for the existence of the metric via a GET request
 | 
						|
 | 
						|
        See
 | 
						|
        https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/get
 | 
						|
 | 
						|
        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
 | 
						|
        :param client: the client to use.  If not passed, falls back to the
 | 
						|
                       ``client`` stored on the current metric.
 | 
						|
        """
 | 
						|
        client = self._require_client(client)
 | 
						|
 | 
						|
        try:
 | 
						|
            client.metrics_api.metric_get(self.project, self.name)
 | 
						|
        except NotFound:
 | 
						|
            return False
 | 
						|
        else:
 | 
						|
            return True
 | 
						|
 | 
						|
    def reload(self, client=None):
 | 
						|
        """API call:  sync local metric configuration via a GET request
 | 
						|
 | 
						|
        See
 | 
						|
        https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/get
 | 
						|
 | 
						|
        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
 | 
						|
        :param client: the client to use.  If not passed, falls back to the
 | 
						|
                       ``client`` stored on the current metric.
 | 
						|
        """
 | 
						|
        client = self._require_client(client)
 | 
						|
        data = client.metrics_api.metric_get(self.project, self.name)
 | 
						|
        self.description = data.get('description', '')
 | 
						|
        self.filter_ = data['filter']
 | 
						|
 | 
						|
    def update(self, client=None):
 | 
						|
        """API call:  update metric configuration via a PUT request
 | 
						|
 | 
						|
        See
 | 
						|
        https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/update
 | 
						|
 | 
						|
        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
 | 
						|
        :param client: the client to use.  If not passed, falls back to the
 | 
						|
                       ``client`` stored on the current metric.
 | 
						|
        """
 | 
						|
        client = self._require_client(client)
 | 
						|
        client.metrics_api.metric_update(
 | 
						|
            self.project, self.name, self.filter_, self.description)
 | 
						|
 | 
						|
    def delete(self, client=None):
 | 
						|
        """API call:  delete a metric via a DELETE request
 | 
						|
 | 
						|
        See
 | 
						|
        https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/delete
 | 
						|
 | 
						|
        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
 | 
						|
        :param client: the client to use.  If not passed, falls back to the
 | 
						|
                       ``client`` stored on the current metric.
 | 
						|
        """
 | 
						|
        client = self._require_client(client)
 | 
						|
        client.metrics_api.metric_delete(self.project, self.name)
 |