| Index: client/third_party/google/auth/transport/grpc.py
 | 
| diff --git a/client/third_party/google/auth/transport/grpc.py b/client/third_party/google/auth/transport/grpc.py
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..8554ffa36a98536229119518d1a0f2c7f479dc88
 | 
| --- /dev/null
 | 
| +++ b/client/third_party/google/auth/transport/grpc.py
 | 
| @@ -0,0 +1,131 @@
 | 
| +# Copyright 2016 Google Inc.
 | 
| +#
 | 
| +# 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.
 | 
| +
 | 
| +"""Authorization support for gRPC."""
 | 
| +
 | 
| +from __future__ import absolute_import
 | 
| +
 | 
| +try:
 | 
| +    import grpc
 | 
| +except ImportError:  # pragma: NO COVER
 | 
| +    raise ImportError(
 | 
| +        'gRPC is not installed, please install the grpcio package to use the '
 | 
| +        'gRPC transport.')
 | 
| +import six
 | 
| +
 | 
| +
 | 
| +class AuthMetadataPlugin(grpc.AuthMetadataPlugin):
 | 
| +    """A `gRPC AuthMetadataPlugin`_ that inserts the credentials into each
 | 
| +    request.
 | 
| +
 | 
| +    .. _gRPC AuthMetadataPlugin:
 | 
| +        http://www.grpc.io/grpc/python/grpc.html#grpc.AuthMetadataPlugin
 | 
| +
 | 
| +    Args:
 | 
| +        credentials (google.auth.credentials.Credentials): The credentials to
 | 
| +            add to requests.
 | 
| +        request (google.auth.transport.Request): A HTTP transport request
 | 
| +            object used to refresh credentials as needed.
 | 
| +    """
 | 
| +    def __init__(self, credentials, request):
 | 
| +        # pylint: disable=no-value-for-parameter
 | 
| +        # pylint doesn't realize that the super method takes no arguments
 | 
| +        # because this class is the same name as the superclass.
 | 
| +        super(AuthMetadataPlugin, self).__init__()
 | 
| +        self._credentials = credentials
 | 
| +        self._request = request
 | 
| +
 | 
| +    def _get_authorization_headers(self, context):
 | 
| +        """Gets the authorization headers for a request.
 | 
| +
 | 
| +        Returns:
 | 
| +            Sequence[Tuple[str, str]]: A list of request headers (key, value)
 | 
| +                to add to the request.
 | 
| +        """
 | 
| +        headers = {}
 | 
| +        self._credentials.before_request(
 | 
| +            self._request,
 | 
| +            context.method_name,
 | 
| +            context.service_url,
 | 
| +            headers)
 | 
| +
 | 
| +        return list(six.iteritems(headers))
 | 
| +
 | 
| +    def __call__(self, context, callback):
 | 
| +        """Passes authorization metadata into the given callback.
 | 
| +
 | 
| +        Args:
 | 
| +            context (grpc.AuthMetadataContext): The RPC context.
 | 
| +            callback (grpc.AuthMetadataPluginCallback): The callback that will
 | 
| +                be invoked to pass in the authorization metadata.
 | 
| +        """
 | 
| +        callback(self._get_authorization_headers(context), None)
 | 
| +
 | 
| +
 | 
| +def secure_authorized_channel(
 | 
| +        credentials, request, target, ssl_credentials=None, **kwargs):
 | 
| +    """Creates a secure authorized gRPC channel.
 | 
| +
 | 
| +    This creates a channel with SSL and :class:`AuthMetadataPlugin`. This
 | 
| +    channel can be used to create a stub that can make authorized requests.
 | 
| +
 | 
| +    Example::
 | 
| +
 | 
| +        import google.auth
 | 
| +        import google.auth.transport.grpc
 | 
| +        import google.auth.transport.requests
 | 
| +        from google.cloud.speech.v1 import cloud_speech_pb2
 | 
| +
 | 
| +        # Get credentials.
 | 
| +        credentials, _ = google.auth.default()
 | 
| +
 | 
| +        # Get an HTTP request function to refresh credentials.
 | 
| +        request = google.auth.transport.requests.Request()
 | 
| +
 | 
| +        # Create a channel.
 | 
| +        channel = google.auth.transport.grpc.secure_authorized_channel(
 | 
| +            credentials, 'speech.googleapis.com:443', request)
 | 
| +
 | 
| +        # Use the channel to create a stub.
 | 
| +        cloud_speech.create_Speech_stub(channel)
 | 
| +
 | 
| +    Args:
 | 
| +        credentials (google.auth.credentials.Credentials): The credentials to
 | 
| +            add to requests.
 | 
| +        request (google.auth.transport.Request): A HTTP transport request
 | 
| +            object used to refresh credentials as needed. Even though gRPC
 | 
| +            is a separate transport, there's no way to refresh the credentials
 | 
| +            without using a standard http transport.
 | 
| +        target (str): The host and port of the service.
 | 
| +        ssl_credentials (grpc.ChannelCredentials): Optional SSL channel
 | 
| +            credentials. This can be used to specify different certificates.
 | 
| +        kwargs: Additional arguments to pass to :func:`grpc.secure_channel`.
 | 
| +
 | 
| +    Returns:
 | 
| +        grpc.Channel: The created gRPC channel.
 | 
| +    """
 | 
| +    # Create the metadata plugin for inserting the authorization header.
 | 
| +    metadata_plugin = AuthMetadataPlugin(credentials, request)
 | 
| +
 | 
| +    # Create a set of grpc.CallCredentials using the metadata plugin.
 | 
| +    google_auth_credentials = grpc.metadata_call_credentials(metadata_plugin)
 | 
| +
 | 
| +    if ssl_credentials is None:
 | 
| +        ssl_credentials = grpc.ssl_channel_credentials()
 | 
| +
 | 
| +    # Combine the ssl credentials and the authorization credentials.
 | 
| +    composite_credentials = grpc.composite_channel_credentials(
 | 
| +        ssl_credentials, google_auth_credentials)
 | 
| +
 | 
| +    return grpc.secure_channel(target, composite_credentials, **kwargs)
 | 
| 
 |