# Copyright 2014 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. """Create / interact with Google Cloud Storage connections.""" import functools from google.cloud import _http from google.cloud.storage import __version__ from google.cloud.storage import _helpers class Connection(_http.JSONConnection): """A connection to Google Cloud Storage via the JSON REST API. Mutual TLS will be enabled if the "GOOGLE_API_USE_CLIENT_CERTIFICATE" environment variable is set to the exact string "true" (case-sensitive). Mutual TLS is not compatible with any API endpoint or universe domain override at this time. If such settings are enabled along with "GOOGLE_API_USE_CLIENT_CERTIFICATE", a ValueError will be raised. :type client: :class:`~google.cloud.storage.client.Client` :param client: The client that owns the current connection. :type client_info: :class:`~google.api_core.client_info.ClientInfo` :param client_info: (Optional) instance used to generate user agent. :type api_endpoint: str :param api_endpoint: (Optional) api endpoint to use. """ DEFAULT_API_ENDPOINT = _helpers._get_default_storage_base_url() DEFAULT_API_MTLS_ENDPOINT = "https://storage.mtls.googleapis.com" def __init__(self, client, client_info=None, api_endpoint=None): super(Connection, self).__init__(client, client_info) self.API_BASE_URL = api_endpoint or self.DEFAULT_API_ENDPOINT self.API_BASE_MTLS_URL = self.DEFAULT_API_MTLS_ENDPOINT self.ALLOW_AUTO_SWITCH_TO_MTLS_URL = api_endpoint is None self._client_info.client_library_version = __version__ # TODO: When metrics all use gccl, this should be removed #9552 if self._client_info.user_agent is None: # pragma: no branch self._client_info.user_agent = "" agent_version = f"gcloud-python/{__version__}" if agent_version not in self._client_info.user_agent: self._client_info.user_agent += f" {agent_version} " API_VERSION = _helpers._API_VERSION """The version of the API, used in building the API call's URL.""" API_URL_TEMPLATE = "{api_base_url}/storage/{api_version}{path}" """A template for the URL of a particular API call.""" def api_request(self, *args, **kwargs): retry = kwargs.pop("retry", None) kwargs["extra_api_info"] = _helpers._get_invocation_id() call = functools.partial(super(Connection, self).api_request, *args, **kwargs) if retry: # If this is a ConditionalRetryPolicy, check conditions. try: retry = retry.get_retry_policy_if_conditions_met(**kwargs) except AttributeError: # This is not a ConditionalRetryPolicy. pass if retry: call = retry(call) return call()