Sha256: d1b10114497a19fdf89ea9ce0ef989276c59d4b5ff53cce324af939fd21ff5ee

Contents?: true

Size: 1.3 KB

Versions: 2

Compression:

Stored size: 1.3 KB

Contents

module RestClient
	# The response from RestClient looks like a string, but is actually one of
	# these.  99% of the time you're making a rest call all you care about is
	# the body, but on the occassion you want to fetch the headers you can:
	#
	#   RestClient.get('http://example.com').headers[:content_type]
	#
	class Response < String
	  include Logging
		attr_reader :net_http_res
    
		def initialize(string, net_http_res)
			@net_http_res = net_http_res
			super(string || "")
		end

		# HTTP status code, always 200 since RestClient throws exceptions for
		# other codes.
		def code
			@code ||= @net_http_res.code.to_i
		end

		# A hash of the headers, beautified with symbols and underscores.
		# e.g. "Content-type" will become :content_type.
		def headers
			@headers ||= self.class.beautify_headers(@net_http_res.to_hash)
		end

    # Hash of cookies extracted from response headers
    def cookies
      @cookies ||= (self.headers[:set_cookie] || "").split('; ').inject({}) do |out, raw_c|
        key, val = raw_c.split('=')
        unless %w(expires domain path secure).member?(key)
          out[key] = val
        end
        out
      end
    end

		def self.beautify_headers(headers)
			headers.inject({}) do |out, (key, value)|
				out[key.gsub(/-/, '_').to_sym] = value.first
				out
			end
		end
	end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
cryx-rest-client-0.9.2 lib/restclient/response.rb
cryx-rest-client-0.9.3 lib/restclient/response.rb