team_members.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. package api
  2. import (
  3. "github.com/grafana/grafana/pkg/api/dtos"
  4. "github.com/grafana/grafana/pkg/bus"
  5. m "github.com/grafana/grafana/pkg/models"
  6. "github.com/grafana/grafana/pkg/services/teamguardian"
  7. "github.com/grafana/grafana/pkg/setting"
  8. "github.com/grafana/grafana/pkg/util"
  9. )
  10. // GET /api/teams/:teamId/members
  11. func GetTeamMembers(c *m.ReqContext) Response {
  12. query := m.GetTeamMembersQuery{OrgId: c.OrgId, TeamId: c.ParamsInt64(":teamId")}
  13. if err := bus.Dispatch(&query); err != nil {
  14. return Error(500, "Failed to get Team Members", err)
  15. }
  16. for _, member := range query.Result {
  17. member.AvatarUrl = dtos.GetGravatarUrl(member.Email)
  18. member.Labels = []string{}
  19. if setting.IsEnterprise && member.External {
  20. authProvider := GetAuthProviderLabel(member.AuthModule)
  21. member.Labels = append(member.Labels, authProvider)
  22. }
  23. }
  24. return JSON(200, query.Result)
  25. }
  26. func GetAuthProviderLabel(authModule string) string {
  27. switch authModule {
  28. case "oauth_github":
  29. return "GitHub"
  30. case "oauth_google":
  31. return "Google"
  32. case "oauth_gitlab":
  33. return "GitLab"
  34. case "oauth_grafana_com", "oauth_grafananet":
  35. return "grafana.com"
  36. case "ldap", "":
  37. return "LDAP"
  38. default:
  39. return "OAuth"
  40. }
  41. }
  42. // POST /api/teams/:teamId/members
  43. func (hs *HTTPServer) AddTeamMember(c *m.ReqContext, cmd m.AddTeamMemberCommand) Response {
  44. cmd.OrgId = c.OrgId
  45. cmd.TeamId = c.ParamsInt64(":teamId")
  46. if err := teamguardian.CanAdmin(hs.Bus, cmd.OrgId, cmd.TeamId, c.SignedInUser); err != nil {
  47. return Error(403, "Not allowed to add team member", err)
  48. }
  49. if err := hs.Bus.Dispatch(&cmd); err != nil {
  50. if err == m.ErrTeamNotFound {
  51. return Error(404, "Team not found", nil)
  52. }
  53. if err == m.ErrTeamMemberAlreadyAdded {
  54. return Error(400, "User is already added to this team", nil)
  55. }
  56. return Error(500, "Failed to add Member to Team", err)
  57. }
  58. return JSON(200, &util.DynMap{
  59. "message": "Member added to Team",
  60. })
  61. }
  62. // PUT /:teamId/members/:userId
  63. func (hs *HTTPServer) UpdateTeamMember(c *m.ReqContext, cmd m.UpdateTeamMemberCommand) Response {
  64. teamId := c.ParamsInt64(":teamId")
  65. orgId := c.OrgId
  66. if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, c.SignedInUser); err != nil {
  67. return Error(403, "Not allowed to update team member", err)
  68. }
  69. if c.OrgRole != m.ROLE_ADMIN {
  70. cmd.ProtectLastAdmin = true
  71. }
  72. cmd.TeamId = teamId
  73. cmd.UserId = c.ParamsInt64(":userId")
  74. cmd.OrgId = orgId
  75. if err := hs.Bus.Dispatch(&cmd); err != nil {
  76. if err == m.ErrTeamMemberNotFound {
  77. return Error(404, "Team member not found.", nil)
  78. }
  79. return Error(500, "Failed to update team member.", err)
  80. }
  81. return Success("Team member updated")
  82. }
  83. // DELETE /api/teams/:teamId/members/:userId
  84. func (hs *HTTPServer) RemoveTeamMember(c *m.ReqContext) Response {
  85. orgId := c.OrgId
  86. teamId := c.ParamsInt64(":teamId")
  87. userId := c.ParamsInt64(":userId")
  88. if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, c.SignedInUser); err != nil {
  89. return Error(403, "Not allowed to remove team member", err)
  90. }
  91. protectLastAdmin := false
  92. if c.OrgRole != m.ROLE_ADMIN {
  93. protectLastAdmin = true
  94. }
  95. if err := hs.Bus.Dispatch(&m.RemoveTeamMemberCommand{OrgId: orgId, TeamId: teamId, UserId: userId, ProtectLastAdmin: protectLastAdmin}); err != nil {
  96. if err == m.ErrTeamNotFound {
  97. return Error(404, "Team not found", nil)
  98. }
  99. if err == m.ErrTeamMemberNotFound {
  100. return Error(404, "Team member not found", nil)
  101. }
  102. return Error(500, "Failed to remove Member from Team", err)
  103. }
  104. return Success("Team Member removed")
  105. }