drone/registry/app/api/controller/metadata/get_artifacts_versions.go
Manjunatha EN a73113f8e6 fix: [AH-771]: gitness unit test refactoring (#3589)
* fix merge conflicts
* fix merge conflicts
* fix review comment
* fix review comment
* fix review comment
* fix: [AH-771]: gitness unit test refactoring
* fix: [AH-771]: resolved review comments
* fix: [AH-771]: resolved review comments
* fix: [AH-771] Registry test refactoring and improvements

- Refactored registry metadata test implementations
- Improved code organization and readability
- Fixed line length issues in test files
- Removed unused fields from request.go
- Added proper license headers
- Fixed linting issues in mock files
- Simplified test setup and assertions
- Updated wire generation for cmd package
- Added nolint:exhaustive directive for package type switch

fix: [AH-771] Registry test refactoring and improvements

- Refactored registry metadata test implementations
- Improved code organization and readability
- Fixed line length issues in test files
- Removed unused fields from request.go
- Added proper license headers
- Fixed linting issues in mock files
- Simplifi
2025-04-22 14:49:24 +00:00

201 lines
6.3 KiB
Go

// Copyright 2023 Harness, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package metadata
import (
"context"
"fmt"
"net/http"
apiauth "github.com/harness/gitness/app/api/auth"
"github.com/harness/gitness/app/api/request"
"github.com/harness/gitness/registry/app/api/openapi/contracts/artifact"
ml "github.com/harness/gitness/registry/app/manifest/manifestlist"
os "github.com/harness/gitness/registry/app/manifest/ocischema"
s2 "github.com/harness/gitness/registry/app/manifest/schema2"
"github.com/harness/gitness/registry/app/pkg/docker"
"github.com/harness/gitness/registry/types"
"github.com/harness/gitness/types/enum"
"github.com/rs/zerolog/log"
)
func (c *APIController) GetAllArtifactVersions(
ctx context.Context,
r artifact.GetAllArtifactVersionsRequestObject,
) (artifact.GetAllArtifactVersionsResponseObject, error) {
registryRequestParams := &RegistryRequestParams{
packageTypesParam: nil,
page: r.Params.Page,
size: r.Params.Size,
search: r.Params.SearchTerm,
Resource: ArtifactVersionResource,
ParentRef: "",
RegRef: string(r.RegistryRef),
labelsParam: nil,
sortOrder: r.Params.SortOrder,
sortField: r.Params.SortField,
registryIDsParam: nil,
}
regInfo, _ := c.GetRegistryRequestInfo(ctx, *registryRequestParams)
space, err := c.SpaceFinder.FindByRef(ctx, regInfo.ParentRef)
if err != nil {
return artifact.GetAllArtifactVersions400JSONResponse{
BadRequestJSONResponse: artifact.BadRequestJSONResponse(
*GetErrorResponse(http.StatusBadRequest, err.Error()),
),
}, nil
}
session, _ := request.AuthSessionFrom(ctx)
permissionChecks := c.RegistryMetadataHelper.GetPermissionChecks(space, regInfo.RegistryIdentifier,
enum.PermissionRegistryView)
if err = apiauth.CheckRegistry(
ctx,
c.Authorizer,
session,
permissionChecks...,
); err != nil {
return artifact.GetAllArtifactVersions403JSONResponse{
UnauthorizedJSONResponse: artifact.UnauthorizedJSONResponse(
*GetErrorResponse(http.StatusForbidden, err.Error()),
),
}, nil
}
image := string(r.Artifact)
registry, err := c.RegistryRepository.Get(ctx, regInfo.RegistryID)
if err != nil {
return throw500Error(err)
}
img, err := c.ImageStore.GetByName(ctx, registry.ID, image)
if err != nil {
return throw500Error(err)
}
//nolint:nestif
if registry.PackageType == artifact.PackageTypeDOCKER || registry.PackageType == artifact.PackageTypeHELM {
tags, err := c.TagStore.GetAllTagsByRepoAndImage(
ctx, regInfo.ParentID, regInfo.RegistryIdentifier,
image, regInfo.sortByField, regInfo.sortByOrder, regInfo.limit, regInfo.offset, regInfo.searchTerm,
)
if err != nil {
return throw500Error(err)
}
var digests []string
for _, tag := range *tags {
if tag.Digest != "" {
digests = append(digests, tag.Digest)
}
}
counts, err := c.DownloadStatRepository.GetTotalDownloadsForManifests(ctx, digests, img.ID)
if err != nil {
return throw500Error(err)
}
for i, tag := range *tags {
if tag.Digest != "" {
(*tags)[i].DownloadCount = counts[tag.Digest]
}
}
count, err := c.TagStore.CountAllTagsByRepoAndImage(
ctx, regInfo.ParentID, regInfo.RegistryIdentifier,
image, regInfo.searchTerm,
)
if err != nil {
return throw500Error(err)
}
err = setDigestCount(ctx, *tags)
if err != nil {
return throw500Error(err)
}
return artifact.GetAllArtifactVersions200JSONResponse{
ListArtifactVersionResponseJSONResponse: *GetAllArtifactVersionResponse(
ctx, tags, image, count, regInfo.pageNumber, regInfo.limit,
c.URLProvider.RegistryURL(ctx, regInfo.RootIdentifier, regInfo.RegistryIdentifier),
),
}, nil
}
metadata, err := c.ArtifactStore.GetAllVersionsByRepoAndImage(
ctx, regInfo.ParentID, regInfo.RegistryIdentifier,
image, regInfo.sortByField, regInfo.sortByOrder, regInfo.limit, regInfo.offset, regInfo.searchTerm,
)
if err != nil {
return throw500Error(err)
}
cnt, _ := c.ArtifactStore.CountAllVersionsByRepoAndImage(
ctx, regInfo.ParentID, regInfo.RegistryIdentifier,
image, regInfo.searchTerm,
)
return artifact.GetAllArtifactVersions200JSONResponse{
ListArtifactVersionResponseJSONResponse: *GetNonOCIAllArtifactVersionResponse(
ctx, metadata, image, cnt, regInfo.pageNumber, regInfo.limit,
c.URLProvider.RegistryURL(ctx, regInfo.RootIdentifier, regInfo.RegistryIdentifier),
),
}, nil
}
func setDigestCount(ctx context.Context, tags []types.TagMetadata) error {
for i := range tags {
err := setDigestCountInTagMetadata(ctx, &tags[i])
if err != nil {
return err
}
}
return nil
}
//nolint:unused // kept for potential future use
func setDigestCountInTagMetadata(ctx context.Context, t *types.TagMetadata) error {
m := types.Manifest{
SchemaVersion: t.SchemaVersion,
MediaType: t.MediaType,
NonConformant: t.NonConformant,
Payload: t.Payload,
}
manifest, err := docker.DBManifestToManifest(&m)
if err != nil {
log.Ctx(ctx).Error().Stack().Err(err).Msg("Failed to convert DBManifest to Manifest")
return err
}
switch reqManifest := manifest.(type) {
case *s2.DeserializedManifest, *os.DeserializedManifest:
t.DigestCount = 1
case *ml.DeserializedManifestList:
t.DigestCount = len(reqManifest.Manifests)
default:
err = fmt.Errorf("unknown manifest type: %T", manifest)
log.Ctx(ctx).Error().Stack().Err(err).Msg("Failed to set digest count")
}
return nil
}
//nolint:unused,unparam // kept for potential future use
func throw500Error(err error) (artifact.GetAllArtifactVersionsResponseObject, error) {
wrappedErr := fmt.Errorf("internal server error: %w", err)
return artifact.GetAllArtifactVersions500JSONResponse{
InternalServerErrorJSONResponse: artifact.InternalServerErrorJSONResponse(
*GetErrorResponse(http.StatusInternalServerError, wrappedErr.Error()),
),
}, nil
}