73 lines
1.8 KiB
73 lines
1.8 KiB
class User < ActiveRecord::Base |
|
include SentientModel |
|
model_stamper |
|
stampable |
|
audited |
|
|
|
# Include default devise modules. Others available are: |
|
# :token_authenticatable, :encryptable, :timeoutable and :omniauthable |
|
devise :database_authenticatable, |
|
:registerable, |
|
:recoverable, |
|
:rememberable, |
|
:trackable, |
|
:validatable, |
|
:confirmable, |
|
:lockable |
|
|
|
validates :first_name, :last_name, :presence => true |
|
|
|
# Setup accessible (or protected) attributes for your model |
|
attr_accessible :email, :password, :password_confirmation, :remember_me, |
|
:first_name, :last_name |
|
|
|
has_many :domains, :inverse_of => :user, :dependent => :destroy |
|
has_many :records, :inverse_of => :user, :dependent => :destroy |
|
has_many :permissions, :inverse_of => :user, :dependent => :destroy |
|
has_many :permitted_domains, :through => :permissions, :source => :domain |
|
has_many :audits, :as => :auditable |
|
|
|
def name |
|
full_name.blank? ? email : full_name |
|
end |
|
|
|
def full_name |
|
"#{first_name} #{last_name}" |
|
end |
|
|
|
# domains per user limit for DOS protection |
|
def domains_exceeding? |
|
domains.count >= Settings.max_domains_per_user.to_i |
|
end |
|
|
|
# Called by Devise to see if an user can currently be signed in |
|
def active_for_authentication? |
|
active? && super |
|
end |
|
|
|
# Called by Devise to get the proper error message when an user cannot be signed in |
|
def inactive_message |
|
!active? ? :deactivated : super |
|
end |
|
|
|
delegate :can?, :cannot?, :to => :ability |
|
|
|
def ability(options = {:reload => false}) |
|
options[:reload] ? _ability : (@ability ||= _ability) |
|
end |
|
|
|
def self.do_as(user) |
|
self.current = user |
|
self.stamper = user |
|
yield |
|
self.current = nil |
|
self.reset_stamper |
|
end |
|
|
|
protected |
|
|
|
def _ability |
|
UserAbility.new(self) |
|
end |
|
|
|
end |