From 0ee968455fa608903de2b6dc28b5bfa57841c81a Mon Sep 17 00:00:00 2001 From: nadavsteindler Date: Thu, 12 Dec 2024 18:41:43 +0200 Subject: [PATCH] fuzzy repo search --- pkg/catalog/catalog.go | 31 +++++++++++++++---------------- 1 file changed, 15 insertions(+), 16 deletions(-) diff --git a/pkg/catalog/catalog.go b/pkg/catalog/catalog.go index 1ffd22c5eeb..2e49bcae34b 100644 --- a/pkg/catalog/catalog.go +++ b/pkg/catalog/catalog.go @@ -599,23 +599,22 @@ func (c *Catalog) ListRepositories(ctx context.Context, limit int, prefix, after for it.Next() { record := it.Value() - if !strings.HasPrefix(string(record.RepositoryID), prefix) { - break - } + if strings.Contains(string(record.RepositoryID), prefix) { - if record.RepositoryID == afterRepositoryID { - continue - } - repos = append(repos, &Repository{ - Name: record.RepositoryID.String(), - StorageNamespace: record.StorageNamespace.String(), - DefaultBranch: record.DefaultBranchID.String(), - CreationDate: record.CreationDate, - ReadOnly: record.ReadOnly, - }) - // collect limit +1 to return limit and has more - if len(repos) >= limit+1 { - break + if record.RepositoryID == afterRepositoryID { + continue + } + repos = append(repos, &Repository{ + Name: record.RepositoryID.String(), + StorageNamespace: record.StorageNamespace.String(), + DefaultBranch: record.DefaultBranchID.String(), + CreationDate: record.CreationDate, + ReadOnly: record.ReadOnly, + }) + // collect limit +1 to return limit and has more + if len(repos) >= limit+1 { + break + } } } if err := it.Err(); err != nil {