diff options
author | slene <vslene@gmail.com> | 2014-04-15 18:27:29 +0200 |
---|---|---|
committer | slene <vslene@gmail.com> | 2014-04-15 18:29:03 +0200 |
commit | 4fafc7605245ef175a8fb8558eb7c30c4f7b0400 (patch) | |
tree | 4479b8792564c088931fd025ce45d31746bf064e /routers/repo/download.go | |
parent | Merge branch 'master' of github.com:gogits/gogs into dev (diff) | |
download | forgejo-4fafc7605245ef175a8fb8558eb7c30c4f7b0400.tar.xz forgejo-4fafc7605245ef175a8fb8558eb7c30c4f7b0400.zip |
zip archive download
Diffstat (limited to 'routers/repo/download.go')
-rw-r--r-- | routers/repo/download.go | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/routers/repo/download.go b/routers/repo/download.go new file mode 100644 index 0000000000..017d957155 --- /dev/null +++ b/routers/repo/download.go @@ -0,0 +1,68 @@ +// Copyright 2014 The Gogs Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package repo + +import ( + "os" + "path/filepath" + + "github.com/Unknwon/com" + "github.com/go-martini/martini" + + "github.com/gogits/gogs/modules/base" + "github.com/gogits/gogs/modules/middleware" +) + +func SingleDownload(ctx *middleware.Context, params martini.Params) { + // Get tree path + treename := params["_1"] + + blob, err := ctx.Repo.Commit.GetBlobByPath(treename) + if err != nil { + ctx.Handle(404, "repo.SingleDownload(GetBlobByPath)", err) + return + } + + data, err := blob.Data() + if err != nil { + ctx.Handle(404, "repo.SingleDownload(Data)", err) + return + } + + contentType, isTextFile := base.IsTextFile(data) + _, isImageFile := base.IsImageFile(data) + ctx.Res.Header().Set("Content-Type", contentType) + if !isTextFile && !isImageFile { + ctx.Res.Header().Set("Content-Disposition", "attachment; filename="+filepath.Base(treename)) + ctx.Res.Header().Set("Content-Transfer-Encoding", "binary") + } + ctx.Res.Write(data) +} + +func ZipDownload(ctx *middleware.Context, params martini.Params) { + commitId := ctx.Repo.CommitId + archivesPath := filepath.Join(ctx.Repo.GitRepo.Path, "archives") + if !com.IsDir(archivesPath) { + if err := os.Mkdir(archivesPath, 0755); err != nil { + ctx.Handle(404, "ZipDownload -> os.Mkdir(archivesPath)", err) + return + } + } + + zipPath := filepath.Join(archivesPath, commitId+".zip") + + if com.IsFile(zipPath) { + ctx.ServeFile(zipPath, ctx.Repo.Repository.Name+".zip") + return + } + + err := ctx.Repo.Commit.CreateArchive(zipPath) + if err != nil { + ctx.Handle(404, "ZipDownload -> CreateArchive "+zipPath, err) + return + } + + ctx.ServeFile(zipPath, ctx.Repo.Repository.Name+".zip") +} |