Rya*_*yan 5 ruby ruby-on-rails devise
我正在尝试添加一个非常简单的策略来设计,它似乎并没有起作用.这是我尝试使用的代码
#config/initializers/devise.rb
Devise.setup do |config|
config.orm = :mongo_mapper
config.warden do |manager|
manager.strategies.add(:auto_login_strategy) do
def valid?
params[:auto_login]
end
def authenticate!
u = User.find(:first)
u.nil? ? fail!("No created users") : success!(u)
end
end
manager.default_strategies(:scope=>:user).unshift :auto_login_strategy
end
end
Run Code Online (Sandbox Code Playgroud)
代码应该检查params的'auto_login'参数,如果存在,找到它可以的第一个用户并登录.我完全跳过安全措施,只是让一个基本的测试用例工作.当我尝试登录到具有before_filter authenticate_user!(即localhost:3000/test?auto_login=true)的控制器时,它无法登录并重定向到登录页面.我究竟做错了什么?
小智 6
您可能想尝试将其直接添加到Warden :: Strategies:
class MyStrategy
def valid?...
def authenticate!...
end
Warden::Strategies.add(:database_authenticatable, MyStrategy)
Run Code Online (Sandbox Code Playgroud)
我不久前做了这个,但后来不再需要了.如果我记得正确,请告诉我.