Ranjib| there is n method/instance variable named options inside serialize, to_hash should be invoke on 'body' instead
This commit is contained in:
		
							parent
							
								
									4a72c529bf
								
							
						
					
					
						commit
						bd04489a43
					
				|  | @ -27,7 +27,7 @@ module Google | ||||||
|     # Represents an API request. |     # Represents an API request. | ||||||
|     class Request |     class Request | ||||||
|       MULTIPART_BOUNDARY = "-----------RubyApiMultipartPost".freeze |       MULTIPART_BOUNDARY = "-----------RubyApiMultipartPost".freeze | ||||||
|        | 
 | ||||||
|       # @return [Hash] Request parameters |       # @return [Hash] Request parameters | ||||||
|       attr_reader :parameters |       attr_reader :parameters | ||||||
|       # @return [Hash] Additional HTTP headers |       # @return [Hash] Additional HTTP headers | ||||||
|  | @ -42,7 +42,7 @@ module Google | ||||||
|       attr_accessor :authenticated |       attr_accessor :authenticated | ||||||
|       # @return [#read, #to_str] Request body |       # @return [#read, #to_str] Request body | ||||||
|       attr_accessor :body |       attr_accessor :body | ||||||
|        | 
 | ||||||
|       ## |       ## | ||||||
|       # Build a request |       # Build a request | ||||||
|       # |       # | ||||||
|  | @ -52,7 +52,7 @@ module Google | ||||||
|       # @option options [Google::APIClient::Method] :api_method |       # @option options [Google::APIClient::Method] :api_method | ||||||
|       #   API method to invoke. Either :api_method or :uri must be specified |       #   API method to invoke. Either :api_method or :uri must be specified | ||||||
|       # @option options [TrueClass, FalseClass] :authenticated |       # @option options [TrueClass, FalseClass] :authenticated | ||||||
|       #   True if request should include credentials. Implicitly true if  |       #   True if request should include credentials. Implicitly true if | ||||||
|       #   unspecified and :authorization present |       #   unspecified and :authorization present | ||||||
|       # @option options [#generate_signed_request] :authorization |       # @option options [#generate_signed_request] :authorization | ||||||
|       #   OAuth credentials |       #   OAuth credentials | ||||||
|  | @ -74,12 +74,12 @@ module Google | ||||||
|         self.api_method = options[:api_method] |         self.api_method = options[:api_method] | ||||||
|         self.authenticated = options[:authenticated] |         self.authenticated = options[:authenticated] | ||||||
|         self.authorization = options[:authorization] |         self.authorization = options[:authorization] | ||||||
|          | 
 | ||||||
|         # These parameters are handled differently because they're not |         # These parameters are handled differently because they're not | ||||||
|         # parameters to the API method, but rather to the API system. |         # parameters to the API method, but rather to the API system. | ||||||
|         self.parameters['key'] ||= options[:key] if options[:key] |         self.parameters['key'] ||= options[:key] if options[:key] | ||||||
|         self.parameters['userIp'] ||= options[:user_ip] if options[:user_ip] |         self.parameters['userIp'] ||= options[:user_ip] if options[:user_ip] | ||||||
|          | 
 | ||||||
|         if options[:media] |         if options[:media] | ||||||
|           self.initialize_media_upload(options) |           self.initialize_media_upload(options) | ||||||
|         elsif options[:body] |         elsif options[:body] | ||||||
|  | @ -90,13 +90,13 @@ module Google | ||||||
|         else |         else | ||||||
|           self.body = '' |           self.body = '' | ||||||
|         end |         end | ||||||
|          | 
 | ||||||
|         unless self.api_method |         unless self.api_method | ||||||
|           self.http_method = options[:http_method] || 'GET' |           self.http_method = options[:http_method] || 'GET' | ||||||
|           self.uri = options[:uri] |           self.uri = options[:uri] | ||||||
|         end |         end | ||||||
|       end |       end | ||||||
|        | 
 | ||||||
|       # @!attribute [r] upload_type |       # @!attribute [r] upload_type | ||||||
|       # @return [String] protocol used for upload |       # @return [String] protocol used for upload | ||||||
|       def upload_type |       def upload_type | ||||||
|  | @ -128,7 +128,7 @@ module Google | ||||||
|             "Expected Google::APIClient::Method, got #{new_api_method.class}." |             "Expected Google::APIClient::Method, got #{new_api_method.class}." | ||||||
|         end |         end | ||||||
|       end |       end | ||||||
|        | 
 | ||||||
|       # @!attribute uri |       # @!attribute uri | ||||||
|       # @return [Addressable::URI] URI to send request |       # @return [Addressable::URI] URI to send request | ||||||
|       def uri |       def uri | ||||||
|  | @ -145,15 +145,15 @@ module Google | ||||||
|       # |       # | ||||||
|       # @api private |       # @api private | ||||||
|       # |       # | ||||||
|       # @param [Faraday::Connection] connection  |       # @param [Faraday::Connection] connection | ||||||
|       #   the connection to transmit with |       #   the connection to transmit with | ||||||
|       #  |       # | ||||||
|       # @return [Google::APIClient::Result]  |       # @return [Google::APIClient::Result] | ||||||
|       #   result of API request |       #   result of API request | ||||||
|       def send(connection) |       def send(connection) | ||||||
|         http_response = connection.app.call(self.to_env(connection))         |         http_response = connection.app.call(self.to_env(connection)) | ||||||
|         result = self.process_http_response(http_response) |         result = self.process_http_response(http_response) | ||||||
|          | 
 | ||||||
|         # Resumamble slightly different than other upload protocols in that it requires at least |         # Resumamble slightly different than other upload protocols in that it requires at least | ||||||
|         # 2 requests. |         # 2 requests. | ||||||
|         if self.upload_type == 'resumable' |         if self.upload_type == 'resumable' | ||||||
|  | @ -164,7 +164,7 @@ module Google | ||||||
|         end |         end | ||||||
|         return result |         return result | ||||||
|       end |       end | ||||||
|        | 
 | ||||||
|       # Convert to an HTTP request. Returns components in order of method, URI, |       # Convert to an HTTP request. Returns components in order of method, URI, | ||||||
|       # request headers, and body |       # request headers, and body | ||||||
|       # |       # | ||||||
|  | @ -172,7 +172,7 @@ module Google | ||||||
|       # |       # | ||||||
|       # @return [Array<(Symbol, Addressable::URI, Hash, [#read,#to_str])>] |       # @return [Array<(Symbol, Addressable::URI, Hash, [#read,#to_str])>] | ||||||
|       def to_http_request |       def to_http_request | ||||||
|         request = (  |         request = ( | ||||||
|           if self.uri |           if self.uri | ||||||
|             unless self.parameters.empty? |             unless self.parameters.empty? | ||||||
|               self.uri.query = Addressable::URI.form_encode(self.parameters) |               self.uri.query = Addressable::URI.form_encode(self.parameters) | ||||||
|  | @ -204,7 +204,7 @@ module Google | ||||||
|         end |         end | ||||||
|         return options |         return options | ||||||
|       end |       end | ||||||
|        | 
 | ||||||
|       ## |       ## | ||||||
|       # Prepares the request for execution, building a hash of parts |       # Prepares the request for execution, building a hash of parts | ||||||
|       # suitable for sending to Faraday::Connection. |       # suitable for sending to Faraday::Connection. | ||||||
|  | @ -233,7 +233,7 @@ module Google | ||||||
| 
 | 
 | ||||||
|         request_env = http_request.to_env(connection) |         request_env = http_request.to_env(connection) | ||||||
|       end |       end | ||||||
|        | 
 | ||||||
|       ## |       ## | ||||||
|       # Convert HTTP response to an API Result |       # Convert HTTP response to an API Result | ||||||
|       # |       # | ||||||
|  | @ -247,9 +247,9 @@ module Google | ||||||
|       def process_http_response(response) |       def process_http_response(response) | ||||||
|         Result.new(self, response) |         Result.new(self, response) | ||||||
|       end |       end | ||||||
|        | 
 | ||||||
|       protected |       protected | ||||||
|        | 
 | ||||||
|       ## |       ## | ||||||
|       # Adjust headers & body for media uploads |       # Adjust headers & body for media uploads | ||||||
|       # |       # | ||||||
|  | @ -269,14 +269,14 @@ module Google | ||||||
|         self.media = options[:media] |         self.media = options[:media] | ||||||
|         case self.upload_type |         case self.upload_type | ||||||
|         when "media" |         when "media" | ||||||
|           if options[:body] || options[:body_object]  |           if options[:body] || options[:body_object] | ||||||
|             raise ArgumentError, "Can not specify body & body object for simple uploads" |             raise ArgumentError, "Can not specify body & body object for simple uploads" | ||||||
|           end |           end | ||||||
|           self.headers['Content-Type'] ||= self.media.content_type |           self.headers['Content-Type'] ||= self.media.content_type | ||||||
|           self.body = self.media |           self.body = self.media | ||||||
|         when "multipart" |         when "multipart" | ||||||
|           unless options[:body_object]  |           unless options[:body_object] | ||||||
|             raise ArgumentError, "Multipart requested but no body object"               |             raise ArgumentError, "Multipart requested but no body object" | ||||||
|           end |           end | ||||||
|           metadata = StringIO.new(serialize_body(options[:body_object])) |           metadata = StringIO.new(serialize_body(options[:body_object])) | ||||||
|           build_multipart([Faraday::UploadIO.new(metadata, 'application/json', 'file.json'), self.media]) |           build_multipart([Faraday::UploadIO.new(metadata, 'application/json', 'file.json'), self.media]) | ||||||
|  | @ -286,13 +286,13 @@ module Google | ||||||
|           self.headers['X-Upload-Content-Length'] = file_length.to_s |           self.headers['X-Upload-Content-Length'] = file_length.to_s | ||||||
|           if options[:body_object] |           if options[:body_object] | ||||||
|             self.headers['Content-Type'] ||= 'application/json' |             self.headers['Content-Type'] ||= 'application/json' | ||||||
|             self.body = serialize_body(options[:body_object])  |             self.body = serialize_body(options[:body_object]) | ||||||
|           else |           else | ||||||
|             self.body = '' |             self.body = '' | ||||||
|           end |           end | ||||||
|         end |         end | ||||||
|       end |       end | ||||||
|        | 
 | ||||||
|       ## |       ## | ||||||
|       # Assemble a multipart message from a set of parts |       # Assemble a multipart message from a set of parts | ||||||
|       # |       # | ||||||
|  | @ -304,7 +304,7 @@ module Google | ||||||
|       #   MIME type of the message |       #   MIME type of the message | ||||||
|       # @param [String] boundary |       # @param [String] boundary | ||||||
|       #   Boundary for separating each part of the message |       #   Boundary for separating each part of the message | ||||||
|       def build_multipart(parts, mime_type = 'multipart/related', boundary = MULTIPART_BOUNDARY)  |       def build_multipart(parts, mime_type = 'multipart/related', boundary = MULTIPART_BOUNDARY) | ||||||
|         env = { |         env = { | ||||||
|           :request_headers => {'Content-Type' => "#{mime_type};boundary=#{boundary}"}, |           :request_headers => {'Content-Type' => "#{mime_type};boundary=#{boundary}"}, | ||||||
|           :request => { :boundary => boundary } |           :request => { :boundary => boundary } | ||||||
|  | @ -313,10 +313,10 @@ module Google | ||||||
|         self.body = multipart.create_multipart(env, parts.map {|part| [nil, part]}) |         self.body = multipart.create_multipart(env, parts.map {|part| [nil, part]}) | ||||||
|         self.headers.update(env[:request_headers]) |         self.headers.update(env[:request_headers]) | ||||||
|       end |       end | ||||||
|        | 
 | ||||||
|       ## |       ## | ||||||
|       # Serialize body object to JSON |       # Serialize body object to JSON | ||||||
|       #  |       # | ||||||
|       # @api private |       # @api private | ||||||
|       # |       # | ||||||
|       # @param [#to_json,#to_hash] body |       # @param [#to_json,#to_hash] body | ||||||
|  | @ -326,7 +326,7 @@ module Google | ||||||
|       #   JSON |       #   JSON | ||||||
|       def serialize_body(body) |       def serialize_body(body) | ||||||
|         return body.to_json if body.respond_to?(:to_json) |         return body.to_json if body.respond_to?(:to_json) | ||||||
|         return MultiJson.dump(options[:body_object].to_hash) if body.respond_to?(:to_hash) |         return MultiJson.dump(body.to_hash) if body.respond_to?(:to_hash) | ||||||
|         raise TypeError, 'Could not convert body object to JSON.' + |         raise TypeError, 'Could not convert body object to JSON.' + | ||||||
|                          'Must respond to :to_json or :to_hash.' |                          'Must respond to :to_json or :to_hash.' | ||||||
|       end |       end | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue