2014-04-13 01:57:42 -04:00
// Copyright 2014 The Gogs Authors. All rights reserved.
2019-02-08 09:45:43 -07:00
// Copyright 2019 The Gitea Authors. All rights reserved.
2014-04-13 01:57:42 -04:00
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
package user
import (
2014-11-23 02:33:47 -05:00
"bytes"
2019-12-02 04:50:36 +01:00
"encoding/json"
2014-04-13 01:57:42 -04:00
"fmt"
2019-12-02 04:50:36 +01:00
"regexp"
2017-12-03 20:39:01 -08:00
"sort"
2019-12-02 04:50:36 +01:00
"strconv"
2019-01-23 06:10:38 +02:00
"strings"
2014-04-13 01:57:42 -04:00
2016-11-10 17:24:48 +01:00
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/base"
"code.gitea.io/gitea/modules/context"
2019-10-09 01:55:16 +08:00
"code.gitea.io/gitea/modules/log"
2016-11-10 17:24:48 +01:00
"code.gitea.io/gitea/modules/setting"
2017-01-24 21:43:02 -05:00
"code.gitea.io/gitea/modules/util"
2017-12-25 18:25:16 -05:00
2019-04-14 18:43:56 +02:00
"github.com/keybase/go-crypto/openpgp"
"github.com/keybase/go-crypto/openpgp/armor"
2014-04-13 01:57:42 -04:00
)
2014-06-22 23:11:12 -04:00
const (
2017-08-18 13:21:46 +02:00
tplDashboard base . TplName = "user/dashboard/dashboard"
2016-11-18 11:03:03 +08:00
tplIssues base . TplName = "user/dashboard/issues"
tplProfile base . TplName = "user/profile"
tplOrgHome base . TplName = "org/home"
2014-06-22 23:11:12 -04:00
)
2016-07-24 01:08:22 +08:00
// getDashboardContextUser finds out dashboard is viewing as which context user.
2016-03-11 11:56:52 -05:00
func getDashboardContextUser ( ctx * context . Context ) * models . User {
2015-08-25 22:58:34 +08:00
ctxUser := ctx . User
2014-07-26 23:53:16 -04:00
orgName := ctx . Params ( ":org" )
if len ( orgName ) > 0 {
// Organization.
org , err := models . GetUserByName ( orgName )
if err != nil {
2015-08-05 11:14:17 +08:00
if models . IsErrUserNotExist ( err ) {
2018-01-10 22:34:17 +01:00
ctx . NotFound ( "GetUserByName" , err )
2014-07-26 23:53:16 -04:00
} else {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetUserByName" , err )
2014-07-26 23:53:16 -04:00
}
2015-08-25 22:58:34 +08:00
return nil
2014-07-26 23:53:16 -04:00
}
ctxUser = org
2015-08-25 22:58:34 +08:00
}
ctx . Data [ "ContextUser" ] = ctxUser
2015-12-17 02:28:47 -05:00
if err := ctx . User . GetOrganizations ( true ) ; err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetOrganizations" , err )
2015-08-25 22:58:34 +08:00
return nil
}
ctx . Data [ "Orgs" ] = ctx . User . Orgs
return ctxUser
}
2017-06-01 20:42:25 -04:00
// retrieveFeeds loads feeds for the specified user
2017-08-23 03:30:54 +02:00
func retrieveFeeds ( ctx * context . Context , options models . GetFeedsOptions ) {
actions , err := models . GetFeeds ( options )
2015-11-22 01:32:09 -05:00
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetFeeds" , err )
2015-11-22 01:32:09 -05:00
return
}
2017-08-23 03:30:54 +02:00
userCache := map [ int64 ] * models . User { options . RequestedUser . ID : options . RequestedUser }
2017-06-07 22:11:41 -04:00
if ctx . User != nil {
userCache [ ctx . User . ID ] = ctx . User
}
2015-11-22 01:32:09 -05:00
for _ , act := range actions {
2018-02-21 18:55:34 +08:00
if act . ActUser != nil {
userCache [ act . ActUserID ] = act . ActUser
2017-05-25 21:38:18 -04:00
}
2018-02-21 18:55:34 +08:00
repoOwner , ok := userCache [ act . Repo . OwnerID ]
2017-05-25 21:38:18 -04:00
if ! ok {
2018-02-21 18:55:34 +08:00
repoOwner , err = models . GetUserByID ( act . Repo . OwnerID )
2017-05-25 21:38:18 -04:00
if err != nil {
if models . IsErrUserNotExist ( err ) {
continue
}
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetUserByID" , err )
2015-11-22 01:32:09 -05:00
return
}
2018-02-21 18:55:34 +08:00
userCache [ repoOwner . ID ] = repoOwner
2015-11-22 01:32:09 -05:00
}
2018-02-21 18:55:34 +08:00
act . Repo . Owner = repoOwner
2015-11-22 01:32:09 -05:00
}
2017-06-01 20:42:25 -04:00
ctx . Data [ "Feeds" ] = actions
2015-11-22 01:32:09 -05:00
}
2016-11-18 11:03:03 +08:00
// Dashboard render the dashborad page
2016-03-11 11:56:52 -05:00
func Dashboard ( ctx * context . Context ) {
2016-03-09 22:56:03 -06:00
ctxUser := getDashboardContextUser ( ctx )
2015-08-25 22:58:34 +08:00
if ctx . Written ( ) {
return
}
2016-07-24 01:08:22 +08:00
ctx . Data [ "Title" ] = ctxUser . DisplayName ( ) + " - " + ctx . Tr ( "dashboard" )
ctx . Data [ "PageIsDashboard" ] = true
ctx . Data [ "PageIsNews" ] = true
2017-08-17 03:31:34 +02:00
ctx . Data [ "SearchLimit" ] = setting . UI . User . RepoPagingNum
2018-10-23 04:57:42 +02:00
ctx . Data [ "EnableHeatmap" ] = setting . Service . EnableUserHeatmap
ctx . Data [ "HeatmapUser" ] = ctxUser . Name
2016-07-24 01:08:22 +08:00
2016-07-24 14:32:46 +08:00
var err error
2017-08-23 03:30:54 +02:00
var mirrors [ ] * models . Repository
2016-02-02 19:29:35 +00:00
if ctxUser . IsOrganization ( ) {
2017-01-25 10:41:38 -05:00
env , err := ctxUser . AccessibleReposEnv ( ctx . User . ID )
2016-07-24 14:32:46 +08:00
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "AccessibleReposEnv" , err )
2017-01-25 10:41:38 -05:00
return
}
2016-07-24 14:32:46 +08:00
2017-01-25 10:41:38 -05:00
mirrors , err = env . MirrorRepos ( )
2016-02-02 19:29:35 +00:00
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "env.MirrorRepos" , err )
2016-07-24 14:32:46 +08:00
return
}
} else {
mirrors , err = ctxUser . GetMirrorRepositories ( )
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetMirrorRepositories" , err )
2016-07-24 14:32:46 +08:00
return
}
2014-04-13 01:57:42 -04:00
}
2016-07-24 14:32:46 +08:00
ctx . Data [ "MaxShowRepoNum" ] = setting . UI . User . RepoPagingNum
2014-04-13 01:57:42 -04:00
2016-07-24 14:32:46 +08:00
if err := models . MirrorRepositoryList ( mirrors ) . LoadAttributes ( ) ; err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "MirrorRepositoryList.LoadAttributes" , err )
2016-07-24 14:32:46 +08:00
return
2014-07-26 02:28:04 -04:00
}
2014-07-26 23:53:16 -04:00
ctx . Data [ "MirrorCount" ] = len ( mirrors )
ctx . Data [ "Mirrors" ] = mirrors
2014-05-12 15:14:22 -04:00
2018-02-21 18:55:34 +08:00
retrieveFeeds ( ctx , models . GetFeedsOptions {
RequestedUser : ctxUser ,
2017-08-23 03:30:54 +02:00
IncludePrivate : true ,
OnlyPerformedBy : false ,
IncludeDeleted : false ,
} )
2018-12-13 23:55:43 +08:00
2015-11-22 01:32:09 -05:00
if ctx . Written ( ) {
2014-04-13 01:57:42 -04:00
return
}
2017-08-18 13:21:46 +02:00
ctx . HTML ( 200 , tplDashboard )
2014-04-13 01:57:42 -04:00
}
2019-12-02 04:50:36 +01:00
// Regexp for repos query
var issueReposQueryPattern = regexp . MustCompile ( ` ^\[\d+(,\d+)*,?\]$ ` )
2016-11-18 11:03:03 +08:00
// Issues render the user issues page
2016-03-11 11:56:52 -05:00
func Issues ( ctx * context . Context ) {
2015-09-02 16:18:09 -04:00
isPullList := ctx . Params ( ":type" ) == "pulls"
if isPullList {
ctx . Data [ "Title" ] = ctx . Tr ( "pull_requests" )
ctx . Data [ "PageIsPulls" ] = true
} else {
ctx . Data [ "Title" ] = ctx . Tr ( "issues" )
ctx . Data [ "PageIsIssues" ] = true
}
2015-08-25 22:58:34 +08:00
ctxUser := getDashboardContextUser ( ctx )
if ctx . Written ( ) {
return
}
// Organization does not have view type and filter mode.
var (
viewType string
2015-11-04 12:50:02 -05:00
sortType = ctx . Query ( "sort" )
2016-11-07 17:24:59 +01:00
filterMode = models . FilterModeAll
2015-08-25 22:58:34 +08:00
)
2017-02-14 22:15:18 +08:00
2015-08-25 22:58:34 +08:00
if ctxUser . IsOrganization ( ) {
viewType = "all"
} else {
viewType = ctx . Query ( "type" )
switch viewType {
case "assigned" :
2016-11-07 17:24:59 +01:00
filterMode = models . FilterModeAssign
2015-08-25 22:58:34 +08:00
case "created_by" :
2016-11-07 17:24:59 +01:00
filterMode = models . FilterModeCreate
2019-09-18 10:24:44 +03:00
case "mentioned" :
filterMode = models . FilterModeMention
2017-12-07 17:02:34 -08:00
case "all" : // filterMode already set to All
default :
viewType = "all"
2015-08-25 22:58:34 +08:00
}
}
2017-02-14 22:15:18 +08:00
page := ctx . QueryInt ( "page" )
if page <= 1 {
page = 1
}
2019-12-02 04:50:36 +01:00
reposQuery := ctx . Query ( "repos" )
var repoIDs [ ] int64
if issueReposQueryPattern . MatchString ( reposQuery ) {
// remove "[" and "]" from string
reposQuery = reposQuery [ 1 : len ( reposQuery ) - 1 ]
//for each ID (delimiter ",") add to int to repoIDs
for _ , rID := range strings . Split ( reposQuery , "," ) {
// Ensure nonempty string entries
if rID != "" && rID != "0" {
rIDint64 , err := strconv . ParseInt ( rID , 10 , 64 )
if err == nil {
repoIDs = append ( repoIDs , rIDint64 )
}
}
}
} else {
log . Error ( "issueReposQueryPattern not match with query" )
}
2019-10-09 01:55:16 +08:00
isShowClosed := ctx . Query ( "state" ) == "closed"
2015-08-25 22:58:34 +08:00
// Get repositories.
2019-10-09 01:55:16 +08:00
var err error
var userRepoIDs [ ] int64
if ctxUser . IsOrganization ( ) {
env , err := ctxUser . AccessibleReposEnv ( ctx . User . ID )
if err != nil {
ctx . ServerError ( "AccessibleReposEnv" , err )
return
}
userRepoIDs , err = env . RepoIDs ( 1 , ctxUser . NumRepos )
if err != nil {
ctx . ServerError ( "env.RepoIDs" , err )
return
}
2016-01-31 20:12:03 +00:00
} else {
2018-06-21 18:00:13 +02:00
unitType := models . UnitTypeIssues
if isPullList {
unitType = models . UnitTypePullRequests
}
2019-10-09 01:55:16 +08:00
userRepoIDs , err = ctxUser . GetAccessRepoIDs ( unitType )
if err != nil {
ctx . ServerError ( "ctxUser.GetAccessRepoIDs" , err )
return
2016-01-31 20:12:03 +00:00
}
2017-02-17 08:58:19 +08:00
}
2019-10-09 01:55:16 +08:00
if len ( userRepoIDs ) == 0 {
userRepoIDs = [ ] int64 { - 1 }
}
opts := & models . IssuesOptions {
IsClosed : util . OptionalBoolOf ( isShowClosed ) ,
IsPull : util . OptionalBoolOf ( isPullList ) ,
SortType : sortType ,
}
2017-02-14 22:15:18 +08:00
switch filterMode {
2019-10-09 01:55:16 +08:00
case models . FilterModeAll :
2019-12-02 04:50:36 +01:00
opts . RepoIDs = userRepoIDs
2017-02-14 22:15:18 +08:00
case models . FilterModeAssign :
2017-08-02 22:09:16 -07:00
opts . AssigneeID = ctxUser . ID
2017-02-14 22:15:18 +08:00
case models . FilterModeCreate :
2017-08-02 22:09:16 -07:00
opts . PosterID = ctxUser . ID
2017-02-14 22:15:18 +08:00
case models . FilterModeMention :
2017-08-02 22:09:16 -07:00
opts . MentionedID = ctxUser . ID
2017-02-14 22:15:18 +08:00
}
2019-10-09 01:55:16 +08:00
counts , err := models . CountIssuesByRepo ( opts )
if err != nil {
ctx . ServerError ( "CountIssuesByRepo" , err )
return
}
opts . Page = page
opts . PageSize = setting . UI . IssuePagingNum
2019-01-23 06:10:38 +02:00
var labelIDs [ ] int64
selectLabels := ctx . Query ( "labels" )
if len ( selectLabels ) > 0 && selectLabels != "0" {
labelIDs , err = base . StringsToInt64s ( strings . Split ( selectLabels , "," ) )
if err != nil {
ctx . ServerError ( "StringsToInt64s" , err )
return
}
}
opts . LabelIDs = labelIDs
2018-10-28 03:55:01 -03:00
2019-12-02 04:50:36 +01:00
opts . RepoIDs = repoIDs
2017-08-02 22:09:16 -07:00
issues , err := models . Issues ( opts )
2017-02-17 08:58:19 +08:00
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "Issues" , err )
2017-02-17 08:58:19 +08:00
return
}
2015-09-02 16:18:09 -04:00
2017-08-02 22:09:16 -07:00
showReposMap := make ( map [ int64 ] * models . Repository , len ( counts ) )
for repoID := range counts {
2019-12-02 04:50:36 +01:00
showReposMap [ repoID ] , err = models . GetRepositoryByID ( repoID )
if models . IsErrRepoNotExist ( err ) {
ctx . NotFound ( "GetRepositoryByID" , err )
return
} else if err != nil {
ctx . ServerError ( "GetRepositoryByID" , fmt . Errorf ( "[%d]%v" , repoID , err ) )
2017-08-02 22:09:16 -07:00
return
2015-09-02 16:18:09 -04:00
}
2019-10-09 01:55:16 +08:00
// Check if user has access to given repository.
2019-12-02 04:50:36 +01:00
perm , err := models . GetUserRepoPermission ( showReposMap [ repoID ] , ctxUser )
2019-10-09 01:55:16 +08:00
if err != nil {
ctx . ServerError ( "GetUserRepoPermission" , fmt . Errorf ( "[%d]%v" , repoID , err ) )
return
}
if ! perm . CanRead ( models . UnitTypeIssues ) {
2019-12-02 04:50:36 +01:00
log . Error ( "User created Issues in Repository which they no longer have access to: [%d]" , repoID )
2019-10-09 01:55:16 +08:00
}
}
2017-08-02 22:09:16 -07:00
showRepos := models . RepositoryListOfMap ( showReposMap )
2017-12-03 20:39:01 -08:00
sort . Sort ( showRepos )
2017-08-02 22:09:16 -07:00
if err = showRepos . LoadAttributes ( ) ; err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "LoadAttributes" , err )
2017-02-17 08:58:19 +08:00
return
2015-08-25 23:22:05 +08:00
}
2019-04-02 21:54:29 +02:00
var commitStatus = make ( map [ int64 ] * models . CommitStatus , len ( issues ) )
2017-08-02 22:09:16 -07:00
for _ , issue := range issues {
issue . Repo = showReposMap [ issue . RepoID ]
2019-04-02 21:54:29 +02:00
if isPullList {
commitStatus [ issue . PullRequest . ID ] , _ = issue . PullRequest . GetLastCommitStatus ( )
}
2017-08-02 22:09:16 -07:00
}
2017-12-25 18:25:16 -05:00
issueStats , err := models . GetUserIssueStats ( models . UserIssueStatsOptions {
2019-10-09 01:55:16 +08:00
UserID : ctxUser . ID ,
UserRepoIDs : userRepoIDs ,
FilterMode : filterMode ,
IsPull : isPullList ,
IsClosed : isShowClosed ,
2017-12-25 18:25:16 -05:00
} )
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetUserIssueStats" , err )
2017-12-25 18:25:16 -05:00
return
}
2017-02-14 22:15:18 +08:00
2019-12-02 04:50:36 +01:00
allIssueStats , err := models . GetUserIssueStats ( models . UserIssueStatsOptions {
UserID : ctxUser . ID ,
UserRepoIDs : userRepoIDs ,
FilterMode : filterMode ,
IsPull : isPullList ,
IsClosed : isShowClosed ,
} )
if err != nil {
ctx . ServerError ( "GetUserIssueStats All" , err )
return
}
var shownIssues int
var totalIssues int
2015-08-25 23:22:05 +08:00
if ! isShowClosed {
2019-12-02 04:50:36 +01:00
shownIssues = int ( issueStats . OpenCount )
totalIssues = int ( allIssueStats . OpenCount )
2015-08-25 23:22:05 +08:00
} else {
2019-12-02 04:50:36 +01:00
shownIssues = int ( issueStats . ClosedCount )
totalIssues = int ( allIssueStats . ClosedCount )
2015-08-25 23:22:05 +08:00
}
2015-08-25 22:58:34 +08:00
ctx . Data [ "Issues" ] = issues
2019-04-02 21:54:29 +02:00
ctx . Data [ "CommitStatus" ] = commitStatus
2017-02-14 22:15:18 +08:00
ctx . Data [ "Repos" ] = showRepos
2017-08-02 22:09:16 -07:00
ctx . Data [ "Counts" ] = counts
2015-08-25 22:58:34 +08:00
ctx . Data [ "IssueStats" ] = issueStats
ctx . Data [ "ViewType" ] = viewType
2015-11-04 12:50:02 -05:00
ctx . Data [ "SortType" ] = sortType
2019-12-02 04:50:36 +01:00
ctx . Data [ "RepoIDs" ] = repoIDs
2015-08-25 22:58:34 +08:00
ctx . Data [ "IsShowClosed" ] = isShowClosed
2019-12-02 04:50:36 +01:00
ctx . Data [ "TotalIssueCount" ] = totalIssues
2017-02-14 22:15:18 +08:00
2015-08-25 22:58:34 +08:00
if isShowClosed {
ctx . Data [ "State" ] = "closed"
} else {
ctx . Data [ "State" ] = "open"
}
2019-12-02 04:50:36 +01:00
// Convert []int64 to string
reposParam , _ := json . Marshal ( repoIDs )
ctx . Data [ "ReposParam" ] = string ( reposParam )
pager := context . NewPagination ( shownIssues , setting . UI . IssuePagingNum , page , 5 )
2019-04-20 06:15:19 +02:00
pager . AddParam ( ctx , "type" , "ViewType" )
2019-12-02 04:50:36 +01:00
pager . AddParam ( ctx , "repos" , "ReposParam" )
2019-04-20 06:15:19 +02:00
pager . AddParam ( ctx , "sort" , "SortType" )
pager . AddParam ( ctx , "state" , "State" )
pager . AddParam ( ctx , "labels" , "SelectLabels" )
pager . AddParam ( ctx , "milestone" , "MilestoneID" )
pager . AddParam ( ctx , "assignee" , "AssigneeID" )
ctx . Data [ "Page" ] = pager
2016-11-18 11:03:03 +08:00
ctx . HTML ( 200 , tplIssues )
2015-08-25 22:58:34 +08:00
}
2016-11-27 12:59:12 +01:00
// ShowSSHKeys output all the ssh keys of user by uid
2016-03-11 11:56:52 -05:00
func ShowSSHKeys ( ctx * context . Context , uid int64 ) {
2014-11-23 02:33:47 -05:00
keys , err := models . ListPublicKeys ( uid )
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "ListPublicKeys" , err )
2014-11-23 02:33:47 -05:00
return
}
var buf bytes . Buffer
for i := range keys {
buf . WriteString ( keys [ i ] . OmitEmail ( ) )
2015-06-08 00:40:38 -07:00
buf . WriteString ( "\n" )
2014-11-23 02:33:47 -05:00
}
2015-10-15 21:28:12 -04:00
ctx . PlainText ( 200 , buf . Bytes ( ) )
2014-11-23 02:33:47 -05:00
}
2019-04-14 18:43:56 +02:00
// ShowGPGKeys output all the public GPG keys of user by uid
func ShowGPGKeys ( ctx * context . Context , uid int64 ) {
keys , err := models . ListGPGKeys ( uid )
if err != nil {
ctx . ServerError ( "ListGPGKeys" , err )
return
}
entities := make ( [ ] * openpgp . Entity , 0 )
failedEntitiesID := make ( [ ] string , 0 )
for _ , k := range keys {
e , err := models . GPGKeyToEntity ( k )
if err != nil {
if models . IsErrGPGKeyImportNotExist ( err ) {
failedEntitiesID = append ( failedEntitiesID , k . KeyID )
continue //Skip previous import without backup of imported armored key
}
ctx . ServerError ( "ShowGPGKeys" , err )
return
}
entities = append ( entities , e )
}
var buf bytes . Buffer
headers := make ( map [ string ] string )
if len ( failedEntitiesID ) > 0 { //If some key need re-import to be exported
headers [ "Note" ] = fmt . Sprintf ( "The keys with the following IDs couldn't be exported and need to be reuploaded %s" , strings . Join ( failedEntitiesID , ", " ) )
}
writer , _ := armor . Encode ( & buf , "PGP PUBLIC KEY BLOCK" , headers )
for _ , e := range entities {
err = e . Serialize ( writer ) //TODO find why key are exported with a different cipherTypeByte as original (should not be blocking but strange)
if err != nil {
ctx . ServerError ( "ShowGPGKeys" , err )
return
}
}
writer . Close ( )
ctx . PlainText ( 200 , buf . Bytes ( ) )
}
2016-03-11 11:56:52 -05:00
func showOrgProfile ( ctx * context . Context ) {
2015-11-24 19:14:00 -05:00
ctx . SetParams ( ":org" , ctx . Params ( ":username" ) )
2016-03-11 11:56:52 -05:00
context . HandleOrgAssignment ( ctx )
2015-11-24 19:14:00 -05:00
if ctx . Written ( ) {
return
}
org := ctx . Org . Organization
2019-02-18 17:00:27 +01:00
if ! models . HasOrgVisible ( org , ctx . User ) {
ctx . NotFound ( "HasOrgVisible" , nil )
return
}
2017-04-15 04:02:46 +02:00
ctx . Data [ "Title" ] = org . DisplayName ( )
2015-11-24 19:14:00 -05:00
2019-02-08 09:45:43 -07:00
var orderBy models . SearchOrderBy
ctx . Data [ "SortType" ] = ctx . Query ( "sort" )
switch ctx . Query ( "sort" ) {
case "newest" :
orderBy = models . SearchOrderByNewest
case "oldest" :
orderBy = models . SearchOrderByOldest
case "recentupdate" :
orderBy = models . SearchOrderByRecentUpdated
case "leastupdate" :
orderBy = models . SearchOrderByLeastUpdated
case "reversealphabetically" :
orderBy = models . SearchOrderByAlphabeticallyReverse
case "alphabetically" :
orderBy = models . SearchOrderByAlphabetically
case "moststars" :
orderBy = models . SearchOrderByStarsReverse
case "feweststars" :
orderBy = models . SearchOrderByStars
case "mostforks" :
orderBy = models . SearchOrderByForksReverse
case "fewestforks" :
orderBy = models . SearchOrderByForks
default :
ctx . Data [ "SortType" ] = "recentupdate"
orderBy = models . SearchOrderByRecentUpdated
}
keyword := strings . Trim ( ctx . Query ( "q" ) , " " )
ctx . Data [ "Keyword" ] = keyword
2016-07-24 14:32:46 +08:00
page := ctx . QueryInt ( "page" )
if page <= 0 {
page = 1
}
var (
repos [ ] * models . Repository
count int64
err error
)
2019-08-25 19:06:36 +02:00
repos , count , err = models . SearchRepository ( & models . SearchRepoOptions {
Keyword : keyword ,
OwnerID : org . ID ,
OrderBy : orderBy ,
Private : ctx . IsSigned ,
UserIsAdmin : ctx . IsUserSiteAdmin ( ) ,
UserID : ctx . Data [ "SignedUserID" ] . ( int64 ) ,
Page : page ,
IsProfile : true ,
PageSize : setting . UI . User . RepoPagingNum ,
IncludeDescription : setting . UI . SearchRepoDescription ,
2019-05-15 16:24:39 +01:00
} )
if err != nil {
2019-08-25 19:06:36 +02:00
ctx . ServerError ( "SearchRepository" , err )
2019-05-15 16:24:39 +01:00
return
2015-11-24 19:14:00 -05:00
}
2016-01-31 10:46:04 +00:00
if err := org . GetMembers ( ) ; err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetMembers" , err )
2015-11-24 19:14:00 -05:00
return
}
2019-02-08 09:45:43 -07:00
ctx . Data [ "Repos" ] = repos
ctx . Data [ "Total" ] = count
ctx . Data [ "Members" ] = org . Members
2016-01-31 19:08:20 +00:00
ctx . Data [ "Teams" ] = org . Teams
2015-11-24 19:14:00 -05:00
2019-04-20 06:15:19 +02:00
pager := context . NewPagination ( int ( count ) , setting . UI . User . RepoPagingNum , page , 5 )
pager . SetDefaultParams ( ctx )
ctx . Data [ "Page" ] = pager
2016-11-18 11:03:03 +08:00
ctx . HTML ( 200 , tplOrgHome )
2015-11-24 19:14:00 -05:00
}
2016-11-18 11:03:03 +08:00
// Email2User show user page via email
2016-03-11 11:56:52 -05:00
func Email2User ( ctx * context . Context ) {
2014-04-13 01:57:42 -04:00
u , err := models . GetUserByEmail ( ctx . Query ( "email" ) )
if err != nil {
2015-08-05 11:14:17 +08:00
if models . IsErrUserNotExist ( err ) {
2018-01-10 22:34:17 +01:00
ctx . NotFound ( "GetUserByEmail" , err )
2014-04-13 01:57:42 -04:00
} else {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetUserByEmail" , err )
2014-04-13 01:57:42 -04:00
}
return
}
2016-11-27 18:14:25 +08:00
ctx . Redirect ( setting . AppSubURL + "/user/" + u . Name )
2014-04-13 01:57:42 -04:00
}