docs/README

httparty

Makes http fun again!

Table of contents

Parsing JSON

If the response Content Type is application/json, HTTParty will parse the response and return Ruby objects such as a hash or array. The default behavior for parsing JSON will return keys as strings. This can be supressed with the format option. To get hash keys as symbols:

response = HTTParty.get('http://example.com', format: :plain)
JSON.parse response, symbolize_names: true

Working with SSL

You can use this guide to work with SSL certificates.

Using pem option

# Use this example if you are using a pem file

class Client
    include HTTParty

    base_uri "https://example.com"
    pem File.read("#{File.expand_path('.')}/path/to/certs/cert.pem"), "123456"

end

Using pkcs12 option

# Use this example if you are using a pkcs12 file

class Client
    include HTTParty

    base_uri "https://example.com"
    pkcs12 File.read("#{File.expand_path('.')}/path/to/certs/cert.p12"), "123456"

end

Using ssl_ca_file option

# Use this example if you are using a pkcs12 file

class Client
    include HTTParty

    base_uri "https://example.com"
    ssl_ca_file "#{File.expand_path('.')}/path/to/certs/cert.pem"

end

Using ssl_ca_path option

# Use this example if you are using a pkcs12 file

class Client
    include HTTParty

    base_uri "https://example.com"
    ssl_ca_path '/path/to/certs'
end

You can also include this options with the call:

class Client
    include HTTParty

    base_uri "https://example.com"

    def self.fetch
        get("/resources", pem: (File.read("#{File.expand_path('.')}/path/to/certs/cert.pem"), "123456")
    end
end

Avoid SSL verification

In some cases you may want to skip SSL verification, because the entity that issue the certificate is not a valid one, but you still want to work with it. You can achieve this through:

#Skips SSL certificate verification

class Client
    include HTTParty

    base_uri "https://example.com"
    pem File.read("#{File.expand_path('.')}/path/to/certs/cert.pem"), "123456"

    def self.fetch
        get("/resources", verify: false)
        # You can also use something like:
        # get("resources", verify_peer: false)
    end
end