|
|
|
@ -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")
|
|
|
|
|
}
|
|
|
|
|