diff options
author | KN4CK3R <admin@oldschoolhack.me> | 2022-04-01 01:08:32 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-04-01 01:08:32 +0200 |
commit | 08d199245ade5f1c4e0898cfe67f3b635a287675 (patch) | |
tree | e8f7d47b7e842e33cb7448e321c5af0901f2b360 | |
parent | 242d71035a8906e2b31360386f8e4861bf4e3da8 (diff) | |
download | gitea-08d199245ade5f1c4e0898cfe67f3b635a287675.tar.gz gitea-08d199245ade5f1c4e0898cfe67f3b635a287675.zip |
Fix container download counter (#19287)
* Increment counter on manifest download.
* Refactor GetPackageFileStream method.
-rw-r--r-- | routers/api/packages/container/container.go | 4 | ||||
-rw-r--r-- | routers/api/packages/nuget/nuget.go | 8 | ||||
-rw-r--r-- | routers/web/user/package.go | 1 | ||||
-rw-r--r-- | services/packages/packages.go | 8 |
4 files changed, 7 insertions, 14 deletions
diff --git a/routers/api/packages/container/container.go b/routers/api/packages/container/container.go index f0b1fafd26..08b6b421b0 100644 --- a/routers/api/packages/container/container.go +++ b/routers/api/packages/container/container.go @@ -367,7 +367,7 @@ func GetBlob(ctx *context.Context) { return } - s, err := packages_module.NewContentStore().Get(packages_module.BlobHash256Key(blob.Blob.HashSHA256)) + s, _, err := packages_service.GetPackageFileStream(ctx, blob.File) if err != nil { apiError(ctx, http.StatusInternalServerError, err) return @@ -506,7 +506,7 @@ func GetManifest(ctx *context.Context) { return } - s, err := packages_module.NewContentStore().Get(packages_module.BlobHash256Key(manifest.Blob.HashSHA256)) + s, _, err := packages_service.GetPackageFileStream(ctx, manifest.File) if err != nil { apiError(ctx, http.StatusInternalServerError, err) return diff --git a/routers/api/packages/nuget/nuget.go b/routers/api/packages/nuget/nuget.go index f3bc586125..3af7155fae 100644 --- a/routers/api/packages/nuget/nuget.go +++ b/routers/api/packages/nuget/nuget.go @@ -376,13 +376,7 @@ func DownloadSymbolFile(ctx *context.Context) { return } - pv, err := packages_model.GetVersionByID(ctx, pfs[0].VersionID) - if err != nil { - apiError(ctx, http.StatusInternalServerError, err) - return - } - - s, _, err := packages_service.GetPackageFileStream(ctx, pv, pfs[0]) + s, _, err := packages_service.GetPackageFileStream(ctx, pfs[0]) if err != nil { if err == packages_model.ErrPackageNotExist || err == packages_model.ErrPackageFileNotExist { apiError(ctx, http.StatusNotFound, err) diff --git a/routers/web/user/package.go b/routers/web/user/package.go index 8a5294dce1..edbb4aadf6 100644 --- a/routers/web/user/package.go +++ b/routers/web/user/package.go @@ -331,7 +331,6 @@ func DownloadPackageFile(ctx *context.Context) { s, _, err := packages_service.GetPackageFileStream( ctx, - ctx.Package.Descriptor.Version, pf, ) if err != nil { diff --git a/services/packages/packages.go b/services/packages/packages.go index b26e60c711..7f90f80baf 100644 --- a/services/packages/packages.go +++ b/services/packages/packages.go @@ -426,7 +426,7 @@ func GetFileStreamByPackageVersionAndFileID(ctx context.Context, owner *user_mod return nil, nil, err } - return GetPackageFileStream(ctx, pv, pf) + return GetPackageFileStream(ctx, pf) } // GetFileStreamByPackageVersion returns the content of the specific package file @@ -436,11 +436,11 @@ func GetFileStreamByPackageVersion(ctx context.Context, pv *packages_model.Packa return nil, nil, err } - return GetPackageFileStream(ctx, pv, pf) + return GetPackageFileStream(ctx, pf) } // GetPackageFileStream returns the content of the specific package file -func GetPackageFileStream(ctx context.Context, pv *packages_model.PackageVersion, pf *packages_model.PackageFile) (io.ReadCloser, *packages_model.PackageFile, error) { +func GetPackageFileStream(ctx context.Context, pf *packages_model.PackageFile) (io.ReadCloser, *packages_model.PackageFile, error) { pb, err := packages_model.GetBlobByID(ctx, pf.BlobID) if err != nil { return nil, nil, err @@ -449,7 +449,7 @@ func GetPackageFileStream(ctx context.Context, pv *packages_model.PackageVersion s, err := packages_module.NewContentStore().Get(packages_module.BlobHash256Key(pb.HashSHA256)) if err == nil { if pf.IsLead { - if err := packages_model.IncrementDownloadCounter(ctx, pv.ID); err != nil { + if err := packages_model.IncrementDownloadCounter(ctx, pf.VersionID); err != nil { log.Error("Error incrementing download counter: %v", err) } } |