В моем приложении есть некоторые действия, которые защищены и требуют аутентификации пользователя. Так как я использую devise, я использую authenticate_user! перед фильтром, чтобы защитить их. Каждый раз, когда пользователь попадает на защищенную страницу, попросите его войти в систему и перенаправить обратно на защищенную страницу. Эта часть отлично работает.
Проблема в том, что когда пользователь пытается войти через Facebook через мое приложение, devise не перенаправляет пользователя на защищенную страницу после входа в систему. Это всегда отбрасывает пользователя обратно к корневому URL. При стандартной аутентификации это не проблема
Я подозреваю, что это имеет какое-то отношение к пассивному методу, который требуется - всесторонняя интеграция требует. Любая помощь будет принята с благодарностью
Вот мой фрагмент кода для обратного вызова omniauth:
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