mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
WTF-1070 Read response body data before closing
Signed-off-by: Chris Cummer <chriscummer@me.com>
This commit is contained in:
parent
2fd9d623a1
commit
50e2281c63
@ -1,8 +1,10 @@
|
|||||||
package jira
|
package jira
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"crypto/tls"
|
"crypto/tls"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
"strings"
|
"strings"
|
||||||
@ -10,6 +12,8 @@ import (
|
|||||||
"github.com/wtfutil/wtf/utils"
|
"github.com/wtfutil/wtf/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// IssuesFor returns a collection of issues for a given collection of projects.
|
||||||
|
// If username is provided, it scopes the issues to that person
|
||||||
func (widget *Widget) IssuesFor(username string, projects []string, jql string) (*SearchResult, error) {
|
func (widget *Widget) IssuesFor(username string, projects []string, jql string) (*SearchResult, error) {
|
||||||
query := []string{}
|
query := []string{}
|
||||||
|
|
||||||
@ -38,7 +42,7 @@ func (widget *Widget) IssuesFor(username string, projects []string, jql string)
|
|||||||
}
|
}
|
||||||
|
|
||||||
searchResult := &SearchResult{}
|
searchResult := &SearchResult{}
|
||||||
err = utils.ParseJSON(searchResult, resp.Body)
|
err = utils.ParseJSON(searchResult, bytes.NewReader(resp))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -52,7 +56,7 @@ func buildJql(key string, value string) string {
|
|||||||
|
|
||||||
/* -------------------- Unexported Functions -------------------- */
|
/* -------------------- Unexported Functions -------------------- */
|
||||||
|
|
||||||
func (widget *Widget) jiraRequest(path string) (*http.Response, error) {
|
func (widget *Widget) jiraRequest(path string) ([]byte, error) {
|
||||||
url := fmt.Sprintf("%s%s", widget.settings.domain, path)
|
url := fmt.Sprintf("%s%s", widget.settings.domain, path)
|
||||||
|
|
||||||
req, err := http.NewRequest("GET", url, nil)
|
req, err := http.NewRequest("GET", url, nil)
|
||||||
@ -61,13 +65,15 @@ func (widget *Widget) jiraRequest(path string) (*http.Response, error) {
|
|||||||
}
|
}
|
||||||
req.SetBasicAuth(widget.settings.email, widget.settings.apiKey)
|
req.SetBasicAuth(widget.settings.email, widget.settings.apiKey)
|
||||||
|
|
||||||
httpClient := &http.Client{Transport: &http.Transport{
|
httpClient := &http.Client{
|
||||||
TLSClientConfig: &tls.Config{
|
Transport: &http.Transport{
|
||||||
InsecureSkipVerify: !widget.settings.verifyServerCertificate,
|
TLSClientConfig: &tls.Config{
|
||||||
|
InsecureSkipVerify: !widget.settings.verifyServerCertificate,
|
||||||
|
},
|
||||||
|
Proxy: http.ProxyFromEnvironment,
|
||||||
},
|
},
|
||||||
Proxy: http.ProxyFromEnvironment,
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
resp, err := httpClient.Do(req)
|
resp, err := httpClient.Do(req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -78,7 +84,12 @@ func (widget *Widget) jiraRequest(path string) (*http.Response, error) {
|
|||||||
return nil, fmt.Errorf(resp.Status)
|
return nil, fmt.Errorf(resp.Status)
|
||||||
}
|
}
|
||||||
|
|
||||||
return resp, nil
|
body, err := ioutil.ReadAll(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return body, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func getProjectQuery(projects []string) string {
|
func getProjectQuery(projects []string) string {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user