1
0
Fork 0
mirror of https://github.com/maybe-finance/maybe.git synced 2025-08-02 20:15:22 +02:00

Impersonation (#1325)

* 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>
This commit is contained in:
Josh Pigford 2024-10-18 11:26:58 -05:00 committed by GitHub
parent 4a3685f503
commit c7c281073f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
29 changed files with 477 additions and 16 deletions

View file

@ -0,0 +1,39 @@
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