require 'addressable/uri'
require 'stringio'
require 'google/api_client/discovery'
+require 'google/api_client/logging'
module Google
class APIClient
##
# Represents an API request.
class Request
+ include Google::APIClient::Logging
+
MULTIPART_BOUNDARY = "-----------RubyApiMultipartPost".freeze
# @return [Hash] Request parameters
# @return [Google::APIClient::Result]
# result of API request
def send(connection)
- http_response = connection.app.call(self.to_env(connection))
+ env = self.to_env(connection)
+ logger.debug { "#{self.class} Sending API request #{env[:method]} #{env[:url].to_s} #{env[:request_headers]}" }
+ http_response = connection.app.call(env)
result = self.process_http_response(http_response)
+ logger.debug { "#{self.class} Result: #{result.status} #{result.headers}" }
+
# Resumamble slightly different than other upload protocols in that it requires at least
# 2 requests.
if self.upload_type == 'resumable'
upload = result.resumable_upload
unless upload.complete?
+ logger.debug { "#{self.class} Sending upload body" }
result = upload.send(connection)
end
end
# @return [Array<(Symbol, Addressable::URI, Hash, [#read,#to_str])>]
def to_http_request
request = (
- if self.uri
+ if self.api_method
+ self.api_method.generate_request(self.parameters, self.body, self.headers)
+ elsif self.uri
unless self.parameters.empty?
self.uri.query = Addressable::URI.form_encode(self.parameters)
end
[self.http_method, self.uri.to_s, self.headers, self.body]
- else
- self.api_method.generate_request(self.parameters, self.body, self.headers)
end)
+ return request
end
##
def to_env(connection)
method, uri, headers, body = self.to_http_request
http_request = connection.build_request(method) do |req|
- req.url(uri)
+ req.url(uri.to_s)
req.headers.update(headers)
req.body = body
end