Class: Savon::Response

Inherits:
Object show all
Defined in:
lib/savon/response.rb

Overview

Savon::Response

Savon::Response represents both HTTP and SOAP response.

SOAP fault

Assuming the default behavior of raising errors is disabled, you can ask the response object if there was a SOAP fault or an HTTP error and get the SOAP fault or HTTP error message.

response.soap_fault?
# => true

response.soap_fault
# => "(soap:Server) Fault occurred while processing."

response.http_error?
# => true

response.http_error
# => "Not found (404)"

Response as XML

To get the raw SOAP response XML, you can call to_xml or to_s on the response object.

response.to_xml
=> "<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
=> "..."
=> "</soap:Envelope>"

Response as a Hash

You can also let Savon translate the SOAP response body to a Hash.

response.to_hash
=> { :findUserByIdResponse => {
=>   :id => "123",
=>   :username => "eve"
=>   :active => true
=> }

When translating the SOAP response to a Hash, some XML tags and values are converted to more convenient Ruby objects. Translation is done through John Nunemaker’s Crack library along with some custom mapping.

  • XML tags (Hash keys) are converted to snake_case Symbols and namespaces are stripped off

  • SOAP xs:nil values are converted to nil objects

  • XML values specified in xs:DateTime format are converted to DateTime objects

  • XML values of “true” and “false” are converted to TrueClass and FalseClass

Net::HTTP response

If for some reason you need to access the Net::HTTP response object … you can.

bc. response.http
=> #<Net::HTTPOK:0x7f749a1aa4a8>

Constant Summary collapse

MaxNonErrorResponseCode =

The maximum HTTP response code considered to be OK.

299
@@raise_errors =

The global setting of whether to raise errors.

true

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(http) ⇒ Response

Expects a Net::HTTPResponse and handles errors.



78
79
80
81
82
83
# File 'lib/savon/response.rb', line 78

def initialize(http)
  @http = http

  handle_soap_fault
  handle_http_error
end

Instance Attribute Details

#httpObject (readonly)

Returns the HTTP response object.



112
113
114
# File 'lib/savon/response.rb', line 112

def http
  @http
end

#http_errorObject (readonly)

Returns the HTTP error message.



99
100
101
# File 'lib/savon/response.rb', line 99

def http_error
  @http_error
end

#soap_faultObject (readonly)

Returns the SOAP fault message.



91
92
93
# File 'lib/savon/response.rb', line 91

def soap_fault
  @soap_fault
end

Class Method Details

.raise_errors=(raise_errors) ⇒ Object

Sets the global setting of whether to raise errors.



68
69
70
# File 'lib/savon/response.rb', line 68

def self.raise_errors=(raise_errors)
  @@raise_errors = raise_errors
end

.raise_errors?Boolean

Returns the global setting of whether to raise errors.

Returns:

  • (Boolean)


73
74
75
# File 'lib/savon/response.rb', line 73

def self.raise_errors?
  @@raise_errors
end

Instance Method Details

#http_error?Boolean

Returns whether there was an HTTP error.

Returns:

  • (Boolean)


94
95
96
# File 'lib/savon/response.rb', line 94

def http_error?
  !@http_error.blank?
end

#soap_fault?Boolean

Returns whether there was a SOAP fault.

Returns:

  • (Boolean)


86
87
88
# File 'lib/savon/response.rb', line 86

def soap_fault?
  !@soap_fault.blank?
end

#to_hashObject

Returns the SOAP response body as a Hash.



102
103
104
# File 'lib/savon/response.rb', line 102

def to_hash
  @body ||= (Crack::XML.parse(@http.body) rescue {}).find_soap_body
end

#to_xmlObject Also known as: to_s

Returns the SOAP response XML.



107
108
109
# File 'lib/savon/response.rb', line 107

def to_xml
  @http.body
end