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' }
如果事情开始变得更加复杂,您可以探索使用单表继承将每种类型的用户的逻辑分离到单独的类中。