# frozen_string_literal: true

module Gitlab
  module SidekiqMiddleware
    module AdminMode
      class Server
        def call(_worker, job, _queue)
          return yield unless Feature.enabled?(:user_mode_in_session)

          admin_mode_user_id = job['admin_mode_user_id']

          # Do not bypass session if this job was not enabled with admin mode on
          return yield unless admin_mode_user_id

          Gitlab::Auth::CurrentUserMode.bypass_session!(admin_mode_user_id) do
            Gitlab::AppLogger.debug("AdminMode::Server bypasses session for admin mode in job: #{job.inspect}")

            yield
          end
        end
      end
    end
  end
end