2016-11-29 3 views
0

Ich benutze devise gem zusammen mit omniauth gem für Facebook, Twitter & Instagram. Im Folgenden finden Sie die gem ‚s ich benutze:Ruby on rails - Umleiten zur vorherigen URL nach der Authentifizierung mit devise/omniauth

gem 'devise' 
gem 'omniauth' 
gem 'omniauth-twitter' 
gem 'omniauth-facebook' 
gem 'omniauth-instagram' 
gem 'twitter' 
gem 'instagram' 

I this toturial für Einrichten entwickeln, um mit Twitter und Facebook folgen.

Inside my omniauth_callbacks_controller.rb Ich habe generic_callback Funktion wie folgt ein:

def generic_callback(provider) 
    @identity = Identity.find_for_oauth env["omniauth.auth"] 
    @user = @identity.user || current_user 
    if @user.nil? 
     @tempUser = User.find_by_email(@identity.email) unless @identity.email.blank? 
     if @tempUser.nil? 
      @user = User.create(email: @identity.email, display_name: @identity.display_name, avatar: @identity.avatar, provider: @identity.provider || nil) 
     else 
     @user = @tempUser 
     end 
     @identity.update_attribute(:user_id, @user.id) 
    end 
    if @user.email.blank? && @identity.email 
     @user.update_attribute(:email, @identity.email) 
    end 
    if @user.persisted? 
     @identity.update_attribute(:user_id, @user.id) 

     @user = FormUser.find @user.id 
     sign_in_and_redirect @user, event: :authentication 
     set_flash_message(:notice, :success, kind: provider.capitalize) if is_navigational_format? 
    else 
     session["devise.#{provider}_data"] = env["omniauth.auth"] 
     redirect_to new_user_registration_url 
    end 
    end 

Alles funktioniert gut und was ich will zu erreichen ist zu umleiten Benutzer vorherige url wenn sie sign_in oder sign_up.

Vor omniauth gem Einrichten und verwendet nur devise gem, benutzte ich diese Methode in meinem application_controller.rb:

def after_sign_in_path_for(resource) 
    session[:previous_url] = request.fullpath unless request.fullpath =~ /\/users/ || request.fullpath =~ /\/macbook1/ 
end 

Das die Magie tat, als nur devise, aber jetzt verwenden, wenn diese Methode in der application_controller.rb ist bekomme ich diesen Fehler :

Error after sign_in or sign_out

ich dies auch mit Fehlern versucht:

def after_sign_in_path_for(resource_or_scope) 
    if request.env['omniauth.origin'] 
     request.env['omniauth.origin'] 
    end 
    end 

Was muss ich tun, um redirect Benutzer in der Lage sein zu vorherige url nach sign_in oder sign_up?

Antwort

0

Innerhalb application_controller.rb benötigen Sie 2 Methoden: store_location & after_sign_in_path_for.

application_controller.rb

class ApplicationController < ActionController::Base 
    after_filter :store_location 

    def store_location 
     return unless request.get? 
     if (request.path != new_user_session_path && 
      request.path != new_user_registration_path && 
      request.path != "https://stackoverflow.com/users/password/new" && 
      request.path != "https://stackoverflow.com/users/password/edit" && 
      request.path != "https://stackoverflow.com/users/confirmation" && 
      request.path != "https://stackoverflow.com/users/edit" && 
      request.path != destroy_user_session_path && 
      !request.xhr?) # don't store ajax calls 
     session[:previous_url] = request.fullpath 
     end 
    end 

    def after_sign_in_path_for(resource) 
     request.env['omniauth.origin'] || stored_location_for(resource) || root_path || request.fullpath =~ /\/admin/ 
    end 

end