mirror of
https://github.com/project-zot/zot.git
synced 2025-01-20 22:52:51 -05:00
9cc990d7ca
Initial code was contributed by Bogdan BIVOLARU <104334+bogdanbiv@users.noreply.github.com> Moved implementation from a separate db to repodb by Andrei Aaron <aaaron@luxoft.com> Not done yet: - run/test dynamodb implementation, only boltdb was tested - add additional coverage for existing functionality - add web-based APIs to toggle the stars/bookmarks on/off Initially graphql mutation was discussed for the missing API but we decided REST endpoints would be better suited for configuration feat(userdb): complete functionality for userdb integration - dynamodb rollback changes to user starred repos in case increasing the total star count fails - dynamodb increment/decrement repostars in repometa when user stars/unstars a repo - dynamodb check anonymous user permissions are working as intendend - common test handle anonymous users - RepoMeta2RepoSummary set IsStarred and IsBookmarked feat(userdb): rest api calls for toggling stars/bookmarks on/off test(userdb): blackbox tests test(userdb): move preferences tests in a different file with specific build tags feat(repodb): add is-starred and is-bookmarked fields to repo-meta - removed duplicated logic for determining if a repo is starred/bookmarked Signed-off-by: Laurentiu Niculae <niculae.laurentiu1@gmail.com> Co-authored-by: Andrei Aaron <aaaron@luxoft.com>
57 lines
1.7 KiB
Go
57 lines
1.7 KiB
Go
package repodb
|
|
|
|
import (
|
|
"time"
|
|
)
|
|
|
|
// DetailedRepoMeta is a auxiliary structure used for sorting RepoMeta arrays by information
|
|
// that's not directly available in the RepoMetadata structure (ex. that needs to be calculated
|
|
// by iterating the manifests, etc.)
|
|
type DetailedRepoMeta struct {
|
|
RepoMetadata
|
|
Rank int
|
|
Downloads int
|
|
UpdateTime time.Time
|
|
}
|
|
|
|
func SortFunctions() map[SortCriteria]func(pageBuffer []DetailedRepoMeta) func(i, j int) bool {
|
|
return map[SortCriteria]func(pageBuffer []DetailedRepoMeta) func(i, j int) bool{
|
|
AlphabeticAsc: SortByAlphabeticAsc,
|
|
AlphabeticDsc: SortByAlphabeticDsc,
|
|
Relevance: SortByRelevance,
|
|
UpdateTime: SortByUpdateTime,
|
|
Downloads: SortByDownloads,
|
|
}
|
|
}
|
|
|
|
func SortByAlphabeticAsc(pageBuffer []DetailedRepoMeta) func(i, j int) bool {
|
|
return func(i, j int) bool {
|
|
return pageBuffer[i].Name < pageBuffer[j].Name
|
|
}
|
|
}
|
|
|
|
func SortByAlphabeticDsc(pageBuffer []DetailedRepoMeta) func(i, j int) bool {
|
|
return func(i, j int) bool {
|
|
return pageBuffer[i].Name > pageBuffer[j].Name
|
|
}
|
|
}
|
|
|
|
func SortByRelevance(pageBuffer []DetailedRepoMeta) func(i, j int) bool {
|
|
return func(i, j int) bool {
|
|
return pageBuffer[i].Rank < pageBuffer[j].Rank
|
|
}
|
|
}
|
|
|
|
// SortByUpdateTime sorting descending by time.
|
|
func SortByUpdateTime(pageBuffer []DetailedRepoMeta) func(i, j int) bool {
|
|
return func(i, j int) bool {
|
|
return pageBuffer[i].UpdateTime.After(pageBuffer[j].UpdateTime)
|
|
}
|
|
}
|
|
|
|
// SortByDownloads returns a comparison function for descendant sorting by downloads.
|
|
func SortByDownloads(pageBuffer []DetailedRepoMeta) func(i, j int) bool {
|
|
return func(i, j int) bool {
|
|
return pageBuffer[i].Downloads > pageBuffer[j].Downloads
|
|
}
|
|
}
|