org.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. package context
  2. import (
  3. "gitote/gitote/models"
  4. "gitote/gitote/models/errors"
  5. "gitote/gitote/pkg/setting"
  6. "strings"
  7. "gopkg.in/macaron.v1"
  8. )
  9. type Organization struct {
  10. IsOwner bool
  11. IsMember bool
  12. IsTeamMember bool // Is member of team.
  13. IsTeamAdmin bool // In owner team or team that has admin permission level.
  14. Organization *models.User
  15. OrgLink string
  16. Team *models.Team
  17. }
  18. func HandleOrgAssignment(c *Context, args ...bool) {
  19. var (
  20. requireMember bool
  21. requireOwner bool
  22. requireTeamMember bool
  23. requireTeamAdmin bool
  24. )
  25. if len(args) >= 1 {
  26. requireMember = args[0]
  27. }
  28. if len(args) >= 2 {
  29. requireOwner = args[1]
  30. }
  31. if len(args) >= 3 {
  32. requireTeamMember = args[2]
  33. }
  34. if len(args) >= 4 {
  35. requireTeamAdmin = args[3]
  36. }
  37. orgName := c.Params(":org")
  38. var err error
  39. c.Org.Organization, err = models.GetUserByName(orgName)
  40. if err != nil {
  41. c.NotFoundOrServerError("GetUserByName", errors.IsUserNotExist, err)
  42. return
  43. }
  44. org := c.Org.Organization
  45. c.Data["Org"] = org
  46. // Force redirection when username is actually a user.
  47. if !org.IsOrganization() {
  48. c.Redirect("/" + org.Name)
  49. return
  50. }
  51. // Admin has super access.
  52. if c.IsLogged && c.User.IsAdmin {
  53. c.Org.IsOwner = true
  54. c.Org.IsMember = true
  55. c.Org.IsTeamMember = true
  56. c.Org.IsTeamAdmin = true
  57. } else if c.IsLogged {
  58. c.Org.IsOwner = org.IsOwnedBy(c.User.ID)
  59. if c.Org.IsOwner {
  60. c.Org.IsMember = true
  61. c.Org.IsTeamMember = true
  62. c.Org.IsTeamAdmin = true
  63. } else {
  64. if org.IsOrgMember(c.User.ID) {
  65. c.Org.IsMember = true
  66. }
  67. }
  68. } else {
  69. // Fake data.
  70. c.Data["SignedUser"] = &models.User{}
  71. }
  72. if (requireMember && !c.Org.IsMember) ||
  73. (requireOwner && !c.Org.IsOwner) {
  74. c.Handle(404, "OrgAssignment", err)
  75. return
  76. }
  77. c.Data["IsOrganizationOwner"] = c.Org.IsOwner
  78. c.Data["IsOrganizationMember"] = c.Org.IsMember
  79. c.Org.OrgLink = setting.AppSubURL + "/org/" + org.Name
  80. c.Data["OrgLink"] = c.Org.OrgLink
  81. // Team.
  82. if c.Org.IsMember {
  83. if c.Org.IsOwner {
  84. if err := org.GetTeams(); err != nil {
  85. c.Handle(500, "GetTeams", err)
  86. return
  87. }
  88. } else {
  89. org.Teams, err = org.GetUserTeams(c.User.ID)
  90. if err != nil {
  91. c.Handle(500, "GetUserTeams", err)
  92. return
  93. }
  94. }
  95. }
  96. teamName := c.Params(":team")
  97. if len(teamName) > 0 {
  98. teamExists := false
  99. for _, team := range org.Teams {
  100. if team.LowerName == strings.ToLower(teamName) {
  101. teamExists = true
  102. c.Org.Team = team
  103. c.Org.IsTeamMember = true
  104. c.Data["Team"] = c.Org.Team
  105. break
  106. }
  107. }
  108. if !teamExists {
  109. c.Handle(404, "OrgAssignment", err)
  110. return
  111. }
  112. c.Data["IsTeamMember"] = c.Org.IsTeamMember
  113. if requireTeamMember && !c.Org.IsTeamMember {
  114. c.Handle(404, "OrgAssignment", err)
  115. return
  116. }
  117. c.Org.IsTeamAdmin = c.Org.Team.IsOwnerTeam() || c.Org.Team.Authorize >= models.ACCESS_MODE_ADMIN
  118. c.Data["IsTeamAdmin"] = c.Org.IsTeamAdmin
  119. if requireTeamAdmin && !c.Org.IsTeamAdmin {
  120. c.Handle(404, "OrgAssignment", err)
  121. return
  122. }
  123. }
  124. }
  125. func OrgAssignment(args ...bool) macaron.Handler {
  126. return func(c *Context) {
  127. HandleOrgAssignment(c, args...)
  128. }
  129. }