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
|
diff --git a/internal/git/protocol_git.go b/internal/git/protocol_git.go
index 7ee650c851b5b3bc68411cb3e3358320fc2b0920..332c8936db1755ab8c64afed597e4f170830aa22 100644
--- a/internal/git/protocol_git.go
+++ b/internal/git/protocol_git.go
@@ -27,7 +27,7 @@ }
if err := pkt.Flush(); err != nil {
return err
}
- return gitService(ctx, "receive-pack", string(c), "--stateless-rpc", "--advertise-refs")
+ return gitService(ctx, "upload-pack", string(c), "--stateless-rpc", "--advertise-refs")
}
func (c CmdProtocol) HTTPUploadPack(ctx ReadWriteContexter) error {
@@ -45,6 +45,7 @@
func gitService(ctx ReadWriteContexter, command, repoDir string, args ...string) error {
cmd := exec.CommandContext(ctx.Context(), "git")
cmd.Args = append(cmd.Args, []string{
+ "-c", "protocol.version=2",
"-c", "uploadpack.allowFilter=true",
"-c", "receive.advertisePushOptions=true",
"-c", fmt.Sprintf("core.hooksPath=%s", filepath.Join(filepath.Dir(repoDir), "hooks")),
@@ -54,9 +55,10 @@ if len(args) > 0 {
cmd.Args = append(cmd.Args, args...)
}
cmd.Args = append(cmd.Args, repoDir)
- cmd.Env = append(os.Environ(), fmt.Sprintf("UGIT_REPODIR=%s", repoDir))
+ cmd.Env = append(os.Environ(), fmt.Sprintf("UGIT_REPODIR=%s", repoDir), "GIT_PROTOCOL=version=2")
cmd.Stdin = ctx
cmd.Stdout = ctx
+ fmt.Println(cmd.Env, cmd.String())
return cmd.Run()
}
|