1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
|
# frozen_string_literal: true
module BitbucketServer
module RetryWithDelay
extend ActiveSupport::Concern
MAXIMUM_DELAY = 20
def retry_with_delay(&block)
run_retry_with_delay(&block)
end
private
def run_retry_with_delay
response = yield
if response.code == 429 && response.headers.has_key?('retry-after')
retry_after = response.headers['retry-after'].to_i
if retry_after <= MAXIMUM_DELAY
logger.info(message: "Retrying in #{retry_after} seconds due to 429 Too Many Requests")
sleep retry_after
response = yield
end
end
response
end
end
end
|