2022-07-15 11:10:51 +00:00
|
|
|
package search
|
|
|
|
|
|
|
|
// This file will be automatically regenerated based on the schema, any resolver implementations
|
|
|
|
// will be copied through when generating and any unknown code will be moved to the end.
|
2023-10-30 14:47:11 -07:00
|
|
|
// Code generated by github.com/99designs/gqlgen version v0.17.40
|
2022-07-15 11:10:51 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2022-12-09 21:40:06 +02:00
|
|
|
"github.com/vektah/gqlparser/v2/gqlerror"
|
2023-01-10 20:45:15 +02:00
|
|
|
zerr "zotregistry.io/zot/errors"
|
2023-04-18 21:07:47 +03:00
|
|
|
"zotregistry.io/zot/pkg/common"
|
2023-09-18 01:12:20 +03:00
|
|
|
"zotregistry.io/zot/pkg/extensions/search/convert"
|
2022-07-15 11:10:51 +00:00
|
|
|
"zotregistry.io/zot/pkg/extensions/search/gql_generated"
|
|
|
|
)
|
|
|
|
|
|
|
|
// CVEListForImage is the resolver for the CVEListForImage field.
|
2023-03-16 21:13:07 +02:00
|
|
|
func (r *queryResolver) CVEListForImage(ctx context.Context, image string, requestedPage *gql_generated.PageInput, searchedCve *string) (*gql_generated.CVEResultForImage, error) {
|
2023-01-10 20:45:15 +02:00
|
|
|
if r.cveInfo == nil {
|
|
|
|
return &gql_generated.CVEResultForImage{}, zerr.ErrCVESearchDisabled
|
|
|
|
}
|
|
|
|
|
2023-03-16 21:13:07 +02:00
|
|
|
if searchedCve == nil {
|
|
|
|
return getCVEListForImage(ctx, image, r.cveInfo, requestedPage, "", r.log)
|
|
|
|
}
|
|
|
|
|
|
|
|
return getCVEListForImage(ctx, image, r.cveInfo, requestedPage, *searchedCve, r.log)
|
2022-07-15 11:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ImageListForCve is the resolver for the ImageListForCVE field.
|
2023-07-11 19:29:04 +03:00
|
|
|
func (r *queryResolver) ImageListForCve(ctx context.Context, id string, filter *gql_generated.Filter, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedImagesResult, error) {
|
2023-01-10 20:45:15 +02:00
|
|
|
if r.cveInfo == nil {
|
2023-02-15 21:34:07 +02:00
|
|
|
return &gql_generated.PaginatedImagesResult{}, zerr.ErrCVESearchDisabled
|
2022-07-15 11:10:51 +00:00
|
|
|
}
|
|
|
|
|
2023-07-11 19:29:04 +03:00
|
|
|
filter = cleanFilter(filter)
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
return getImageListForCVE(ctx, id, r.cveInfo, filter, requestedPage, r.metaDB, r.log)
|
2022-07-15 11:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ImageListWithCVEFixed is the resolver for the ImageListWithCVEFixed field.
|
2023-07-11 19:29:04 +03:00
|
|
|
func (r *queryResolver) ImageListWithCVEFixed(ctx context.Context, id string, image string, filter *gql_generated.Filter, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedImagesResult, error) {
|
2023-01-10 20:45:15 +02:00
|
|
|
if r.cveInfo == nil {
|
2023-02-15 21:34:07 +02:00
|
|
|
return &gql_generated.PaginatedImagesResult{}, zerr.ErrCVESearchDisabled
|
2022-01-19 17:57:10 +02:00
|
|
|
}
|
2022-07-15 11:10:51 +00:00
|
|
|
|
2023-07-11 19:29:04 +03:00
|
|
|
filter = cleanFilter(filter)
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
return getImageListWithCVEFixed(ctx, id, image, r.cveInfo, filter, requestedPage, r.metaDB, r.log)
|
2022-07-15 11:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ImageListForDigest is the resolver for the ImageListForDigest field.
|
2023-02-15 21:34:07 +02:00
|
|
|
func (r *queryResolver) ImageListForDigest(ctx context.Context, id string, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedImagesResult, error) {
|
2022-07-15 11:10:51 +00:00
|
|
|
r.log.Info().Msg("extracting repositories")
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
imgResultForDigest, err := getImageListForDigest(ctx, id, r.metaDB, r.cveInfo, requestedPage)
|
2022-07-15 11:10:51 +00:00
|
|
|
|
2023-01-18 00:31:54 +02:00
|
|
|
return imgResultForDigest, err
|
2022-07-15 11:10:51 +00:00
|
|
|
}
|
|
|
|
|
2022-07-29 18:33:34 +03:00
|
|
|
// RepoListWithNewestImage is the resolver for the RepoListWithNewestImage field.
|
2023-01-19 00:20:55 +02:00
|
|
|
func (r *queryResolver) RepoListWithNewestImage(ctx context.Context, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedReposResult, error) {
|
2022-07-15 11:10:51 +00:00
|
|
|
r.log.Info().Msg("extension api: finding image list")
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
paginatedReposResult, err := repoListWithNewestImage(ctx, r.cveInfo, r.log, requestedPage, r.metaDB)
|
2022-09-13 17:20:44 +03:00
|
|
|
if err != nil {
|
2023-01-09 22:37:44 +02:00
|
|
|
r.log.Error().Err(err).Msg("unable to retrieve repo list")
|
2022-09-13 17:20:44 +03:00
|
|
|
|
2023-01-19 00:20:55 +02:00
|
|
|
return paginatedReposResult, err
|
2022-09-13 17:20:44 +03:00
|
|
|
}
|
|
|
|
|
2023-01-19 00:20:55 +02:00
|
|
|
return paginatedReposResult, nil
|
2022-07-15 11:10:51 +00:00
|
|
|
}
|
|
|
|
|
2022-01-19 17:57:10 +02:00
|
|
|
// ImageList is the resolver for the ImageList field.
|
2023-02-15 21:34:07 +02:00
|
|
|
func (r *queryResolver) ImageList(ctx context.Context, repo string, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedImagesResult, error) {
|
2022-01-19 17:57:10 +02:00
|
|
|
r.log.Info().Msg("extension api: getting a list of all images")
|
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
imageList, err := getImageList(ctx, repo, r.metaDB, r.cveInfo, requestedPage, r.log)
|
2022-01-19 17:57:10 +02:00
|
|
|
if err != nil {
|
2023-04-28 05:44:22 +03:00
|
|
|
r.log.Error().Err(err).Str("repository", repo).Msg("unable to retrieve image list for repo")
|
2022-01-19 17:57:10 +02:00
|
|
|
|
|
|
|
return imageList, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return imageList, nil
|
|
|
|
}
|
|
|
|
|
2022-07-15 11:10:51 +00:00
|
|
|
// ExpandedRepoInfo is the resolver for the ExpandedRepoInfo field.
|
|
|
|
func (r *queryResolver) ExpandedRepoInfo(ctx context.Context, repo string) (*gql_generated.RepoInfo, error) {
|
2023-07-18 20:27:26 +03:00
|
|
|
repoInfo, err := expandedRepoInfo(ctx, repo, r.metaDB, r.cveInfo, r.log)
|
2022-07-29 17:51:10 +03:00
|
|
|
|
2023-01-09 22:37:44 +02:00
|
|
|
return repoInfo, err
|
2022-07-15 11:10:51 +00:00
|
|
|
}
|
|
|
|
|
2022-07-12 15:58:04 +03:00
|
|
|
// GlobalSearch is the resolver for the GlobalSearch field.
|
2023-01-09 22:37:44 +02:00
|
|
|
func (r *queryResolver) GlobalSearch(ctx context.Context, query string, filter *gql_generated.Filter, requestedPage *gql_generated.PageInput) (*gql_generated.GlobalSearchResult, error) {
|
|
|
|
if err := validateGlobalSearchInput(query, filter, requestedPage); err != nil {
|
2022-07-12 15:58:04 +03:00
|
|
|
return &gql_generated.GlobalSearchResult{}, err
|
|
|
|
}
|
|
|
|
|
2023-01-09 22:37:44 +02:00
|
|
|
query = cleanQuery(query)
|
|
|
|
filter = cleanFilter(filter)
|
2022-08-16 11:57:09 +03:00
|
|
|
|
2023-07-18 20:27:26 +03:00
|
|
|
paginatedReposResult, images, layers, err := globalSearch(ctx, query, r.metaDB, filter, requestedPage, r.cveInfo, r.log)
|
2022-07-12 15:58:04 +03:00
|
|
|
|
|
|
|
return &gql_generated.GlobalSearchResult{
|
2023-01-19 00:20:55 +02:00
|
|
|
Page: paginatedReposResult.Page,
|
2022-07-12 15:58:04 +03:00
|
|
|
Images: images,
|
2023-01-19 00:20:55 +02:00
|
|
|
Repos: paginatedReposResult.Results,
|
2022-07-12 15:58:04 +03:00
|
|
|
Layers: layers,
|
2023-01-09 22:37:44 +02:00
|
|
|
}, err
|
2022-07-12 15:58:04 +03:00
|
|
|
}
|
|
|
|
|
2022-09-23 19:23:31 +03:00
|
|
|
// DependencyListForImage is the resolver for the DependencyListForImage field.
|
2023-02-27 21:23:18 +02:00
|
|
|
func (r *queryResolver) DerivedImageList(ctx context.Context, image string, digest *string, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedImagesResult, error) {
|
2023-07-18 20:27:26 +03:00
|
|
|
derivedList, err := derivedImageList(ctx, image, digest, r.metaDB, requestedPage, r.cveInfo, r.log)
|
2022-09-23 19:23:31 +03:00
|
|
|
|
2023-01-26 00:06:02 +02:00
|
|
|
return derivedList, err
|
2022-09-23 19:23:31 +03:00
|
|
|
}
|
|
|
|
|
2022-09-22 22:08:58 +03:00
|
|
|
// BaseImageList is the resolver for the BaseImageList field.
|
2023-02-27 21:23:18 +02:00
|
|
|
func (r *queryResolver) BaseImageList(ctx context.Context, image string, digest *string, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedImagesResult, error) {
|
2023-07-18 20:27:26 +03:00
|
|
|
imageList, err := baseImageList(ctx, image, digest, r.metaDB, requestedPage, r.cveInfo, r.log)
|
2022-09-22 22:08:58 +03:00
|
|
|
|
2023-01-26 00:06:02 +02:00
|
|
|
return imageList, err
|
2022-09-22 22:08:58 +03:00
|
|
|
}
|
|
|
|
|
2022-09-30 20:32:32 +03:00
|
|
|
// Image is the resolver for the Image field.
|
|
|
|
func (r *queryResolver) Image(ctx context.Context, image string) (*gql_generated.ImageSummary, error) {
|
|
|
|
repo, tag := common.GetImageDirAndTag(image)
|
|
|
|
|
2022-12-09 21:40:06 +02:00
|
|
|
if tag == "" {
|
|
|
|
return &gql_generated.ImageSummary{}, gqlerror.Errorf("no reference provided")
|
|
|
|
}
|
|
|
|
|
2023-09-18 01:12:20 +03:00
|
|
|
skip := convert.SkipQGLField{
|
|
|
|
Vulnerabilities: canSkipField(convert.GetPreloads(ctx), "Vulnerabilities"),
|
|
|
|
}
|
|
|
|
|
|
|
|
return getImageSummary(ctx, repo, tag, nil, skip, r.metaDB, r.cveInfo, r.log)
|
2022-09-30 20:32:32 +03:00
|
|
|
}
|
|
|
|
|
2022-11-23 20:53:28 +02:00
|
|
|
// Referrers is the resolver for the Referrers field.
|
2023-01-26 10:13:12 -08:00
|
|
|
func (r *queryResolver) Referrers(ctx context.Context, repo string, digest string, typeArg []string) ([]*gql_generated.Referrer, error) {
|
2023-07-18 20:27:26 +03:00
|
|
|
referrers, err := getReferrers(r.metaDB, repo, digest, typeArg, r.log)
|
2022-11-23 20:53:28 +02:00
|
|
|
if err != nil {
|
|
|
|
r.log.Error().Err(err).Msg("unable to get referrers from default store")
|
|
|
|
|
|
|
|
return []*gql_generated.Referrer{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return referrers, nil
|
|
|
|
}
|
|
|
|
|
2023-04-24 21:13:15 +03:00
|
|
|
// StarredRepos is the resolver for the StarredRepos field.
|
|
|
|
func (r *queryResolver) StarredRepos(ctx context.Context, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedReposResult, error) {
|
2023-07-18 20:27:26 +03:00
|
|
|
return getStarredRepos(ctx, r.cveInfo, r.log, requestedPage, r.metaDB)
|
2023-04-24 21:13:15 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// BookmarkedRepos is the resolver for the BookmarkedRepos field.
|
|
|
|
func (r *queryResolver) BookmarkedRepos(ctx context.Context, requestedPage *gql_generated.PageInput) (*gql_generated.PaginatedReposResult, error) {
|
2023-07-18 20:27:26 +03:00
|
|
|
return getBookmarkedRepos(ctx, r.cveInfo, r.log, requestedPage, r.metaDB)
|
2023-04-24 21:13:15 +03:00
|
|
|
}
|
|
|
|
|
2022-07-15 11:10:51 +00:00
|
|
|
// Query returns gql_generated.QueryResolver implementation.
|
|
|
|
func (r *Resolver) Query() gql_generated.QueryResolver { return &queryResolver{r} }
|
|
|
|
|
|
|
|
type queryResolver struct{ *Resolver }
|