2020-03-13 15:44:24 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Gitlab
|
|
|
|
module SidekiqMiddleware
|
|
|
|
module AdminMode
|
|
|
|
class Server
|
|
|
|
def call(_worker, job, _queue)
|
2021-04-29 21:17:54 +05:30
|
|
|
# Not calling Gitlab::CurrentSettings.admin_mode on purpose on sidekiq middleware
|
|
|
|
# Only when admin_mode setting is enabled can it be true here
|
2020-03-13 15:44:24 +05:30
|
|
|
|
|
|
|
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
|