From 6a4d8603fc3ca99a4c95fafdf9ad50171a0034d9 Mon Sep 17 00:00:00 2001 From: Florent Daigniere Date: Tue, 14 Feb 2023 13:41:46 +0100 Subject: [PATCH] Create the user before logging it in --- core/admin/mailu/sso/views/base.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/core/admin/mailu/sso/views/base.py b/core/admin/mailu/sso/views/base.py index 539d18eb..5ca4a52d 100644 --- a/core/admin/mailu/sso/views/base.py +++ b/core/admin/mailu/sso/views/base.py @@ -94,10 +94,10 @@ def proxy(target='webmail'): return flask.abort(500, 'Too many users in (domain=%s)' % domain) user = models.User(localpart=localpart, domain=domain) user.set_password(secrets.token_urlsafe()) - flask.session.regenerate() - flask_login.login_user(user) models.db.session.add(user) models.db.session.commit() + flask.session.regenerate() + flask_login.login_user(user) user.send_welcome() flask.current_app.logger.info(f'Login succeeded by proxy created user: {user} from {client_ip} through {flask.request.remote_addr}.') return flask.redirect(app.config['WEB_ADMIN'] if target=='admin' else app.config['WEB_WEBMAIL'])