11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
# File 'lib/yarder/rack/logger.rb', line 11
def call(env)
t1 = Time.now
request = ActionDispatch::Request.new(env)
event = Yarder::Event.create Rails.logger, tags(request), true
event['message'] = "#{request.request_method} #{request.filtered_path} for #{request.ip}"
entry = (event.fields['rack'] ||= {})
entry['client_ip'] = request.ip
entry['method'] = request.request_method
entry['path'] = request.filtered_path
entry['url'] = request.url
Yarder.log_entries[Thread.current] = event
status, , response = @app.call(env)
[status, , response]
ensure
if event
entry['status'] = status
event.fields['duration']['total'] = (Time.now - t1)*1000
event.write(true)
end
Yarder.log_entries[Thread.current] = nil
end
|