- Generate swagger.json into public/ - Add swagger-ui auto-installation - Add footer link to local swagger-ui - Add /swagger url for using app url. - Fix Swagger-UI version via git tag
		
			
				
	
	
		
			274 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			274 lines
		
	
	
		
			6.5 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,
 | |
| 		})
 | |
| 		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,
 | |
| 			})
 | |
| 			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)
 | |
| }
 |