Skip to content

Instantly share code, notes, and snippets.

@maxlapshin
Created August 19, 2009 14:14
Show Gist options
  • Save maxlapshin/170364 to your computer and use it in GitHub Desktop.
Save maxlapshin/170364 to your computer and use it in GitHub Desktop.
class AsyncRequestLogger
def initialize(app, logger = nil)
@app = app
@logger = logger || Logger.new(STDOUT)
end
def call(env)
time = Time.now
status, header, body = @app.call(env)
ensure
now = Time.now
@logger << %{ [HTTP] %s - %s [%s] "%s %s%s %s" %s %0.4f\n} %
[
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"],
status ? status.to_s[0..3] : "AIO",
now - time
]
[status, header, body]
end
end
Thin::Server.start('0.0.0.0', 4567) do
use AsyncRequestLogger
run ProxyServer.new
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment