Sha256: d2a64a3074a5a830e303a18366a4b4f28ec6849bdd6f1c555cb260d400f4b95b

Contents?: true

Size: 1.87 KB

Versions: 35

Compression:

Stored size: 1.87 KB

Contents

# frozen_string_literal: true

module Faraday
  class Request
    # Middleware for instrumenting Requests.
    class Instrumentation < Faraday::Middleware
      # Options class used in Request::Instrumentation class.
      Options = Faraday::Options.new(:name, :instrumenter) do
        remove_method :name
        # @return [String]
        def name
          self[:name] ||= 'request.faraday'
        end

        remove_method :instrumenter
        # @return [Class]
        def instrumenter
          self[:instrumenter] ||= ActiveSupport::Notifications
        end
      end

      # Instruments requests using Active Support.
      #
      # Measures time spent only for synchronous requests.
      #
      # @example Using ActiveSupport::Notifications to measure time spent
      #   for Faraday requests.
      #   ActiveSupport::Notifications
      #     .subscribe('request.faraday') do |name, starts, ends, _, env|
      #     url = env[:url]
      #     http_method = env[:method].to_s.upcase
      #     duration = ends - starts
      #     $stderr.puts '[%s] %s %s (%.3f s)' %
      #       [url.host, http_method, url.request_uri, duration]
      #   end
      # @param app [#call]
      # @param options [nil, Hash] Options hash
      # @option options [String] :name ('request.faraday')
      #   Name of the instrumenter
      # @option options [Class] :instrumenter (ActiveSupport::Notifications)
      #   Active Support instrumenter class.
      def initialize(app, options = nil)
        super(app)
        @name, @instrumenter = Options.from(options)
                                      .values_at(:name, :instrumenter)
      end

      # @param env [Faraday::Env]
      def call(env)
        @instrumenter.instrument(@name, env) do
          @app.call(env)
        end
      end
    end
  end
end

Faraday::Request.register_middleware(instrumentation: Faraday::Request::Instrumentation)

Version data entries

35 entries across 35 versions & 3 rubygems

Version Path
faraday-2.9.0 lib/faraday/request/instrumentation.rb
faraday-2.8.1 lib/faraday/request/instrumentation.rb
moneykit-0.1.2 vendor/bundle/ruby/3.2.0/gems/faraday-2.7.12/lib/faraday/request/instrumentation.rb
faraday-2.8.0 lib/faraday/request/instrumentation.rb
moneykit-0.1.1 vendor/bundle/ruby/3.2.0/gems/faraday-2.7.12/lib/faraday/request/instrumentation.rb
moneykit-0.1.0 vendor/bundle/ruby/3.2.0/gems/faraday-2.7.12/lib/faraday/request/instrumentation.rb
moneykit-0.1.0.alpha.2 vendor/bundle/ruby/3.2.0/gems/faraday-2.7.12/lib/faraday/request/instrumentation.rb
moneykit-0.1.0.alpha.1 vendor/bundle/ruby/3.2.0/gems/faraday-2.7.12/lib/faraday/request/instrumentation.rb
faraday-2.7.12 lib/faraday/request/instrumentation.rb
faraday-2.7.11 lib/faraday/request/instrumentation.rb
faraday-2.7.10 lib/faraday/request/instrumentation.rb
faraday-2.7.9 lib/faraday/request/instrumentation.rb
faraday-2.7.8 lib/faraday/request/instrumentation.rb
faraday-2.7.7 lib/faraday/request/instrumentation.rb
faraday-2.7.6 lib/faraday/request/instrumentation.rb