From 997eacd4b635a2a7a86eadeeb2b229f153c52626 Mon Sep 17 00:00:00 2001 From: Saturnino Abril Date: Tue, 4 Apr 2017 02:35:29 +0900 Subject: APIv4 DELETE /teams/{team_id} (#5937) --- 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 d71ccbf2e..6ea989a9b 100644 --- a/api4/team.go +++ b/api4/team.go @@ -26,6 +26,7 @@ func InitTeam() { BaseRoutes.Team.Handle("", ApiSessionRequired(getTeam)).Methods("GET") BaseRoutes.Team.Handle("", ApiSessionRequired(updateTeam)).Methods("PUT") + BaseRoutes.Team.Handle("", ApiSessionRequired(softDeleteTeam)).Methods("DELETE") BaseRoutes.Team.Handle("/patch", ApiSessionRequired(patchTeam)).Methods("PUT") BaseRoutes.Team.Handle("/stats", ApiSessionRequired(getTeamStats)).Methods("GET") BaseRoutes.TeamMembers.Handle("", ApiSessionRequired(getTeamMembers)).Methods("GET") @@ -165,6 +166,26 @@ func patchTeam(c *Context, w http.ResponseWriter, r *http.Request) { w.Write([]byte(patchedTeam.ToJson())) } +func softDeleteTeam(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_MANAGE_TEAM) { + c.SetPermissionError(model.PERMISSION_MANAGE_TEAM) + return + } + + err := app.SoftDeleteTeam(c.Params.TeamId) + if err != nil { + c.Err = err + return + } + + ReturnStatusOK(w) +} + func getTeamsForUser(c *Context, w http.ResponseWriter, r *http.Request) { c.RequireUserId() if c.Err != nil { -- cgit v1.2.3-1-g7c22