summaryrefslogtreecommitdiffstats
path: root/routers/repo/download.go
diff options
context:
space:
mode:
authorUnknown <joe2010xtmf@163.com>2014-05-16 19:41:08 +0200
committerUnknown <joe2010xtmf@163.com>2014-05-16 19:41:08 +0200
commit956f011dd3cb09d78f4cb2fb09b1cb4f50d23473 (patch)
treeb13150bdc2b3cca0a83d717b7622c6017d78b9c7 /routers/repo/download.go
parentissue label ui design (diff)
downloadforgejo-956f011dd3cb09d78f4cb2fb09b1cb4f50d23473.tar.xz
forgejo-956f011dd3cb09d78f4cb2fb09b1cb4f50d23473.zip
Fix #186
Diffstat (limited to 'routers/repo/download.go')
-rw-r--r--routers/repo/download.go42
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")
}