2015-08-12 3 views
6

Я пытался в течение нескольких дней настроить мой Omniauth для facebook. Я не знаю, что я делаю неправильно.Ruby on Rails Omniauth facebook не возвращает адрес электронной почты

Я не могу получить электронное письмо пользователя. Возвращенный хэш содержит только "имя" и "UID" даже не "first_name" и "last_name"

devise.rb:

config.omniauth :facebook, "KEY", "SECRET" 

omniauth_callbacks_controller.rb:

class OmniauthCallbacksController < Devise::OmniauthCallbacksController 
    def facebook 
    logger.info request.env["omniauth.auth"] 
    @user = User.from_omniauth(request.env["omniauth.auth"]) 
    sign_in_and_redirect @user 
    end 
end 

пользователя .rb:

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] 

has_many :authentications 

def self.from_omniauth(auth) 
    logger.info auth 
    user = where(email: auth.info.email).first 
    if(user != nil) 
    user.authentications.where(provider: auth.provider, uid: auth.uid).first_or_create do |l| 
     user.authentications.create!(user_id: user.id, 
            provider: auth.provider, 
            uid: auth.uid) 
    end 
    else 
    user = User.create!(email: auth.info.email, 
         password: Devise.friendly_token[0,20], 
         first_name: auth.info.first_name, 
         last_name: auth.info.last_name) 
    user.authentications.create!(user_id: user.id, 
           provider: auth.provider, 
           uid: auth.uid) 
    end 
    user 
end 
end 

registrations_controller.rb:

class RegistrationsController < Devise::RegistrationsController 

    private 

    def sign_up_params 
    params.require(:user).permit(:first_name, :last_name, :email, :password, :password_confirmation) 
    end 

    def account_update_params 
    params.require(:user).permit(:first_name, :last_name, :email, :password, :password_confirmation, :current_password) 
    end 
end 

routes.rb:

devise_for :users, :controllers => { registrations: 'registrations', omniauth_callbacks: 'omniauth_callbacks' } 

Возвращается хэш:

#<OmniAuth::AuthHash credentials=#<OmniAuth::AuthHash expires=true expires_at=1444504014 token="TOKEN"> 
extra=#<OmniAuth::AuthHash raw_info=#<OmniAuth::AuthHash id="1506781179612589" name="Ayman Salah">> info=# 
<OmniAuth::AuthHash::InfoHash image="http://graph.facebook.com/1506781179612589/picture" name="Ayman Salah"> provider="facebook" uid="1506781179612589"> 

ответ

7

я получил только, чтобы получить электронную почту, добавив это в devise.rb:

config.omniauth :facebook, "KEY", "SECRET", scope: 'email', info_fields: 'email, name' 
+2

Facebook теперь позволяет пользователям не разглашать свой адрес электронной почты при использовании oauth login. Это создаст исключение, потому что Devise требует адрес электронной почты в пользовательской модели. – Red

+1

Спасибо, человек! –

+0

@SankalpSingha Вы более чем с удовольствием. –

2

Вам нужно запросить разрешения. Например, чтобы запросить email, user_birthday и read_stream разрешения и отобразить страницу аутентификации во всплывающем окне:

Rails.application.config.middleware.use OmniAuth::Builder do 
    provider :facebook, ENV['FACEBOOK_KEY'], ENV['FACEBOOK_SECRET'], 
     :scope => 'email,user_birthday,read_stream', :display => 'popup' 
end 

Пожалуйста, проверьте этот Omniauth-facebook, если у вас есть какие-либо сомнения.

+0

Где это должно быть?Я попытался добавить: scope {"email"} в devise.rb, но это не имело никакого эффекта. –

+0

Я только что проверил ссылку. Я не знаю, есть ли у меня этот файл. Я проверю это, как только я доберусь до своего компьютера, и я сообщу, если у меня был какой-то успех. Благодарю. –

+0

Конечно, дайте мне знать. – nik

10

Убедитесь, что вы не ставьте пробелы в запросе инфо-поля (еще один ответ, вероятно, typo'ed это).

Вам нужно специально запросить, чтобы письмо возвращалось из хеша информационного поля, поскольку оно не по умолчанию.

Если вы используете OmniAuth-Facebook без Завещания, установите в вашем конфигурации/инициализаторов/omniauth.rb файл следующим образом:

Rails.application.config.middleware.use OmniAuth::Builder do 
    provider :facebook, Rails.application.secrets.omniauth_provider_key, Rails.application.secrets.omniauth_provider_secret, 
    :scope => 'email', :display => 'popup', :info_fields => 'name,email' 
end 

Эта информация отчасти скрыта в самом конце раздела Configuring, посвященного GitHub readme омняута-facebook gem.

С Devise плюс OmniAuth, однако, вы установите его в конфигурации/инициализаторах/devise.rb как так (без пробелов в строке!):

config.omniauth :facebook, 'app_id', 'app_secret', scope: 'email', info_fields: 'name,email' 
+0

Большое спасибо за ваш ответ. Но я хочу сообщить вам, что у меня есть пробелы, как в моем ответе, и он работает нормально. –

+0

Это здорово! – Sia

5

У меня была такая же проблема. Я заставил его работать, обновляя омняут и омнауты-facebook gems.

1

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

FB.login(function(response) { 
    // hit API callback endpoint 
}, {scope: 'email'}); 
Смежные вопросы