2017-11-11 14:23:33 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class UserPolicy < ApplicationPolicy
|
|
|
|
def reset_password?
|
|
|
|
staff? && !record.staff?
|
|
|
|
end
|
|
|
|
|
2018-04-10 03:16:06 -04:00
|
|
|
def change_email?
|
|
|
|
staff? && !record.staff?
|
|
|
|
end
|
|
|
|
|
2017-11-11 14:23:33 -05:00
|
|
|
def disable_2fa?
|
|
|
|
admin? && !record.staff?
|
|
|
|
end
|
|
|
|
|
2021-07-07 23:31:28 -04:00
|
|
|
def disable_sign_in_token_auth?
|
|
|
|
staff?
|
|
|
|
end
|
|
|
|
|
|
|
|
def enable_sign_in_token_auth?
|
|
|
|
staff?
|
|
|
|
end
|
|
|
|
|
2017-11-11 14:23:33 -05:00
|
|
|
def confirm?
|
|
|
|
staff? && !record.confirmed?
|
|
|
|
end
|
|
|
|
|
|
|
|
def enable?
|
2018-08-23 17:26:29 -04:00
|
|
|
staff?
|
2017-11-11 14:23:33 -05:00
|
|
|
end
|
|
|
|
|
2019-03-14 00:28:30 -04:00
|
|
|
def approve?
|
|
|
|
staff? && !record.approved?
|
|
|
|
end
|
|
|
|
|
|
|
|
def reject?
|
|
|
|
staff? && !record.approved?
|
|
|
|
end
|
|
|
|
|
2017-11-11 14:23:33 -05:00
|
|
|
def disable?
|
2018-08-23 17:26:29 -04:00
|
|
|
staff? && !record.admin?
|
2017-11-11 14:23:33 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def promote?
|
2022-03-06 16:51:40 -05:00
|
|
|
admin? && promotable?
|
2017-11-11 14:23:33 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def demote?
|
|
|
|
admin? && !record.admin? && demoteable?
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2022-03-06 16:51:40 -05:00
|
|
|
def promotable?
|
2019-03-14 00:28:30 -04:00
|
|
|
record.approved? && (!record.staff? || !record.admin?)
|
2017-11-11 14:23:33 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def demoteable?
|
|
|
|
record.staff?
|
|
|
|
end
|
|
|
|
end
|