From 8139c71ccb48907d128c8910af9f9dd10a55fc8a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miloslav=20Trma=C4=8D?= Date: Sat, 7 Jan 2017 00:18:14 +0100 Subject: [PATCH] WIP: Dump HTTP operations MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Miloslav Trmač --- docker/docker_client.go | 17 +++++++++++++++++ openshift/openshift.go | 9 ++++++--- 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/docker/docker_client.go b/docker/docker_client.go index 9fca4100b0..fd071f110d 100644 --- a/docker/docker_client.go +++ b/docker/docker_client.go @@ -9,6 +9,7 @@ import ( "io/ioutil" "net" "net/http" + "net/http/httputil" "os" "path/filepath" "strings" @@ -230,10 +231,14 @@ func (c *dockerClient) makeRequestToResolvedURL(method, url string, headers map[ } } logrus.Debugf("%s %s", method, url) + dro, _ := httputil.DumpRequestOut(req, false) + logrus.Errorf("===REQ===\n%s\n===REQ===\n", dro) res, err := c.client.Do(req) if err != nil { return nil, err } + dr, _ := httputil.DumpResponse(res, false) + logrus.Errorf("===RES===\n%s\n===RES===\n", dr) return res, nil } @@ -259,10 +264,14 @@ func (c *dockerClient) setupRequestAuth(req *http.Request) error { // Do not use the body stream, or we couldn't reuse it for the "real" call later. testReq.Body = nil testReq.ContentLength = 0 + dro, _ := httputil.DumpRequestOut(&testReq, false) + logrus.Errorf("===REQ===\n%s\n===REQ===\n", dro) res, err := c.client.Do(&testReq) if err != nil { return err } + dr, _ := httputil.DumpResponse(res, false) + logrus.Errorf("===RES===\n%s\n===RES===\n", dr) chs := parseAuthHeader(res.Header) // We could end up in this "if" statement if the /v2/ call (during ping) // returned 401 with a valid WWW-Authenticate=Bearer header. @@ -288,10 +297,14 @@ func (c *dockerClient) setupRequestAuth(req *http.Request) error { testReq2.Body = nil testReq2.ContentLength = 0 testReq2.SetBasicAuth(c.username, c.password) + dro, _ := httputil.DumpRequestOut(&testReq2, false) + logrus.Errorf("===REQ===\n%s\n===REQ===\n", dro) res, err := c.client.Do(&testReq2) if err != nil { return err } + dr, _ := httputil.DumpResponse(res, false) + logrus.Errorf("===RES===\n%s\n===RES===\n", dr) chs = parseAuthHeader(res.Header) if res.StatusCode != http.StatusUnauthorized || chs == nil || len(chs) == 0 { // no need for bearer? wtf? @@ -340,10 +353,14 @@ func (c *dockerClient) getBearerToken(realm, service, scope string) (string, err // TODO(runcom): insecure for now to contact the external token service tr.TLSClientConfig = &tls.Config{InsecureSkipVerify: true} client := &http.Client{Transport: tr} + dro, _ := httputil.DumpRequestOut(authReq, false) + logrus.Errorf("===REQ===\n%s\n===REQ===\n", dro) res, err := client.Do(authReq) if err != nil { return "", err } + dr, _ := httputil.DumpResponse(res, false) + logrus.Errorf("===RES===\n%s\n===RES===\n", dr) defer res.Body.Close() switch res.StatusCode { case http.StatusUnauthorized: diff --git a/openshift/openshift.go b/openshift/openshift.go index cb3deb199d..8de92f75cc 100644 --- a/openshift/openshift.go +++ b/openshift/openshift.go @@ -8,6 +8,7 @@ import ( "io" "io/ioutil" "net/http" + "net/http/httputil" "net/url" "strings" @@ -94,18 +95,20 @@ func (c *openshiftClient) doRequest(method, path string, requestBody []byte) ([] } logrus.Debugf("%s %s", method, url) + dro, _ := httputil.DumpRequestOut(req, false) + logrus.Errorf("===REQ===\n%s\n===REQ===\n", dro) res, err := c.httpClient.Do(req) if err != nil { return nil, err } + dr, _ := httputil.DumpResponse(res, false) + logrus.Errorf("===RES===\n%s\n===RES===\n", dr) defer res.Body.Close() body, err := ioutil.ReadAll(res.Body) if err != nil { return nil, err } - logrus.Debugf("Got body: %s", body) - // FIXME: Just throwing this useful information away only to try to guess later... - logrus.Debugf("Got content-type: %s", res.Header.Get("Content-Type")) + // FIXME: Just throwing Content-Type away only to try to guess later... var status status statusValid := false