From fff0b2bd86f96967b25f8e634a580befef79c609 Mon Sep 17 00:00:00 2001 From: Saturnino Abril Date: Thu, 23 Feb 2017 08:55:31 +0900 Subject: APIv4: GET /teams/{team_id}/members (#5460) * APIv4: GET /teams/{team_id}/members * removed unecessary comment * changed route to session required, and logout test to unauthorized Signed-off-by: Saturnino Abril --- api4/team.go | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'api4/team.go') diff --git a/api4/team.go b/api4/team.go index ed096e058..db42dc6b6 100644 --- a/api4/team.go +++ b/api4/team.go @@ -20,6 +20,7 @@ func InitTeam() { BaseRoutes.Team.Handle("", ApiSessionRequired(getTeam)).Methods("GET") BaseRoutes.Team.Handle("/stats", ApiSessionRequired(getTeamStats)).Methods("GET") + BaseRoutes.Team.Handle("/members", ApiSessionRequired(getTeamMembers)).Methods("GET") BaseRoutes.TeamByName.Handle("", ApiSessionRequired(getTeamByName)).Methods("GET") BaseRoutes.TeamMember.Handle("", ApiSessionRequired(getTeamMember)).Methods("GET") @@ -122,6 +123,26 @@ func getTeamMember(c *Context, w http.ResponseWriter, r *http.Request) { } } +func getTeamMembers(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamId() + if c.Err != nil { + return + } + + if !app.SessionHasPermissionToTeam(c.Session, c.Params.TeamId, model.PERMISSION_VIEW_TEAM) { + c.SetPermissionError(model.PERMISSION_VIEW_TEAM) + return + } + + if members, err := app.GetTeamMembers(c.Params.TeamId, c.Params.Page, c.Params.PerPage); err != nil { + c.Err = err + return + } else { + w.Write([]byte(model.TeamMembersToJson(members))) + return + } +} + func getTeamStats(c *Context, w http.ResponseWriter, r *http.Request) { c.RequireTeamId() if c.Err != nil { -- cgit v1.2.3-1-g7c22