diff options
author | Carlos Tadeu Panato Junior <ctadeu@gmail.com> | 2018-05-28 16:20:08 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-28 16:20:08 +0200 |
commit | c3e9c414408a8c9c2806af12e659e395c605496f (patch) | |
tree | 26510a3576d891c01e1bd4a7595f24f50332ee21 /api4/user.go | |
parent | b6d5cc4f696b7438317948710efb860e11c0a1a9 (diff) | |
download | chat-c3e9c414408a8c9c2806af12e659e395c605496f.tar.gz chat-c3e9c414408a8c9c2806af12e659e395c605496f.tar.bz2 chat-c3e9c414408a8c9c2806af12e659e395c605496f.zip |
[MM-1915] Add Deactivate Account - server side (#8699)
Diffstat (limited to 'api4/user.go')
-rw-r--r-- | api4/user.go | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/api4/user.go b/api4/user.go index 2a539a551..ea90d2127 100644 --- a/api4/user.go +++ b/api4/user.go @@ -713,6 +713,12 @@ func updateUserActive(c *Context, w http.ResponseWriter, r *http.Request) { return } + // if EnableUserDeactivation flag is disabled the user cannot deactivate himself. + if isSelfDeactive && !*c.App.GetConfig().TeamSettings.EnableUserDeactivation { + c.Err = model.NewAppError("updateUserActive", "api.user.update_active.not_enable.app_error", nil, "userId="+c.Params.UserId, http.StatusUnauthorized) + return + } + var user *model.User var err *model.AppError @@ -725,6 +731,13 @@ func updateUserActive(c *Context, w http.ResponseWriter, r *http.Request) { c.Err = err } else { c.LogAuditWithUserId(user.Id, fmt.Sprintf("active=%v", active)) + if isSelfDeactive { + c.App.Go(func() { + if err = c.App.SendDeactivateAccountEmail(user.Email, user.Locale, c.App.GetSiteURL()); err != nil { + mlog.Error(err.Error()) + } + }) + } ReturnStatusOK(w) } } |