From 58397f853a31773f24ad4e62dc1f34df0a975d53 Mon Sep 17 00:00:00 2001 From: Joram Wilander Date: Mon, 27 Mar 2017 09:21:48 -0400 Subject: Implement some MFA endpoints for APIv4 (#5864) --- app/user.go | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'app/user.go') diff --git a/app/user.go b/app/user.go index 33d052708..850b26f1b 100644 --- a/app/user.go +++ b/app/user.go @@ -5,6 +5,7 @@ package app import ( "bytes" + b64 "encoding/base64" "fmt" "hash/fnv" "image" @@ -554,6 +555,27 @@ func GetUsersByIds(userIds []string, asAdmin bool) ([]*model.User, *model.AppErr } } +func GenerateMfaSecret(userId string) (*model.MfaSecret, *model.AppError) { + mfaInterface := einterfaces.GetMfaInterface() + if mfaInterface == nil { + return nil, model.NewAppError("generateMfaSecret", "api.user.generate_mfa_qr.not_available.app_error", nil, "", http.StatusNotImplemented) + } + + var user *model.User + var err *model.AppError + if user, err = GetUser(userId); err != nil { + return nil, err + } + + secret, img, err := mfaInterface.GenerateSecret(user) + if err != nil { + return nil, err + } + + mfaSecret := &model.MfaSecret{Secret: secret, QRCode: b64.StdEncoding.EncodeToString(img)} + return mfaSecret, nil +} + func ActivateMfa(userId, token string) *model.AppError { mfaInterface := einterfaces.GetMfaInterface() if mfaInterface == nil { -- cgit v1.2.3-1-g7c22