0
0
mirror of https://github.com/go-gitea/gitea.git synced 2025-11-08 20:32:29 +01:00

feat: new generic package version/file enumeration api endpoint

This commit is contained in:
imgurbot12 2025-10-29 00:26:57 -07:00
parent cddff73bbd
commit 4130feb124
No known key found for this signature in database
2 changed files with 61 additions and 0 deletions

View File

@ -336,6 +336,7 @@ func CommonRoutes() *web.Router {
}) })
}, reqPackageAccess(perm.AccessModeRead)) }, reqPackageAccess(perm.AccessModeRead))
r.Group("/generic", func() { r.Group("/generic", func() {
r.Get("/{packagename}/list", generic.EnumeratePackageVersions)
r.Group("/{packagename}/{packageversion}", func() { r.Group("/{packagename}/{packageversion}", func() {
r.Delete("", reqPackageAccess(perm.AccessModeWrite), generic.DeletePackage) r.Delete("", reqPackageAccess(perm.AccessModeWrite), generic.DeletePackage)
r.Group("/{filename}", func() { r.Group("/{filename}", func() {

View File

@ -12,6 +12,7 @@ import (
packages_model "code.gitea.io/gitea/models/packages" packages_model "code.gitea.io/gitea/models/packages"
packages_module "code.gitea.io/gitea/modules/packages" packages_module "code.gitea.io/gitea/modules/packages"
"code.gitea.io/gitea/modules/timeutil"
"code.gitea.io/gitea/routers/api/packages/helper" "code.gitea.io/gitea/routers/api/packages/helper"
"code.gitea.io/gitea/services/context" "code.gitea.io/gitea/services/context"
packages_service "code.gitea.io/gitea/services/packages" packages_service "code.gitea.io/gitea/services/packages"
@ -22,11 +23,70 @@ var (
filenameRegex = regexp.MustCompile(`\A[-_+=:;.()\[\]{}~!@#$%^& \w]+\z`) filenameRegex = regexp.MustCompile(`\A[-_+=:;.()\[\]{}~!@#$%^& \w]+\z`)
) )
// GenericPackageFileInfo represents information about an existing package file
// swagger:model
type GenericPackageFileInfo struct {
// Name of package file
Name string `json:"name"`
// swagger:strfmt date-time
// Date when package file was created/uploaded
CreatedUnix timeutil.TimeStamp `json:"created"`
}
// GenericPackageInfo represents information about an existing package file
// swagger:model
type GenericPackageInfo struct {
/// Version linked to package information
Version string `json:"version"`
/// Download count for files within version
DownloadCount int64 `json:"downloads"`
/// Files uploaded for package version
Files []GenericPackageFileInfo `json:"files"`
}
func apiError(ctx *context.Context, status int, obj any) { func apiError(ctx *context.Context, status int, obj any) {
message := helper.ProcessErrorForUser(ctx, status, obj) message := helper.ProcessErrorForUser(ctx, status, obj)
ctx.PlainText(status, message) ctx.PlainText(status, message)
} }
// EnumeratePackageVersions lists upload versions and their associated files
func EnumeratePackageVersions(ctx *context.Context) {
pvs, err := packages_model.GetVersionsByPackageName(ctx, ctx.Package.Owner.ID, packages_model.TypeGeneric, ctx.PathParam("packagename"))
if err != nil {
apiError(ctx, http.StatusInternalServerError, err)
return
}
if len(pvs) == 0 {
apiError(ctx, http.StatusNotFound, err)
return
}
var info []GenericPackageInfo
for _, pv := range pvs {
packageFiles, err := packages_model.GetFilesByVersionID(ctx, pv.ID)
if err != nil {
apiError(ctx, http.StatusInternalServerError, err)
return
}
var files []GenericPackageFileInfo
for _, file := range packageFiles {
files = append(files, GenericPackageFileInfo{
Name: file.Name,
CreatedUnix: file.CreatedUnix,
})
}
info = append(info, GenericPackageInfo{
Version: pv.Version,
DownloadCount: pv.DownloadCount,
Files: files,
})
}
ctx.JSON(http.StatusOK, info)
}
// DownloadPackageFile serves the specific generic package. // DownloadPackageFile serves the specific generic package.
func DownloadPackageFile(ctx *context.Context) { func DownloadPackageFile(ctx *context.Context) {
s, u, pf, err := packages_service.OpenFileForDownloadByPackageNameAndVersion( s, u, pf, err := packages_service.OpenFileForDownloadByPackageNameAndVersion(