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