2015-08-12 20 views
6

Ho cercato per giorni di impostare il mio Omniauth per facebook Non so cosa sto sbagliando.Ruby on Rails Omniauth facebook non restituisce email

Non riesco a ottenere l'e-mail dell'utente. L'hash restituita contiene solo il "nome" e il "uid" nemmeno "first_name" e "cognome"

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 

utente .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' } 

restituito hash:

#<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"> 

risposta

7

ho ottenuto solo per recuperare l'e-mail con l'aggiunta di questo devise.rb:

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

Facebook ora consente agli utenti di non condividere il proprio indirizzo email quando si utilizza il login oauth. Questo creerà un'eccezione perché Devise richiede l'indirizzo email nel modello utente. – Red

+1

Grazie mille! –

+0

@SankalpSingha Sei più che benvenuto. –

2

è necessario richiedere le autorizzazioni. Ad esempio, per richiedere email, user_birthday e read_stream permessi e visualizzare la pagina di autenticazione in una finestra pop-up:

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 

Si prega di controllare questo Omniauth-facebook se avete dei dubbi.

+0

dove dovrebbe essere?Ho provato ad aggiungere,: scope {"email"} in devise.rb ma non ha avuto assolutamente alcun effetto. –

+0

Ho appena controllato il collegamento. Non so se ho quel file. Lo controllerò non appena raggiungerò il mio PC e ti farò sapere se ho avuto qualche successo. Grazie. –

+0

Certo, fammi sapere. – nik

10

Assicurarsi di non inserire spazi nella richiesta info-campo (un'altra risposta probabilmente typo'ed questo).

È necessario chiedere espressamente che l'e-mail venga restituita dall'hash del campo informazioni in quanto non è predefinita.

Se stai usando Omniauth-Facebook senza Devise, impostare questa funzione nella vostra config// file di initializers omniauth.rb in questo modo:

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 

Questa informazione è un po 'nascosto proprio alla fine della sezione Configuring sul readme GitHub della gem di omniauth-facebook.

Con Devise più Omniauth, tuttavia, lo si imposta in config/inizializzatori/devise.rb in questo modo (senza spazi nella stringa!):

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

Grazie mille per la risposta. Ma voglio farti sapere che ce l'ho con gli spazi come nella mia risposta e sta funzionando bene. –

+0

È bello saperlo! – Sia

5

Ho avuto lo stesso problema. L'ho fatto funzionare aggiornando le gemme omniauth e omniauth-facebook.

1

Ho avuto lo stesso problema, ma si scopre che era una questione diversa, se si utilizza un flusso lato client assicuratevi di chiedere gli ambiti necessari sul client:

FB.login(function(response) { 
    // hit API callback endpoint 
}, {scope: 'email'});