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

27 lines
712 B
Ruby
Raw Normal View History

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 #{original_user.username} has stopped impersonating #{impersonator.username}")
2016-04-22 17:19:55 -04:00
session[:impersonator_id] = nil
2016-04-22 17:58:09 -04:00
redirect_to admin_user_path(original_user)
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!
render_404 unless impersonator && impersonator.is_admin? && !impersonator.blocked?
end
end