omniauth_callbacks_controller.rb 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. # frozen_string_literal: true
  2. class Auth::OmniauthCallbacksController < Devise::OmniauthCallbacksController
  3. skip_before_action :check_self_destruct!
  4. skip_before_action :verify_authenticity_token
  5. def self.provides_callback_for(provider)
  6. define_method provider do
  7. @provider = provider
  8. @user = User.find_for_omniauth(request.env['omniauth.auth'], current_user)
  9. if @user.persisted?
  10. record_login_activity
  11. sign_in_and_redirect @user, event: :authentication
  12. set_flash_message(:notice, :success, kind: label_for_provider) if is_navigational_format?
  13. else
  14. session["devise.#{provider}_data"] = request.env['omniauth.auth']
  15. redirect_to new_user_registration_url
  16. end
  17. rescue ActiveRecord::RecordInvalid
  18. flash[:alert] = I18n.t('devise.failure.omniauth_user_creation_failure') if is_navigational_format?
  19. redirect_to new_user_session_url
  20. end
  21. end
  22. Devise.omniauth_configs.each_key do |provider|
  23. provides_callback_for provider
  24. end
  25. def after_sign_in_path_for(resource)
  26. if resource.email_present?
  27. stored_location_for(resource) || root_path
  28. else
  29. auth_setup_path(missing_email: '1')
  30. end
  31. end
  32. private
  33. def record_login_activity
  34. LoginActivity.create(
  35. user: @user,
  36. success: true,
  37. authentication_method: :omniauth,
  38. provider: @provider,
  39. ip: request.remote_ip,
  40. user_agent: request.user_agent
  41. )
  42. end
  43. def label_for_provider
  44. provider_display_name || configured_provider_name
  45. end
  46. def provider_display_name
  47. Devise.omniauth_configs[@provider]&.strategy&.display_name.presence
  48. end
  49. def configured_provider_name
  50. I18n.t("auth.providers.#{@provider}", default: @provider.to_s.chomp('_oauth2').capitalize)
  51. end
  52. end