gitea源码

repo.go 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. // Copyright 2017 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package user
  4. import (
  5. "net/http"
  6. access_model "code.gitea.io/gitea/models/perm/access"
  7. repo_model "code.gitea.io/gitea/models/repo"
  8. user_model "code.gitea.io/gitea/models/user"
  9. api "code.gitea.io/gitea/modules/structs"
  10. "code.gitea.io/gitea/routers/api/v1/utils"
  11. "code.gitea.io/gitea/services/context"
  12. "code.gitea.io/gitea/services/convert"
  13. )
  14. // listUserRepos - List the repositories owned by the given user.
  15. func listUserRepos(ctx *context.APIContext, u *user_model.User, private bool) {
  16. opts := utils.GetListOptions(ctx)
  17. repos, count, err := repo_model.GetUserRepositories(ctx, repo_model.SearchRepoOptions{
  18. Actor: u,
  19. Private: private,
  20. ListOptions: opts,
  21. OrderBy: "id ASC",
  22. })
  23. if err != nil {
  24. ctx.APIErrorInternal(err)
  25. return
  26. }
  27. if err := repos.LoadAttributes(ctx); err != nil {
  28. ctx.APIErrorInternal(err)
  29. return
  30. }
  31. apiRepos := make([]*api.Repository, 0, len(repos))
  32. for i := range repos {
  33. permission, err := access_model.GetUserRepoPermission(ctx, repos[i], ctx.Doer)
  34. if err != nil {
  35. ctx.APIErrorInternal(err)
  36. return
  37. }
  38. if ctx.IsSigned && ctx.Doer.IsAdmin || permission.HasAnyUnitAccess() {
  39. apiRepos = append(apiRepos, convert.ToRepo(ctx, repos[i], permission))
  40. }
  41. }
  42. ctx.SetLinkHeader(int(count), opts.PageSize)
  43. ctx.SetTotalCountHeader(count)
  44. ctx.JSON(http.StatusOK, &apiRepos)
  45. }
  46. // ListUserRepos - list the repos owned by the given user.
  47. func ListUserRepos(ctx *context.APIContext) {
  48. // swagger:operation GET /users/{username}/repos user userListRepos
  49. // ---
  50. // summary: List the repos owned by the given user
  51. // produces:
  52. // - application/json
  53. // parameters:
  54. // - name: username
  55. // in: path
  56. // description: username of the user whose owned repos are to be listed
  57. // type: string
  58. // required: true
  59. // - name: page
  60. // in: query
  61. // description: page number of results to return (1-based)
  62. // type: integer
  63. // - name: limit
  64. // in: query
  65. // description: page size of results
  66. // type: integer
  67. // responses:
  68. // "200":
  69. // "$ref": "#/responses/RepositoryList"
  70. // "404":
  71. // "$ref": "#/responses/notFound"
  72. private := ctx.IsSigned
  73. listUserRepos(ctx, ctx.ContextUser, private)
  74. }
  75. // ListMyRepos - list the repositories you own or have access to.
  76. func ListMyRepos(ctx *context.APIContext) {
  77. // swagger:operation GET /user/repos user userCurrentListRepos
  78. // ---
  79. // summary: List the repos that the authenticated user owns
  80. // produces:
  81. // - application/json
  82. // parameters:
  83. // - name: page
  84. // in: query
  85. // description: page number of results to return (1-based)
  86. // type: integer
  87. // - name: limit
  88. // in: query
  89. // description: page size of results
  90. // type: integer
  91. // responses:
  92. // "200":
  93. // "$ref": "#/responses/RepositoryList"
  94. opts := repo_model.SearchRepoOptions{
  95. ListOptions: utils.GetListOptions(ctx),
  96. Actor: ctx.Doer,
  97. OwnerID: ctx.Doer.ID,
  98. Private: ctx.IsSigned,
  99. IncludeDescription: true,
  100. }
  101. repos, count, err := repo_model.SearchRepository(ctx, opts)
  102. if err != nil {
  103. ctx.APIErrorInternal(err)
  104. return
  105. }
  106. results := make([]*api.Repository, len(repos))
  107. for i, repo := range repos {
  108. if err = repo.LoadOwner(ctx); err != nil {
  109. ctx.APIErrorInternal(err)
  110. return
  111. }
  112. permission, err := access_model.GetUserRepoPermission(ctx, repo, ctx.Doer)
  113. if err != nil {
  114. ctx.APIErrorInternal(err)
  115. }
  116. results[i] = convert.ToRepo(ctx, repo, permission)
  117. }
  118. ctx.SetLinkHeader(int(count), opts.ListOptions.PageSize)
  119. ctx.SetTotalCountHeader(count)
  120. ctx.JSON(http.StatusOK, &results)
  121. }
  122. // ListOrgRepos - list the repositories of an organization.
  123. func ListOrgRepos(ctx *context.APIContext) {
  124. // swagger:operation GET /orgs/{org}/repos organization orgListRepos
  125. // ---
  126. // summary: List an organization's repos
  127. // produces:
  128. // - application/json
  129. // parameters:
  130. // - name: org
  131. // in: path
  132. // description: name of the organization
  133. // type: string
  134. // required: true
  135. // - name: page
  136. // in: query
  137. // description: page number of results to return (1-based)
  138. // type: integer
  139. // - name: limit
  140. // in: query
  141. // description: page size of results
  142. // type: integer
  143. // responses:
  144. // "200":
  145. // "$ref": "#/responses/RepositoryList"
  146. // "404":
  147. // "$ref": "#/responses/notFound"
  148. listUserRepos(ctx, ctx.Org.Organization.AsUser(), ctx.IsSigned)
  149. }