2016-12-16 22:03:20 +00:00
|
|
|
package tq
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/git-lfs/git-lfs/lfsapi"
|
2017-02-22 17:55:58 +00:00
|
|
|
"github.com/git-lfs/git-lfs/tools"
|
|
|
|
"github.com/rubyist/tracerx"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
maxVerifiesConfigKey = "lfs.transfer.maxverifies"
|
|
|
|
defaultMaxVerifyAttempts = 3
|
2016-12-16 22:03:20 +00:00
|
|
|
)
|
|
|
|
|
2017-03-24 21:27:07 +00:00
|
|
|
func verifyUpload(c *lfsapi.Client, remote string, t *Transfer) error {
|
2016-12-16 22:03:20 +00:00
|
|
|
action, err := t.Actions.Get("verify")
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2017-03-06 19:36:21 +00:00
|
|
|
if action == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2016-12-16 22:03:20 +00:00
|
|
|
|
2016-12-20 21:03:00 +00:00
|
|
|
req, err := http.NewRequest("POST", action.Href, nil)
|
2016-12-16 22:03:20 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2016-12-20 21:03:00 +00:00
|
|
|
err = lfsapi.MarshalToRequest(req, struct {
|
|
|
|
Oid string `json:"oid"`
|
|
|
|
Size int64 `json:"size"`
|
|
|
|
}{Oid: t.Oid, Size: t.Size})
|
2016-12-16 22:03:20 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
for key, value := range action.Header {
|
|
|
|
req.Header.Set(key, value)
|
|
|
|
}
|
|
|
|
req.Header.Set("Content-Type", "application/vnd.git-lfs+json")
|
|
|
|
|
2017-02-22 17:55:58 +00:00
|
|
|
mv := c.GitEnv().Int(maxVerifiesConfigKey, defaultMaxVerifyAttempts)
|
|
|
|
mv = tools.MaxInt(defaultMaxVerifyAttempts, mv)
|
2017-04-27 22:27:36 +00:00
|
|
|
req = c.LogRequest(req, "lfs.verify")
|
2016-12-16 22:03:20 +00:00
|
|
|
|
2017-02-22 17:55:58 +00:00
|
|
|
for i := 1; i <= mv; i++ {
|
|
|
|
tracerx.Printf("tq: verify %s attempt #%d (max: %d)", t.Oid[:7], i, mv)
|
|
|
|
|
|
|
|
var res *http.Response
|
2017-03-24 21:27:17 +00:00
|
|
|
if t.Authenticated {
|
|
|
|
res, err = c.Do(req)
|
|
|
|
} else {
|
|
|
|
res, err = c.DoWithAuth(remote, req)
|
|
|
|
}
|
2017-02-22 17:55:58 +00:00
|
|
|
|
2017-03-24 21:27:17 +00:00
|
|
|
if err != nil {
|
2017-02-22 20:53:35 +00:00
|
|
|
tracerx.Printf("tq: verify err: %+v", err.Error())
|
|
|
|
} else {
|
2017-02-22 17:55:58 +00:00
|
|
|
err = res.Body.Close()
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return err
|
2016-12-16 22:03:20 +00:00
|
|
|
}
|