2024-11-25 11:35:49 -08:00
|
|
|
// Copyright 2024 The Gitea Authors. All rights reserved.
|
|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
|
|
|
|
package repo
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"code.gitea.io/gitea/modules/git"
|
|
|
|
"code.gitea.io/gitea/modules/gitrepo"
|
|
|
|
"code.gitea.io/gitea/services/context"
|
|
|
|
archiver_service "code.gitea.io/gitea/services/repository/archiver"
|
|
|
|
)
|
|
|
|
|
|
|
|
func DownloadArchive(ctx *context.APIContext) {
|
|
|
|
var tp git.ArchiveType
|
|
|
|
switch ballType := ctx.PathParam("ball_type"); ballType {
|
|
|
|
case "tarball":
|
2025-01-13 09:07:05 +08:00
|
|
|
tp = git.ArchiveTarGz
|
2024-11-25 11:35:49 -08:00
|
|
|
case "zipball":
|
2025-01-13 09:07:05 +08:00
|
|
|
tp = git.ArchiveZip
|
2024-11-25 11:35:49 -08:00
|
|
|
case "bundle":
|
2025-01-13 09:07:05 +08:00
|
|
|
tp = git.ArchiveBundle
|
2024-11-25 11:35:49 -08:00
|
|
|
default:
|
|
|
|
ctx.Error(http.StatusBadRequest, "", fmt.Sprintf("Unknown archive type: %s", ballType))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if ctx.Repo.GitRepo == nil {
|
2024-12-24 11:43:57 +08:00
|
|
|
var err error
|
2024-12-31 12:22:09 +08:00
|
|
|
ctx.Repo.GitRepo, err = gitrepo.RepositoryFromRequestContextOrOpen(ctx, ctx.Repo.Repository)
|
2024-11-25 11:35:49 -08:00
|
|
|
if err != nil {
|
|
|
|
ctx.Error(http.StatusInternalServerError, "OpenRepository", err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2025-01-13 09:07:05 +08:00
|
|
|
r, err := archiver_service.NewRequest(ctx.Repo.Repository.ID, ctx.Repo.GitRepo, ctx.PathParam("*")+"."+tp.String())
|
2024-11-25 11:35:49 -08:00
|
|
|
if err != nil {
|
|
|
|
ctx.ServerError("NewRequest", err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
archive, err := r.Await(ctx)
|
|
|
|
if err != nil {
|
|
|
|
ctx.ServerError("archive.Await", err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
download(ctx, r.GetArchiveName(), archive)
|
|
|
|
}
|