2020-12-02 10:09:37 -05:00
|
|
|
package git
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
2022-06-30 05:10:05 -04:00
|
|
|
"gitlab.com/gitlab-org/gitaly/v15/proto/go/gitalypb"
|
2020-12-02 10:09:37 -05:00
|
|
|
|
2022-05-18 05:07:58 -04:00
|
|
|
"gitlab.com/gitlab-org/gitlab/workhorse/internal/api"
|
2021-07-21 11:08:52 -04:00
|
|
|
"gitlab.com/gitlab-org/gitlab/workhorse/internal/gitaly"
|
|
|
|
"gitlab.com/gitlab-org/gitlab/workhorse/internal/helper"
|
|
|
|
"gitlab.com/gitlab-org/gitlab/workhorse/internal/senddata"
|
2020-12-02 10:09:37 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
type blob struct{ senddata.Prefix }
|
|
|
|
type blobParams struct {
|
2022-05-18 05:07:58 -04:00
|
|
|
GitalyServer api.GitalyServer
|
2020-12-02 10:09:37 -05:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2022-05-18 05:07:58 -04:00
|
|
|
ctx, blobClient, err := gitaly.NewBlobClient(
|
|
|
|
r.Context(),
|
|
|
|
params.GitalyServer,
|
|
|
|
gitaly.WithFeatures(params.GitalyServer.Features),
|
|
|
|
)
|
|
|
|
|
2020-12-02 10:09:37 -05:00
|
|
|
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")
|
|
|
|
}
|