Merge pull request #477 from restic/rest-backend

rest backend: Remove indirection on http.Client
This commit is contained in:
Alexander Neumann 2016-02-25 22:24:00 +01:00
commit 1e0b7dbdd2

View file

@ -48,7 +48,7 @@ func restPath(url *url.URL, h backend.Handle) string {
type restBackend struct { type restBackend struct {
url *url.URL url *url.URL
connChan chan struct{} connChan chan struct{}
client *http.Client client http.Client
} }
// Open opens the REST backend with the given config. // Open opens the REST backend with the given config.
@ -60,7 +60,7 @@ func Open(cfg Config) (backend.Backend, error) {
tr := &http.Transport{} tr := &http.Transport{}
client := http.Client{Transport: tr} client := http.Client{Transport: tr}
return &restBackend{url: cfg.URL, connChan: connChan, client: &client}, nil return &restBackend{url: cfg.URL, connChan: connChan, client: client}, nil
} }
// Location returns this backend's location (the server's URL). // Location returns this backend's location (the server's URL).
@ -80,10 +80,8 @@ func (b *restBackend) Load(h backend.Handle, p []byte, off int64) (n int, err er
return 0, err return 0, err
} }
req.Header.Add("Range", fmt.Sprintf("bytes=%d-%d", off, off+int64(len(p)))) req.Header.Add("Range", fmt.Sprintf("bytes=%d-%d", off, off+int64(len(p))))
client := *b.client
<-b.connChan <-b.connChan
resp, err := client.Do(req) resp, err := b.client.Do(req)
b.connChan <- struct{}{} b.connChan <- struct{}{}
if resp != nil { if resp != nil {
@ -112,10 +110,8 @@ func (b *restBackend) Save(h backend.Handle, p []byte) (err error) {
return err return err
} }
client := *b.client
<-b.connChan <-b.connChan
resp, err := client.Post(restPath(b.url, h), "binary/octet-stream", bytes.NewReader(p)) resp, err := b.client.Post(restPath(b.url, h), "binary/octet-stream", bytes.NewReader(p))
b.connChan <- struct{}{} b.connChan <- struct{}{}
if resp != nil { if resp != nil {
@ -145,9 +141,8 @@ func (b *restBackend) Stat(h backend.Handle) (backend.BlobInfo, error) {
return backend.BlobInfo{}, err return backend.BlobInfo{}, err
} }
client := *b.client
<-b.connChan <-b.connChan
resp, err := client.Head(restPath(b.url, h)) resp, err := b.client.Head(restPath(b.url, h))
b.connChan <- struct{}{} b.connChan <- struct{}{}
if err != nil { if err != nil {
return backend.BlobInfo{}, err return backend.BlobInfo{}, err
@ -193,10 +188,8 @@ func (b *restBackend) Remove(t backend.Type, name string) error {
if err != nil { if err != nil {
return err return err
} }
client := *b.client
<-b.connChan <-b.connChan
resp, err := client.Do(req) resp, err := b.client.Do(req)
b.connChan <- struct{}{} b.connChan <- struct{}{}
if err != nil { if err != nil {
@ -221,9 +214,8 @@ func (b *restBackend) List(t backend.Type, done <-chan struct{}) <-chan string {
url += "/" url += "/"
} }
client := *b.client
<-b.connChan <-b.connChan
resp, err := client.Get(url) resp, err := b.client.Get(url)
b.connChan <- struct{}{} b.connChan <- struct{}{}
if resp != nil { if resp != nil {