diff options
author | Joram Wilander <jwawilander@gmail.com> | 2017-03-27 09:21:48 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-03-27 09:21:48 -0400 |
commit | 58397f853a31773f24ad4e62dc1f34df0a975d53 (patch) | |
tree | c2055df17b6347199bf48054d606cf1b3b0e89c2 /model/client4.go | |
parent | a0d5c01dfd97b45478353ccff777de677f088d0f (diff) | |
download | chat-58397f853a31773f24ad4e62dc1f34df0a975d53.tar.gz chat-58397f853a31773f24ad4e62dc1f34df0a975d53.tar.bz2 chat-58397f853a31773f24ad4e62dc1f34df0a975d53.zip |
Implement some MFA endpoints for APIv4 (#5864)
Diffstat (limited to 'model/client4.go')
-rw-r--r-- | model/client4.go | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/model/client4.go b/model/client4.go index 6306039ff..72d8951b9 100644 --- a/model/client4.go +++ b/model/client4.go @@ -545,6 +545,36 @@ func (c *Client4) UpdateUserMfa(userId, code string, activate bool) (bool, *Resp } } +// CheckUserMfa checks whether a user has MFA active on their account or not based on the +// provided login id. +func (c *Client4) CheckUserMfa(loginId string) (bool, *Response) { + requestBody := make(map[string]interface{}) + requestBody["login_id"] = loginId + + if r, err := c.DoApiPost(c.GetUsersRoute()+"/mfa", StringInterfaceToJson(requestBody)); err != nil { + return false, &Response{StatusCode: r.StatusCode, Error: err} + } else { + defer closeBody(r) + data := StringInterfaceFromJson(r.Body) + if mfaRequired, ok := data["mfa_required"].(bool); !ok { + return false, BuildResponse(r) + } else { + return mfaRequired, BuildResponse(r) + } + } +} + +// GenerateMfaSecret will generate a new MFA secret for a user and return it as a string and +// as a base64 encoded image QR code. +func (c *Client4) GenerateMfaSecret(userId string) (*MfaSecret, *Response) { + if r, err := c.DoApiPost(c.GetUserRoute(userId)+"/mfa/generate", ""); err != nil { + return nil, &Response{StatusCode: r.StatusCode, Error: err} + } else { + defer closeBody(r) + return MfaSecretFromJson(r.Body), BuildResponse(r) + } +} + // UpdateUserPassword updates a user's password. Must be logged in as the user or be a system administrator. func (c *Client4) UpdateUserPassword(userId, currentPassword, newPassword string) (bool, *Response) { requestBody := map[string]string{"current_password": currentPassword, "new_password": newPassword} |