3 class Logger < Faraday::Response::Middleware
6 def initialize(app, logger=nil)
8 @logger = logger || begin
10 ::Logger.new(self.class::LOG_FILE_PATH)
15 def_delegators :@logger, :debug, :info, :warn, :error, :fatal
19 info(env[:method].to_s.upcase) { env[:url].to_s }
20 debug('REQ_HEAD') { dump_headers env[:request_headers] }
21 debug('REQ_BODY') { dump_body env[:body] }
27 info('STATUS') { env[:status].to_s }
28 debug('RES_HEAD') { dump_headers env[:response_headers] }
29 debug('RES_BODY') { dump_body env[:body] }
33 def self.configure(log_file_path)
34 # Return a subclass with its logfile path set. This
35 # must be done so that different sessions can log to
37 Class.new(self) { const_set('LOG_FILE_PATH', log_file_path) }
46 # :TODO => Make this configurable
47 body.gsub(/["']password["']:["']\w*["']/, '"password":[FILTERED_VALUE]')
50 def dump_headers(headers)
51 headers.map { |k, v| "#{k}: #{v.inspect}" }.join("; ")