使用remember me选项签出用户时,设计使用record = nil调用的before_logout挂钩

时间:2012-04-19 09:13:39

标签: ruby-on-rails devise neo4j warden

我正在使用Devise 2.0.4(使用devise-neo4j),Warden 1.1.1,Rails 3.2.3。
当我在没有记住选项的情况下登录时,我可以毫无问题地退出 但是,当我使用“记住我”选项登录时,我无法退出 挖掘代码我发现devise-2.0.4/lib/devise/hooks/forgetable.rbWarden::Manager.before_logout do |record, warden, options|)中出现的before_logout挂钩用record => nil调用。
我不确定它是Devise bug,Warden还是我的......

堆栈跟踪如下:

devise-2.0.4/lib/devise/hooks/forgetable.rb:7:in `(root)'
org/jruby/RubyProc.java:258:in `call'
warden-1.1.1/lib/warden/hooks.rb:14:in `_run_callbacks'
org/jruby/RubyArray.java:1615:in `each'
warden-1.1.1/lib/warden/hooks.rb:9:in `_run_callbacks'
warden-1.1.1/lib/warden/manager.rb:53:in `_run_callbacks'
warden-1.1.1/lib/warden/proxy.rb:243:in `logout'
org/jruby/RubyArray.java:1615:in `each'
warden-1.1.1/lib/warden/proxy.rb:241:in `logout'
devise-2.0.4/lib/devise/controllers/helpers.rb:159:in `sign_out_all_scopes'
devise-2.0.4/lib/devise/controllers/helpers.rb:139:in `sign_out'
devise-2.0.4/app/controllers/devise/sessions_controller.rb:23:in `destroy'

1 个答案:

答案 0 :(得分:-1)

该问题与Torquebox和会话存储配置(config / initializers / session_store.rb)有关。 使用默认Rails配置或Torquebox注释掉(出于某种原因)时会出现问题。