class Faraday::Request::Multipart
def call(env)
def call(env) match_content_type(env) do |params| env[:request] ||= {} env[:request][:boundary] ||= DEFAULT_BOUNDARY env[:request_headers][CONTENT_TYPE] += ";boundary=#{env[:request][:boundary]}" env[:body] = create_multipart(env, params) end @app.call env end
def create_multipart(env, params)
def create_multipart(env, params) boundary = env[:request][:boundary] parts = process_params(params) do |key, value| Faraday::Parts::Part.new(boundary, key, value) end parts << Faraday::Parts::EpiloguePart.new(boundary) body = Faraday::CompositeReadIO.new(parts) env[:request_headers]['Content-Length'] = body.length.to_s return body end
def has_multipart?(body)
def has_multipart?(body) body.values.each do |val| if val.respond_to?(:content_type) return true elsif val.respond_to?(:values) return true if has_multipart?(val) end end false end
def process_params(params, prefix = nil, pieces = nil, &block)
def process_params(params, prefix = nil, pieces = nil, &block) params.inject(pieces || []) do |all, (key, value)| key = "#{prefix}[#{key}]" if prefix case value when Array values = value.inject([]) { |a,v| a << [nil, v] } process_params(values, key, all, &block) when Hash process_params(value, key, all, &block) else all << block.call(key, value) end end end
def process_request?(env)
def process_request?(env) type = request_type(env) env[:body].respond_to?(:each_key) and !env[:body].empty? and ( (type.empty? and has_multipart?(env[:body])) or type == self.class.mime_type ) end