summaryrefslogtreecommitdiffstats
path: root/api
diff options
context:
space:
mode:
authorChristopher Speller <crspeller@gmail.com>2016-07-26 12:39:35 -0400
committerGitHub <noreply@github.com>2016-07-26 12:39:35 -0400
commit528890dba01d6835754c78bf7695621c828b6838 (patch)
tree2870cab02f121a69021aa1e9f2cde1a7287f4d05 /api
parent00291c652ed7dba4649d50243bbde1633722d3df (diff)
downloadchat-528890dba01d6835754c78bf7695621c828b6838.tar.gz
chat-528890dba01d6835754c78bf7695621c828b6838.tar.bz2
chat-528890dba01d6835754c78bf7695621c828b6838.zip
Changing LDAP behavour so users disabled in LDAP server are disabled in Mattermost. (#3669)
Diffstat (limited to 'api')
-rw-r--r--api/user.go28
1 files changed, 17 insertions, 11 deletions
diff --git a/api/user.go b/api/user.go
index fa643007f..f9d982048 100644
--- a/api/user.go
+++ b/api/user.go
@@ -1608,14 +1608,21 @@ func updateActive(c *Context, w http.ResponseWriter, r *http.Request) {
return
}
- ruser := UpdateActive(c, user, active)
+ if user.IsLDAPUser() {
+ c.Err = model.NewLocAppError("updateActive", "api.user.update_active.no_deactivate_ldap.app_error", nil, "userId="+user_id)
+ c.Err.StatusCode = http.StatusBadRequest
+ return
+ }
- if c.Err == nil {
+ if ruser, err := UpdateActive(user, active); err != nil {
+ c.Err = err
+ } else {
+ c.LogAuditWithUserId(ruser.Id, fmt.Sprintf("active=%v", active))
w.Write([]byte(ruser.ToJson()))
}
}
-func UpdateActive(c *Context, user *model.User, active bool) *model.User {
+func UpdateActive(user *model.User, active bool) (*model.User, *model.AppError) {
if active {
user.DeleteAt = 0
} else {
@@ -1623,24 +1630,21 @@ func UpdateActive(c *Context, user *model.User, active bool) *model.User {
}
if result := <-Srv.Store.User().Update(user, true); result.Err != nil {
- c.Err = result.Err
- return nil
+ return nil, result.Err
} else {
- c.LogAuditWithUserId(user.Id, fmt.Sprintf("active=%v", active))
-
if user.DeleteAt > 0 {
- RevokeAllSession(c, user.Id)
+ RevokeAllSessionsNoContext(user.Id)
}
if extra := <-Srv.Store.Channel().ExtraUpdateByUser(user.Id, model.GetMillis()); extra.Err != nil {
- c.Err = extra.Err
+ return nil, extra.Err
}
ruser := result.Data.([2]*model.User)[0]
options := utils.Cfg.GetSanitizeOptions()
options["passwordupdate"] = false
ruser.Sanitize(options)
- return ruser
+ return ruser, nil
}
}
@@ -1653,7 +1657,9 @@ func PermanentDeleteUser(c *Context, user *model.User) *model.AppError {
l4g.Warn(utils.T("api.user.permanent_delete_user.system_admin.warn"), user.Email)
}
- UpdateActive(c, user, false)
+ if _, err := UpdateActive(user, false); err != nil {
+ return err
+ }
if result := <-Srv.Store.Session().PermanentDeleteSessionsByUser(user.Id); result.Err != nil {
return result.Err