From 29e6db5713c57d7bb46d7aea38b1001b9e8a1212 Mon Sep 17 00:00:00 2001 From: Carlos Tadeu Panato Junior Date: Thu, 30 Mar 2017 17:09:39 +0200 Subject: Implement POST /users/status/ids for apiv4 (#5894) --- api4/status.go | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'api4/status.go') diff --git a/api4/status.go b/api4/status.go index 5cd6a4536..142f5ce5a 100644 --- a/api4/status.go +++ b/api4/status.go @@ -17,6 +17,7 @@ func InitStatus() { l4g.Debug(utils.T("api.status.init.debug")) BaseRoutes.User.Handle("/status", ApiHandler(getUserStatus)).Methods("GET") + BaseRoutes.Users.Handle("/status/ids", ApiHandler(getUserStatusesByIds)).Methods("POST") } @@ -26,6 +27,8 @@ func getUserStatus(c *Context, w http.ResponseWriter, r *http.Request) { return } + // No permission check required + if statusMap, err := app.GetUserStatusesByIds([]string{c.Params.UserId}); err != nil { c.Err = err return @@ -38,3 +41,21 @@ func getUserStatus(c *Context, w http.ResponseWriter, r *http.Request) { } } } + +func getUserStatusesByIds(c *Context, w http.ResponseWriter, r *http.Request) { + userIds := model.ArrayFromJson(r.Body) + + if len(userIds) == 0 { + c.SetInvalidParam("user_ids") + return + } + + // No permission check required + + if statusMap, err := app.GetUserStatusesByIds(userIds); err != nil { + c.Err = err + return + } else { + w.Write([]byte(model.StatusListToJson(statusMap))) + } +} -- cgit v1.2.3-1-g7c22