Class: SalesforceBulkQuery::Logger

Inherits:
Faraday::Response::Middleware
  • Object
show all
Extended by:
Forwardable
Defined in:
lib/salesforce_bulk_query/logger.rb

Overview

Custom logger for Restforce that doesn’t log tons of data.

Constant Summary collapse

MAX_LOG_LENGTH =
2000

Instance Method Summary collapse

Constructor Details

#initialize(app, logger, options) ⇒ Logger

Returns a new instance of Logger.



11
12
13
14
15
16
17
18
# File 'lib/salesforce_bulk_query/logger.rb', line 11

def initialize(app, logger, options)
  super(app)
  @options = options
  @logger = logger || begin
    require 'logger'
    ::Logger.new(STDOUT)
  end
end

Instance Method Details

#call(env) ⇒ Object



22
23
24
25
26
27
28
29
30
# File 'lib/salesforce_bulk_query/logger.rb', line 22

def call(env)
  debug('request') do
    dump :url => env[:url].to_s,
      :method => env[:method],
      :headers => env[:request_headers],
      :body => env[:body] ? env[:body][0..MAX_LOG_LENGTH] : nil
  end
  super
end

#dump(hash) ⇒ Object



40
41
42
# File 'lib/salesforce_bulk_query/logger.rb', line 40

def dump(hash)
  "\n" + hash.map { |k, v| " #{k}: #{v.inspect}" }.join("\n")
end

#on_complete(env) ⇒ Object



32
33
34
35
36
37
38
# File 'lib/salesforce_bulk_query/logger.rb', line 32

def on_complete(env)
  debug('response') do
    dump :status => env[:status].to_s,
      :headers => env[:response_headers],
      :body => env[:body] ? env[:body][0..MAX_LOG_LENGTH] : nil
  end
end