diff options
author | Unknown <joe2010xtmf@163.com> | 2014-05-16 19:41:08 +0200 |
---|---|---|
committer | Unknown <joe2010xtmf@163.com> | 2014-05-16 19:41:08 +0200 |
commit | 956f011dd3cb09d78f4cb2fb09b1cb4f50d23473 (patch) | |
tree | b13150bdc2b3cca0a83d717b7622c6017d78b9c7 /routers/repo/download.go | |
parent | issue label ui design (diff) | |
download | forgejo-956f011dd3cb09d78f4cb2fb09b1cb4f50d23473.tar.xz forgejo-956f011dd3cb09d78f4cb2fb09b1cb4f50d23473.zip |
Fix #186
Diffstat (limited to 'routers/repo/download.go')
-rw-r--r-- | routers/repo/download.go | 42 |
1 files changed, 35 insertions, 7 deletions
diff --git a/routers/repo/download.go b/routers/repo/download.go index 017d957155..d94e47665d 100644 --- a/routers/repo/download.go +++ b/routers/repo/download.go @@ -11,6 +11,8 @@ import ( "github.com/Unknwon/com" "github.com/go-martini/martini" + "github.com/gogits/git" + "github.com/gogits/gogs/modules/base" "github.com/gogits/gogs/modules/middleware" ) @@ -43,7 +45,7 @@ func SingleDownload(ctx *middleware.Context, params martini.Params) { func ZipDownload(ctx *middleware.Context, params martini.Params) { commitId := ctx.Repo.CommitId - archivesPath := filepath.Join(ctx.Repo.GitRepo.Path, "archives") + archivesPath := filepath.Join(ctx.Repo.GitRepo.Path, "archives/zip") if !com.IsDir(archivesPath) { if err := os.Mkdir(archivesPath, 0755); err != nil { ctx.Handle(404, "ZipDownload -> os.Mkdir(archivesPath)", err) @@ -51,18 +53,44 @@ func ZipDownload(ctx *middleware.Context, params martini.Params) { } } - zipPath := filepath.Join(archivesPath, commitId+".zip") + archivePath := filepath.Join(archivesPath, commitId+".zip") + + if com.IsFile(archivePath) { + ctx.ServeFile(archivePath, ctx.Repo.Repository.Name+".zip") + return + } + + err := ctx.Repo.Commit.CreateArchive(archivePath, git.AT_ZIP) + if err != nil { + ctx.Handle(404, "ZipDownload -> CreateArchive "+archivePath, err) + return + } + + ctx.ServeFile(archivePath, ctx.Repo.Repository.Name+".zip") +} + +func TarGzDownload(ctx *middleware.Context, params martini.Params) { + commitId := ctx.Repo.CommitId + archivesPath := filepath.Join(ctx.Repo.GitRepo.Path, "archives/targz") + if !com.IsDir(archivesPath) { + if err := os.Mkdir(archivesPath, 0755); err != nil { + ctx.Handle(404, "TarGzDownload -> os.Mkdir(archivesPath)", err) + return + } + } + + archivePath := filepath.Join(archivesPath, commitId+".tar.gz") - if com.IsFile(zipPath) { - ctx.ServeFile(zipPath, ctx.Repo.Repository.Name+".zip") + if com.IsFile(archivePath) { + ctx.ServeFile(archivePath, ctx.Repo.Repository.Name+".tar.gz") return } - err := ctx.Repo.Commit.CreateArchive(zipPath) + err := ctx.Repo.Commit.CreateArchive(archivePath, git.AT_TARGZ) if err != nil { - ctx.Handle(404, "ZipDownload -> CreateArchive "+zipPath, err) + ctx.Handle(404, "TarGzDownload -> CreateArchive "+archivePath, err) return } - ctx.ServeFile(zipPath, ctx.Repo.Repository.Name+".zip") + ctx.ServeFile(archivePath, ctx.Repo.Repository.Name+".tar.gz") } |