aboutsummaryrefslogtreecommitdiffstats
path: root/models/repo.go
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2016-03-11 15:33:12 -0500
committerUnknwon <u@gogs.io>2016-03-11 15:33:12 -0500
commit2bf8494332592b3c57f9a12a26b9abd356fb3f15 (patch)
treee46c61ba30018ebbafcda6b97b36d3ffece3cfb0 /models/repo.go
parentdf2bdf7ea36ad0729e0326ca799d8896d7f96946 (diff)
downloadgitea-2bf8494332592b3c57f9a12a26b9abd356fb3f15.tar.gz
gitea-2bf8494332592b3c57f9a12a26b9abd356fb3f15.zip
#13 finish user and repository search
Both are possible on explore and admin panel
Diffstat (limited to 'models/repo.go')
-rw-r--r--models/repo.go73
1 files changed, 49 insertions, 24 deletions
diff --git a/models/repo.go b/models/repo.go
index 4ee99dab7c..4c19037624 100644
--- a/models/repo.go
+++ b/models/repo.go
@@ -1049,11 +1049,16 @@ func CountPublicRepositories() int64 {
return countRepositories(false)
}
+func Repositories(page, pageSize int) (_ []*Repository, err error) {
+ repos := make([]*Repository, 0, pageSize)
+ return repos, x.Limit(pageSize, (page-1)*pageSize).Asc("id").Find(&repos)
+}
+
// RepositoriesWithUsers returns number of repos in given page.
func RepositoriesWithUsers(page, pageSize int) (_ []*Repository, err error) {
- repos := make([]*Repository, 0, pageSize)
- if err = x.Limit(pageSize, (page-1)*pageSize).Asc("id").Find(&repos); err != nil {
- return nil, err
+ repos, err := Repositories(page, pageSize)
+ if err != nil {
+ return nil, fmt.Errorf("Repositories: %v", err)
}
for i := range repos {
@@ -1474,9 +1479,9 @@ func GetRepositories(uid int64, private bool) ([]*Repository, error) {
}
// GetRecentUpdatedRepositories returns the list of repositories that are recently updated.
-func GetRecentUpdatedRepositories(page int) (repos []*Repository, err error) {
- return repos, x.Limit(setting.ExplorePagingNum, (page-1)*setting.ExplorePagingNum).
- Where("is_private=?", false).Limit(setting.ExplorePagingNum).Desc("updated_unix").Find(&repos)
+func GetRecentUpdatedRepositories(page, pageSize int) (repos []*Repository, err error) {
+ return repos, x.Limit(pageSize, (page-1)*pageSize).
+ Where("is_private=?", false).Limit(pageSize).Desc("updated_unix").Find(&repos)
}
func getRepositoryCount(e Engine, u *User) (int64, error) {
@@ -1488,32 +1493,52 @@ func GetRepositoryCount(u *User) (int64, error) {
return getRepositoryCount(x, u)
}
-type SearchOption struct {
- Keyword string
- Uid int64
- Limit int
- Private bool
+type SearchRepoOptions struct {
+ Keyword string
+ OwnerID int64
+ OrderBy string
+ Private bool // Include private repositories in results
+ Page int
+ PageSize int // Can be smaller than or equal to setting.ExplorePagingNum
}
-// SearchRepositoryByName returns given number of repositories whose name contains keyword.
-func SearchRepositoryByName(opt SearchOption) (repos []*Repository, err error) {
- if len(opt.Keyword) == 0 {
- return repos, nil
+// SearchRepositoryByName takes keyword and part of repository name to search,
+// it returns results in given range and number of total results.
+func SearchRepositoryByName(opts *SearchRepoOptions) (repos []*Repository, _ int64, _ error) {
+ if len(opts.Keyword) == 0 {
+ return repos, 0, nil
+ }
+ opts.Keyword = strings.ToLower(opts.Keyword)
+
+ if opts.PageSize <= 0 || opts.PageSize > setting.ExplorePagingNum {
+ opts.PageSize = setting.ExplorePagingNum
+ }
+ if opts.Page <= 0 {
+ opts.Page = 1
}
- opt.Keyword = strings.ToLower(opt.Keyword)
- repos = make([]*Repository, 0, opt.Limit)
+ repos = make([]*Repository, 0, opts.PageSize)
- // Append conditions.
- sess := x.Limit(opt.Limit)
- if opt.Uid > 0 {
- sess.Where("owner_id=?", opt.Uid)
+ // Append conditions
+ sess := x.Where("lower_name like ?", "%"+opts.Keyword+"%")
+ if opts.OwnerID > 0 {
+ sess.And("owner_id = ?", opts.OwnerID)
}
- if !opt.Private {
+ if !opts.Private {
sess.And("is_private=?", false)
}
- sess.And("lower_name like ?", "%"+opt.Keyword+"%").Find(&repos)
- return repos, err
+ if len(opts.OrderBy) > 0 {
+ sess.OrderBy(opts.OrderBy)
+ }
+
+ var countSess xorm.Session
+ countSess = *sess
+ count, err := countSess.Count(new(Repository))
+ if err != nil {
+ return nil, 0, fmt.Errorf("Count: %v", err)
+ }
+
+ return repos, count, sess.Limit(opts.PageSize, (opts.Page-1)*opts.PageSize).Find(&repos)
}
// DeleteRepositoryArchives deletes all repositories' archives.