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

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