-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathhttp.go
More file actions
134 lines (101 loc) · 3.04 KB
/
http.go
File metadata and controls
134 lines (101 loc) · 3.04 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
package deis
import (
"bytes"
"crypto/tls"
"encoding/json"
"fmt"
"io/ioutil"
"net/http"
"strconv"
"strings"
)
// createHTTPClient creates a HTTP Client with proper SSL options.
func createHTTPClient(sslVerify bool) *http.Client {
tr := &http.Transport{
TLSClientConfig: &tls.Config{InsecureSkipVerify: !sslVerify},
DisableKeepAlives: true,
Proxy: http.ProxyFromEnvironment,
}
return &http.Client{Transport: tr}
}
// Request makes a HTTP request on the controller.
func (c *Client) Request(method string, path string, body []byte) (*http.Response, error) {
url := *c.ControllerURL
if strings.Contains(path, "?") {
parts := strings.Split(path, "?")
url.Path = parts[0]
url.RawQuery = parts[1]
} else {
url.Path = path
}
req, err := http.NewRequest(method, url.String(), bytes.NewBuffer(body))
if err != nil {
return nil, err
}
req.Header.Add("Content-Type", "application/json")
if c.Token != "" {
req.Header.Add("Authorization", "token "+c.Token)
}
addUserAgent(&req.Header, c.UserAgent)
res, err := c.HTTPClient.Do(req)
if err != nil {
return nil, err
}
if err = checkForErrors(res); err != nil {
return nil, err
}
apiVersion := res.Header.Get("DEIS_API_VERSION")
// Update controller api version
c.ControllerAPIVersion = apiVersion
// Return results along with api compatibility error
return res, checkAPICompatibility(apiVersion)
}
// LimitedRequest allows limiting the number of responses in a request.
func (c *Client) LimitedRequest(path string, results int) (string, int, error) {
res, err := c.Request("GET", path+"?limit="+strconv.Itoa(results), nil)
if err != nil {
return "", -1, err
}
defer res.Body.Close()
body, err := ioutil.ReadAll(res.Body)
if err != nil {
return "", -1, err
}
r := make(map[string]interface{})
if err = json.Unmarshal([]byte(body), &r); err != nil {
return "", -1, err
}
out, err := json.Marshal(r["results"].([]interface{}))
if err != nil {
return "", -1, err
}
return string(out), int(r["count"].(float64)), nil
}
// CheckConnection checks that the user is connected to a network and the URL points to a valid controller.
func (c *Client) CheckConnection() error {
errorMessage := `%s does not appear to be a valid Deis controller.
Make sure that the Controller URI is correct, the server is running and
your deis version is correct.`
// Make a request to /v2/ and expect a 401 respone
req, err := http.NewRequest("GET", c.ControllerURL.String()+"/v2/", bytes.NewBuffer(nil))
addUserAgent(&req.Header, c.UserAgent)
if err != nil {
return err
}
res, err := c.HTTPClient.Do(req)
if err != nil {
fmt.Printf(errorMessage+"\n", c.ControllerURL.String())
return err
}
defer res.Body.Close()
if res.StatusCode != 401 {
return fmt.Errorf(errorMessage, c.ControllerURL.String())
}
// Update controller api version
apiVersion := res.Header.Get("DEIS_API_VERSION")
c.ControllerAPIVersion = apiVersion
return checkAPICompatibility(apiVersion)
}
func addUserAgent(headers *http.Header, userAgent string) {
headers.Add("User-Agent", userAgent)
}