|
|
@ -6,6 +6,7 @@ package repo |
|
|
|
|
|
|
|
|
|
|
|
import ( |
|
|
|
import ( |
|
|
|
"bytes" |
|
|
|
"bytes" |
|
|
|
|
|
|
|
"compress/gzip" |
|
|
|
"encoding/base64" |
|
|
|
"encoding/base64" |
|
|
|
"errors" |
|
|
|
"errors" |
|
|
|
"fmt" |
|
|
|
"fmt" |
|
|
@ -283,23 +284,42 @@ func serviceReceivePack(hr handler) { |
|
|
|
|
|
|
|
|
|
|
|
func serviceRpc(rpc string, hr handler) { |
|
|
|
func serviceRpc(rpc string, hr handler) { |
|
|
|
w, r, dir := hr.w, hr.r, hr.Dir |
|
|
|
w, r, dir := hr.w, hr.r, hr.Dir |
|
|
|
access := hasAccess(r, hr.Config, dir, rpc, true) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
access := hasAccess(r, hr.Config, dir, rpc, true) |
|
|
|
if access == false { |
|
|
|
if access == false { |
|
|
|
renderNoAccess(w) |
|
|
|
renderNoAccess(w) |
|
|
|
return |
|
|
|
return |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
w.Header().Set("Content-Type", fmt.Sprintf("application/x-git-%s-result", rpc)) |
|
|
|
w.Header().Set("Content-Type", fmt.Sprintf("application/x-git-%s-result", rpc)) |
|
|
|
w.WriteHeader(http.StatusOK) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var input []byte |
|
|
|
var ( |
|
|
|
var br io.Reader |
|
|
|
reqBody = r.Body |
|
|
|
|
|
|
|
input []byte |
|
|
|
|
|
|
|
br io.Reader |
|
|
|
|
|
|
|
err error |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Handle GZIP.
|
|
|
|
|
|
|
|
if r.Header.Get("Content-Encoding") == "gzip" { |
|
|
|
|
|
|
|
reqBody, err = gzip.NewReader(reqBody) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
log.GitLogger.Error(2, "fail to create gzip reader: %v", err) |
|
|
|
|
|
|
|
w.WriteHeader(http.StatusInternalServerError) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if hr.Config.OnSucceed != nil { |
|
|
|
if hr.Config.OnSucceed != nil { |
|
|
|
input, _ = ioutil.ReadAll(r.Body) |
|
|
|
input, err = ioutil.ReadAll(reqBody) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
log.GitLogger.Error(2, "fail to read request body: %v", err) |
|
|
|
|
|
|
|
w.WriteHeader(http.StatusInternalServerError) |
|
|
|
|
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
br = bytes.NewReader(input) |
|
|
|
br = bytes.NewReader(input) |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
br = r.Body |
|
|
|
br = reqBody |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
args := []string{rpc, "--stateless-rpc", dir} |
|
|
|
args := []string{rpc, "--stateless-rpc", dir} |
|
|
@ -308,15 +328,16 @@ func serviceRpc(rpc string, hr handler) { |
|
|
|
cmd.Stdout = w |
|
|
|
cmd.Stdout = w |
|
|
|
cmd.Stdin = br |
|
|
|
cmd.Stdin = br |
|
|
|
|
|
|
|
|
|
|
|
err := cmd.Run() |
|
|
|
if err := cmd.Run(); err != nil { |
|
|
|
if err != nil { |
|
|
|
log.GitLogger.Error(2, "fail to serve RPC(%s): %v", rpc, err) |
|
|
|
log.GitLogger.Error(4, err.Error()) |
|
|
|
w.WriteHeader(http.StatusInternalServerError) |
|
|
|
return |
|
|
|
return |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if hr.Config.OnSucceed != nil { |
|
|
|
if hr.Config.OnSucceed != nil { |
|
|
|
hr.Config.OnSucceed(rpc, input) |
|
|
|
hr.Config.OnSucceed(rpc, input) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
w.WriteHeader(http.StatusOK) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func getInfoRefs(hr handler) { |
|
|
|
func getInfoRefs(hr handler) { |
|
|
|