2017-04-09 18:24:16 -05:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
2017-12-20 14:20:12 -06:00
|
|
|
"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"
|
2019-03-12 07:59:53 -05:00
|
|
|
"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
|
2019-03-06 04:47:18 -06:00
|
|
|
func (hs *HTTPServer) CreateTeam(c *m.ReqContext, cmd m.CreateTeamCommand) Response {
|
2017-04-09 18:24:16 -05:00
|
|
|
cmd.OrgId = c.OrgId
|
2019-03-13 04:38:09 -05:00
|
|
|
|
|
|
|
if c.OrgRole == m.ROLE_VIEWER {
|
|
|
|
return Error(403, "Not allowed to create team.", nil)
|
|
|
|
}
|
|
|
|
|
2019-03-14 06:18:07 -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(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 {
|
2019-03-06 04:47:18 -06:00
|
|
|
addMemberCmd := m.AddTeamMemberCommand{
|
|
|
|
UserId: c.SignedInUser.UserId,
|
|
|
|
OrgId: cmd.OrgId,
|
|
|
|
TeamId: cmd.Result.Id,
|
2019-03-12 11:24:18 -05:00
|
|
|
Permission: m.PERMISSION_ADMIN,
|
2019-03-06 04:47:18 -06:00
|
|
|
}
|
2019-03-08 04:56:48 -06:00
|
|
|
|
2019-03-14 06:18:07 -05:00
|
|
|
if err := hs.Bus.Dispatch(&addMemberCmd); err != nil {
|
2019-03-08 04:56:48 -06:00
|
|
|
c.Logger.Error("Could not add creator to team.", "error", err)
|
|
|
|
}
|
2019-03-06 04:47:18 -06:00
|
|
|
}
|
|
|
|
|
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
|
2019-03-14 06:10:10 -05:00
|
|
|
func (hs *HTTPServer) UpdateTeam(c *m.ReqContext, cmd m.UpdateTeamCommand) Response {
|
2018-02-09 10:26:15 -06:00
|
|
|
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
|
|
|
|
2019-03-14 06:10:10 -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
|
|
|
}
|
|
|
|
|
2019-03-14 06:10:10 -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
|
2019-03-14 06:10:10 -05:00
|
|
|
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
|
|
|
|
|
2019-03-14 06:10:10 -05:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
|
2019-03-14 06:10:10 -05:00
|
|
|
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
|
2019-03-13 08:05:08 -05:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2019-03-11 08:40:57 -05:00
|
|
|
var userIdFilter int64
|
2019-03-13 08:05:08 -05:00
|
|
|
if hs.Cfg.EditorsCanAdmin && c.OrgRole != m.ROLE_ADMIN {
|
2019-03-11 08:40:57 -05:00
|
|
|
userIdFilter = c.SignedInUser.UserId
|
|
|
|
}
|
|
|
|
|
2017-12-08 09:25:45 -06:00
|
|
|
query := m.SearchTeamsQuery{
|
2019-03-11 08:40:57 -05:00
|
|
|
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
|
|
|
}
|
|
|
|
|
2017-12-20 14:20:12 -06: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 {
|
2018-02-09 10:26:15 -06:00
|
|
|
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
|
|
|
}
|
|
|
|
|
2018-07-11 13:23:07 -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
|
2019-03-14 06:10:10 -05:00
|
|
|
func (hs *HTTPServer) GetTeamPreferences(c *m.ReqContext) Response {
|
2019-03-12 07:59:53 -05:00
|
|
|
teamId := c.ParamsInt64(":teamId")
|
|
|
|
orgId := c.OrgId
|
|
|
|
|
2019-03-14 06:10:10 -05:00
|
|
|
if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, c.SignedInUser); err != nil {
|
2019-03-12 07:59:53 -05:00
|
|
|
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
|
2019-03-14 06:10:10 -05:00
|
|
|
func (hs *HTTPServer) UpdateTeamPreferences(c *m.ReqContext, dtoCmd dtos.UpdatePrefsCmd) Response {
|
2019-03-11 07:14:06 -05:00
|
|
|
teamId := c.ParamsInt64(":teamId")
|
|
|
|
orgId := c.OrgId
|
|
|
|
|
2019-03-14 06:10:10 -05:00
|
|
|
if err := teamguardian.CanAdmin(hs.Bus, orgId, teamId, c.SignedInUser); err != nil {
|
2019-03-11 07:14:06 -05:00
|
|
|
return Error(403, "Not allowed to update team preferences.", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return updatePreferencesFor(orgId, 0, teamId, &dtoCmd)
|
2018-11-12 13:01:53 -06:00
|
|
|
}
|