team_members.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  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 && setting.LdapEnabled && member.External {
  20. member.Labels = append(member.Labels, "LDAP")
  21. }
  22. }
  23. return JSON(200, query.Result)
  24. }
  25. // POST /api/teams/:teamId/members
  26. func AddTeamMember(c *m.ReqContext, cmd m.AddTeamMemberCommand) Response {
  27. teamId := c.ParamsInt64(":teamId")
  28. orgId := c.OrgId
  29. if err := teamguardian.CanAdmin(orgId, teamId, c.SignedInUser); err != nil {
  30. return Error(403, "Not allowed to add team member", err)
  31. }
  32. cmd.TeamId = teamId
  33. cmd.OrgId = orgId
  34. if err := bus.Dispatch(&cmd); err != nil {
  35. if err == m.ErrTeamNotFound {
  36. return Error(404, "Team not found", nil)
  37. }
  38. if err == m.ErrTeamMemberAlreadyAdded {
  39. return Error(400, "User is already added to this team", nil)
  40. }
  41. return Error(500, "Failed to add Member to Team", err)
  42. }
  43. return JSON(200, &util.DynMap{
  44. "message": "Member added to Team",
  45. })
  46. }
  47. // PUT /:teamId/members/:userId
  48. func UpdateTeamMember(c *m.ReqContext, cmd m.UpdateTeamMemberCommand) Response {
  49. teamId := c.ParamsInt64(":teamId")
  50. orgId := c.OrgId
  51. if err := teamguardian.CanAdmin(orgId, teamId, c.SignedInUser); err != nil {
  52. return Error(403, "Not allowed to update team member", err)
  53. }
  54. if c.OrgRole != m.ROLE_ADMIN {
  55. cmd.ProtectLastAdmin = true
  56. }
  57. cmd.TeamId = teamId
  58. cmd.UserId = c.ParamsInt64(":userId")
  59. cmd.OrgId = orgId
  60. if err := bus.Dispatch(&cmd); err != nil {
  61. if err == m.ErrTeamMemberNotFound {
  62. return Error(404, "Team member not found.", nil)
  63. }
  64. return Error(500, "Failed to update team member.", err)
  65. }
  66. return Success("Team member updated")
  67. }
  68. // DELETE /api/teams/:teamId/members/:userId
  69. func (hs *HTTPServer) RemoveTeamMember(c *m.ReqContext) Response {
  70. orgId := c.OrgId
  71. teamId := c.ParamsInt64(":teamId")
  72. userId := c.ParamsInt64(":userId")
  73. if err := teamguardian.CanAdmin(orgId, teamId, c.SignedInUser); err != nil {
  74. return Error(403, "Not allowed to remove team member", err)
  75. }
  76. protectLastAdmin := false
  77. if c.OrgRole != m.ROLE_ADMIN {
  78. protectLastAdmin = true
  79. }
  80. if err := bus.Dispatch(&m.RemoveTeamMemberCommand{OrgId: orgId, TeamId: teamId, UserId: userId, ProtectLastAdmin: protectLastAdmin}); err != nil {
  81. if err == m.ErrTeamNotFound {
  82. return Error(404, "Team not found", nil)
  83. }
  84. if err == m.ErrTeamMemberNotFound {
  85. return Error(404, "Team member not found", nil)
  86. }
  87. return Error(500, "Failed to remove Member from Team", err)
  88. }
  89. return Success("Team Member removed")
  90. }