Rails how to create an Authlogic session from Omniauth Facebook

Here is my controller

def social_login
    user = User.from_omniauth(env["omniauth.auth"])
    session_params = user.attributes.merge("email" => user.email, "password" => user.crypted_password)
    @user_session ||= UserSession.new(session_params, true)
    if @user_session.save
      user = User.where(email: @user_session.email).first
      redirect_to root_path, :notice => "Signed in succesfully from #{env["omniauth.auth"].provider.titleize}. Greetings #{user.name.titleize} ;)"    
    else
      flash.now[:alert] = "Sign in failed."
      render "new"
    end
end

here is the model for omniauth process processing

  def self.from_omniauth(auth)
    where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
      user.provider = auth.provider
      user.uid = auth.uid
      user.name = auth.info.name
      user.email = auth.info.email
      user.password = auth.credentials.token
      user.password_confirmation = auth.credentials.token
      user.oauth_token = auth.credentials.token
      user.oauth_expires_at = Time.at(auth.credentials.expires_at)
      user.save!
    end
  end

I always get an error when trying to save a session. It says:

Authlogic::Session::Existence::SessionInvalidError: Your session is invalid and has the following errors: Email is not valid

Can you guys help me? thanks

+4
source share
1 answer

Have you enabled email permission in your app / configs configuration on facebook?

Like this:

config.omniauth :facebook, "APP_ID", "APP_SECRET",  {:scope => 'email,...'}
0
source

Source: https://habr.com/ru/post/1611873/


All Articles