Sha256: 84e402194f1c1469b223a51792bc491b2e39a4b6781632e8605285640077f2e1

Contents?: true

Size: 828 Bytes

Versions: 11

Compression:

Stored size: 828 Bytes

Contents

require 'faraday'

module FaradayMiddleware
  # Public: Instruments requests using Active Support.
  #
  # Measures time spent only for synchronous requests.
  #
  # Examples
  #
  #   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
  class Instrumentation < Faraday::Middleware
    dependency 'active_support/notifications'

    def initialize(app, options = {})
      super(app)
      @name = options.fetch(:name, 'request.faraday')
    end

    def call(env)
      ::ActiveSupport::Notifications.instrument(@name, env) do
        @app.call(env)
      end
    end
  end
end

Version data entries

11 entries across 11 versions & 3 rubygems

Version Path
faraday_middleware-0.14.0 lib/faraday_middleware/instrumentation.rb
faraday_middleware-0.13.1 lib/faraday_middleware/instrumentation.rb
faraday_middleware-0.13.0 lib/faraday_middleware/instrumentation.rb
faraday_middleware-0.12.2 lib/faraday_middleware/instrumentation.rb
faraday_middleware-0.12.0 lib/faraday_middleware/instrumentation.rb
faraday_middleware_safeyaml-0.12.pre.safeyaml lib/faraday_middleware/instrumentation.rb
logstash-input-salesforce-3.0.0 vendor/jruby/1.9/gems/faraday_middleware-0.11.0.1/lib/faraday_middleware/instrumentation.rb
faraday_middleware-0.11.0.1 lib/faraday_middleware/instrumentation.rb
faraday_middleware-0.10.1 lib/faraday_middleware/instrumentation.rb
faraday_middleware-0.10.0 lib/faraday_middleware/instrumentation.rb
faraday_middleware-0.9.2 lib/faraday_middleware/instrumentation.rb