Sha256: 2913d7ff313ebf3437b1d0993eb666b20b60af2d111ec11fdee96f066f47f051
Contents?: true
Size: 1.03 KB
Versions: 41
Compression:
Stored size: 1.03 KB
Contents
# frozen_string_literal: true require 'forwardable' require 'logger' require 'faraday/logging/formatter' module Faraday class Response # Logger is a middleware that logs internal events in the HTTP request # lifecycle to a given Logger object. By default, this logs to STDOUT. See # Faraday::Logging::Formatter to see specifically what is logged. class Logger < Middleware def initialize(app, logger = nil, options = {}) super(app) logger ||= ::Logger.new($stdout) formatter_class = options.delete(:formatter) || Logging::Formatter @formatter = formatter_class.new(logger: logger, options: options) yield @formatter if block_given? end def call(env) @formatter.request(env) super end def on_complete(env) @formatter.response(env) end def on_error(exc) @formatter.exception(exc) if @formatter.respond_to?(:exception) end end end end Faraday::Response.register_middleware(logger: Faraday::Response::Logger)
Version data entries
41 entries across 41 versions & 5 rubygems