diff options
Diffstat (limited to 'config/initializers/rack_attack.rb')
-rw-r--r-- | config/initializers/rack_attack.rb | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/config/initializers/rack_attack.rb b/config/initializers/rack_attack.rb index b0778633199..58bf3f6013c 100644 --- a/config/initializers/rack_attack.rb +++ b/config/initializers/rack_attack.rb @@ -1,3 +1,5 @@ +# frozen_string_literal: true + # Specs for this file can be found on: # * spec/lib/gitlab/throttle_spec.rb # * spec/requests/rack_attack_global_spec.rb @@ -15,6 +17,13 @@ module Gitlab::Throttle Rack::Attack.throttles.key?('protected paths') end + def self.bypass_header + env_value = ENV['GITLAB_THROTTLE_BYPASS_HEADER'] + return unless env_value.present? + + "HTTP_#{env_value.upcase.tr('-', '_')}" + end + def self.unauthenticated_options limit_proc = proc { |req| settings.throttle_unauthenticated_requests_per_period } period_proc = proc { |req| settings.throttle_unauthenticated_period_in_seconds.seconds } @@ -112,6 +121,11 @@ class Rack::Attack end end + safelist('throttle_bypass_header') do |req| + Gitlab::Throttle.bypass_header.present? && + req.get_header(Gitlab::Throttle.bypass_header) == '1' + end + class Request def unauthenticated? !(authenticated_user_id([:api, :rss, :ics]) || authenticated_runner_id) |