mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-21 18:27:02 +00:00
f61a1d210c
* fix missing collabrative repos * fix bug of collabrative * fix SQL quotes
275 lines
6.6 KiB
Go
275 lines
6.6 KiB
Go
// Copyright 2014 The Gogs Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package routers
|
|
|
|
import (
|
|
"bytes"
|
|
"strings"
|
|
|
|
"code.gitea.io/gitea/models"
|
|
"code.gitea.io/gitea/modules/base"
|
|
"code.gitea.io/gitea/modules/context"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
"code.gitea.io/gitea/routers/user"
|
|
|
|
"github.com/Unknwon/paginater"
|
|
)
|
|
|
|
const (
|
|
// tplHome home page template
|
|
tplHome base.TplName = "home"
|
|
// tplSwagger swagger page template
|
|
tplSwagger base.TplName = "swagger"
|
|
// tplExploreRepos explore repositories page template
|
|
tplExploreRepos base.TplName = "explore/repos"
|
|
// tplExploreUsers explore users page template
|
|
tplExploreUsers base.TplName = "explore/users"
|
|
// tplExploreOrganizations explore organizations page template
|
|
tplExploreOrganizations base.TplName = "explore/organizations"
|
|
)
|
|
|
|
// Home render home page
|
|
func Home(ctx *context.Context) {
|
|
if ctx.IsSigned {
|
|
if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm {
|
|
ctx.Data["Title"] = ctx.Tr("auth.active_your_account")
|
|
ctx.HTML(200, user.TplActivate)
|
|
} else {
|
|
user.Dashboard(ctx)
|
|
}
|
|
return
|
|
}
|
|
|
|
// Check auto-login.
|
|
uname := ctx.GetCookie(setting.CookieUserName)
|
|
if len(uname) != 0 {
|
|
ctx.Redirect(setting.AppSubURL + "/user/login")
|
|
return
|
|
}
|
|
|
|
ctx.Data["PageIsHome"] = true
|
|
ctx.HTML(200, tplHome)
|
|
}
|
|
|
|
// Swagger render swagger-ui page
|
|
func Swagger(ctx *context.Context) {
|
|
ctx.HTML(200, tplSwagger)
|
|
}
|
|
|
|
// RepoSearchOptions when calling search repositories
|
|
type RepoSearchOptions struct {
|
|
Ranger func(*models.SearchRepoOptions) (models.RepositoryList, int64, error)
|
|
Searcher *models.User
|
|
Private bool
|
|
PageSize int
|
|
TplName base.TplName
|
|
}
|
|
|
|
var (
|
|
nullByte = []byte{0x00}
|
|
)
|
|
|
|
func isKeywordValid(keyword string) bool {
|
|
return !bytes.Contains([]byte(keyword), nullByte)
|
|
}
|
|
|
|
// RenderRepoSearch render repositories search page
|
|
func RenderRepoSearch(ctx *context.Context, opts *RepoSearchOptions) {
|
|
page := ctx.QueryInt("page")
|
|
if page <= 0 {
|
|
page = 1
|
|
}
|
|
|
|
var (
|
|
repos []*models.Repository
|
|
count int64
|
|
err error
|
|
orderBy string
|
|
)
|
|
ctx.Data["SortType"] = ctx.Query("sort")
|
|
|
|
switch ctx.Query("sort") {
|
|
case "oldest":
|
|
orderBy = "created_unix ASC"
|
|
case "recentupdate":
|
|
orderBy = "updated_unix DESC"
|
|
case "leastupdate":
|
|
orderBy = "updated_unix ASC"
|
|
case "reversealphabetically":
|
|
orderBy = "name DESC"
|
|
case "alphabetically":
|
|
orderBy = "name ASC"
|
|
case "reversesize":
|
|
orderBy = "size DESC"
|
|
case "size":
|
|
orderBy = "size ASC"
|
|
default:
|
|
orderBy = "created_unix DESC"
|
|
}
|
|
|
|
keyword := strings.Trim(ctx.Query("q"), " ")
|
|
if len(keyword) == 0 {
|
|
repos, count, err = opts.Ranger(&models.SearchRepoOptions{
|
|
Page: page,
|
|
PageSize: opts.PageSize,
|
|
Searcher: ctx.User,
|
|
OrderBy: orderBy,
|
|
Private: opts.Private,
|
|
Collaborate: true,
|
|
})
|
|
if err != nil {
|
|
ctx.Handle(500, "opts.Ranger", err)
|
|
return
|
|
}
|
|
} else {
|
|
if isKeywordValid(keyword) {
|
|
repos, count, err = models.SearchRepositoryByName(&models.SearchRepoOptions{
|
|
Keyword: keyword,
|
|
OrderBy: orderBy,
|
|
Private: opts.Private,
|
|
Page: page,
|
|
PageSize: opts.PageSize,
|
|
Searcher: ctx.User,
|
|
Collaborate: true,
|
|
})
|
|
if err != nil {
|
|
ctx.Handle(500, "SearchRepositoryByName", err)
|
|
return
|
|
}
|
|
}
|
|
}
|
|
ctx.Data["Keyword"] = keyword
|
|
ctx.Data["Total"] = count
|
|
ctx.Data["Page"] = paginater.New(int(count), opts.PageSize, page, 5)
|
|
ctx.Data["Repos"] = repos
|
|
|
|
ctx.HTML(200, opts.TplName)
|
|
}
|
|
|
|
// ExploreRepos render explore repositories page
|
|
func ExploreRepos(ctx *context.Context) {
|
|
ctx.Data["Title"] = ctx.Tr("explore")
|
|
ctx.Data["PageIsExplore"] = true
|
|
ctx.Data["PageIsExploreRepositories"] = true
|
|
|
|
RenderRepoSearch(ctx, &RepoSearchOptions{
|
|
Ranger: models.GetRecentUpdatedRepositories,
|
|
PageSize: setting.UI.ExplorePagingNum,
|
|
Searcher: ctx.User,
|
|
Private: ctx.User != nil && ctx.User.IsAdmin,
|
|
TplName: tplExploreRepos,
|
|
})
|
|
}
|
|
|
|
// UserSearchOptions options when render search user page
|
|
type UserSearchOptions struct {
|
|
Type models.UserType
|
|
Counter func() int64
|
|
Ranger func(*models.SearchUserOptions) ([]*models.User, error)
|
|
PageSize int
|
|
TplName base.TplName
|
|
}
|
|
|
|
// RenderUserSearch render user search page
|
|
func RenderUserSearch(ctx *context.Context, opts *UserSearchOptions) {
|
|
page := ctx.QueryInt("page")
|
|
if page <= 1 {
|
|
page = 1
|
|
}
|
|
|
|
var (
|
|
users []*models.User
|
|
count int64
|
|
err error
|
|
orderBy string
|
|
)
|
|
|
|
ctx.Data["SortType"] = ctx.Query("sort")
|
|
switch ctx.Query("sort") {
|
|
case "oldest":
|
|
orderBy = "id ASC"
|
|
case "recentupdate":
|
|
orderBy = "updated_unix DESC"
|
|
case "leastupdate":
|
|
orderBy = "updated_unix ASC"
|
|
case "reversealphabetically":
|
|
orderBy = "name DESC"
|
|
case "alphabetically":
|
|
orderBy = "name ASC"
|
|
default:
|
|
orderBy = "id DESC"
|
|
}
|
|
|
|
keyword := strings.Trim(ctx.Query("q"), " ")
|
|
if len(keyword) == 0 {
|
|
users, err = opts.Ranger(&models.SearchUserOptions{
|
|
OrderBy: orderBy,
|
|
Page: page,
|
|
PageSize: opts.PageSize,
|
|
})
|
|
if err != nil {
|
|
ctx.Handle(500, "opts.Ranger", err)
|
|
return
|
|
}
|
|
count = opts.Counter()
|
|
} else {
|
|
if isKeywordValid(keyword) {
|
|
users, count, err = models.SearchUserByName(&models.SearchUserOptions{
|
|
Keyword: keyword,
|
|
Type: opts.Type,
|
|
OrderBy: orderBy,
|
|
Page: page,
|
|
PageSize: opts.PageSize,
|
|
})
|
|
if err != nil {
|
|
ctx.Handle(500, "SearchUserByName", err)
|
|
return
|
|
}
|
|
}
|
|
}
|
|
ctx.Data["Keyword"] = keyword
|
|
ctx.Data["Total"] = count
|
|
ctx.Data["Page"] = paginater.New(int(count), opts.PageSize, page, 5)
|
|
ctx.Data["Users"] = users
|
|
ctx.Data["ShowUserEmail"] = setting.UI.ShowUserEmail
|
|
|
|
ctx.HTML(200, opts.TplName)
|
|
}
|
|
|
|
// ExploreUsers render explore users page
|
|
func ExploreUsers(ctx *context.Context) {
|
|
ctx.Data["Title"] = ctx.Tr("explore")
|
|
ctx.Data["PageIsExplore"] = true
|
|
ctx.Data["PageIsExploreUsers"] = true
|
|
|
|
RenderUserSearch(ctx, &UserSearchOptions{
|
|
Type: models.UserTypeIndividual,
|
|
Counter: models.CountUsers,
|
|
Ranger: models.Users,
|
|
PageSize: setting.UI.ExplorePagingNum,
|
|
TplName: tplExploreUsers,
|
|
})
|
|
}
|
|
|
|
// ExploreOrganizations render explore organizations page
|
|
func ExploreOrganizations(ctx *context.Context) {
|
|
ctx.Data["Title"] = ctx.Tr("explore")
|
|
ctx.Data["PageIsExplore"] = true
|
|
ctx.Data["PageIsExploreOrganizations"] = true
|
|
|
|
RenderUserSearch(ctx, &UserSearchOptions{
|
|
Type: models.UserTypeOrganization,
|
|
Counter: models.CountOrganizations,
|
|
Ranger: models.Organizations,
|
|
PageSize: setting.UI.ExplorePagingNum,
|
|
TplName: tplExploreOrganizations,
|
|
})
|
|
}
|
|
|
|
// NotFound render 404 page
|
|
func NotFound(ctx *context.Context) {
|
|
ctx.Data["Title"] = "Page Not Found"
|
|
ctx.Handle(404, "home.NotFound", nil)
|
|
}
|