首先,请原谅我可怜的英语,我是法国人......解释我的问题很棘手!
我在Rails应用程序中有一个模型用户模型:
class User < ActiveRecord::Base
attr_accessible :email, :gender, :lastname, :firstname
end
从User继承的BackUser模型:
class BackUser < User
# Class for Backoffice User
devise :database_authenticatable,
:rememberable,
:trackable,
:lockable,
:invitable,
:confirmable,
:validatable,
:validate_on_invite => true
attr_accessible :password, :password_confirmation, :remember_me, :active, :role
validates :role, presence: true,
inclusion: ["admin", "normal"]
validates :gender, presence: true
validates :firstname, presence: true
validates :lastname, presence: true
def admin?
self.role == 'admin'
end
end
第二节课应该在邀请之前验证记录! 但是,当我使用控制台执行以下操作时:
u = BackUser.new
u.invite!
“u”保存在数据库中,邀请函将发送到空白电子邮件......
你知道我该做什么吗?
吃了很多!
答案 0 :(得分:18)
我相信你现在已经找到了解决问题或解决问题的方法,但对于遇到同样问题的未来SO用户,我发现了一个非常简单的修复方法。
Devise Invitable's model configuration docs没有完整解释如何实施:validate_on_invite
,但您必须将配置选项设置为true
- :validate_on_invite => true
。
以下是我的用户模型中的设计方法,以使其正常工作。
<强>模型/ user.rb 强>
# Include default devise modules. Others available are:
# :confirmable, :lockable, :timeoutable and :omniauthable
devise :invitable, :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable, :validatable, :validate_on_invite => true
现在,当我尝试提交邀请时,它会在允许发送邀请并创建用户记录之前,使用我在用户模型中设置的验证完全验证记录。查看文档,我猜你也可以在设计初始化程序中启用此设置,但我还没有尝试过这条路线。
* 根据需要启用验证的第二个可能选项
<强>配置/初始化/ devise.rb 强>
config.validate_on_invite = true
答案 1 :(得分:4)
我从来没有能够使验证正常工作,以便设计可用。您不能使用RobHeaton的建议,因为您将收到密码验证错误。我使用这个小黑客来验证工作:
def create
@user = User.new(user_params)
@user.valid?
@user.errors.messages.except!(:password) #remove password from errors
if (@user.errors.any?)
render 'new'
else
@user.invite!(current_user)
redirect_to user_path(@user)
end
end
答案 2 :(得分:-1)
它并没有解决你的行为发生的原因,但是:
if u.save
u.invite!
end
将给出您追求的最终结果。