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

org.go 4.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Copyright 2020 The Gitea Authors.
  3. // Use of this source code is governed by a MIT-style
  4. // license that can be found in the LICENSE file.
  5. package context
  6. import (
  7. "strings"
  8. "code.gitea.io/gitea/models"
  9. "code.gitea.io/gitea/modules/setting"
  10. "gitea.com/macaron/macaron"
  11. )
  12. // Organization contains organization context
  13. type Organization struct {
  14. IsOwner bool
  15. IsMember bool
  16. IsTeamMember bool // Is member of team.
  17. IsTeamAdmin bool // In owner team or team that has admin permission level.
  18. Organization *models.User
  19. OrgLink string
  20. CanCreateOrgRepo bool
  21. Team *models.Team
  22. }
  23. // HandleOrgAssignment handles organization assignment
  24. func HandleOrgAssignment(ctx *Context, args ...bool) {
  25. var (
  26. requireMember bool
  27. requireOwner bool
  28. requireTeamMember bool
  29. requireTeamAdmin bool
  30. )
  31. if len(args) >= 1 {
  32. requireMember = args[0]
  33. }
  34. if len(args) >= 2 {
  35. requireOwner = args[1]
  36. }
  37. if len(args) >= 3 {
  38. requireTeamMember = args[2]
  39. }
  40. if len(args) >= 4 {
  41. requireTeamAdmin = args[3]
  42. }
  43. orgName := ctx.Params(":org")
  44. var err error
  45. ctx.Org.Organization, err = models.GetUserByName(orgName)
  46. if err != nil {
  47. if models.IsErrUserNotExist(err) {
  48. redirectUserID, err := models.LookupUserRedirect(orgName)
  49. if err == nil {
  50. RedirectToUser(ctx, orgName, redirectUserID)
  51. } else if models.IsErrUserRedirectNotExist(err) {
  52. ctx.NotFound("GetUserByName", err)
  53. } else {
  54. ctx.ServerError("LookupUserRedirect", err)
  55. }
  56. } else {
  57. ctx.ServerError("GetUserByName", err)
  58. }
  59. return
  60. }
  61. org := ctx.Org.Organization
  62. ctx.Data["Org"] = org
  63. // Force redirection when username is actually a user.
  64. if !org.IsOrganization() {
  65. ctx.Redirect(setting.AppSubURL + "/" + org.Name)
  66. return
  67. }
  68. // Admin has super access.
  69. if ctx.IsSigned && ctx.User.IsAdmin {
  70. ctx.Org.IsOwner = true
  71. ctx.Org.IsMember = true
  72. ctx.Org.IsTeamMember = true
  73. ctx.Org.IsTeamAdmin = true
  74. ctx.Org.CanCreateOrgRepo = true
  75. } else if ctx.IsSigned {
  76. ctx.Org.IsOwner, err = org.IsOwnedBy(ctx.User.ID)
  77. if err != nil {
  78. ctx.ServerError("IsOwnedBy", err)
  79. return
  80. }
  81. if ctx.Org.IsOwner {
  82. ctx.Org.IsMember = true
  83. ctx.Org.IsTeamMember = true
  84. ctx.Org.IsTeamAdmin = true
  85. ctx.Org.CanCreateOrgRepo = true
  86. } else {
  87. ctx.Org.IsMember, err = org.IsOrgMember(ctx.User.ID)
  88. if err != nil {
  89. ctx.ServerError("IsOrgMember", err)
  90. return
  91. }
  92. ctx.Org.CanCreateOrgRepo, err = org.CanCreateOrgRepo(ctx.User.ID)
  93. if err != nil {
  94. ctx.ServerError("CanCreateOrgRepo", err)
  95. return
  96. }
  97. }
  98. } else {
  99. // Fake data.
  100. ctx.Data["SignedUser"] = &models.User{}
  101. }
  102. if (requireMember && !ctx.Org.IsMember) ||
  103. (requireOwner && !ctx.Org.IsOwner) {
  104. ctx.NotFound("OrgAssignment", err)
  105. return
  106. }
  107. ctx.Data["IsOrganizationOwner"] = ctx.Org.IsOwner
  108. ctx.Data["IsOrganizationMember"] = ctx.Org.IsMember
  109. ctx.Data["CanCreateOrgRepo"] = ctx.Org.CanCreateOrgRepo
  110. ctx.Org.OrgLink = setting.AppSubURL + "/org/" + org.Name
  111. ctx.Data["OrgLink"] = ctx.Org.OrgLink
  112. // Team.
  113. if ctx.Org.IsMember {
  114. if ctx.Org.IsOwner {
  115. if err := org.GetTeams(&models.SearchTeamOptions{}); err != nil {
  116. ctx.ServerError("GetTeams", err)
  117. return
  118. }
  119. } else {
  120. org.Teams, err = org.GetUserTeams(ctx.User.ID)
  121. if err != nil {
  122. ctx.ServerError("GetUserTeams", err)
  123. return
  124. }
  125. }
  126. }
  127. teamName := ctx.Params(":team")
  128. if len(teamName) > 0 {
  129. teamExists := false
  130. for _, team := range org.Teams {
  131. if team.LowerName == strings.ToLower(teamName) {
  132. teamExists = true
  133. ctx.Org.Team = team
  134. ctx.Org.IsTeamMember = true
  135. ctx.Data["Team"] = ctx.Org.Team
  136. break
  137. }
  138. }
  139. if !teamExists {
  140. ctx.NotFound("OrgAssignment", err)
  141. return
  142. }
  143. ctx.Data["IsTeamMember"] = ctx.Org.IsTeamMember
  144. if requireTeamMember && !ctx.Org.IsTeamMember {
  145. ctx.NotFound("OrgAssignment", err)
  146. return
  147. }
  148. ctx.Org.IsTeamAdmin = ctx.Org.Team.IsOwnerTeam() || ctx.Org.Team.Authorize >= models.AccessModeAdmin
  149. ctx.Data["IsTeamAdmin"] = ctx.Org.IsTeamAdmin
  150. if requireTeamAdmin && !ctx.Org.IsTeamAdmin {
  151. ctx.NotFound("OrgAssignment", err)
  152. return
  153. }
  154. }
  155. }
  156. // OrgAssignment returns a macaron middleware to handle organization assignment
  157. func OrgAssignment(args ...bool) macaron.Handler {
  158. return func(ctx *Context) {
  159. HandleOrgAssignment(ctx, args...)
  160. }
  161. }