Sha256: fdaaef4100d63f3bd3afc1aa1dda36bb764c558f6bae15fa46f70892fa6d8831
Contents?: true
Size: 1.51 KB
Versions: 3
Compression:
Stored size: 1.51 KB
Contents
module Samuel module DriverPatches module HTTPClient def self.included(klass) methods_to_wrap = %w(initialize do_get_block do_get_stream) methods_to_wrap.each do |method| klass.send(:alias_method, "#{method}_without_samuel", method) klass.send(:alias_method, method, "#{method}_with_samuel") end end def initialize_with_samuel(*args) initialize_without_samuel(*args) @request_filter << LoggingFilter.new(self) end def do_get_block_with_samuel(req, proxy, conn, &block) begin do_get_block_without_samuel(req, proxy, conn, &block) rescue Exception => e Samuel::Diary.record_response(self, req, e, Time.now) raise end end def do_get_stream_with_samuel(req, proxy, conn) begin do_get_stream_without_samuel(req, proxy, conn) rescue Exception => e Samuel::Diary.record_response(self, req, e, Time.now) raise end end class LoggingFilter def initialize(http_client_instance) @http_client_instance = http_client_instance end def filter_request(request) Samuel::Diary.record_request(@http_client_instance, request, Time.now) end def filter_response(request, response) Samuel::Diary.record_response(@http_client_instance, request, response, Time.now) nil # this returns command symbols like :retry, etc. end end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
samuel-0.3.2 | lib/samuel/driver_patches/http_client.rb |
samuel-0.3.1 | lib/samuel/driver_patches/http_client.rb |
samuel-0.3.0 | lib/samuel/driver_patches/http_client.rb |