0
Fork 0
mirror of https://codeberg.org/forgejo/forgejo.git synced 2025-01-15 10:54:47 -05:00
forgejo/routers/home.go

216 lines
5.2 KiB
Go
Raw Normal View History

2014-02-12 12:49:46 -05:00
// 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
2014-02-12 14:54:09 -05:00
import (
2014-09-05 16:28:09 -05:00
"fmt"
2015-09-01 06:04:35 -05:00
"github.com/Unknwon/paginater"
"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"
2014-02-12 14:54:09 -05:00
)
const (
// tplHome home page template
tplHome base.TplName = "home"
// 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
2016-03-11 11:56:52 -05:00
func Home(ctx *context.Context) {
2014-03-15 09:34:33 -05:00
if ctx.IsSigned {
2014-08-09 23:02:00 -05:00
if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm {
ctx.Data["Title"] = ctx.Tr("auth.active_your_account")
ctx.HTML(200, user.TplActivate)
2014-08-09 23:02:00 -05:00
} else {
user.Dashboard(ctx)
}
2014-03-06 08:33:17 -05:00
return
}
2014-03-24 11:43:51 -05:00
// Check auto-login.
2014-07-25 23:24:27 -05:00
uname := ctx.GetCookie(setting.CookieUserName)
if len(uname) != 0 {
2014-09-19 19:11:34 -05:00
ctx.Redirect(setting.AppSubUrl + "/user/login")
2014-03-24 11:43:51 -05:00
return
}
2014-05-24 14:28:31 -05:00
ctx.Data["PageIsHome"] = true
ctx.HTML(200, tplHome)
2014-02-12 12:49:46 -05:00
}
2014-03-16 02:41:22 -05:00
// RepoSearchOptions when calling search repositories
type RepoSearchOptions struct {
2016-07-24 01:32:46 -05:00
Counter func(bool) int64
Ranger func(int, int) ([]*models.Repository, error)
Private bool
PageSize int
OrderBy string
TplName base.TplName
}
// RenderRepoSearch render repositories search page
func RenderRepoSearch(ctx *context.Context, opts *RepoSearchOptions) {
2015-09-01 06:04:35 -05:00
page := ctx.QueryInt("page")
2016-07-24 01:32:46 -05:00
if page <= 0 {
2015-09-01 06:04:35 -05:00
page = 1
}
var (
repos []*models.Repository
count int64
err error
)
2015-09-01 06:04:35 -05:00
keyword := ctx.Query("q")
if len(keyword) == 0 {
repos, err = opts.Ranger(page, opts.PageSize)
if err != nil {
ctx.Handle(500, "opts.Ranger", err)
return
}
2016-07-24 01:32:46 -05:00
count = opts.Counter(opts.Private)
} else {
repos, count, err = models.SearchRepositoryByName(&models.SearchRepoOptions{
Keyword: keyword,
OrderBy: opts.OrderBy,
Private: opts.Private,
Page: page,
PageSize: opts.PageSize,
})
if err != nil {
ctx.Handle(500, "SearchRepositoryByName", err)
return
}
2014-09-05 16:28:09 -05:00
}
ctx.Data["Keyword"] = keyword
ctx.Data["Total"] = count
ctx.Data["Page"] = paginater.New(int(count), opts.PageSize, page, 5)
2014-09-05 16:28:09 -05:00
for _, repo := range repos {
if err = repo.GetOwner(); err != nil {
2015-08-08 09:43:14 -05:00
ctx.Handle(500, "GetOwner", fmt.Errorf("%d: %v", repo.ID, err))
2014-09-05 16:28:09 -05:00
return
}
}
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{
2016-07-24 01:32:46 -05:00
Counter: models.CountRepositories,
Ranger: models.GetRecentUpdatedRepositories,
2016-07-23 11:23:54 -05:00
PageSize: setting.UI.ExplorePagingNum,
OrderBy: "updated_unix DESC",
TplName: tplExploreRepos,
})
}
// UserSearchOptions options when render search user page
type UserSearchOptions struct {
Type models.UserType
Counter func() int64
Ranger func(int, int) ([]*models.User, error)
PageSize int
OrderBy string
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
)
keyword := ctx.Query("q")
if len(keyword) == 0 {
users, err = opts.Ranger(page, opts.PageSize)
if err != nil {
ctx.Handle(500, "opts.Ranger", err)
return
}
count = opts.Counter()
} else {
users, count, err = models.SearchUserByName(&models.SearchUserOptions{
Keyword: keyword,
Type: opts.Type,
OrderBy: opts.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.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{
2016-11-07 11:53:22 -05:00
Type: models.UserTypeIndividual,
Counter: models.CountUsers,
Ranger: models.Users,
2016-07-23 11:23:54 -05:00
PageSize: setting.UI.ExplorePagingNum,
OrderBy: "name ASC",
TplName: tplExploreUsers,
})
2014-09-05 16:28:09 -05:00
}
// 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{
2016-11-07 11:53:22 -05:00
Type: models.UserTypeOrganization,
Counter: models.CountOrganizations,
Ranger: models.Organizations,
PageSize: setting.UI.ExplorePagingNum,
OrderBy: "name ASC",
TplName: tplExploreOrganizations,
})
}
// NotFound render 404 page
2016-03-11 11:56:52 -05:00
func NotFound(ctx *context.Context) {
2014-03-23 07:40:40 -05:00
ctx.Data["Title"] = "Page Not Found"
2014-03-23 00:48:01 -05:00
ctx.Handle(404, "home.NotFound", nil)
}