Module: HTTParty::HashConversions

Defined in:
lib/httparty/hash_conversions.rb

Class Method Summary collapse

Class Method Details

.normalize_param(key, value) ⇒ String

Returns This key value pair as a param.

Examples:

normalize_param(:name, “Bob Jones”) #=> “name=Bob%20Jones&”

Parameters:

  • key (Object)

    The key for the param.

  • value (Object)

    The value for the param.

Returns:

  • (String)

    This key value pair as a param



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/httparty/hash_conversions.rb', line 24

def self.normalize_param(key, value)
  param = ''
  stack = []

  if value.respond_to?(:to_ary)
    param << if value.empty?
               "#{key}[]=&"
             else
               value.to_ary.map { |element| normalize_param("#{key}[]", element) }.join
             end
  elsif value.respond_to?(:to_hash)
    stack << [key, value.to_hash]
  else
    param << "#{key}=#{ERB::Util.url_encode(value.to_s)}&"
  end

  stack.each do |parent, hash|
    hash.each do |k, v|
      if v.respond_to?(:to_hash)
        stack << ["#{parent}[#{k}]", v.to_hash]
      else
        param << normalize_param("#{parent}[#{k}]", v)
      end
    end
  end

  param
end

.to_params(hash) ⇒ String

Returns This hash as a query string.

Examples:

{ name: "Bob",
  address: {
    street: '111 Ruby Ave.',
    city: 'Ruby Central',
    phones: ['111-111-1111', '222-222-2222']
  }
}.to_params
  #=> "name=Bob&address[city]=Ruby Central&address[phones][]=111-111-1111&address[phones][]=222-222-2222&address[street]=111 Ruby Ave."

Returns:

  • (String)

    This hash as a query string



14
15
16
# File 'lib/httparty/hash_conversions.rb', line 14

def self.to_params(hash)
  hash.to_hash.map { |k, v| normalize_param(k, v) }.join.chop
end