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.2KB

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