mirror of
https://github.com/puma/puma.git
synced 2022-11-09 13:48:40 -05:00
Improve the logging output when hijack is used. Fixes #332
This commit is contained in:
parent
3726b7ef19
commit
09bffcfc96
2 changed files with 23 additions and 1 deletions
|
@ -13,7 +13,10 @@ module Rack
|
|||
status, header, body = @app.call(env)
|
||||
header = Utils::HeaderHash.new(header)
|
||||
|
||||
if ary = env['rack.after_reply']
|
||||
# If we've been hijacked, then output a special line
|
||||
if env['rack.hijack_io']
|
||||
log_hijacking(env, 'HIJACK', header, began_at)
|
||||
elsif ary = env['rack.after_reply']
|
||||
ary << lambda { log(env, status, header, began_at) }
|
||||
else
|
||||
body = BodyProxy.new(body) { log(env, status, header, began_at) }
|
||||
|
@ -21,5 +24,22 @@ module Rack
|
|||
|
||||
[status, header, body]
|
||||
end
|
||||
|
||||
HIJACK_FORMAT = %{%s - %s [%s] "%s %s%s %s" HIJACKED -1 %0.4f\n}
|
||||
|
||||
def log_hijacking(env, status, header, began_at)
|
||||
now = Time.now
|
||||
|
||||
logger = @logger || env['rack.errors']
|
||||
logger.write HIJACK_FORMAT % [
|
||||
env['HTTP_X_FORWARDED_FOR'] || env["REMOTE_ADDR"] || "-",
|
||||
env["REMOTE_USER"] || "-",
|
||||
now.strftime("%d/%b/%Y %H:%M:%S"),
|
||||
env["REQUEST_METHOD"],
|
||||
env["PATH_INFO"],
|
||||
env["QUERY_STRING"].empty? ? "" : "?"+env["QUERY_STRING"],
|
||||
env["HTTP_VERSION"],
|
||||
now - began_at ]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -13,6 +13,8 @@ require 'puma/delegation'
|
|||
require 'puma/accept_nonblock'
|
||||
require 'puma/util'
|
||||
|
||||
require 'puma/rack_patch'
|
||||
|
||||
require 'puma/puma_http11'
|
||||
|
||||
unless Puma.const_defined? "IOBuffer"
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue