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:
parent
715f49c3fe
commit
b90b56f953
|
@ -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
|
||||||
|
|
|
@ -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?
|
||||||
|
|
|
@ -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") }
|
||||||
|
|
Loading…
Reference in New Issue