mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-07-19 05:09:38 +02:00
* Initial impersonation * Impersonation audit * Keep super admin separate * Remove vscode settings * Comment cleanup * Comment out impersonation fixtures for now * Remove unused controlelr * Add impersonation testing (#1326) * Add impersonation testing * Remove unused method * Update schema.rb * Update brakeman --------- Co-authored-by: Zach Gollwitzer <zach@maybe.co>
39 lines
1.1 KiB
Ruby
39 lines
1.1 KiB
Ruby
class ImpersonationSession < ApplicationRecord
|
|
belongs_to :impersonator, class_name: "User"
|
|
belongs_to :impersonated, class_name: "User"
|
|
|
|
has_many :logs, class_name: "ImpersonationSessionLog"
|
|
|
|
enum :status, { pending: "pending", in_progress: "in_progress", complete: "complete", rejected: "rejected" }
|
|
|
|
scope :initiated, -> { where(status: [ :pending, :in_progress ]) }
|
|
|
|
validate :impersonator_is_super_admin
|
|
validate :impersonated_is_not_super_admin
|
|
validate :impersonator_different_from_impersonated
|
|
|
|
def approve!
|
|
update! status: :in_progress
|
|
end
|
|
|
|
def reject!
|
|
update! status: :rejected
|
|
end
|
|
|
|
def complete!
|
|
update! status: :complete
|
|
end
|
|
|
|
private
|
|
def impersonator_is_super_admin
|
|
errors.add(:impersonator, "must be a super admin to impersonate") unless impersonator.super_admin?
|
|
end
|
|
|
|
def impersonated_is_not_super_admin
|
|
errors.add(:impersonated, "cannot be a super admin") if impersonated.super_admin?
|
|
end
|
|
|
|
def impersonator_different_from_impersonated
|
|
errors.add(:impersonator, "cannot be the same as the impersonated user") if impersonator == impersonated
|
|
end
|
|
end
|