验证用户模型中特定角色名称的唯一性


add_column :users, :role, :string
class User < ActiveRecord::Base
  attr_accessible :email, :password, :remember_me, :username
  devise :database_authenticatable, ................
  validates_uniqueness_of :username, :email
  before_create :setup_default_role_for_new_users
  ROLES = %w[admin default banned]
  private
  def setup_default_role_for_new_users
    if self.role.blank?
      self.role = "default"
    end
  end
end

有没有办法专门验证:role列中的名称?我想让我的"admin"角色独一无二,这样我就可以保证出于安全原因不会再次使用它。

如果您只有一个管理员角色,则可以执行以下操作:

validates_uniqueness_of :name, :if => lambda {|user| user.role == 'admin' }

如果事情开始变得更加复杂,您可以探索使用单表继承将每种类型的用户的逻辑分离到单独的类中。

最新更新