diff options
author | Joram Wilander <jwawilander@gmail.com> | 2017-03-13 09:46:28 -0400 |
---|---|---|
committer | Christopher Speller <crspeller@gmail.com> | 2017-03-13 09:46:28 -0400 |
commit | a284cd8c1817bb5419cb9eae118c85cd7e99c039 (patch) | |
tree | 71fd6ace54692477acea746f47b3266514ae9292 /api4/team.go | |
parent | 5ec49c0db03d4ec6fd36619055f99c9a3bb34148 (diff) | |
download | chat-a284cd8c1817bb5419cb9eae118c85cd7e99c039.tar.gz chat-a284cd8c1817bb5419cb9eae118c85cd7e99c039.tar.bz2 chat-a284cd8c1817bb5419cb9eae118c85cd7e99c039.zip |
Implement some team endpoints for APIv4 (#5745)
* Implement PUT /teams/{team_id} endpoint for APIv4
* Implement GET /users/{user_id}/teams/{team_id}/unread endpoint for APIv4
* Implement POST /teams/{team_id}/members/ids endpoint for APIv4
* Remove debug statement
Diffstat (limited to 'api4/team.go')
-rw-r--r-- | api4/team.go | 88 |
1 files changed, 87 insertions, 1 deletions
diff --git a/api4/team.go b/api4/team.go index 40f41aaab..ed4929326 100644 --- a/api4/team.go +++ b/api4/team.go @@ -21,8 +21,12 @@ func InitTeam() { BaseRoutes.TeamsForUser.Handle("/unread", ApiSessionRequired(getTeamsUnreadForUser)).Methods("GET") BaseRoutes.Team.Handle("", ApiSessionRequired(getTeam)).Methods("GET") + BaseRoutes.Team.Handle("", ApiSessionRequired(updateTeam)).Methods("PUT") BaseRoutes.Team.Handle("/stats", ApiSessionRequired(getTeamStats)).Methods("GET") - BaseRoutes.Team.Handle("/members", ApiSessionRequired(getTeamMembers)).Methods("GET") + BaseRoutes.TeamMembers.Handle("", ApiSessionRequired(getTeamMembers)).Methods("GET") + BaseRoutes.TeamMembers.Handle("/ids", ApiSessionRequired(getTeamMembersByIds)).Methods("POST") + + BaseRoutes.TeamForUser.Handle("/unread", ApiSessionRequired(getTeamUnread)).Methods("GET") BaseRoutes.TeamByName.Handle("", ApiSessionRequired(getTeamByName)).Methods("GET") BaseRoutes.TeamMember.Handle("", ApiSessionRequired(getTeamMember)).Methods("GET") @@ -92,6 +96,36 @@ func getTeamByName(c *Context, w http.ResponseWriter, r *http.Request) { } } +func updateTeam(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamId() + if c.Err != nil { + return + } + + team := model.TeamFromJson(r.Body) + + if team == nil { + c.SetInvalidParam("team") + return + } + + team.Id = c.Params.TeamId + + if !app.SessionHasPermissionToTeam(c.Session, c.Params.TeamId, model.PERMISSION_MANAGE_TEAM) { + c.SetPermissionError(model.PERMISSION_MANAGE_TEAM) + return + } + + updatedTeam, err := app.UpdateTeam(team) + + if err != nil { + c.Err = err + return + } + + w.Write([]byte(updatedTeam.ToJson())) +} + func getTeamsForUser(c *Context, w http.ResponseWriter, r *http.Request) { c.RequireUserId() if c.Err != nil { @@ -174,6 +208,58 @@ func getTeamMembers(c *Context, w http.ResponseWriter, r *http.Request) { } } +func getTeamMembersByIds(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamId() + if c.Err != nil { + return + } + + userIds := model.ArrayFromJson(r.Body) + + if len(userIds) == 0 { + c.SetInvalidParam("user_ids") + return + } + + if !app.SessionHasPermissionToTeam(c.Session, c.Params.TeamId, model.PERMISSION_VIEW_TEAM) { + c.SetPermissionError(model.PERMISSION_VIEW_TEAM) + return + } + + members, err := app.GetTeamMembersByIds(c.Params.TeamId, userIds) + if err != nil { + c.Err = err + return + } + + w.Write([]byte(model.TeamMembersToJson(members))) +} + +func getTeamUnread(c *Context, w http.ResponseWriter, r *http.Request) { + c.RequireTeamId().RequireUserId() + if c.Err != nil { + return + } + + if !app.SessionHasPermissionToUser(c.Session, c.Params.UserId) { + c.SetPermissionError(model.PERMISSION_EDIT_OTHER_USERS) + return + } + + if !app.SessionHasPermissionToTeam(c.Session, c.Params.TeamId, model.PERMISSION_VIEW_TEAM) { + c.SetPermissionError(model.PERMISSION_VIEW_TEAM) + return + } + + unreadTeam, err := app.GetTeamUnread(c.Params.TeamId, c.Params.UserId) + if err != nil { + c.Err = err + return + } + + w.Write([]byte(unreadTeam.ToJson())) +} + func getTeamStats(c *Context, w http.ResponseWriter, r *http.Request) { c.RequireTeamId() if c.Err != nil { |