X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/454ee2b8f0385c542b6f1165a3baf2820425e1a3..70d97b98ddf977505069795ef08236fb439b18e1:/services/api/config/initializers/lograge.rb diff --git a/services/api/config/initializers/lograge.rb b/services/api/config/initializers/lograge.rb index 07dba3aef4..9c0f766915 100644 --- a/services/api/config/initializers/lograge.rb +++ b/services/api/config/initializers/lograge.rb @@ -9,10 +9,26 @@ Server::Application.configure do config.lograge.formatter = Lograge::Formatters::Logstash.new config.lograge.custom_options = lambda do |event| payload = { + ClusterID: Rails.configuration.ClusterID, request_id: event.payload[:request_id], client_ipaddr: event.payload[:client_ipaddr], client_auth: event.payload[:client_auth], } + + # Lograge adds exceptions not being rescued to event.payload, but we're + # catching all errors on ApplicationController so we look for backtraces + # elsewhere. + if !Thread.current[:backtrace].nil? + payload.merge!( + { + exception: Thread.current[:exception], + exception_backtrace: Thread.current[:backtrace], + } + ) + Thread.current[:exception] = nil + Thread.current[:backtrace] = nil + end + exceptions = %w(controller action format id) params = event.payload[:params].except(*exceptions)