FIX: do not enforce 2fa when an account is created with OAuth (#28625)

In this PR we introduced a new setting `enforce_second_factor_on_external_auth` which disables enforce 2FA when the user is authenticated with an external provider.

https://github.com/discourse/discourse/pull/27506

However, with the first registration with an external provider, we authenticate the user right after activation. In that case, we need to also keep information that the user was authenticated with an external OAuth provider.
This commit is contained in:
Krzysztof Kotlarek 2024-08-29 11:19:04 +10:00 committed by GitHub
parent 715f49c3fe
commit b90b56f953
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 14 additions and 2 deletions

View File

@ -67,7 +67,7 @@ class LoginActivator < UserActivator
include CurrentUser include CurrentUser
def activate def activate
log_on_user(user) log_on_user(user, { authenticated_with_oauth: @session["authenticated_with_oauth"] })
user.enqueue_welcome_message("welcome_user") user.enqueue_welcome_message("welcome_user")
success_message success_message
end end

View File

@ -36,7 +36,10 @@ class UserAuthenticator
authenticator.after_create_account(@user, @auth_result) authenticator.after_create_account(@user, @auth_result)
confirm_email confirm_email
end end
@session[:authentication] = @auth_result = nil if @session&.dig(:authentication) if @session&.dig(:authentication)
@session[:authentication] = @auth_result = nil
@session[:authenticated_with_oauth] = true
end
end end
def email_valid? def email_valid?

View File

@ -81,6 +81,15 @@ RSpec.describe UserAuthenticator do
expect(session[:authentication]).to eq(nil) expect(session[:authentication]).to eq(nil)
end end
it "sets the authenticated_with_oauth flag in the session" do
user = Fabricate(:user, email: "user53@discourse.org")
session = { authentication: github_auth(true) }
UserAuthenticator.new(user, session).finish
expect(session[:authenticated_with_oauth]).to be true
end
it "raises an error for non-boolean values" do it "raises an error for non-boolean values" do
user = Fabricate(:user, email: "user53@discourse.org") user = Fabricate(:user, email: "user53@discourse.org")
session = { authentication: github_auth("string") } session = { authentication: github_auth("string") }