Skip to content

Commit

Permalink
Set BasicAuth in http.go only if username and password are not empty (#…
Browse files Browse the repository at this point in the history
…914)

This prevents error "read/write on closed pipe".

Go's http.client::send() always closes req.Body, so if the first request attempt
is unsuccessful, any subsequent requests after calling the `CredentialsCallback`
will attempt to read/write on a closed pipe.

(cherry picked from commit 9db5de1)
  • Loading branch information
clns authored and lhchavez committed Jul 13, 2022
1 parent a61660f commit 38313ce
Showing 1 changed file with 3 additions and 1 deletion.
4 changes: 3 additions & 1 deletion http.go
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,9 @@ func (self *httpSmartSubtransportStream) sendRequest() error {
req.ContentLength = -1
}

req.SetBasicAuth(userName, password)
if userName != "" && password != "" {
req.SetBasicAuth(userName, password)
}
resp, err = http.DefaultClient.Do(req)
if err != nil {
return err
Expand Down

0 comments on commit 38313ce

Please sign in to comment.