summaryrefslogtreecommitdiffstats
path: root/api4
diff options
context:
space:
mode:
authorCarlos Tadeu Panato Junior <ctadeu@gmail.com>2017-04-03 18:40:45 +0200
committerGeorge Goldberg <george@gberg.me>2017-04-03 17:40:45 +0100
commitda5265681d42549ad9072d762fec67293d742d43 (patch)
tree9fa01f92fde5a5de1131d41d371fb337e02f6965 /api4
parent7eb09dbffdd87f36eff0d781eaeb0e816bbdac21 (diff)
downloadchat-da5265681d42549ad9072d762fec67293d742d43.tar.gz
chat-da5265681d42549ad9072d762fec67293d742d43.tar.bz2
chat-da5265681d42549ad9072d762fec67293d742d43.zip
[APIV4] Implement PUT /users/{user_id}/status for apiV4 (#5928)
Diffstat (limited to 'api4')
-rw-r--r--api4/status.go34
-rw-r--r--api4/status_test.go38
2 files changed, 71 insertions, 1 deletions
diff --git a/api4/status.go b/api4/status.go
index 142f5ce5a..46d4f963b 100644
--- a/api4/status.go
+++ b/api4/status.go
@@ -18,7 +18,7 @@ func InitStatus() {
BaseRoutes.User.Handle("/status", ApiHandler(getUserStatus)).Methods("GET")
BaseRoutes.Users.Handle("/status/ids", ApiHandler(getUserStatusesByIds)).Methods("POST")
-
+ BaseRoutes.User.Handle("/status", ApiHandler(updateUserStatus)).Methods("PUT")
}
func getUserStatus(c *Context, w http.ResponseWriter, r *http.Request) {
@@ -59,3 +59,35 @@ func getUserStatusesByIds(c *Context, w http.ResponseWriter, r *http.Request) {
w.Write([]byte(model.StatusListToJson(statusMap)))
}
}
+
+func updateUserStatus(c *Context, w http.ResponseWriter, r *http.Request) {
+ c.RequireUserId()
+ if c.Err != nil {
+ return
+ }
+
+ status := model.StatusFromJson(r.Body)
+ if status == nil {
+ c.SetInvalidParam("status")
+ return
+ }
+
+ if !app.SessionHasPermissionToUser(c.Session, c.Params.UserId) {
+ c.SetPermissionError(model.PERMISSION_EDIT_OTHER_USERS)
+ return
+ }
+
+ switch status.Status {
+ case "online":
+ app.SetStatusOnline(c.Params.UserId, "", true)
+ case "offline":
+ app.SetStatusOffline(c.Params.UserId, true)
+ case "away":
+ app.SetStatusAwayIfNeeded(c.Params.UserId, true)
+ default:
+ c.SetInvalidParam("status")
+ return
+ }
+
+ getUserStatus(c, w, r)
+}
diff --git a/api4/status_test.go b/api4/status_test.go
index 35bf62379..c8277b3de 100644
--- a/api4/status_test.go
+++ b/api4/status_test.go
@@ -4,6 +4,7 @@ import (
"testing"
"github.com/mattermost/platform/app"
+ "github.com/mattermost/platform/model"
)
func TestGetUserStatus(t *testing.T) {
@@ -89,3 +90,40 @@ func TestGetUsersStatusesByIds(t *testing.T) {
}
}
}
+
+func TestUpdateUserStatus(t *testing.T) {
+ th := Setup().InitBasic().InitSystemAdmin()
+ defer TearDown()
+ Client := th.Client
+
+ toUpdateUserStatus := &model.Status{Status: "online"}
+ updateUserStatus, resp := Client.UpdateUserStatus(th.BasicUser.Id, toUpdateUserStatus)
+ CheckNoError(t, resp)
+ if updateUserStatus.Status != "online" {
+ t.Fatal("Should return online status")
+ }
+
+ toUpdateUserStatus.Status = "away"
+ updateUserStatus, resp = Client.UpdateUserStatus(th.BasicUser.Id, toUpdateUserStatus)
+ CheckNoError(t, resp)
+ if updateUserStatus.Status != "away" {
+ t.Fatal("Should return away status")
+ }
+
+ toUpdateUserStatus.Status = "offline"
+ updateUserStatus, resp = Client.UpdateUserStatus(th.BasicUser.Id, toUpdateUserStatus)
+ CheckNoError(t, resp)
+ if updateUserStatus.Status != "offline" {
+ t.Fatal("Should return offline status")
+ }
+
+ toUpdateUserStatus.Status = "online"
+ updateUserStatus, resp = Client.UpdateUserStatus(th.BasicUser2.Id, toUpdateUserStatus)
+ CheckForbiddenStatus(t, resp)
+
+ toUpdateUserStatus.Status = "online"
+ updateUserStatus, resp = th.SystemAdminClient.UpdateUserStatus(th.BasicUser2.Id, toUpdateUserStatus)
+ if updateUserStatus.Status != "online" {
+ t.Fatal("Should return online status")
+ }
+}