我有这个密码验证规则 - 我想在用户创建帐户时验证密码,然后在设置中验证密码 - 如果他不更改密码,我不想更改它(仅当相应的用户将更改它时 = 他通过密码确认设置新密码)。
这是我所拥有的:
validates :password,
:length => {:within => 6..40},
:on => :create
但是规则:on => :create
对我不起作用 - 如果我在设置中发送空白密码,我仍然会收到有关密码不正确的错误。
我做错了什么?
看起来应该这样做:
validates :password, length: { within: (6..40) }, if: -> user { not user.persisted? or user.password.present? }
仅当用户尚未持久化(create
操作)或稍后提供了密码(通过设置)时,它才会验证密码