2019-11-11 15:04:53 +00:00
|
|
|
// Copyright 2012 Google LLC. All rights reserved.
|
2019-04-13 12:47:57 +00:00
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
// Package transport contains HTTP transports used to make
|
|
|
|
// authenticated API requests.
|
2020-02-25 14:20:57 +00:00
|
|
|
//
|
|
|
|
// This package is DEPRECATED. Users should instead use,
|
|
|
|
//
|
|
|
|
// service, err := NewService(..., option.WithAPIKey(...))
|
2019-04-13 12:47:57 +00:00
|
|
|
package transport
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"net/http"
|
|
|
|
)
|
|
|
|
|
|
|
|
// APIKey is an HTTP Transport which wraps an underlying transport and
|
|
|
|
// appends an API Key "key" parameter to the URL of outgoing requests.
|
2020-02-25 14:20:57 +00:00
|
|
|
//
|
|
|
|
// Deprecated: please use NewService(..., option.WithAPIKey(...)) instead.
|
2019-04-13 12:47:57 +00:00
|
|
|
type APIKey struct {
|
|
|
|
// Key is the API Key to set on requests.
|
|
|
|
Key string
|
|
|
|
|
|
|
|
// Transport is the underlying HTTP transport.
|
|
|
|
// If nil, http.DefaultTransport is used.
|
|
|
|
Transport http.RoundTripper
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *APIKey) RoundTrip(req *http.Request) (*http.Response, error) {
|
|
|
|
rt := t.Transport
|
|
|
|
if rt == nil {
|
|
|
|
rt = http.DefaultTransport
|
|
|
|
if rt == nil {
|
|
|
|
return nil, errors.New("googleapi/transport: no Transport specified or available")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
newReq := *req
|
|
|
|
args := newReq.URL.Query()
|
|
|
|
args.Set("key", t.Key)
|
|
|
|
newReq.URL.RawQuery = args.Encode()
|
|
|
|
return rt.RoundTrip(&newReq)
|
|
|
|
}
|