Sha256: 8c0f989d965305ba50417eebbbf0fe9f10276d4c503ae311391e069155bf1e0c
Contents?: true
Size: 1.12 KB
Versions: 2
Compression:
Stored size: 1.12 KB
Contents
require "faraday/middleware" module ZaloAPI module Middleware module Request # Faraday middleware to handle HTTP Status 429 (rate limiting) / 503 (maintenance) # @private class Retry < Faraday::Middleware DEFAULT_RETRY_AFTER = 10 ERROR_CODES = [429, 503] def initialize(app, options = {}) super(app) @logger = options[:logger] end def call(env) original_env = env.dup response = @app.call(env) if ERROR_CODES.include?(response.env[:status]) seconds_left = (response.env[:response_headers][:retry_after] || DEFAULT_RETRY_AFTER).to_i @logger.warn "You have been rate limited. Retrying in #{seconds_left} seconds..." if @logger seconds_left.times do |i| sleep 1 time_left = seconds_left - i @logger.warn "#{time_left}..." if time_left > 0 && time_left % 5 == 0 && @logger end @logger.warn "" if @logger @app.call(original_env) else response end end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
zalo-api-0.1.1 | lib/zalo_api/middleware/request/retry.rb |
zalo-api-0.1.0 | lib/zalo_api/middleware/request/retry.rb |