gitlab-org--gitlab-foss/app/controllers/admin/impersonations_controller.rb

29 lines
756 B
Ruby
Raw Normal View History

# frozen_string_literal: true
2016-04-22 17:19:55 -04:00
class Admin::ImpersonationsController < Admin::ApplicationController
skip_before_action :authenticate_admin!
before_action :authenticate_impersonator!
def destroy
2016-04-22 17:58:09 -04:00
original_user = current_user
2016-04-22 17:19:55 -04:00
warden.set_user(impersonator, scope: :user)
Gitlab::AppLogger.info("User #{impersonator.username} has stopped impersonating #{original_user.username}")
2016-04-22 17:19:55 -04:00
session[:impersonator_id] = nil
2018-07-02 06:43:06 -04:00
redirect_to admin_user_path(original_user), status: :found
2016-04-22 17:19:55 -04:00
end
private
def impersonator
@impersonator ||= User.find(session[:impersonator_id]) if session[:impersonator_id]
end
def authenticate_impersonator!
2017-04-08 22:20:57 -04:00
render_404 unless impersonator && impersonator.admin? && !impersonator.blocked?
2016-04-22 17:19:55 -04:00
end
end