| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- package api
- import (
- "github.com/grafana/grafana/pkg/api/dtos"
- "github.com/grafana/grafana/pkg/bus"
- m "github.com/grafana/grafana/pkg/models"
- "github.com/grafana/grafana/pkg/services/teamguardian"
- "github.com/grafana/grafana/pkg/util"
- )
- // POST /api/teams
- func (hs *HTTPServer) CreateTeam(c *m.ReqContext, cmd m.CreateTeamCommand) Response {
- cmd.OrgId = c.OrgId
- if c.OrgRole == m.ROLE_VIEWER {
- return Error(403, "Not allowed to create team.", nil)
- }
- if err := hs.Bus.Dispatch(&cmd); err != nil {
- if err == m.ErrTeamNameTaken {
- return Error(409, "Team name taken", err)
- }
- return Error(500, "Failed to create Team", err)
- }
- if c.OrgRole == m.ROLE_EDITOR && hs.Cfg.EditorsCanAdmin {
- addMemberCmd := m.AddTeamMemberCommand{
- UserId: c.SignedInUser.UserId,
- OrgId: cmd.OrgId,
- TeamId: cmd.Result.Id,
- Permission: m.PERMISSION_ADMIN,
- }
- if err := hs.Bus.Dispatch(&addMemberCmd); err != nil {
- c.Logger.Error("Could not add creator to team.", "error", err)
- }
- }
- return JSON(200, &util.DynMap{
- "teamId": cmd.Result.Id,
- "message": "Team created",
- })
- }
- // PUT /api/teams/:teamId
- func (hs *HTTPServer) UpdateTeam(c *m.ReqContext, cmd m.UpdateTeamCommand) Response {
- cmd.OrgId = c.OrgId
- cmd.Id = c.ParamsInt64(":teamId")
- if err := teamguardian.CanAdmin(hs.Bus, cmd.OrgId, cmd.Id, c.SignedInUser); err != nil {
- return Error(403, "Not allowed to update team", err)
- }
- if err := hs.Bus.Dispatch(&cmd); err != nil {
- if err == m.ErrTeamNameTaken {
- return Error(400, "Team name taken", err)
- }
- return Error(500, "Failed to update Team", err)
- }
- return Success("Team updated")
- }
- // DELETE /api/teams/:teamId
- func (hs *HTTPServer) DeleteTeamByID(c *m.ReqContext) Response {
- orgId := c.OrgId
- teamId := c.ParamsInt64(":teamId")
- user := c.SignedInUser
- if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, user); err != nil {
- return Error(403, "Not allowed to delete team", err)
- }
- if err := hs.Bus.Dispatch(&m.DeleteTeamCommand{OrgId: orgId, Id: teamId}); err != nil {
- if err == m.ErrTeamNotFound {
- return Error(404, "Failed to delete Team. ID not found", nil)
- }
- return Error(500, "Failed to delete Team", err)
- }
- return Success("Team deleted")
- }
- // GET /api/teams/search
- func (hs *HTTPServer) SearchTeams(c *m.ReqContext) Response {
- perPage := c.QueryInt("perpage")
- if perPage <= 0 {
- perPage = 1000
- }
- page := c.QueryInt("page")
- if page < 1 {
- page = 1
- }
- var userIdFilter int64
- if hs.Cfg.EditorsCanAdmin && c.OrgRole != m.ROLE_ADMIN {
- userIdFilter = c.SignedInUser.UserId
- }
- query := m.SearchTeamsQuery{
- OrgId: c.OrgId,
- Query: c.Query("query"),
- Name: c.Query("name"),
- UserIdFilter: userIdFilter,
- Page: page,
- Limit: perPage,
- }
- if err := bus.Dispatch(&query); err != nil {
- return Error(500, "Failed to search Teams", err)
- }
- for _, team := range query.Result.Teams {
- team.AvatarUrl = dtos.GetGravatarUrlWithDefault(team.Email, team.Name)
- }
- query.Result.Page = page
- query.Result.PerPage = perPage
- return JSON(200, query.Result)
- }
- // GET /api/teams/:teamId
- func GetTeamByID(c *m.ReqContext) Response {
- query := m.GetTeamByIdQuery{OrgId: c.OrgId, Id: c.ParamsInt64(":teamId")}
- if err := bus.Dispatch(&query); err != nil {
- if err == m.ErrTeamNotFound {
- return Error(404, "Team not found", err)
- }
- return Error(500, "Failed to get Team", err)
- }
- query.Result.AvatarUrl = dtos.GetGravatarUrlWithDefault(query.Result.Email, query.Result.Name)
- return JSON(200, &query.Result)
- }
- // GET /api/teams/:teamId/preferences
- func (hs *HTTPServer) GetTeamPreferences(c *m.ReqContext) Response {
- teamId := c.ParamsInt64(":teamId")
- orgId := c.OrgId
- if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, c.SignedInUser); err != nil {
- return Error(403, "Not allowed to view team preferences.", err)
- }
- return getPreferencesFor(orgId, 0, teamId)
- }
- // PUT /api/teams/:teamId/preferences
- func (hs *HTTPServer) UpdateTeamPreferences(c *m.ReqContext, dtoCmd dtos.UpdatePrefsCmd) Response {
- teamId := c.ParamsInt64(":teamId")
- orgId := c.OrgId
- if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, c.SignedInUser); err != nil {
- return Error(403, "Not allowed to update team preferences.", err)
- }
- return updatePreferencesFor(orgId, 0, teamId, &dtoCmd)
- }
|