Class: SalesforceBulkQuery::Logger
- Inherits:
-
Faraday::Response::Middleware
- Object
- Faraday::Response::Middleware
- SalesforceBulkQuery::Logger
- 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
- #call(env) ⇒ Object
- #dump(hash) ⇒ Object
-
#initialize(app, logger, options) ⇒ Logger
constructor
A new instance of Logger.
- #on_complete(env) ⇒ Object
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, ) super(app) @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 |