team.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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/util"
  8. )
  9. // POST /api/teams
  10. func (hs *HTTPServer) CreateTeam(c *m.ReqContext, cmd m.CreateTeamCommand) Response {
  11. cmd.OrgId = c.OrgId
  12. if c.OrgRole == m.ROLE_VIEWER {
  13. return Error(403, "Not allowed to create team.", nil)
  14. }
  15. if err := hs.Bus.Dispatch(&cmd); err != nil {
  16. if err == m.ErrTeamNameTaken {
  17. return Error(409, "Team name taken", err)
  18. }
  19. return Error(500, "Failed to create Team", err)
  20. }
  21. if c.OrgRole == m.ROLE_EDITOR && hs.Cfg.EditorsCanAdmin {
  22. addMemberCmd := m.AddTeamMemberCommand{
  23. UserId: c.SignedInUser.UserId,
  24. OrgId: cmd.OrgId,
  25. TeamId: cmd.Result.Id,
  26. Permission: m.PERMISSION_ADMIN,
  27. }
  28. if err := hs.Bus.Dispatch(&addMemberCmd); err != nil {
  29. c.Logger.Error("Could not add creator to team.", "error", err)
  30. }
  31. }
  32. return JSON(200, &util.DynMap{
  33. "teamId": cmd.Result.Id,
  34. "message": "Team created",
  35. })
  36. }
  37. // PUT /api/teams/:teamId
  38. func (hs *HTTPServer) UpdateTeam(c *m.ReqContext, cmd m.UpdateTeamCommand) Response {
  39. cmd.OrgId = c.OrgId
  40. cmd.Id = c.ParamsInt64(":teamId")
  41. if err := teamguardian.CanAdmin(hs.Bus, cmd.OrgId, cmd.Id, c.SignedInUser); err != nil {
  42. return Error(403, "Not allowed to update team", err)
  43. }
  44. if err := hs.Bus.Dispatch(&cmd); err != nil {
  45. if err == m.ErrTeamNameTaken {
  46. return Error(400, "Team name taken", err)
  47. }
  48. return Error(500, "Failed to update Team", err)
  49. }
  50. return Success("Team updated")
  51. }
  52. // DELETE /api/teams/:teamId
  53. func (hs *HTTPServer) DeleteTeamByID(c *m.ReqContext) Response {
  54. orgId := c.OrgId
  55. teamId := c.ParamsInt64(":teamId")
  56. user := c.SignedInUser
  57. if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, user); err != nil {
  58. return Error(403, "Not allowed to delete team", err)
  59. }
  60. if err := hs.Bus.Dispatch(&m.DeleteTeamCommand{OrgId: orgId, Id: teamId}); err != nil {
  61. if err == m.ErrTeamNotFound {
  62. return Error(404, "Failed to delete Team. ID not found", nil)
  63. }
  64. return Error(500, "Failed to delete Team", err)
  65. }
  66. return Success("Team deleted")
  67. }
  68. // GET /api/teams/search
  69. func (hs *HTTPServer) SearchTeams(c *m.ReqContext) Response {
  70. perPage := c.QueryInt("perpage")
  71. if perPage <= 0 {
  72. perPage = 1000
  73. }
  74. page := c.QueryInt("page")
  75. if page < 1 {
  76. page = 1
  77. }
  78. var userIdFilter int64
  79. if hs.Cfg.EditorsCanAdmin && c.OrgRole != m.ROLE_ADMIN {
  80. userIdFilter = c.SignedInUser.UserId
  81. }
  82. query := m.SearchTeamsQuery{
  83. OrgId: c.OrgId,
  84. Query: c.Query("query"),
  85. Name: c.Query("name"),
  86. UserIdFilter: userIdFilter,
  87. Page: page,
  88. Limit: perPage,
  89. }
  90. if err := bus.Dispatch(&query); err != nil {
  91. return Error(500, "Failed to search Teams", err)
  92. }
  93. for _, team := range query.Result.Teams {
  94. team.AvatarUrl = dtos.GetGravatarUrlWithDefault(team.Email, team.Name)
  95. }
  96. query.Result.Page = page
  97. query.Result.PerPage = perPage
  98. return JSON(200, query.Result)
  99. }
  100. // GET /api/teams/:teamId
  101. func GetTeamByID(c *m.ReqContext) Response {
  102. query := m.GetTeamByIdQuery{OrgId: c.OrgId, Id: c.ParamsInt64(":teamId")}
  103. if err := bus.Dispatch(&query); err != nil {
  104. if err == m.ErrTeamNotFound {
  105. return Error(404, "Team not found", err)
  106. }
  107. return Error(500, "Failed to get Team", err)
  108. }
  109. query.Result.AvatarUrl = dtos.GetGravatarUrlWithDefault(query.Result.Email, query.Result.Name)
  110. return JSON(200, &query.Result)
  111. }
  112. // GET /api/teams/:teamId/preferences
  113. func (hs *HTTPServer) GetTeamPreferences(c *m.ReqContext) Response {
  114. teamId := c.ParamsInt64(":teamId")
  115. orgId := c.OrgId
  116. if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, c.SignedInUser); err != nil {
  117. return Error(403, "Not allowed to view team preferences.", err)
  118. }
  119. return getPreferencesFor(orgId, 0, teamId)
  120. }
  121. // PUT /api/teams/:teamId/preferences
  122. func (hs *HTTPServer) UpdateTeamPreferences(c *m.ReqContext, dtoCmd dtos.UpdatePrefsCmd) Response {
  123. teamId := c.ParamsInt64(":teamId")
  124. orgId := c.OrgId
  125. if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, c.SignedInUser); err != nil {
  126. return Error(403, "Not allowed to update team preferences.", err)
  127. }
  128. return updatePreferencesFor(orgId, 0, teamId, &dtoCmd)
  129. }