You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

home.go 14 kB

11 years ago
11 years ago
11 years ago
10 years ago
11 years ago
4 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
Restricted users (#6274) * Restricted users (#4334): initial implementation * Add User.IsRestricted & UI to edit it * Pass user object instead of user id to places where IsRestricted flag matters * Restricted users: maintain access rows for all referenced repos (incl public) * Take logged in user & IsRestricted flag into account in org/repo listings, searches and accesses * Add basic repo access tests for restricted users Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Mention restricted users in the faq Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert unnecessary change `.isUserPartOfOrg` -> `.IsUserPartOfOrg` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Remove unnecessary `org.IsOrganization()` call Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert to an `int64` keyed `accessMap` * Add type `userAccess` * Add convenience func updateUserAccess() * Turn accessMap into a `map[int64]userAccess` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * or even better: `map[int64]*userAccess` * updateUserAccess(): use tighter syntax as suggested by lafriks * even tighter * Avoid extra loop * Don't disclose limited orgs to unauthenticated users * Don't assume block only applies to orgs * Use an array of `VisibleType` for filtering * fix yet another thinko * Ok - no need for u * Revert "Ok - no need for u" This reverts commit 5c3e886aabd5acd997a3b35687d322439732c200. Co-authored-by: Antoine GIRARD <sapk@users.noreply.github.com> Co-authored-by: Lauris BH <lauris@nix.lv>
5 years ago
API add/generalize pagination (#9452) * paginate results * fixed deadlock * prevented breaking change * updated swagger * go fmt * fixed find topic * go mod tidy * go mod vendor with go1.13.5 * fixed repo find topics * fixed unit test * added Limit method to Engine struct; use engine variable when provided; fixed gitignore * use ItemsPerPage for default pagesize; fix GetWatchers, getOrgUsersByOrgID and GetStargazers; fix GetAllCommits headers; reverted some changed behaviors * set Page value on Home route * improved memory allocations * fixed response headers * removed logfiles * fixed import order * import order * improved swagger * added function to get models.ListOptions from context * removed pagesize diff on unit test * fixed imports * removed unnecessary struct field * fixed go fmt * scoped PR * code improvements * code improvements * go mod tidy * fixed import order * fixed commit statuses session * fixed files headers * fixed headers; added pagination for notifications * go mod tidy * go fmt * removed Private from user search options; added setting.UI.IssuePagingNum as default valeu on repo's issues list * Apply suggestions from code review Co-Authored-By: 6543 <6543@obermui.de> Co-Authored-By: zeripath <art27@cantab.net> * fixed build error * CI.restart() * fixed merge conflicts resolve * fixed conflicts resolve * improved FindTrackedTimesOptions.ToOptions() method * added backwards compatibility on ListReleases request; fixed issue tracked time ToSession * fixed build error; fixed swagger template * fixed swagger template * fixed ListReleases backwards compatibility * added page to user search route Co-authored-by: techknowlogick <matti@mdranta.net> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: zeripath <art27@cantab.net>
5 years ago
Restricted users (#6274) * Restricted users (#4334): initial implementation * Add User.IsRestricted & UI to edit it * Pass user object instead of user id to places where IsRestricted flag matters * Restricted users: maintain access rows for all referenced repos (incl public) * Take logged in user & IsRestricted flag into account in org/repo listings, searches and accesses * Add basic repo access tests for restricted users Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Mention restricted users in the faq Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert unnecessary change `.isUserPartOfOrg` -> `.IsUserPartOfOrg` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Remove unnecessary `org.IsOrganization()` call Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert to an `int64` keyed `accessMap` * Add type `userAccess` * Add convenience func updateUserAccess() * Turn accessMap into a `map[int64]userAccess` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * or even better: `map[int64]*userAccess` * updateUserAccess(): use tighter syntax as suggested by lafriks * even tighter * Avoid extra loop * Don't disclose limited orgs to unauthenticated users * Don't assume block only applies to orgs * Use an array of `VisibleType` for filtering * fix yet another thinko * Ok - no need for u * Revert "Ok - no need for u" This reverts commit 5c3e886aabd5acd997a3b35687d322439732c200. Co-authored-by: Antoine GIRARD <sapk@users.noreply.github.com> Co-authored-by: Lauris BH <lauris@nix.lv>
5 years ago
10 years ago
10 years ago
10 years ago
API add/generalize pagination (#9452) * paginate results * fixed deadlock * prevented breaking change * updated swagger * go fmt * fixed find topic * go mod tidy * go mod vendor with go1.13.5 * fixed repo find topics * fixed unit test * added Limit method to Engine struct; use engine variable when provided; fixed gitignore * use ItemsPerPage for default pagesize; fix GetWatchers, getOrgUsersByOrgID and GetStargazers; fix GetAllCommits headers; reverted some changed behaviors * set Page value on Home route * improved memory allocations * fixed response headers * removed logfiles * fixed import order * import order * improved swagger * added function to get models.ListOptions from context * removed pagesize diff on unit test * fixed imports * removed unnecessary struct field * fixed go fmt * scoped PR * code improvements * code improvements * go mod tidy * fixed import order * fixed commit statuses session * fixed files headers * fixed headers; added pagination for notifications * go mod tidy * go fmt * removed Private from user search options; added setting.UI.IssuePagingNum as default valeu on repo's issues list * Apply suggestions from code review Co-Authored-By: 6543 <6543@obermui.de> Co-Authored-By: zeripath <art27@cantab.net> * fixed build error * CI.restart() * fixed merge conflicts resolve * fixed conflicts resolve * improved FindTrackedTimesOptions.ToOptions() method * added backwards compatibility on ListReleases request; fixed issue tracked time ToSession * fixed build error; fixed swagger template * fixed swagger template * fixed ListReleases backwards compatibility * added page to user search route Co-authored-by: techknowlogick <matti@mdranta.net> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: zeripath <art27@cantab.net>
5 years ago
10 years ago
Restricted users (#6274) * Restricted users (#4334): initial implementation * Add User.IsRestricted & UI to edit it * Pass user object instead of user id to places where IsRestricted flag matters * Restricted users: maintain access rows for all referenced repos (incl public) * Take logged in user & IsRestricted flag into account in org/repo listings, searches and accesses * Add basic repo access tests for restricted users Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Mention restricted users in the faq Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert unnecessary change `.isUserPartOfOrg` -> `.IsUserPartOfOrg` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Remove unnecessary `org.IsOrganization()` call Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert to an `int64` keyed `accessMap` * Add type `userAccess` * Add convenience func updateUserAccess() * Turn accessMap into a `map[int64]userAccess` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * or even better: `map[int64]*userAccess` * updateUserAccess(): use tighter syntax as suggested by lafriks * even tighter * Avoid extra loop * Don't disclose limited orgs to unauthenticated users * Don't assume block only applies to orgs * Use an array of `VisibleType` for filtering * fix yet another thinko * Ok - no need for u * Revert "Ok - no need for u" This reverts commit 5c3e886aabd5acd997a3b35687d322439732c200. Co-authored-by: Antoine GIRARD <sapk@users.noreply.github.com> Co-authored-by: Lauris BH <lauris@nix.lv>
5 years ago
Restricted users (#6274) * Restricted users (#4334): initial implementation * Add User.IsRestricted & UI to edit it * Pass user object instead of user id to places where IsRestricted flag matters * Restricted users: maintain access rows for all referenced repos (incl public) * Take logged in user & IsRestricted flag into account in org/repo listings, searches and accesses * Add basic repo access tests for restricted users Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Mention restricted users in the faq Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert unnecessary change `.isUserPartOfOrg` -> `.IsUserPartOfOrg` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Remove unnecessary `org.IsOrganization()` call Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert to an `int64` keyed `accessMap` * Add type `userAccess` * Add convenience func updateUserAccess() * Turn accessMap into a `map[int64]userAccess` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * or even better: `map[int64]*userAccess` * updateUserAccess(): use tighter syntax as suggested by lafriks * even tighter * Avoid extra loop * Don't disclose limited orgs to unauthenticated users * Don't assume block only applies to orgs * Use an array of `VisibleType` for filtering * fix yet another thinko * Ok - no need for u * Revert "Ok - no need for u" This reverts commit 5c3e886aabd5acd997a3b35687d322439732c200. Co-authored-by: Antoine GIRARD <sapk@users.noreply.github.com> Co-authored-by: Lauris BH <lauris@nix.lv>
5 years ago
API add/generalize pagination (#9452) * paginate results * fixed deadlock * prevented breaking change * updated swagger * go fmt * fixed find topic * go mod tidy * go mod vendor with go1.13.5 * fixed repo find topics * fixed unit test * added Limit method to Engine struct; use engine variable when provided; fixed gitignore * use ItemsPerPage for default pagesize; fix GetWatchers, getOrgUsersByOrgID and GetStargazers; fix GetAllCommits headers; reverted some changed behaviors * set Page value on Home route * improved memory allocations * fixed response headers * removed logfiles * fixed import order * import order * improved swagger * added function to get models.ListOptions from context * removed pagesize diff on unit test * fixed imports * removed unnecessary struct field * fixed go fmt * scoped PR * code improvements * code improvements * go mod tidy * fixed import order * fixed commit statuses session * fixed files headers * fixed headers; added pagination for notifications * go mod tidy * go fmt * removed Private from user search options; added setting.UI.IssuePagingNum as default valeu on repo's issues list * Apply suggestions from code review Co-Authored-By: 6543 <6543@obermui.de> Co-Authored-By: zeripath <art27@cantab.net> * fixed build error * CI.restart() * fixed merge conflicts resolve * fixed conflicts resolve * improved FindTrackedTimesOptions.ToOptions() method * added backwards compatibility on ListReleases request; fixed issue tracked time ToSession * fixed build error; fixed swagger template * fixed swagger template * fixed ListReleases backwards compatibility * added page to user search route Co-authored-by: techknowlogick <matti@mdranta.net> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: zeripath <art27@cantab.net>
5 years ago
Restricted users (#6274) * Restricted users (#4334): initial implementation * Add User.IsRestricted & UI to edit it * Pass user object instead of user id to places where IsRestricted flag matters * Restricted users: maintain access rows for all referenced repos (incl public) * Take logged in user & IsRestricted flag into account in org/repo listings, searches and accesses * Add basic repo access tests for restricted users Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Mention restricted users in the faq Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert unnecessary change `.isUserPartOfOrg` -> `.IsUserPartOfOrg` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Remove unnecessary `org.IsOrganization()` call Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert to an `int64` keyed `accessMap` * Add type `userAccess` * Add convenience func updateUserAccess() * Turn accessMap into a `map[int64]userAccess` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * or even better: `map[int64]*userAccess` * updateUserAccess(): use tighter syntax as suggested by lafriks * even tighter * Avoid extra loop * Don't disclose limited orgs to unauthenticated users * Don't assume block only applies to orgs * Use an array of `VisibleType` for filtering * fix yet another thinko * Ok - no need for u * Revert "Ok - no need for u" This reverts commit 5c3e886aabd5acd997a3b35687d322439732c200. Co-authored-by: Antoine GIRARD <sapk@users.noreply.github.com> Co-authored-by: Lauris BH <lauris@nix.lv>
5 years ago
Restricted users (#6274) * Restricted users (#4334): initial implementation * Add User.IsRestricted & UI to edit it * Pass user object instead of user id to places where IsRestricted flag matters * Restricted users: maintain access rows for all referenced repos (incl public) * Take logged in user & IsRestricted flag into account in org/repo listings, searches and accesses * Add basic repo access tests for restricted users Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Mention restricted users in the faq Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert unnecessary change `.isUserPartOfOrg` -> `.IsUserPartOfOrg` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Remove unnecessary `org.IsOrganization()` call Signed-off-by: Manush Dodunekov <manush@stendahls.se> * Revert to an `int64` keyed `accessMap` * Add type `userAccess` * Add convenience func updateUserAccess() * Turn accessMap into a `map[int64]userAccess` Signed-off-by: Manush Dodunekov <manush@stendahls.se> * or even better: `map[int64]*userAccess` * updateUserAccess(): use tighter syntax as suggested by lafriks * even tighter * Avoid extra loop * Don't disclose limited orgs to unauthenticated users * Don't assume block only applies to orgs * Use an array of `VisibleType` for filtering * fix yet another thinko * Ok - no need for u * Revert "Ok - no need for u" This reverts commit 5c3e886aabd5acd997a3b35687d322439732c200. Co-authored-by: Antoine GIRARD <sapk@users.noreply.github.com> Co-authored-by: Lauris BH <lauris@nix.lv>
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Copyright 2019 The Gitea Authors. All rights reserved.
  3. // Use of this source code is governed by a MIT-style
  4. // license that can be found in the LICENSE file.
  5. package routers
  6. import (
  7. "bytes"
  8. "strings"
  9. "code.gitea.io/gitea/models"
  10. "code.gitea.io/gitea/modules/base"
  11. "code.gitea.io/gitea/modules/context"
  12. code_indexer "code.gitea.io/gitea/modules/indexer/code"
  13. "code.gitea.io/gitea/modules/log"
  14. "code.gitea.io/gitea/modules/setting"
  15. "code.gitea.io/gitea/modules/structs"
  16. "code.gitea.io/gitea/modules/util"
  17. "code.gitea.io/gitea/routers/user"
  18. )
  19. const (
  20. // tplHome home page template
  21. tplHome base.TplName = "home"
  22. // tplExploreRepos explore repositories page template
  23. tplExploreRepos base.TplName = "explore/repos"
  24. // tplExploreDataset explore datasets page template
  25. tplExploreDataset base.TplName = "explore/datasets"
  26. // tplExploreUsers explore users page template
  27. tplExploreUsers base.TplName = "explore/users"
  28. // tplExploreOrganizations explore organizations page template
  29. tplExploreOrganizations base.TplName = "explore/organizations"
  30. // tplExploreCode explore code page template
  31. tplExploreCode base.TplName = "explore/code"
  32. )
  33. // Home render home page
  34. func Home(ctx *context.Context) {
  35. ctx.Data["PageIsHome"] = true
  36. ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  37. ctx.HTML(200, tplHome)
  38. }
  39. func Dashboard(ctx *context.Context) {
  40. if ctx.IsSigned {
  41. if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm {
  42. ctx.Data["Title"] = ctx.Tr("auth.active_your_account")
  43. ctx.HTML(200, user.TplActivate)
  44. } else if !ctx.User.IsActive || ctx.User.ProhibitLogin {
  45. log.Info("Failed authentication attempt for %s from %s", ctx.User.Name, ctx.RemoteAddr())
  46. ctx.Data["Title"] = ctx.Tr("auth.prohibit_login")
  47. ctx.HTML(200, "user/auth/prohibit_login")
  48. } else if ctx.User.MustChangePassword {
  49. ctx.Data["Title"] = ctx.Tr("auth.must_change_password")
  50. ctx.Data["ChangePasscodeLink"] = setting.AppSubURL + "/user/change_password"
  51. ctx.SetCookie("redirect_to", setting.AppSubURL+ctx.Req.URL.RequestURI(), 0, setting.AppSubURL)
  52. ctx.Redirect(setting.AppSubURL + "/user/settings/change_password")
  53. } else {
  54. user.Dashboard(ctx)
  55. }
  56. return
  57. // Check non-logged users landing page.
  58. } else if setting.LandingPageURL != setting.LandingPageHome {
  59. ctx.Redirect(setting.AppSubURL + string(setting.LandingPageURL))
  60. return
  61. }
  62. // Check auto-login.
  63. uname := ctx.GetCookie(setting.CookieUserName)
  64. if len(uname) != 0 {
  65. ctx.Redirect(setting.AppSubURL + "/user/login")
  66. return
  67. }
  68. ctx.Data["PageIsHome"] = true
  69. ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  70. ctx.HTML(200, tplHome)
  71. }
  72. // RepoSearchOptions when calling search repositories
  73. type RepoSearchOptions struct {
  74. OwnerID int64
  75. Private bool
  76. Restricted bool
  77. PageSize int
  78. TplName base.TplName
  79. }
  80. var (
  81. nullByte = []byte{0x00}
  82. )
  83. func isKeywordValid(keyword string) bool {
  84. return !bytes.Contains([]byte(keyword), nullByte)
  85. }
  86. // RenderRepoSearch render repositories search page
  87. func RenderRepoSearch(ctx *context.Context, opts *RepoSearchOptions) {
  88. page := ctx.QueryInt("page")
  89. if page <= 0 {
  90. page = 1
  91. }
  92. var (
  93. repos []*models.Repository
  94. count int64
  95. err error
  96. orderBy models.SearchOrderBy
  97. )
  98. ctx.Data["SortType"] = ctx.Query("sort")
  99. switch ctx.Query("sort") {
  100. case "newest":
  101. orderBy = models.SearchOrderByNewest
  102. case "oldest":
  103. orderBy = models.SearchOrderByOldest
  104. case "recentupdate":
  105. orderBy = models.SearchOrderByRecentUpdated
  106. case "leastupdate":
  107. orderBy = models.SearchOrderByLeastUpdated
  108. case "reversealphabetically":
  109. orderBy = models.SearchOrderByAlphabeticallyReverse
  110. case "alphabetically":
  111. orderBy = models.SearchOrderByAlphabetically
  112. case "reversesize":
  113. orderBy = models.SearchOrderBySizeReverse
  114. case "size":
  115. orderBy = models.SearchOrderBySize
  116. case "moststars":
  117. orderBy = models.SearchOrderByStarsReverse
  118. case "feweststars":
  119. orderBy = models.SearchOrderByStars
  120. case "mostforks":
  121. orderBy = models.SearchOrderByForksReverse
  122. case "fewestforks":
  123. orderBy = models.SearchOrderByForks
  124. default:
  125. ctx.Data["SortType"] = "recentupdate"
  126. orderBy = models.SearchOrderByRecentUpdated
  127. }
  128. keyword := strings.Trim(ctx.Query("q"), " ")
  129. topicOnly := ctx.QueryBool("topic")
  130. ctx.Data["TopicOnly"] = topicOnly
  131. repos, count, err = models.SearchRepository(&models.SearchRepoOptions{
  132. ListOptions: models.ListOptions{
  133. Page: page,
  134. PageSize: opts.PageSize,
  135. },
  136. Actor: ctx.User,
  137. OrderBy: orderBy,
  138. Private: opts.Private,
  139. Keyword: keyword,
  140. OwnerID: opts.OwnerID,
  141. AllPublic: true,
  142. AllLimited: true,
  143. TopicOnly: topicOnly,
  144. IncludeDescription: setting.UI.SearchRepoDescription,
  145. })
  146. if err != nil {
  147. ctx.ServerError("SearchRepository", err)
  148. return
  149. }
  150. ctx.Data["Keyword"] = keyword
  151. ctx.Data["Total"] = count
  152. ctx.Data["Repos"] = repos
  153. ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  154. pager := context.NewPagination(int(count), opts.PageSize, page, 5)
  155. pager.SetDefaultParams(ctx)
  156. pager.AddParam(ctx, "topic", "TopicOnly")
  157. ctx.Data["Page"] = pager
  158. ctx.HTML(200, opts.TplName)
  159. }
  160. // ExploreRepos render explore repositories page
  161. func ExploreRepos(ctx *context.Context) {
  162. ctx.Data["Title"] = ctx.Tr("explore")
  163. ctx.Data["PageIsExplore"] = true
  164. ctx.Data["PageIsExploreRepositories"] = true
  165. ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  166. var ownerID int64
  167. if ctx.User != nil && !ctx.User.IsAdmin {
  168. ownerID = ctx.User.ID
  169. }
  170. RenderRepoSearch(ctx, &RepoSearchOptions{
  171. PageSize: setting.UI.ExplorePagingNum,
  172. OwnerID: ownerID,
  173. Private: ctx.User != nil,
  174. TplName: tplExploreRepos,
  175. })
  176. }
  177. func ExploreDatasets(ctx *context.Context) {
  178. ctx.Data["Title"] = ctx.Tr("explore")
  179. ctx.Data["PageIsExplore"] = true
  180. ctx.Data["PageIsExploreDatasets"] = true
  181. // ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  182. var (
  183. datasets []*models.Dataset
  184. count int64
  185. err error
  186. orderBy models.SearchOrderBy
  187. )
  188. page := ctx.QueryInt("page")
  189. if page <= 0 {
  190. page = 1
  191. }
  192. ctx.Data["SortType"] = ctx.Query("sort")
  193. switch ctx.Query("sort") {
  194. case "newest":
  195. orderBy = models.SearchOrderByNewest
  196. case "oldest":
  197. orderBy = models.SearchOrderByOldest
  198. case "recentupdate":
  199. orderBy = models.SearchOrderByRecentUpdated
  200. case "leastupdate":
  201. orderBy = models.SearchOrderByLeastUpdated
  202. case "reversealphabetically":
  203. orderBy = models.SearchOrderByAlphabeticallyReverse
  204. case "alphabetically":
  205. orderBy = models.SearchOrderByAlphabetically
  206. case "reversesize":
  207. orderBy = models.SearchOrderBySizeReverse
  208. case "downloadtimes":
  209. orderBy = models.SearchOrderByDownloadTimes
  210. default:
  211. ctx.Data["SortType"] = "recentupdate"
  212. orderBy = models.SearchOrderByRecentUpdated
  213. }
  214. keyword := strings.Trim(ctx.Query("q"), " ")
  215. var ownerID int64
  216. if ctx.User != nil && !ctx.User.IsAdmin {
  217. ownerID = ctx.User.ID
  218. }
  219. opts := &models.SearchDatasetOptions{
  220. Keyword: keyword,
  221. IncludePublic: true,
  222. SearchOrderBy: orderBy,
  223. OwnerID: ownerID,
  224. ListOptions: models.ListOptions{
  225. Page: page,
  226. PageSize: setting.UI.ExplorePagingNum,
  227. },
  228. }
  229. datasets, count, err = models.SearchDataset(opts)
  230. if err != nil {
  231. ctx.ServerError("SearchDatasets", err)
  232. return
  233. }
  234. pager := context.NewPagination(int(count), opts.PageSize, page, 5)
  235. pager.SetDefaultParams(ctx)
  236. ctx.Data["Page"] = pager
  237. ctx.Data["Keyword"] = opts.Keyword
  238. ctx.Data["Datasets"] = datasets
  239. ctx.Data["Total"] = count
  240. ctx.Data["PageIsDatasets"] = true
  241. ctx.HTML(200, tplExploreDataset)
  242. }
  243. // RenderUserSearch render user search page
  244. func RenderUserSearch(ctx *context.Context, opts *models.SearchUserOptions, tplName base.TplName) {
  245. opts.Page = ctx.QueryInt("page")
  246. if opts.Page <= 1 {
  247. opts.Page = 1
  248. }
  249. var (
  250. users []*models.User
  251. count int64
  252. err error
  253. orderBy models.SearchOrderBy
  254. )
  255. ctx.Data["SortType"] = ctx.Query("sort")
  256. switch ctx.Query("sort") {
  257. case "newest":
  258. orderBy = models.SearchOrderByIDReverse
  259. case "oldest":
  260. orderBy = models.SearchOrderByID
  261. case "recentupdate":
  262. orderBy = models.SearchOrderByRecentUpdated
  263. case "leastupdate":
  264. orderBy = models.SearchOrderByLeastUpdated
  265. case "reversealphabetically":
  266. orderBy = models.SearchOrderByAlphabeticallyReverse
  267. case "alphabetically":
  268. orderBy = models.SearchOrderByAlphabetically
  269. default:
  270. ctx.Data["SortType"] = "alphabetically"
  271. orderBy = models.SearchOrderByAlphabetically
  272. }
  273. opts.Keyword = strings.Trim(ctx.Query("q"), " ")
  274. opts.OrderBy = orderBy
  275. if len(opts.Keyword) == 0 || isKeywordValid(opts.Keyword) {
  276. users, count, err = models.SearchUsers(opts)
  277. if err != nil {
  278. ctx.ServerError("SearchUsers", err)
  279. return
  280. }
  281. }
  282. ctx.Data["Keyword"] = opts.Keyword
  283. ctx.Data["Total"] = count
  284. ctx.Data["Users"] = users
  285. ctx.Data["ShowUserEmail"] = setting.UI.ShowUserEmail
  286. ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  287. pager := context.NewPagination(int(count), opts.PageSize, opts.Page, 5)
  288. pager.SetDefaultParams(ctx)
  289. ctx.Data["Page"] = pager
  290. ctx.HTML(200, tplName)
  291. }
  292. // ExploreUsers render explore users page
  293. func ExploreUsers(ctx *context.Context) {
  294. ctx.Data["Title"] = ctx.Tr("explore")
  295. ctx.Data["PageIsExplore"] = true
  296. ctx.Data["PageIsExploreUsers"] = true
  297. ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  298. RenderUserSearch(ctx, &models.SearchUserOptions{
  299. Actor: ctx.User,
  300. Type: models.UserTypeIndividual,
  301. ListOptions: models.ListOptions{PageSize: setting.UI.ExplorePagingNum},
  302. IsActive: util.OptionalBoolTrue,
  303. Visible: []structs.VisibleType{structs.VisibleTypePublic, structs.VisibleTypeLimited, structs.VisibleTypePrivate},
  304. }, tplExploreUsers)
  305. }
  306. // ExploreOrganizations render explore organizations page
  307. func ExploreOrganizations(ctx *context.Context) {
  308. ctx.Data["Title"] = ctx.Tr("explore")
  309. ctx.Data["PageIsExplore"] = true
  310. ctx.Data["PageIsExploreOrganizations"] = true
  311. ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  312. visibleTypes := []structs.VisibleType{structs.VisibleTypePublic}
  313. if ctx.User != nil {
  314. visibleTypes = append(visibleTypes, structs.VisibleTypeLimited, structs.VisibleTypePrivate)
  315. }
  316. RenderUserSearch(ctx, &models.SearchUserOptions{
  317. Actor: ctx.User,
  318. Type: models.UserTypeOrganization,
  319. ListOptions: models.ListOptions{PageSize: setting.UI.ExplorePagingNum},
  320. Visible: visibleTypes,
  321. }, tplExploreOrganizations)
  322. }
  323. // ExploreCode render explore code page
  324. func ExploreCode(ctx *context.Context) {
  325. if !setting.Indexer.RepoIndexerEnabled {
  326. ctx.Redirect(setting.AppSubURL+"/explore", 302)
  327. return
  328. }
  329. ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
  330. ctx.Data["Title"] = ctx.Tr("explore")
  331. ctx.Data["PageIsExplore"] = true
  332. ctx.Data["PageIsExploreCode"] = true
  333. language := strings.TrimSpace(ctx.Query("l"))
  334. keyword := strings.TrimSpace(ctx.Query("q"))
  335. page := ctx.QueryInt("page")
  336. if page <= 0 {
  337. page = 1
  338. }
  339. var (
  340. repoIDs []int64
  341. err error
  342. isAdmin bool
  343. userID int64
  344. )
  345. if ctx.User != nil {
  346. userID = ctx.User.ID
  347. isAdmin = ctx.User.IsAdmin
  348. }
  349. // guest user or non-admin user
  350. if ctx.User == nil || !isAdmin {
  351. repoIDs, err = models.FindUserAccessibleRepoIDs(ctx.User)
  352. if err != nil {
  353. ctx.ServerError("SearchResults", err)
  354. return
  355. }
  356. }
  357. var (
  358. total int
  359. searchResults []*code_indexer.Result
  360. searchResultLanguages []*code_indexer.SearchResultLanguages
  361. )
  362. // if non-admin login user, we need check UnitTypeCode at first
  363. if ctx.User != nil && len(repoIDs) > 0 {
  364. repoMaps, err := models.GetRepositoriesMapByIDs(repoIDs)
  365. if err != nil {
  366. ctx.ServerError("SearchResults", err)
  367. return
  368. }
  369. var rightRepoMap = make(map[int64]*models.Repository, len(repoMaps))
  370. repoIDs = make([]int64, 0, len(repoMaps))
  371. for id, repo := range repoMaps {
  372. if repo.CheckUnitUser(userID, isAdmin, models.UnitTypeCode) {
  373. rightRepoMap[id] = repo
  374. repoIDs = append(repoIDs, id)
  375. }
  376. }
  377. ctx.Data["RepoMaps"] = rightRepoMap
  378. total, searchResults, searchResultLanguages, err = code_indexer.PerformSearch(repoIDs, language, keyword, page, setting.UI.RepoSearchPagingNum)
  379. if err != nil {
  380. ctx.ServerError("SearchResults", err)
  381. return
  382. }
  383. // if non-login user or isAdmin, no need to check UnitTypeCode
  384. } else if (ctx.User == nil && len(repoIDs) > 0) || isAdmin {
  385. total, searchResults, searchResultLanguages, err = code_indexer.PerformSearch(repoIDs, language, keyword, page, setting.UI.RepoSearchPagingNum)
  386. if err != nil {
  387. ctx.ServerError("SearchResults", err)
  388. return
  389. }
  390. var loadRepoIDs = make([]int64, 0, len(searchResults))
  391. for _, result := range searchResults {
  392. var find bool
  393. for _, id := range loadRepoIDs {
  394. if id == result.RepoID {
  395. find = true
  396. break
  397. }
  398. }
  399. if !find {
  400. loadRepoIDs = append(loadRepoIDs, result.RepoID)
  401. }
  402. }
  403. repoMaps, err := models.GetRepositoriesMapByIDs(loadRepoIDs)
  404. if err != nil {
  405. ctx.ServerError("SearchResults", err)
  406. return
  407. }
  408. ctx.Data["RepoMaps"] = repoMaps
  409. }
  410. ctx.Data["Keyword"] = keyword
  411. ctx.Data["Language"] = language
  412. ctx.Data["SearchResults"] = searchResults
  413. ctx.Data["SearchResultLanguages"] = searchResultLanguages
  414. ctx.Data["RequireHighlightJS"] = true
  415. ctx.Data["PageIsViewCode"] = true
  416. pager := context.NewPagination(total, setting.UI.RepoSearchPagingNum, page, 5)
  417. pager.SetDefaultParams(ctx)
  418. pager.AddParam(ctx, "l", "Language")
  419. ctx.Data["Page"] = pager
  420. ctx.HTML(200, tplExploreCode)
  421. }
  422. // NotFound render 404 page
  423. func NotFound(ctx *context.Context) {
  424. ctx.Data["Title"] = "Page Not Found"
  425. ctx.NotFound("home.NotFound", nil)
  426. }