providers/lib/client/client.go (39 lines of code) (raw):
// Copyright (c) Facebook, Inc. and its affiliates.
//
// 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.
package client
import (
"context"
"fmt"
"net/http"
)
// Client is an interface used for making http requests
type Client interface {
Do(req *http.Request) (*http.Response, error)
Get(url string) (*http.Response, error)
}
// Default returns the default http client to use
func Default() Client {
return http.DefaultClient
}
// Get will create a GET request with given headers and call Do on the client
func Get(ctx context.Context, c Client, url string, header http.Header) (*http.Response, error) {
req, err := http.NewRequestWithContext(ctx, "GET", url, nil)
if err != nil {
return nil, fmt.Errorf("cannot create http get request: %v", err)
}
req.Header = header
id := traceRequestStart(req)
if debug.failRequestNum == id {
return nil, &Err{
Code: 503,
Status: "Service Unavailable",
Body: "Request cancelled by debug feature",
}
}
resp, err := c.Do(req)
traceRequestEnd(id, resp)
return resp, err
}
// Err encapsulates stuff from the http.Response
type Err struct {
Code int
Status string
Body string
}
// Error is a part of the error interface
func (e *Err) Error() string {
return fmt.Sprintf("http error %s:\n %q", e.Status, e.Body)
}