As of January 1, 2020 this library no longer supports Python 2 on the latest released version. Library versions released prior to that date will continue to be available. For more information please visit Python 2 support on Google Cloud.

Source code for google.cloud.logging_v2.sink

# Copyright 2016 Google LLC
#
# 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 Cloud Logging API Sinks."""

from google.cloud.exceptions import NotFound


[docs]class Sink(object): """Sinks represent filtered exports for log entries. See https://cloud.google.com/logging/docs/reference/v2/rest/v2/projects.sinks """ def __init__( self, name, *, filter_=None, parent=None, destination=None, client=None ): """ Args: name (str): The name of the sink. parent(Optional[str]): The resource in which to create the sink: :: "projects/[PROJECT_ID]" "organizations/[ORGANIZATION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]" "folders/[FOLDER_ID]". Defaults to the project stored on the client. filter_ (Optional[str]): The advanced logs filter expression defining the entries exported by the sink. destination (Optional[str]): Destination URI for the entries exported by the sink. If not passed, the instance should already exist, to be refreshed via :meth:`reload`. client (Optional[~logging_v2.client.Client]): A client which holds credentials and project configuration for the sink (which requires a project). """ self.name = name self.filter_ = filter_ self.destination = destination self._client = client self._parent = parent self._writer_identity = None @property def client(self): """Client bound to the sink.""" return self._client @property def parent(self): """Parent resource of the sink (project, organization, billingAccount, or folder).""" if self._parent is None: self._parent = f"projects/{self.client.project}" return self._parent @property def full_name(self): """Fully-qualified name used in sink APIs""" return f"{self.parent}/sinks/{self.name}" @property def path(self): """URL path for the sink's APIs""" return f"/{self.full_name}" @property def writer_identity(self): """Identity used for exports via the sink""" return self._writer_identity def _update_from_api_repr(self, resource): """Helper for API methods returning sink resources.""" self.destination = resource["destination"] self.filter_ = resource.get("filter") self._writer_identity = resource.get("writerIdentity")
[docs] @classmethod def from_api_repr(cls, resource, client, *, parent=None): """Construct a sink given its API representation Args: resource (dict): sink resource representation returned from the API client (~logging_v2.client.Client): Client which holds credentials and project configuration for the sink. parent(Optional[str]): The resource in which to create the sink: :: "projects/[PROJECT_ID]" "organizations/[ORGANIZATION_ID]" "billingAccounts/[BILLING_ACCOUNT_ID]" "folders/[FOLDER_ID]". Defaults to the project stored on the client. Returns: ~logging_v2.sink.Sink: Sink parsed from ``resource``. Raises: ValueError: if ``client`` is not ``None`` and the project from the resource does not agree with the project from the client. """ sink_name = resource["name"] instance = cls(sink_name, client=client, parent=parent) instance._update_from_api_repr(resource) return instance
def _require_client(self, client): """Check client or verify over-ride. Also sets ``parent``. Args: client (Union[None, ~logging_v2.client.Client]): The client to use. If not passed, falls back to the ``client`` stored on the current sink. Returns: ~logging_v2.client.Client: The client passed in or the currently bound client. """ if client is None: client = self._client return client
[docs] def create(self, *, client=None, unique_writer_identity=False): """Create the sink via a PUT request See https://cloud.google.com/logging/docs/reference/v2/rest/v2/projects.sinks/create Args: client (Optional[~logging_v2.client.Client]): The client to use. If not passed, falls back to the ``client`` stored on the current sink. unique_writer_identity (Optional[bool]): Determines the kind of IAM identity returned as writer_identity in the new sink. """ client = self._require_client(client) resource = client.sinks_api.sink_create( self.parent, self.name, self.filter_, self.destination, unique_writer_identity=unique_writer_identity, ) self._update_from_api_repr(resource)
[docs] def exists(self, *, client=None): """Test for the existence of the sink via a GET request See https://cloud.google.com/logging/docs/reference/v2/rest/v2/projects.sinks/get Args: client (Optional[~logging_v2.client.Client]): The client to use. If not passed, falls back to the ``client`` stored on the current sink. Returns: bool: Boolean indicating existence of the sink. """ client = self._require_client(client) try: client.sinks_api.sink_get(self.full_name) except NotFound: return False else: return True
[docs] def reload(self, *, client=None): """Sync local sink configuration via a GET request See https://cloud.google.com/logging/docs/reference/v2/rest/v2/projects.sinks/get Args: client (Optional[~logging_v2.client.Client]): The client to use. If not passed, falls back to the ``client`` stored on the current sink. """ client = self._require_client(client) resource = client.sinks_api.sink_get(self.full_name) self._update_from_api_repr(resource)
[docs] def update(self, *, client=None, unique_writer_identity=False): """Update sink configuration via a PUT request See https://cloud.google.com/logging/docs/reference/v2/rest/v2/projects.sinks/update Args: client (Optional[~logging_v2.client.Client]): The client to use. If not passed, falls back to the ``client`` stored on the current sink. unique_writer_identity (Optional[bool]): Determines the kind of IAM identity returned as writer_identity in the new sink. """ client = self._require_client(client) resource = client.sinks_api.sink_update( self.full_name, self.filter_, self.destination, unique_writer_identity=unique_writer_identity, ) self._update_from_api_repr(resource)
[docs] def delete(self, *, client=None): """Delete a sink via a DELETE request See https://cloud.google.com/logging/docs/reference/v2/rest/v2/projects.sinks/delete Args: client (Optional[~logging_v2.client.Client]): The client to use. If not passed, falls back to the ``client`` stored on the current sink. """ client = self._require_client(client) client.sinks_api.sink_delete(self.full_name)