From 69ea134b33daf14e9a6b1f48fdb0501d8954e223 Mon Sep 17 00:00:00 2001 From: Livio Spring Date: Fri, 15 Mar 2024 06:50:55 +0100 Subject: [PATCH] fix: enable resend code in user initialization without auth request (#7568) (cherry picked from commit 20d1d56669fd64f760ddb10826cc49d5ab87f4c1) --- .../api/ui/login/init_password_handler.go | 24 +++++++------------ 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/internal/api/ui/login/init_password_handler.go b/internal/api/ui/login/init_password_handler.go index f177099703..db2518c437 100644 --- a/internal/api/ui/login/init_password_handler.go +++ b/internal/api/ui/login/init_password_handler.go @@ -22,6 +22,7 @@ type initPasswordFormData struct { Password string `schema:"password"` PasswordConfirm string `schema:"passwordconfirm"` UserID string `schema:"userID"` + OrgID string `schema:"orgID"` Resend bool `schema:"resend"` } @@ -56,7 +57,7 @@ func (l *Login) handleInitPasswordCheck(w http.ResponseWriter, r *http.Request) } if data.Resend { - l.resendPasswordSet(w, r, authReq) + l.resendPasswordSet(w, r, authReq, data) return } l.checkPWCode(w, r, authReq, data) @@ -81,27 +82,20 @@ func (l *Login) checkPWCode(w http.ResponseWriter, r *http.Request, authReq *dom l.renderInitPasswordDone(w, r, authReq, userOrg) } -func (l *Login) resendPasswordSet(w http.ResponseWriter, r *http.Request, authReq *domain.AuthRequest) { - if authReq == nil { - l.renderError(w, r, nil, zerrors.ThrowInternal(nil, "LOGIN-8sn7s", "Errors.AuthRequest.NotFound")) - return - } - userOrg := login +func (l *Login) resendPasswordSet(w http.ResponseWriter, r *http.Request, authReq *domain.AuthRequest, data *initPasswordFormData) { + userOrg := data.OrgID + userID := data.UserID if authReq != nil { userOrg = authReq.UserOrgID - } - user, err := l.query.GetUserByLoginName(setContext(r.Context(), userOrg), false, authReq.LoginName) - if err != nil { - l.renderInitPassword(w, r, authReq, authReq.UserID, "", err) - return + userID = authReq.UserID } passwordCodeGenerator, err := l.query.InitEncryptionGenerator(r.Context(), domain.SecretGeneratorTypePasswordResetCode, l.userCodeAlg) if err != nil { - l.renderInitPassword(w, r, authReq, authReq.UserID, "", err) + l.renderInitPassword(w, r, authReq, userID, "", err) return } - _, err = l.command.RequestSetPassword(setContext(r.Context(), userOrg), user.ID, user.ResourceOwner, domain.NotificationTypeEmail, passwordCodeGenerator) - l.renderInitPassword(w, r, authReq, authReq.UserID, "", err) + _, err = l.command.RequestSetPassword(setContext(r.Context(), userOrg), userID, userOrg, domain.NotificationTypeEmail, passwordCodeGenerator) + l.renderInitPassword(w, r, authReq, userID, "", err) } func (l *Login) renderInitPassword(w http.ResponseWriter, r *http.Request, authReq *domain.AuthRequest, userID, code string, err error) {