54 lines
1.7 KiB
Ruby
54 lines
1.7 KiB
Ruby
class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
|
|
|
|
def twitter
|
|
sign_in_with :twitter
|
|
end
|
|
|
|
def facebook
|
|
sign_in_with :facebook
|
|
end
|
|
|
|
def google_oauth2
|
|
sign_in_with :google_oauth2
|
|
end
|
|
|
|
def after_sign_in_path_for(resource)
|
|
if resource.pending_finish_signup?
|
|
finish_signup_path
|
|
else
|
|
super(resource)
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def sign_in_with(provider)
|
|
auth = env["omniauth.auth"]
|
|
|
|
identity = Identity.first_or_create_from_oauth(auth)
|
|
@user = current_user || identity.user || User.first_or_initialize_for_oauth(auth)
|
|
|
|
# If there are no problems with the email/username, then they were provided by oauth or they
|
|
# correspond to an existing user. Associate the identity and sign in
|
|
if @user.save
|
|
identity.update(user: @user)
|
|
sign_in_and_redirect @user, event: :authentication
|
|
set_flash_message(:notice, :success, kind: "#{provider}".capitalize) if is_navigational_format?
|
|
else
|
|
# If either the username or email have provoked a failure, we save the user anyway (but marked for revision)
|
|
# This mark will be detected by applicationcontroller and the user will be redirected to finish_signup
|
|
@user.registering_with_oauth = true
|
|
if @user.save
|
|
identity.update(user: @user)
|
|
sign_in_and_redirect @user, event: :authentication
|
|
set_flash_message(:notice, :success, kind: "#{provider}".capitalize) if is_navigational_format?
|
|
else
|
|
# If the failure is because something else happens, just present the "new user" form
|
|
session["devise.#{provider}_data"] = auth
|
|
redirect_to new_user_registration_url
|
|
end
|
|
end
|
|
end
|
|
|
|
end
|