0

Я играю с драгоценным камнем omniauth-facebook, чтобы войти в сеанс разработки через учетную запись на facebook. Когда я нажимаю ссылку «Войти в facebook», все идет хорошо: создается новая учетная запись, я подписываюсь и возвращаюсь на главную страницу с сообщением, подтверждающим мою новую сессию (очень хорошо!).Omniauth Facebook login переадресовывает подписку, если существует

Проблема: Однако, когда учетная запись уже существует, при нажатии ссылки я перенаправляется на страницу user/sign_up. Я искал this documentation из wiki. Существует большая документация по аналогичным ошибкам here, here, here и here. Однако каждое из решений уже реализовано в моем приложении (насколько я могу судить) ИЛИ (в случае последней ссылки), похоже, основывается на более старой модели конфигурации, которая кажется достаточно отличной от вики, m не уверен, что это применимо.

Моя догадка, что он имеет что-то делать с контроллером обратных вызовов, так как @user.persisted?, кажется, придумывают false.This заставляет меня верить, что мое определение @user не является правильным. Смотрите ниже:

class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController 
    def facebook 
    logger.debug "Inside facebook" 
    # You need to implement the method below in your model (e.g. app/models/user.rb) 
    @user = User.from_omniauth(request.env["omniauth.auth"]) 
    logger.debug "User is #{@user}" 

    if @user.persisted? 
     logger.debug "@user.persisted?" 
     debugger 
     sign_in_and_redirect @user, :event => :authentication #this will throw if @user is not activated 
     set_flash_message(:notice, :success, :kind => "Facebook") if is_navigational_format? 
     logger.debug "user exists" 
    else 
     session["devise.facebook_data"] = request.env["omniauth.auth"] 
     redirect_to new_user_registration_url 
    end 
    end 

    def failure 
    redirect_to root_path, alert: "Login failed" 
    end 
end 

Кроме того, моя пользовательская модель выглядит следующим образом:

class User < ActiveRecord::Base 
    # Include default devise modules. Others available are: 
    # :confirmable, :lockable, :timeoutable and :omniauthable 
    devise :database_authenticatable, :registerable, 
       :recoverable, :rememberable, :trackable, :validatable, :omniauthable, :omniauth_providers => [:facebook] 

    def self.from_omniauth(auth) 
     where(provider: auth.provider, uid: auth.uid).first_or_create do |user| 
      user.provider = Devise.friendly_token[0,20] 
      user.email = auth.info.email 
      user.password = Devise.friendly_token[0,20] 
      user.fname = auth.info.first_name 
      user.lname = auth.info.last_name 
     end 
    end 
end 

Любые предложения будут, конечно, добро пожаловать! Заранее спасибо.

+0

У вас есть 'after_sign_in_path_for' метод в любом месте проект? – chumakoff

ответ

0

from_omniauth никогда не находит существующий пользователь facebook, потому что вы перезаписать атрибут поставщика:

where(provider: auth.provider, uid: auth.uid).first_or_create do |user| 

поиска для пользователя с провайдером «facebook» в этом случае, но никто не может быть найден:

user.provider = Devise.friendly_token[0,20] 

изменяет провайдера на некоторый случайный токен

просто удалите эту строку и он должен нормально работать

0

Try Нечто подобное

class Authentication < ActiveRecord::Base 

    belongs_to :user 
    # validates :provider, :uid, :presence => true 

    def self.from_omniauth(auth) 
    authenticate = where(provider: auth[:provider], :uid=>auth[:uid]).first_or_initialize 
     if authenticate.user 
      authenticate.provider = auth[:provider] 
      authenticate.uid =auth[:uid] 
     else 
      user = User.find_or_initialize_by(:email => email) 
      authenticate.provider = auth[:provider] 
      user.email = email 
      user.first_name = first_name 
      user.last_name = last_name 
      user.social_image = image 
      user.password = Devise.friendly_token.first(8) 
      user.save(validate: false) 
      if user.errors.any? 
       return user 
      else 
      authenticate.user_id = user.id 
      end 
     end 
     authenticate.save 
     authenticate.user 

     end 
    end 
1

Попробуйте

def after_sign_in_path_for(resource) 
     super resource 
    end 

Из того, что я понял, что вы не собираетесь целевой страницы

Смежные вопросы