2013-11-12 17:37:38 -05:00
|
|
|
class UserAuthenticator
|
2014-11-17 06:04:29 -05:00
|
|
|
|
2013-11-12 17:37:38 -05:00
|
|
|
def initialize(user, session, authenticator_finder = Users::OmniauthCallbacksController)
|
|
|
|
@user = user
|
|
|
|
@session = session[:authentication]
|
|
|
|
@authenticator_finder = authenticator_finder
|
|
|
|
end
|
|
|
|
|
|
|
|
def start
|
|
|
|
if authenticated?
|
|
|
|
@user.active = true
|
|
|
|
else
|
|
|
|
@user.password_required!
|
|
|
|
end
|
2016-09-07 14:05:46 -04:00
|
|
|
|
|
|
|
@user.skip_email_validation = true if @session && @session[:skip_email_validation].present?
|
2013-11-12 17:37:38 -05:00
|
|
|
end
|
|
|
|
|
2014-03-19 23:49:25 -04:00
|
|
|
def has_authenticator?
|
|
|
|
!!authenticator
|
|
|
|
end
|
|
|
|
|
2013-11-12 17:37:38 -05:00
|
|
|
def finish
|
2018-05-22 19:26:07 -04:00
|
|
|
if authenticator
|
|
|
|
authenticator.after_create_account(@user, @session)
|
|
|
|
confirm_email
|
|
|
|
end
|
2013-11-12 17:37:38 -05:00
|
|
|
@session = nil
|
|
|
|
end
|
|
|
|
|
2017-10-16 13:51:35 -04:00
|
|
|
def email_valid?
|
|
|
|
@session && @session[:email_valid]
|
|
|
|
end
|
2013-11-12 17:37:38 -05:00
|
|
|
|
|
|
|
def authenticated?
|
2018-05-22 19:26:07 -04:00
|
|
|
@session && @session[:email]&.downcase == @user.email.downcase && @session[:email_valid].to_s == "true"
|
2013-11-12 17:37:38 -05:00
|
|
|
end
|
|
|
|
|
2017-10-16 13:51:35 -04:00
|
|
|
private
|
|
|
|
|
2018-05-22 19:26:07 -04:00
|
|
|
def confirm_email
|
|
|
|
if authenticated?
|
|
|
|
EmailToken.confirm(@user.email_tokens.first.token)
|
|
|
|
@user.set_automatic_groups
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-11-12 17:37:38 -05:00
|
|
|
def authenticator
|
|
|
|
if authenticator_name
|
|
|
|
@authenticator ||= @authenticator_finder.find_authenticator(authenticator_name)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def authenticator_name
|
|
|
|
@session && @session[:authenticator_name]
|
|
|
|
end
|
2014-11-17 06:04:29 -05:00
|
|
|
|
2013-11-12 17:37:38 -05:00
|
|
|
end
|