2021-02-22 17:27:13 +05:30
|
|
|
package git
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
2021-09-04 01:27:46 +05:30
|
|
|
"gitlab.com/gitlab-org/gitaly/v14/proto/go/gitalypb"
|
2021-02-22 17:27:13 +05:30
|
|
|
|
2021-10-27 15:23:28 +05:30
|
|
|
"gitlab.com/gitlab-org/gitlab/workhorse/internal/gitaly"
|
|
|
|
"gitlab.com/gitlab-org/gitlab/workhorse/internal/helper"
|
|
|
|
"gitlab.com/gitlab-org/gitlab/workhorse/internal/senddata"
|
2021-02-22 17:27:13 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
type blob struct{ senddata.Prefix }
|
|
|
|
type blobParams struct {
|
|
|
|
GitalyServer gitaly.Server
|
|
|
|
GetBlobRequest gitalypb.GetBlobRequest
|
|
|
|
}
|
|
|
|
|
|
|
|
var SendBlob = &blob{"git-blob:"}
|
|
|
|
|
|
|
|
func (b *blob) Inject(w http.ResponseWriter, r *http.Request, sendData string) {
|
|
|
|
var params blobParams
|
|
|
|
if err := b.Unpack(¶ms, sendData); err != nil {
|
|
|
|
helper.Fail500(w, r, fmt.Errorf("SendBlob: unpack sendData: %v", err))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx, blobClient, err := gitaly.NewBlobClient(r.Context(), params.GitalyServer)
|
|
|
|
if err != nil {
|
|
|
|
helper.Fail500(w, r, fmt.Errorf("blob.GetBlob: %v", err))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
setBlobHeaders(w)
|
|
|
|
if err := blobClient.SendBlob(ctx, w, ¶ms.GetBlobRequest); err != nil {
|
|
|
|
helper.Fail500(w, r, fmt.Errorf("blob.GetBlob: %v", err))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func setBlobHeaders(w http.ResponseWriter) {
|
|
|
|
// Caching proxies usually don't cache responses with Set-Cookie header
|
|
|
|
// present because it implies user-specific data, which is not the case
|
|
|
|
// for blobs.
|
|
|
|
w.Header().Del("Set-Cookie")
|
|
|
|
}
|