grafana/pkg/api/team.go

161 lines
4.2 KiB
Go
Raw Normal View History

2017-04-09 18:24:16 -05:00
package api
import (
"github.com/grafana/grafana/pkg/api/dtos"
2017-04-09 18:24:16 -05:00
"github.com/grafana/grafana/pkg/bus"
m "github.com/grafana/grafana/pkg/models"
"github.com/grafana/grafana/pkg/services/teamguardian"
2017-04-09 18:24:16 -05:00
"github.com/grafana/grafana/pkg/util"
)
2017-12-08 09:25:45 -06:00
// POST /api/teams
func (hs *HTTPServer) CreateTeam(c *m.ReqContext, cmd m.CreateTeamCommand) Response {
2017-04-09 18:24:16 -05:00
cmd.OrgId = c.OrgId
if c.OrgRole == m.ROLE_VIEWER {
return Error(403, "Not allowed to create team.", nil)
}
2017-04-09 18:24:16 -05:00
if err := bus.Dispatch(&cmd); err != nil {
2017-12-08 09:25:45 -06:00
if err == m.ErrTeamNameTaken {
2018-03-22 16:13:46 -05:00
return Error(409, "Team name taken", err)
2017-04-09 18:24:16 -05:00
}
2018-03-22 16:13:46 -05:00
return Error(500, "Failed to create Team", err)
2017-04-09 18:24:16 -05:00
}
2019-03-12 01:32:47 -05:00
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 := bus.Dispatch(&addMemberCmd); err != nil {
c.Logger.Error("Could not add creator to team.", "error", err)
}
}
2018-03-22 16:13:46 -05:00
return JSON(200, &util.DynMap{
2017-12-08 09:25:45 -06:00
"teamId": cmd.Result.Id,
"message": "Team created",
2017-04-09 18:24:16 -05:00
})
}
2017-12-08 09:25:45 -06:00
// PUT /api/teams/:teamId
func (hs *HTTPServer) UpdateTeam(c *m.ReqContext, cmd m.UpdateTeamCommand) Response {
cmd.OrgId = c.OrgId
2017-12-08 09:25:45 -06:00
cmd.Id = c.ParamsInt64(":teamId")
2019-03-11 05:26:01 -05:00
if err := teamguardian.CanAdmin(hs.Bus, cmd.OrgId, cmd.Id, c.SignedInUser); err != nil {
2019-03-11 06:03:15 -05:00
return Error(403, "Not allowed to update team", err)
2019-03-11 05:26:01 -05:00
}
if err := hs.Bus.Dispatch(&cmd); err != nil {
2017-12-08 09:25:45 -06:00
if err == m.ErrTeamNameTaken {
2018-03-22 16:13:46 -05:00
return Error(400, "Team name taken", err)
2017-04-18 08:01:05 -05:00
}
2018-03-22 16:13:46 -05:00
return Error(500, "Failed to update Team", err)
2017-04-18 08:01:05 -05:00
}
2018-03-22 16:13:46 -05:00
return Success("Team updated")
2017-04-18 08:01:05 -05:00
}
2017-12-08 09:25:45 -06:00
// DELETE /api/teams/:teamId
func (hs *HTTPServer) DeleteTeamByID(c *m.ReqContext) Response {
2019-03-11 06:03:15 -05:00
orgId := c.OrgId
teamId := c.ParamsInt64(":teamId")
user := c.SignedInUser
if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, user); err != nil {
2019-03-11 06:03:15 -05:00
return Error(403, "Not allowed to delete team", err)
}
if err := hs.Bus.Dispatch(&m.DeleteTeamCommand{OrgId: orgId, Id: teamId}); err != nil {
2017-12-08 09:25:45 -06:00
if err == m.ErrTeamNotFound {
2018-03-22 16:13:46 -05:00
return Error(404, "Failed to delete Team. ID not found", nil)
2017-04-09 18:24:16 -05:00
}
2019-03-11 06:03:15 -05:00
return Error(500, "Failed to delete Team", err)
2017-04-09 18:24:16 -05:00
}
2018-03-22 16:13:46 -05:00
return Success("Team deleted")
2017-04-09 18:24:16 -05:00
}
2017-12-08 09:25:45 -06:00
// GET /api/teams/search
func (hs *HTTPServer) SearchTeams(c *m.ReqContext) Response {
2017-04-09 18:24:16 -05:00
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
}
2017-12-08 09:25:45 -06:00
query := m.SearchTeamsQuery{
OrgId: c.OrgId,
Query: c.Query("query"),
Name: c.Query("name"),
UserIdFilter: userIdFilter,
Page: page,
Limit: perPage,
2017-04-09 18:24:16 -05:00
}
if err := bus.Dispatch(&query); err != nil {
2018-03-22 16:13:46 -05:00
return Error(500, "Failed to search Teams", err)
2017-04-09 18:24:16 -05:00
}
for _, team := range query.Result.Teams {
team.AvatarUrl = dtos.GetGravatarUrlWithDefault(team.Email, team.Name)
}
2017-04-09 18:24:16 -05:00
query.Result.Page = page
query.Result.PerPage = perPage
2018-03-22 16:13:46 -05:00
return JSON(200, query.Result)
2017-04-09 18:24:16 -05:00
}
2017-04-18 08:01:05 -05:00
2017-12-08 09:25:45 -06:00
// GET /api/teams/:teamId
2018-03-22 06:37:35 -05:00
func GetTeamByID(c *m.ReqContext) Response {
query := m.GetTeamByIdQuery{OrgId: c.OrgId, Id: c.ParamsInt64(":teamId")}
2017-04-18 08:01:05 -05:00
if err := bus.Dispatch(&query); err != nil {
2017-12-08 09:25:45 -06:00
if err == m.ErrTeamNotFound {
2018-03-22 16:13:46 -05:00
return Error(404, "Team not found", err)
2017-04-18 08:01:05 -05:00
}
2018-03-22 16:13:46 -05:00
return Error(500, "Failed to get Team", err)
2017-04-18 08:01:05 -05:00
}
query.Result.AvatarUrl = dtos.GetGravatarUrlWithDefault(query.Result.Email, query.Result.Name)
2018-03-22 16:13:46 -05:00
return JSON(200, &query.Result)
2017-04-18 08:01:05 -05:00
}
2018-11-12 13:01:53 -06:00
// 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)
2018-11-12 13:01:53 -06:00
}
// 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)
2018-11-12 13:01:53 -06:00
}