summaryrefslogtreecommitdiffstats
path: root/routers
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2016-03-15 14:23:12 -0400
committerUnknwon <u@gogs.io>2016-03-15 14:23:12 -0400
commit149d62a648d5b852e43125834ed9b1cb6b49bdc0 (patch)
tree6380491938794ab1125fde8e488c8e2840c038cd /routers
parent9df5c39bca6fb397449525b0f1eb0d24d993439f (diff)
downloadgitea-149d62a648d5b852e43125834ed9b1cb6b49bdc0.tar.gz
gitea-149d62a648d5b852e43125834ed9b1cb6b49bdc0.zip
#13 fix admin can't search private repos
- update glide info
Diffstat (limited to 'routers')
-rw-r--r--routers/admin/orgs.go10
-rw-r--r--routers/admin/repos.go10
-rw-r--r--routers/admin/users.go10
-rw-r--r--routers/home.go76
4 files changed, 75 insertions, 31 deletions
diff --git a/routers/admin/orgs.go b/routers/admin/orgs.go
index 395243a5f7..28e9d79f06 100644
--- a/routers/admin/orgs.go
+++ b/routers/admin/orgs.go
@@ -21,6 +21,12 @@ func Organizations(ctx *context.Context) {
ctx.Data["PageIsAdmin"] = true
ctx.Data["PageIsAdminOrganizations"] = true
- routers.RenderUserSearch(ctx, models.USER_TYPE_ORGANIZATION, models.CountOrganizations, models.Organizations,
- setting.AdminOrgPagingNum, "id ASC", ORGS)
+ routers.RenderUserSearch(ctx, &routers.UserSearchOptions{
+ Type: models.USER_TYPE_ORGANIZATION,
+ Counter: models.CountOrganizations,
+ Ranger: models.Organizations,
+ PageSize: setting.AdminOrgPagingNum,
+ OrderBy: "id ASC",
+ TplName: ORGS,
+ })
}
diff --git a/routers/admin/repos.go b/routers/admin/repos.go
index e78941ab4c..8b5caa8d72 100644
--- a/routers/admin/repos.go
+++ b/routers/admin/repos.go
@@ -22,8 +22,14 @@ func Repos(ctx *context.Context) {
ctx.Data["PageIsAdmin"] = true
ctx.Data["PageIsAdminRepositories"] = true
- routers.RenderRepoSearch(ctx, models.CountRepositories, models.Repositories,
- setting.AdminRepoPagingNum, "id ASC", REPOS)
+ routers.RenderRepoSearch(ctx, &routers.RepoSearchOptions{
+ Counter: models.CountRepositories,
+ Ranger: models.Repositories,
+ Private: true,
+ PageSize: setting.AdminRepoPagingNum,
+ OrderBy: "id ASC",
+ TplName: REPOS,
+ })
}
func DeleteRepo(ctx *context.Context) {
diff --git a/routers/admin/users.go b/routers/admin/users.go
index 00028a2fdd..76fbcd1683 100644
--- a/routers/admin/users.go
+++ b/routers/admin/users.go
@@ -30,8 +30,14 @@ func Users(ctx *context.Context) {
ctx.Data["PageIsAdmin"] = true
ctx.Data["PageIsAdminUsers"] = true
- routers.RenderUserSearch(ctx, models.USER_TYPE_INDIVIDUAL, models.CountUsers, models.Users,
- setting.AdminUserPagingNum, "id ASC", USERS)
+ routers.RenderUserSearch(ctx, &routers.UserSearchOptions{
+ Type: models.USER_TYPE_INDIVIDUAL,
+ Counter: models.CountUsers,
+ Ranger: models.Users,
+ PageSize: setting.AdminUserPagingNum,
+ OrderBy: "id ASC",
+ TplName: USERS,
+ })
}
func NewUser(ctx *context.Context) {
diff --git a/routers/home.go b/routers/home.go
index 0836dd5060..16967521d7 100644
--- a/routers/home.go
+++ b/routers/home.go
@@ -44,9 +44,16 @@ func Home(ctx *context.Context) {
ctx.HTML(200, HOME)
}
-func RenderRepoSearch(ctx *context.Context,
- counter func() int64, ranger func(int, int) ([]*models.Repository, error),
- pagingNum int, orderBy string, tplName base.TplName) {
+type RepoSearchOptions struct {
+ Counter func() int64
+ Ranger func(int, int) ([]*models.Repository, error)
+ Private bool
+ PageSize int
+ OrderBy string
+ TplName base.TplName
+}
+
+func RenderRepoSearch(ctx *context.Context, opts *RepoSearchOptions) {
page := ctx.QueryInt("page")
if page <= 1 {
page = 1
@@ -60,18 +67,19 @@ func RenderRepoSearch(ctx *context.Context,
keyword := ctx.Query("q")
if len(keyword) == 0 {
- repos, err = ranger(page, pagingNum)
+ repos, err = opts.Ranger(page, opts.PageSize)
if err != nil {
- ctx.Handle(500, "ranger", err)
+ ctx.Handle(500, "opts.Ranger", err)
return
}
- count = counter()
+ count = opts.Counter()
} else {
repos, count, err = models.SearchRepositoryByName(&models.SearchRepoOptions{
Keyword: keyword,
- OrderBy: orderBy,
+ OrderBy: opts.OrderBy,
+ Private: opts.Private,
Page: page,
- PageSize: pagingNum,
+ PageSize: opts.PageSize,
})
if err != nil {
ctx.Handle(500, "SearchRepositoryByName", err)
@@ -80,7 +88,7 @@ func RenderRepoSearch(ctx *context.Context,
}
ctx.Data["Keyword"] = keyword
ctx.Data["Total"] = count
- ctx.Data["Page"] = paginater.New(int(count), pagingNum, page, 5)
+ ctx.Data["Page"] = paginater.New(int(count), opts.PageSize, page, 5)
for _, repo := range repos {
if err = repo.GetOwner(); err != nil {
@@ -90,7 +98,7 @@ func RenderRepoSearch(ctx *context.Context,
}
ctx.Data["Repos"] = repos
- ctx.HTML(200, tplName)
+ ctx.HTML(200, opts.TplName)
}
func ExploreRepos(ctx *context.Context) {
@@ -98,13 +106,25 @@ func ExploreRepos(ctx *context.Context) {
ctx.Data["PageIsExplore"] = true
ctx.Data["PageIsExploreRepositories"] = true
- RenderRepoSearch(ctx, models.CountPublicRepositories, models.GetRecentUpdatedRepositories,
- setting.ExplorePagingNum, "updated_unix DESC", EXPLORE_REPOS)
+ RenderRepoSearch(ctx, &RepoSearchOptions{
+ Counter: models.CountPublicRepositories,
+ Ranger: models.GetRecentUpdatedRepositories,
+ PageSize: setting.ExplorePagingNum,
+ OrderBy: "updated_unix DESC",
+ TplName: EXPLORE_REPOS,
+ })
+}
+
+type UserSearchOptions struct {
+ Type models.UserType
+ Counter func() int64
+ Ranger func(int, int) ([]*models.User, error)
+ PageSize int
+ OrderBy string
+ TplName base.TplName
}
-func RenderUserSearch(ctx *context.Context, userType models.UserType,
- counter func() int64, ranger func(int, int) ([]*models.User, error),
- pagingNum int, orderBy string, tplName base.TplName) {
+func RenderUserSearch(ctx *context.Context, opts *UserSearchOptions) {
page := ctx.QueryInt("page")
if page <= 1 {
page = 1
@@ -118,19 +138,19 @@ func RenderUserSearch(ctx *context.Context, userType models.UserType,
keyword := ctx.Query("q")
if len(keyword) == 0 {
- users, err = ranger(page, pagingNum)
+ users, err = opts.Ranger(page, opts.PageSize)
if err != nil {
- ctx.Handle(500, "ranger", err)
+ ctx.Handle(500, "opts.Ranger", err)
return
}
- count = counter()
+ count = opts.Counter()
} else {
users, count, err = models.SearchUserByName(&models.SearchUserOptions{
Keyword: keyword,
- Type: userType,
- OrderBy: orderBy,
+ Type: opts.Type,
+ OrderBy: opts.OrderBy,
Page: page,
- PageSize: pagingNum,
+ PageSize: opts.PageSize,
})
if err != nil {
ctx.Handle(500, "SearchUserByName", err)
@@ -139,10 +159,10 @@ func RenderUserSearch(ctx *context.Context, userType models.UserType,
}
ctx.Data["Keyword"] = keyword
ctx.Data["Total"] = count
- ctx.Data["Page"] = paginater.New(int(count), pagingNum, page, 5)
+ ctx.Data["Page"] = paginater.New(int(count), opts.PageSize, page, 5)
ctx.Data["Users"] = users
- ctx.HTML(200, tplName)
+ ctx.HTML(200, opts.TplName)
}
func ExploreUsers(ctx *context.Context) {
@@ -150,8 +170,14 @@ func ExploreUsers(ctx *context.Context) {
ctx.Data["PageIsExplore"] = true
ctx.Data["PageIsExploreUsers"] = true
- RenderUserSearch(ctx, models.USER_TYPE_INDIVIDUAL, models.CountUsers, models.Users,
- setting.ExplorePagingNum, "updated_unix DESC", EXPLORE_USERS)
+ RenderUserSearch(ctx, &UserSearchOptions{
+ Type: models.USER_TYPE_INDIVIDUAL,
+ Counter: models.CountUsers,
+ Ranger: models.Users,
+ PageSize: setting.ExplorePagingNum,
+ OrderBy: "updated_unix DESC",
+ TplName: EXPLORE_USERS,
+ })
}
func NotFound(ctx *context.Context) {