Sha256: 3c35fbf2811ced234dcc015aac3d68db7632594001f4a977307eea022f200443

Contents?: true

Size: 1.63 KB

Versions: 1

Compression:

Stored size: 1.63 KB

Contents

= Apricot eats Gorilla

Apricot eats Gorilla converts SOAP response messages to Ruby hashes.
It's based on CobraVsMongoose but uses Hpricot instead of REXML and it
also doesn't follow the BadgerFish convention.

== Install

  $ sudo gem sources -a http://gems.github.com
  $ sudo gem install smacks-apricoteatsgorilla hpricot

== An example

Let's assume you receive the following SOAP response message:

  <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
    <soap:Body>
      <ns2:findCustomerByIdResponse xmlns:ns2="http://v1_0.ws.example.com/">
        <return>
          <empty>false</empty>
          <customer>
            <id>449810</id>
            <title xsi:nil="true" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"/>
            <name>Jungle Julia</name>
            <email>jj@example.com</email>
            <address />
          </customer>
        </return>
      </ns2:findCustomerByIdResponse>
    </soap:Body>
  </soap:Envelope>

Just pass in the raw XML string like this:

  require 'apricoteatsgorilla'
  hash = ApricotEatsGorilla.soap_response_to_hash(xml)

And it gets converted into a nice little hash:

  "empty" => false,
  "customer" => {
    "address" => nil,
    "name" => "Jungle Julia",
    "title" => nil,
    "id" => "449810",
    "email" => "jj@example.com"
  }

== The conclusion

* It assumes a root node named "return", but you can pass in an XPath
  expession as the second parameter, to define a different root node.
* All attributes are ignored and won't be included in the hash.
* The value of empty element nodes will be nil.
* Values of "true" or "false" will be converted to boolean objects.

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
smacks-apricoteatsgorilla-0.1.1 README.rdoc