1.search refactor due to storing repositories in database 2.bug fix: filter repositories in project view

This commit is contained in:
Wenkai Yin 2016-09-06 16:25:23 +08:00
parent bc52b212cf
commit ce3c3fe8f1
2 changed files with 12 additions and 7 deletions

View File

@ -22,7 +22,6 @@ import (
"github.com/vmware/harbor/dao" "github.com/vmware/harbor/dao"
"github.com/vmware/harbor/models" "github.com/vmware/harbor/models"
"github.com/vmware/harbor/service/cache"
"github.com/vmware/harbor/utils" "github.com/vmware/harbor/utils"
"github.com/vmware/harbor/utils/log" "github.com/vmware/harbor/utils/log"
) )
@ -85,11 +84,17 @@ func (s *SearchAPI) Get() {
} }
} }
repositories, err2 := cache.GetRepoFromCache() repos, err := dao.GetAllRepositories()
if err2 != nil { if err != nil {
log.Errorf("Failed to get repos from cache, error: %v", err2) log.Errorf("failed to list repositories: %v", err)
s.CustomAbort(http.StatusInternalServerError, "Failed to get repositories search result") s.CustomAbort(http.StatusInternalServerError, "")
} }
repositories := []string{}
for _, repo := range repos {
repositories = append(repositories, repo.Name)
}
sort.Strings(repositories) sort.Strings(repositories)
repositoryResult := filterRepositories(repositories, projects, keyword) repositoryResult := filterRepositories(repositories, projects, keyword)
result := &searchResult{Project: projectResult, Repository: repositoryResult} result := &searchResult{Project: projectResult, Repository: repositoryResult}

View File

@ -477,10 +477,10 @@ func getReposByProject(name string, keyword ...string) ([]string, error) {
} }
needMatchKeyword := len(keyword) > 0 && len(keyword[0]) != 0 needMatchKeyword := len(keyword) > 0 && len(keyword[0]) != 0
for _, repo := range repos { for _, repo := range repos {
if needMatchKeyword && if needMatchKeyword &&
strings.Contains(repo.Name, keyword[0]) { !strings.Contains(repo.Name, keyword[0]) {
repositories = append(repositories, repo.Name)
continue continue
} }