Devise не перенаправляется должным образом, чтобы сохранить местоположение при использовании поставщика Omniauth, как Facebook

У меня в моем приложении некоторые действия, которые защищены и нуждаются в аутентификации пользователя. Так как я использую разработку, я использую Authenticlection_user! перед фильтром, чтобы защитить их. Всякий раз, когда пользователь поражает защищенную страницу, придумать попросить пользователя войти, а затем перенаправлять обратно на защищенную страницу. Эта часть работает отлично.

Проблема в том, что когда пользователь пытается войти в систему с Facebook через мое приложение, Devise не перенаправляет пользователя на защищенную страницу после входа в систему. Это всегда бросает пользователя обратно в корневой URL. С помощью стандартной аутентификации это не проблема

Я подозреваю, что есть что связано с методом Passthru, который придумывает интеграцию Omniauth. Любая помощь была бы очень оценена

Вот мой фрагмент кода для Omniauth Callback:

def facebook
# You need to implement the method below in your model
omniauth = request.env["omniauth.auth"]
@user = User.find_for_facebook_oauth(omniauth, current_user)

if @user.persisted?
  flash[:notice] = I18n.t "devise.omniauth_callbacks.success", :kind => "Facebook"
  sign_in_and_redirect @user, :event => :authentication
else
  session["devise.facebook_data"] = env["omniauth.auth"]
  redirect_to new_user_registration_url
end
end

def passthru
  render :file => "#{Rails.root}/public/404.html", :status => 404, :layout => false
end
10
задан amunda 2 September 2011 в 14:54
поделиться