diff options
author | Peter Hoffmann <Hoffmann.P@gmx.net> | 2018-11-18 19:45:40 +0100 |
---|---|---|
committer | techknowlogick <hello@techknowlogick.com> | 2018-11-18 13:45:40 -0500 |
commit | e08c7e521b02859f0e53a858443e78b86c301884 (patch) | |
tree | c9b20317c40b866992540aae0384cf411ffabc8c /routers/repo | |
parent | 4651ba06c17856c5e613b8027461a42c17f17234 (diff) | |
download | gitea-e08c7e521b02859f0e53a858443e78b86c301884.tar.gz gitea-e08c7e521b02859f0e53a858443e78b86c301884.zip |
Add raw blob endpoint to get objects by SHA ID (#5334)
* Add raw blob endpoint
This should make it possible to download raw blobs directly from
/:repo/:username/raw/blob/:sha1 URLs.
* fix: Make it work
* As an SHA-ID is no path getRefNameFromPath can't be used to verify
file specifying parameter
* added relevant change in go-gitea/git #132
Signed-off-by: Berengar W. Lehr <Berengar.Lehr@kompetenztest.de>
* Update Gopkg.lock
Can't update all vendors due to errors
Signed-off-by: Berengar W. Lehr <Berengar.Lehr@kompetenztest.de>
* style: Add Gitea copyright header
* feat: Added integration test for /repo/u/r/raw/blob
* fix: correct year in copyright header
Diffstat (limited to 'routers/repo')
-rw-r--r-- | routers/repo/download.go | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/routers/repo/download.go b/routers/repo/download.go index 820a98c0dc..a863236d6e 100644 --- a/routers/repo/download.go +++ b/routers/repo/download.go @@ -1,4 +1,5 @@ // Copyright 2014 The Gogs Authors. All rights reserved. +// Copyright 2018 The Gitea Authors. All rights reserved. // Use of this source code is governed by a MIT-style // license that can be found in the LICENSE file. @@ -69,3 +70,19 @@ func SingleDownload(ctx *context.Context) { ctx.ServerError("ServeBlob", err) } } + +// DownloadByID download a file by sha1 ID +func DownloadByID(ctx *context.Context) { + blob, err := ctx.Repo.GitRepo.GetBlob(ctx.Params("sha")) + if err != nil { + if git.IsErrNotExist(err) { + ctx.NotFound("GetBlob", nil) + } else { + ctx.ServerError("GetBlob", err) + } + return + } + if err = ServeBlob(ctx, blob); err != nil { + ctx.ServerError("ServeBlob", err) + } +} |