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