forked from TrueCloudLab/rclone
rest: add NoRedirect flag to Options
This commit is contained in:
parent
a29a1de43d
commit
1a65c3a740
1 changed files with 16 additions and 1 deletions
|
@ -143,6 +143,7 @@ type Opts struct {
|
||||||
Parameters url.Values // any parameters for the final URL
|
Parameters url.Values // any parameters for the final URL
|
||||||
TransferEncoding []string // transfer encoding, set to "identity" to disable chunked encoding
|
TransferEncoding []string // transfer encoding, set to "identity" to disable chunked encoding
|
||||||
Close bool // set to close the connection after this transaction
|
Close bool // set to close the connection after this transaction
|
||||||
|
NoRedirect bool // if this is set then the client won't follow redirects
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy creates a copy of the options
|
// Copy creates a copy of the options
|
||||||
|
@ -189,6 +190,15 @@ func ClientWithHeaderReset(c *http.Client, headers map[string]string) *http.Clie
|
||||||
return &clientCopy
|
return &clientCopy
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ClientWithNoRedirects makes a new http client which won't follow redirects
|
||||||
|
func ClientWithNoRedirects(c *http.Client) *http.Client {
|
||||||
|
clientCopy := *c
|
||||||
|
clientCopy.CheckRedirect = func(req *http.Request, via []*http.Request) error {
|
||||||
|
return http.ErrUseLastResponse
|
||||||
|
}
|
||||||
|
return &clientCopy
|
||||||
|
}
|
||||||
|
|
||||||
// Call makes the call and returns the http.Response
|
// Call makes the call and returns the http.Response
|
||||||
//
|
//
|
||||||
// if err != nil then resp.Body will need to be closed
|
// if err != nil then resp.Body will need to be closed
|
||||||
|
@ -252,7 +262,12 @@ func (api *Client) Call(opts *Opts) (resp *http.Response, err error) {
|
||||||
if opts.UserName != "" || opts.Password != "" {
|
if opts.UserName != "" || opts.Password != "" {
|
||||||
req.SetBasicAuth(opts.UserName, opts.Password)
|
req.SetBasicAuth(opts.UserName, opts.Password)
|
||||||
}
|
}
|
||||||
c := ClientWithHeaderReset(api.c, headers)
|
var c *http.Client
|
||||||
|
if opts.NoRedirect {
|
||||||
|
c = ClientWithNoRedirects(api.c)
|
||||||
|
} else {
|
||||||
|
c = ClientWithHeaderReset(api.c, headers)
|
||||||
|
}
|
||||||
if api.signer != nil {
|
if api.signer != nil {
|
||||||
err = api.signer(req)
|
err = api.signer(req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
Loading…
Reference in a new issue