From 19ec4c42989df53279a1e7fe8dc997244ffbb20c Mon Sep 17 00:00:00 2001 From: Carlos Tadeu Panato Junior Date: Wed, 8 Mar 2017 01:30:33 +0100 Subject: add team exists endpoint for APIv4 (#5517) --- api4/team.go | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'api4/team.go') diff --git a/api4/team.go b/api4/team.go index c88c553fb..40f41aaab 100644 --- a/api4/team.go +++ b/api4/team.go @@ -26,6 +26,7 @@ func InitTeam() { BaseRoutes.TeamByName.Handle("", ApiSessionRequired(getTeamByName)).Methods("GET") BaseRoutes.TeamMember.Handle("", ApiSessionRequired(getTeamMember)).Methods("GET") + BaseRoutes.TeamByName.Handle("/exists", ApiSessionRequired(teamExists)).Methods("GET") BaseRoutes.TeamMember.Handle("/roles", ApiSessionRequired(updateTeamMemberRoles)).Methods("PUT") } @@ -72,6 +73,11 @@ func getTeam(c *Context, w http.ResponseWriter, r *http.Request) { } func getTeamByName(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamName() + if c.Err != nil { + return + } + if team, err := app.GetTeamByName(c.Params.TeamName); err != nil { c.Err = err return @@ -232,3 +238,21 @@ func getAllTeams(c *Context, w http.ResponseWriter, r *http.Request) { w.Write([]byte(model.TeamListToJson(teams))) } + +func teamExists(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamName() + if c.Err != nil { + return + } + + resp := make(map[string]bool) + + if _, err := app.GetTeamByName(c.Params.TeamName); err != nil { + resp["exists"] = false + } else { + resp["exists"] = true + } + + w.Write([]byte(model.MapBoolToJson(resp))) + return +} -- cgit v1.2.3-1-g7c22