2020-04-08 14:13:33 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Gitlab
|
|
|
|
module Lograge
|
|
|
|
module CustomOptions
|
2020-05-24 23:13:21 +05:30
|
|
|
include ::Gitlab::Logging::CloudflareHelper
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
LIMITED_ARRAY_SENTINEL = { key: 'truncated', value: '...' }.freeze
|
|
|
|
IGNORE_PARAMS = Set.new(%w(controller action format)).freeze
|
|
|
|
|
|
|
|
def self.call(event)
|
|
|
|
params = event
|
|
|
|
.payload[:params]
|
|
|
|
.each_with_object([]) { |(k, v), array| array << { key: k, value: v } unless IGNORE_PARAMS.include?(k) }
|
|
|
|
|
|
|
|
payload = {
|
|
|
|
time: Time.now.utc.iso8601(3),
|
|
|
|
params: Gitlab::Utils::LogLimitedArray.log_limited_array(params, sentinel: LIMITED_ARRAY_SENTINEL),
|
|
|
|
remote_ip: event.payload[:remote_ip],
|
|
|
|
user_id: event.payload[:user_id],
|
|
|
|
username: event.payload[:username],
|
|
|
|
ua: event.payload[:ua],
|
2020-04-22 19:07:51 +05:30
|
|
|
queue_duration_s: event.payload[:queue_duration_s]
|
2020-04-08 14:13:33 +05:30
|
|
|
}
|
|
|
|
|
2020-05-24 23:13:21 +05:30
|
|
|
payload.merge!(event.payload[:metadata]) if event.payload[:metadata]
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
::Gitlab::InstrumentationHelper.add_instrumentation_data(payload)
|
|
|
|
|
|
|
|
payload[:response] = event.payload[:response] if event.payload[:response]
|
|
|
|
payload[:etag_route] = event.payload[:etag_route] if event.payload[:etag_route]
|
|
|
|
payload[Labkit::Correlation::CorrelationId::LOG_KEY] = Labkit::Correlation::CorrelationId.current_id
|
|
|
|
|
|
|
|
if cpu_s = Gitlab::Metrics::System.thread_cpu_duration(::Gitlab::RequestContext.instance.start_thread_cpu_time)
|
2020-04-22 19:07:51 +05:30
|
|
|
payload[:cpu_s] = cpu_s.round(2)
|
2020-04-08 14:13:33 +05:30
|
|
|
end
|
|
|
|
|
2020-05-24 23:13:21 +05:30
|
|
|
CLOUDFLARE_CUSTOM_HEADERS.each do |_, value|
|
|
|
|
payload[value] = event.payload[value] if event.payload[value]
|
|
|
|
end
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
# https://github.com/roidrage/lograge#logging-errors--exceptions
|
|
|
|
exception = event.payload[:exception_object]
|
|
|
|
|
|
|
|
::Gitlab::ExceptionLogFormatter.format!(exception, payload)
|
|
|
|
|
|
|
|
payload
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|