You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

70 lines
2.0 KiB

class User < ApplicationRecord
enum :role, { user: 'user', admin: 'admin' }, suffix: true
include PgSearch::Model
pg_search_scope :pg_search, against: [:lastname, :firstname, :email, :phone, :title],
using: {tsearch: {dictionary: "danish"}}
has_secure_password
has_many :verification_codes, dependent: :destroy
before_destroy :dont_destroy_admin
validates_presence_of :email
validates_presence_of :password, on: :create
validates_uniqueness_of :email
validates_format_of :email, with: URI::MailTo::EMAIL_REGEXP
normalizes :email, with: -> email { email.strip.downcase }
validate :cant_change_admin, on: :update
scope :enabled, -> { where.not enabled_at: nil }
scope :by_last_modified, ->(rev) { order(updated_at: rev ? :asc : :desc) }
scope :by_name, ->(rev) { order(lastname: rev ? :desc : :asc, firstname: rev ? :desc : :asc) }
scope :by_email, ->(rev) { order(email: rev ? :desc : :asc) }
scope :by_title, ->(rev) { order(title: rev ? :desc : :asc) }
scope :simple_search, ->(q) { pg_search(q) unless q.blank? }
def su?
email == 'mattias@oncotype.dk'
end
def name
return email if lastname.blank? and firstname.blank?
[firstname, lastname].select{ |v| !v.blank? }.join(' ')
end
def initials
name.split(' ').map{ |s| s[0] }.join('').mb_chars.upcase
end
def enabled?
!self.enabled_at.nil?
end
protected
#Prevent the user admins from beeing changed
def cant_change_admin
user = self.class.find(self.id)
errors.add(:email, I18n.t(:you_cant_change_the_email_on_this_user, scope: 'users')) if user.su? and self.email != user.email
errors.add(:email, I18n.t(:you_cant_change_this_on_this_user, scope: 'users')) if user.su? and !self.admin_role? and self.role_changed?
errors.add(:email, I18n.t(:you_cant_disable_this_user, scope: 'users')) if user.su? and self.enabled_at.nil?
end
# Prevents the super user admin to be removed"
def dont_destroy_admin
raise I18n.t(:cant_destroy_this_user, scope: 'users') if self.su?
end
end