File: //home/arjun/projects/aigenerator/venv/lib64/python3.12/site-packages/google/cloud/storage/_http.py
# 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
from google.cloud.storage._opentelemetry_tracing import create_trace_span
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)
invocation_id = _helpers._get_invocation_id()
kwargs["extra_api_info"] = invocation_id
span_attributes = {
"gccl-invocation-id": invocation_id,
}
call = functools.partial(super(Connection, self).api_request, *args, **kwargs)
with create_trace_span(
name="Storage.Connection.api_request",
attributes=span_attributes,
client=self._client,
api_request=kwargs,
retry=retry,
):
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()