У меня в моем приложении некоторые действия, которые защищены и нуждаются в аутентификации пользователя. Так как я использую разработку, я использую 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