Sha256: 9d37f67a35acc8419f5940092103c4073203fd435be6af613d2361cac5812181
Contents?: true
Size: 1.97 KB
Versions: 2
Compression:
Stored size: 1.97 KB
Contents
require "httpi" require "savon/soap/response" module Savon module SOAP # = Savon::SOAP::Request # # Executes SOAP requests. class Request # Content-Types by SOAP version. ContentType = { 1 => "text/xml;charset=UTF-8", 2 => "application/soap+xml;charset=UTF-8" } # Expects an <tt>HTTPI::Request</tt> and a <tt>Savon::SOAP::XML</tt> object # to execute a SOAP request and returns the response. def self.execute(http, soap) new(http, soap).response end # Expects an <tt>HTTPI::Request</tt> and a <tt>Savon::SOAP::XML</tt> object. def initialize(http, soap) self.soap = soap self.http = configure(http) end attr_accessor :soap, :http # Executes the request and returns the response. def response @response ||= SOAP::Response.new( Savon.hooks.select(:soap_request).call(self) || with_logging { HTTPI.post(http) } ) end private # Configures a given +http+ from the +soap+ object. def configure(http) http.url = soap.endpoint http.body = soap.to_xml http.headers["Content-Type"] = ContentType[soap.version] http.headers["Content-Length"] = soap.to_xml.bytesize.to_s http end # Logs the HTTP request, yields to a given +block+ and returns a <tt>Savon::SOAP::Response</tt>. def with_logging log_request http.url, http.headers, http.body response = yield log_response response.code, response.body response end # Logs the SOAP request +url+, +headers+ and +body+. def log_request(url, headers, body) Savon.log "SOAP request: #{url}" Savon.log headers.map { |key, value| "#{key}: #{value}" }.join(", ") Savon.log body, :filter end # Logs the SOAP response +code+ and +body+. def log_response(code, body) Savon.log "SOAP response (status #{code}):" Savon.log body end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
savon-0.9.9 | lib/savon/soap/request.rb |
savon-0.9.8 | lib/savon/soap/request.rb |