2016-09-08 10:25:33 -05:00
|
|
|
# frozen_string_literal: true
|
2016-07-26 17:00:00 -05:00
|
|
|
class User < ApplicationRecord
|
|
|
|
has_secure_password
|
2016-09-15 13:26:31 -05:00
|
|
|
has_many :candidates, foreign_key: :recruiter_id
|
|
|
|
has_many :reviewer_to_quizzes
|
|
|
|
has_many :quizzes, through: :reviewer_to_quizzes
|
2016-08-18 15:35:17 -05:00
|
|
|
|
2016-08-25 19:10:58 -05:00
|
|
|
validates :email, presence: true, uniqueness: true
|
|
|
|
validates :name, presence: true
|
|
|
|
validates :role, presence: true
|
2016-08-24 15:02:32 -05:00
|
|
|
validates :reset_token, uniqueness: true, allow_nil: true
|
|
|
|
|
|
|
|
def setup_reset
|
|
|
|
gen_reset_token
|
|
|
|
save
|
|
|
|
end
|
|
|
|
|
2016-09-21 17:04:08 -05:00
|
|
|
# Roles
|
2016-09-20 14:22:20 -05:00
|
|
|
def admin?
|
2016-09-20 17:19:11 -05:00
|
|
|
'admin' == role
|
|
|
|
end
|
|
|
|
|
2016-09-22 13:30:30 -05:00
|
|
|
def acts_as_admin?
|
|
|
|
'admin' == role
|
|
|
|
end
|
|
|
|
|
2016-09-20 17:19:11 -05:00
|
|
|
def manager?
|
2016-09-22 13:30:30 -05:00
|
|
|
'manager' == role
|
|
|
|
end
|
|
|
|
|
|
|
|
def acts_as_manager?
|
2016-09-20 17:19:11 -05:00
|
|
|
%w(admin manager).include? role
|
|
|
|
end
|
|
|
|
|
|
|
|
def recruiter?
|
|
|
|
'recruiter' == role
|
|
|
|
end
|
|
|
|
|
2016-09-22 13:30:30 -05:00
|
|
|
def acts_as_recruiter?
|
|
|
|
%w(admin recruiter).include? role
|
|
|
|
end
|
|
|
|
|
2016-09-20 17:19:11 -05:00
|
|
|
def reviewer?
|
|
|
|
'reviewer' == role
|
2016-09-20 14:22:20 -05:00
|
|
|
end
|
|
|
|
|
2016-09-22 13:30:30 -05:00
|
|
|
def acts_as_reviewer?
|
|
|
|
%w(admin reviewer).include? role
|
|
|
|
end
|
|
|
|
|
2016-08-24 15:02:32 -05:00
|
|
|
private
|
|
|
|
|
|
|
|
def gen_reset_token
|
|
|
|
loop do
|
|
|
|
self[:reset_token] = SecureRandom.urlsafe_base64(10)
|
2016-09-08 11:52:34 -05:00
|
|
|
self[:reset_timestamp] = DateTime.current
|
2016-08-24 15:02:32 -05:00
|
|
|
break unless User.exists?(reset_token: self[:reset_token])
|
|
|
|
end
|
|
|
|
end
|
2016-07-26 17:00:00 -05:00
|
|
|
end
|