ruby-on-rails-3 – 即使设置了allow_unconfirmed_access_for,为什么Devise不允许未确认的用户登录?

我们拥有现有的用户群,并添加电子邮件确认.确认是可选的,但将允许其他功能.用户不需要确认.我添加了可确认的模块并运行迁移.确认工作正如广告一样.

但是,用户无法登录,因为没有确认.所有当前用户都有无确认值,这是我们想要的(用户可以随时返回并确认其电子邮件).我遵循了所有Devise wiki文章,并在初始化程序中设置allow_unconfirmed_access_for:

config.allow_unconfirmed_access_for = 10.years

我也试过在我们的用户模型中设置它:

devise :confirmable,allow_unconfirmed_access_for: 10.years

我也试过使用其他值(1年,500天等)

我的会话控制器,与Devise的方法没有什么不同(here on github)

class Users::SessionsController < Devise::SessionsController
  respond_to :json

  def new
    redirect_to "/#login"
  end

  def create
    resource = warden.authenticate(auth_options)
    if !resource
      render json: {error: "Invalid email or password" },status: 401 and return
    end

    sign_in(resource_name,resource)
    render "sign_in",formats: [:json],locals: { object: resource }
  end
end

设计师的回应:

{“错误”:“您必须先确认您的帐户才能继续.”}

Devise 2.1.2 with Rails 3.2.9.

解决方法

我只需要在我的用户模型中执行此操作,而不是使用allow_unconfirmed_access_for:
protected
    def confirmation_required?
      false
    end

相关文章

以下代码导致我的问题: class Foo def initialize(n=0) @n = n end attr_accessor :n d...
这是我的spec文件,当为上下文添加测试“而不是可单独更新用户余额”时,我得到以下错误. require 's...
我有一个拦截器:DevelopmentMailInterceptor和一个启动拦截器的inititializer setup_mail.rb. 但我想将...
例如,如果我有YAML文件 en: questions: new: 'New Question' other: recent: ...
我听说在RSpec中避免它,let,let !,指定,之前和主题是最佳做法. 关于让,让!之前,如果不使用这些,我该如...
我在Rails中使用MongoDB和mongo_mapper gem,项目足够大.有什么办法可以将数据从Mongoid迁移到 Postgres...