omniauth_callbacks_controller.rb 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. # frozen_string_literal: true
  2. class Auth::OmniauthCallbacksController < Devise::OmniauthCallbacksController
  3. skip_before_action :verify_authenticity_token
  4. def self.provides_callback_for(provider)
  5. define_method provider do
  6. @user = User.find_for_omniauth(request.env['omniauth.auth'], current_user)
  7. if @user.persisted?
  8. LoginActivity.create(
  9. user: @user,
  10. success: true,
  11. authentication_method: :omniauth,
  12. provider: provider,
  13. ip: request.remote_ip,
  14. user_agent: request.user_agent
  15. )
  16. sign_in_and_redirect @user, event: :authentication
  17. set_flash_message(:notice, :success, kind: Devise.omniauth_configs[provider].strategy.display_name.capitalize) if is_navigational_format?
  18. else
  19. session["devise.#{provider}_data"] = request.env['omniauth.auth']
  20. redirect_to new_user_registration_url
  21. end
  22. rescue ActiveRecord::RecordInvalid
  23. flash[:alert] = I18n.t('devise.failure.omniauth_user_creation_failure') if is_navigational_format?
  24. redirect_to new_user_session_url
  25. end
  26. end
  27. Devise.omniauth_configs.each_key do |provider|
  28. provides_callback_for provider
  29. end
  30. def after_sign_in_path_for(resource)
  31. if resource.email_present?
  32. root_path
  33. else
  34. auth_setup_path(missing_email: '1')
  35. end
  36. end
  37. end