2014-05-21 18:19:40 -04:00
|
|
|
class Auth::GoogleOAuth2Authenticator < Auth::Authenticator
|
|
|
|
|
|
|
|
def name
|
|
|
|
"google_oauth2"
|
|
|
|
end
|
|
|
|
|
|
|
|
def after_authenticate(auth_hash)
|
|
|
|
session_info = parse_hash(auth_hash)
|
|
|
|
google_hash = session_info[:google]
|
|
|
|
|
2017-03-07 16:00:51 -05:00
|
|
|
result = ::Auth::Result.new
|
2014-05-21 18:19:40 -04:00
|
|
|
result.email = session_info[:email]
|
|
|
|
result.email_valid = session_info[:email_valid]
|
|
|
|
result.name = session_info[:name]
|
|
|
|
|
|
|
|
result.extra_data = google_hash
|
|
|
|
|
2017-03-07 16:00:51 -05:00
|
|
|
user_info = ::GoogleUserInfo.find_by(google_user_id: google_hash[:google_user_id])
|
2014-05-21 18:19:40 -04:00
|
|
|
result.user = user_info.try(:user)
|
|
|
|
|
2016-11-06 20:48:00 -05:00
|
|
|
if !result.user && !result.email.blank? && result.email_valid
|
|
|
|
result.user = User.find_by_email(result.email)
|
|
|
|
if result.user
|
2017-03-07 16:00:51 -05:00
|
|
|
::GoogleUserInfo.create({user_id: result.user.id}.merge(google_hash))
|
2016-11-06 20:48:00 -05:00
|
|
|
end
|
2014-05-21 18:19:40 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
result
|
|
|
|
end
|
|
|
|
|
|
|
|
def after_create_account(user, auth)
|
|
|
|
data = auth[:extra_data]
|
|
|
|
GoogleUserInfo.create({user_id: user.id}.merge(data))
|
2017-07-07 16:04:56 -04:00
|
|
|
if auth[:email_valid].to_s == 'true'
|
|
|
|
EmailToken.confirm(user.email_tokens.first.token)
|
|
|
|
user.set_automatic_groups
|
|
|
|
end
|
2014-05-21 18:19:40 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def register_middleware(omniauth)
|
2016-02-04 16:48:16 -05:00
|
|
|
# jwt encoding is causing auth to fail in quite a few conditions
|
|
|
|
# skipping
|
2014-05-21 18:19:40 -04:00
|
|
|
omniauth.provider :google_oauth2,
|
|
|
|
:setup => lambda { |env|
|
|
|
|
strategy = env["omniauth.strategy"]
|
|
|
|
strategy.options[:client_id] = SiteSetting.google_oauth2_client_id
|
|
|
|
strategy.options[:client_secret] = SiteSetting.google_oauth2_client_secret
|
2016-02-04 16:48:16 -05:00
|
|
|
},
|
|
|
|
skip_jwt: true
|
2014-05-21 18:19:40 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def parse_hash(hash)
|
|
|
|
extra = hash[:extra][:raw_info]
|
|
|
|
|
|
|
|
h = {}
|
|
|
|
|
|
|
|
h[:email] = hash[:info][:email]
|
|
|
|
h[:name] = hash[:info][:name]
|
2017-02-28 22:58:24 -05:00
|
|
|
h[:email_valid] = extra[:email_verified]
|
2014-05-21 18:19:40 -04:00
|
|
|
|
|
|
|
h[:google] = {
|
|
|
|
google_user_id: hash[:uid] || extra[:sub],
|
|
|
|
email: extra[:email],
|
|
|
|
first_name: extra[:given_name],
|
|
|
|
last_name: extra[:family_name],
|
|
|
|
gender: extra[:gender],
|
|
|
|
name: extra[:name],
|
|
|
|
link: extra[:hd],
|
|
|
|
profile_link: extra[:profile],
|
|
|
|
picture: extra[:picture]
|
|
|
|
}
|
|
|
|
|
|
|
|
h
|
|
|
|
end
|
2015-04-24 13:10:43 -04:00
|
|
|
end
|