diff options
author | Jamis Buck <jamis@37signals.com> | 2006-10-23 22:21:09 +0000 |
---|---|---|
committer | Jamis Buck <jamis@37signals.com> | 2006-10-23 22:21:09 +0000 |
commit | 9c9443812f1274667cea14edd387c6124205ac1c (patch) | |
tree | 9d1820ecd0b19802ff3d049c1ac4d102f83deef8 /activeresource/lib/active_resource | |
parent | 18e2188f5d4453e551fc0ed1e1603205e69e51bb (diff) | |
download | rails-9c9443812f1274667cea14edd387c6124205ac1c.tar.gz rails-9c9443812f1274667cea14edd387c6124205ac1c.tar.bz2 rails-9c9443812f1274667cea14edd387c6124205ac1c.zip |
Add basic logging support for logging outgoing requests.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@5343 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activeresource/lib/active_resource')
-rw-r--r-- | activeresource/lib/active_resource/base.rb | 4 | ||||
-rw-r--r-- | activeresource/lib/active_resource/connection.rb | 13 |
2 files changed, 15 insertions, 2 deletions
diff --git a/activeresource/lib/active_resource/base.rb b/activeresource/lib/active_resource/base.rb index 40fd965487..05013e8edd 100644 --- a/activeresource/lib/active_resource/base.rb +++ b/activeresource/lib/active_resource/base.rb @@ -2,6 +2,10 @@ require 'active_resource/connection' module ActiveResource class Base + # The logger for logging diagnostic and trace information during ARes + # calls. + cattr_accessor :logger + class << self attr_reader :site diff --git a/activeresource/lib/active_resource/connection.rb b/activeresource/lib/active_resource/connection.rb index 57471957e2..1a1b376d3a 100644 --- a/activeresource/lib/active_resource/connection.rb +++ b/activeresource/lib/active_resource/connection.rb @@ -2,6 +2,7 @@ require 'net/https' require 'date' require 'time' require 'uri' +require 'benchmark' module ActiveResource class ConnectionError < StandardError @@ -63,8 +64,12 @@ module ActiveResource end private - def request(method, *arguments) - handle_response(http.send(method, *arguments)) + def request(method, path, *arguments) + logger.info "requesting #{method.to_s.upcase} #{site.scheme}://#{site.host}:#{site.port}#{path}" if logger + result = nil + time = Benchmark.realtime { result = http.send(method, path, *arguments) } + logger.info "--> #{result.code} #{result.message} (#{result.body.length}b %.2fs)" % time if logger + handle_response(result) end def handle_response(response) @@ -103,5 +108,9 @@ module ActiveResource def authorization_header (@site.user || @site.password ? { 'Authorization' => 'Basic ' + ["#{@site.user}:#{ @site.password}"].pack('m').delete("\r\n") } : {}) end + + def logger + ActiveResource::Base.logger + end end end |