forked from git-lfs/git-lfs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
verify.go
66 lines (55 loc) · 1.4 KB
/
verify.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package tq
import (
"net/http"
"github.com/git-lfs/git-lfs/v3/lfsapi"
"github.com/git-lfs/git-lfs/v3/tools"
"github.com/rubyist/tracerx"
)
const (
maxVerifiesConfigKey = "lfs.transfer.maxverifies"
defaultMaxVerifyAttempts = 3
)
func verifyUpload(c *lfsapi.Client, remote string, t *Transfer) error {
action, err := t.Actions.Get("verify")
if err != nil {
return err
}
if action == nil {
return nil
}
req, err := http.NewRequest("POST", action.Href, nil)
if err != nil {
return err
}
err = lfsapi.MarshalToRequest(req, struct {
Oid string `json:"oid"`
Size int64 `json:"size"`
}{Oid: t.Oid, Size: t.Size})
if err != nil {
return err
}
req.Header.Set("Content-Type", "application/vnd.git-lfs+json")
req.Header.Set("Accept", "application/vnd.git-lfs+json")
for key, value := range action.Header {
req.Header.Set(key, value)
}
mv := c.GitEnv().Int(maxVerifiesConfigKey, defaultMaxVerifyAttempts)
mv = tools.MaxInt(defaultMaxVerifyAttempts, mv)
req = c.LogRequest(req, "lfs.verify")
for i := 1; i <= mv; i++ {
tracerx.Printf("tq: verify %s attempt #%d (max: %d)", t.Oid[:7], i, mv)
var res *http.Response
if t.Authenticated {
res, err = c.Do(req)
} else {
res, err = c.DoWithAuth(remote, c.Endpoints.AccessFor(action.Href), req)
}
if err != nil {
tracerx.Printf("tq: verify err: %+v", err.Error())
} else {
err = res.Body.Close()
break
}
}
return err
}