Commit 55444e03 authored by Kamil Trzcinski's avatar Kamil Trzcinski

Update github.com/jfbus/httprs to fix https://gitlab.com/gitlab-org/gitlab-workhorse/issues/153

parent 367f10dd
...@@ -16,6 +16,7 @@ If you want use a specific http.Client for additional range requests : ...@@ -16,6 +16,7 @@ If you want use a specific http.Client for additional range requests :
package httprs package httprs
import ( import (
"context"
"errors" "errors"
"fmt" "fmt"
"io" "io"
...@@ -33,6 +34,7 @@ type HttpReadSeeker struct { ...@@ -33,6 +34,7 @@ type HttpReadSeeker struct {
c *http.Client c *http.Client
req *http.Request req *http.Request
res *http.Response res *http.Response
ctx context.Context
r io.ReadCloser r io.ReadCloser
pos int64 pos int64
canSeek bool canSeek bool
...@@ -63,6 +65,7 @@ var ( ...@@ -63,6 +65,7 @@ var (
func NewHttpReadSeeker(res *http.Response, client ...*http.Client) *HttpReadSeeker { func NewHttpReadSeeker(res *http.Response, client ...*http.Client) *HttpReadSeeker {
r := &HttpReadSeeker{ r := &HttpReadSeeker{
req: res.Request, req: res.Request,
ctx: res.Request.Context(),
res: res, res: res,
r: res.Body, r: res.Body,
canSeek: (res.Header.Get("Accept-Ranges") == "bytes"), canSeek: (res.Header.Get("Accept-Ranges") == "bytes"),
...@@ -159,7 +162,27 @@ func (r *HttpReadSeeker) Seek(offset int64, whence int) (int64, error) { ...@@ -159,7 +162,27 @@ func (r *HttpReadSeeker) Seek(offset int64, whence int) (int64, error) {
return r.pos, err return r.pos, err
} }
func cloneHeader(h http.Header) http.Header {
h2 := make(http.Header, len(h))
for k, vv := range h {
vv2 := make([]string, len(vv))
copy(vv2, vv)
h2[k] = vv2
}
return h2
}
func (r *HttpReadSeeker) newRequest() *http.Request {
newreq := r.req.WithContext(r.ctx) // includes shallow copies of maps, but okay
if r.req.ContentLength == 0 {
newreq.Body = nil // Issue 16036: nil Body for http.Transport retries
}
newreq.Header = cloneHeader(r.req.Header)
return newreq
}
func (r *HttpReadSeeker) rangeRequest() error { func (r *HttpReadSeeker) rangeRequest() error {
r.req = r.newRequest()
r.req.Header.Set("Range", fmt.Sprintf("bytes=%d-", r.pos)) r.req.Header.Set("Range", fmt.Sprintf("bytes=%d-", r.pos))
etag, last := r.res.Header.Get("ETag"), r.res.Header.Get("Last-Modified") etag, last := r.res.Header.Get("ETag"), r.res.Header.Get("Last-Modified")
switch { switch {
......
...@@ -91,10 +91,10 @@ ...@@ -91,10 +91,10 @@
"revision": "e8f0f8aaa98dfb6586cbdf2978d511e3199a960a" "revision": "e8f0f8aaa98dfb6586cbdf2978d511e3199a960a"
}, },
{ {
"checksumSHA1": "g46WnPAlsmkyNDUFdObDgP6DP+s=", "checksumSHA1": "6TbprMZzwDk+SaW+JxdxvnauyDk=",
"path": "github.com/jfbus/httprs", "path": "github.com/jfbus/httprs",
"revision": "e879ae6bf984ca6c009eb44696e9f400ec3ed2d9", "revision": "32cf48c14a79f94eb3d8100efc00e773c5c8b160",
"revisionTime": "2017-07-03T13:54:35Z" "revisionTime": "2017-11-08T13:45:55Z"
}, },
{ {
"checksumSHA1": "oIkoHb8+rM5Etur5HhZVY/sDQKQ=", "checksumSHA1": "oIkoHb8+rM5Etur5HhZVY/sDQKQ=",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment