patch_ruby 2.4.0 → 2.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 72dbfba7072374e513325586e0b97747ed704411eb94757c8e99d1a6118a3581
4
- data.tar.gz: d6de008d7638027888cecec5ea3252da1ab2551cd621e562ff3b41821683d250
3
+ metadata.gz: 7f45f73f5a0d485524694df0e81f00c0df48628442ef1edb9153d47047fcc8ad
4
+ data.tar.gz: 17700875029da791ce206a83f0a85736173c6d22050567f2e124b79d0250e2f4
5
5
  SHA512:
6
- metadata.gz: 64a89d7316c018533bb2d654906020e1f1182dc6007c096caed3af86be478df00d44149fb90b7804701e3e7f2acbb3a41f256b3da41c8fd54b913120a496760e
7
- data.tar.gz: '030669673243f9d01079cb3f1b013941680a64fbb73d09169a46b8157e445ecf557ffddb943e876432618d11e46ddeecee81c8812a39e6e91d5b367d987447aa'
6
+ metadata.gz: e0c9c11a47c3472d0d62f379a60c1ff9128bbad335965b388c2e6e7e27cfd1602424b803e448a68f28196e2164dd6793b64dc5e37da9460ad37ddb4db2d28c4e
7
+ data.tar.gz: a8f8649b420733b967ebbf992043e1082b3a48c436c78f777de4f72c8999943ee2f58577ecbba5e4762970c542d86321ca4cabd7d14757791109c2a92f99c7cc
data/CHANGELOG.md CHANGED
@@ -5,6 +5,12 @@ All notable changes to this project will be documented in this file.
5
5
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
6
6
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
7
7
 
8
+ ## [2.5.0] - 2025-08-19
9
+
10
+ ### Removed
11
+
12
+ - Removes `create_flight_estimate_request` method
13
+
8
14
  ## [2.4.0] - 2025-05-16
9
15
 
10
16
  ### Removed
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- patch_ruby (2.4.0)
4
+ patch_ruby (2.5.0)
5
5
  typhoeus (~> 1.0, >= 1.0.1)
6
6
 
7
7
  GEM
data/README.md CHANGED
@@ -123,10 +123,6 @@ Estimates allow API users to get a quote for the cost of compensating a certain
123
123
  mass = 1_000_000 # Pass in the mass in grams (i.e. 1 metric tonne)
124
124
  Patch::Estimate.create_mass_estimate(mass_g: mass)
125
125
 
126
- # Create a flight estimate
127
- distance_m = 1_000_000 # Pass in the distance traveled in meters
128
- Patch::Estimate.create_flight_estimate(distance_m: distance_m)
129
-
130
126
  # Create a vehicle estimate
131
127
  distance_m = 1_000_000 # Pass in the shipping distance in meters
132
128
  make = "Toyota" # Pass in the car make
@@ -17,7 +17,6 @@ module Patch
17
17
  OPERATIONS = [
18
18
  :create_air_shipping_estimate,
19
19
  :create_bitcoin_estimate,
20
- :create_flight_estimate,
21
20
  :create_mass_estimate,
22
21
  :create_rail_shipping_estimate,
23
22
  :create_road_shipping_estimate,
@@ -179,80 +178,6 @@ module Patch
179
178
  return data, status_code, headers
180
179
  end
181
180
 
182
- # Create a flight estimate given the distance traveled in meters
183
- # Creates a flight estimate for the amount of CO2 to be compensated. An order in the `draft` state may be created based on the parameters, linked to the estimate.
184
- # @param create_flight_estimate_request [CreateFlightEstimateRequest]
185
- # @param [Hash] opts the optional parameters
186
- # @option opts [Integer] :patch_version
187
- # @return [EstimateResponse]
188
- def create_flight_estimate(create_flight_estimate_request = {}, opts = {})
189
- _create_flight_estimate_request = Patch::CreateFlightEstimateRequest.new(create_flight_estimate_request)
190
- data, _status_code, _headers = create_flight_estimate_with_http_info(_create_flight_estimate_request, opts)
191
- data
192
- end
193
-
194
- # Create a flight estimate given the distance traveled in meters
195
- # Creates a flight estimate for the amount of CO2 to be compensated. An order in the `draft` state may be created based on the parameters, linked to the estimate.
196
- # @param create_flight_estimate_request [CreateFlightEstimateRequest]
197
- # @param [Hash] opts the optional parameters
198
- # @option opts [Integer] :patch_version
199
- # @return [Array<(EstimateResponse, Integer, Hash)>] EstimateResponse data, response status code and response headers
200
- def create_flight_estimate_with_http_info(create_flight_estimate_request, opts = {})
201
- if @api_client.config.debugging
202
- @api_client.config.logger.debug 'Calling API: EstimatesApi.create_flight_estimate ...'
203
- end
204
- # verify the required parameter 'create_flight_estimate_request' is set
205
- if @api_client.config.client_side_validation && create_flight_estimate_request.nil?
206
- fail ArgumentError, "Missing the required parameter 'create_flight_estimate_request' when calling EstimatesApi.create_flight_estimate"
207
- end
208
- # resource path
209
- local_var_path = '/v1/estimates/flight'
210
-
211
- # query parameters
212
- query_params = opts[:query_params] || {}
213
-
214
- # header parameters
215
- header_params = opts[:header_params] || {}
216
-
217
- # HTTP header 'Accept' (if needed)
218
- header_params['Accept'] = @api_client.select_header_accept(['application/json'])
219
- # HTTP header 'Content-Type'
220
- content_type = @api_client.select_header_content_type(['application/json'])
221
- if !content_type.nil?
222
- header_params['Content-Type'] = content_type
223
- end
224
- header_params['Patch-Version'] = 2
225
- header_params[:'Patch-Version'] = opts[:'patch_version'] if !opts[:'patch_version'].nil?
226
-
227
- # form parameters
228
- form_params = opts[:form_params] || {}
229
-
230
- # http body (model)
231
- post_body = opts[:debug_body] || @api_client.object_to_http_body(create_flight_estimate_request)
232
-
233
- # return_type
234
- return_type = opts[:debug_return_type] || 'EstimateResponse'
235
-
236
- # auth_names
237
- auth_names = opts[:debug_auth_names] || ['bearer_auth']
238
-
239
- new_options = opts.merge(
240
- :operation => :"EstimatesApi.create_flight_estimate",
241
- :header_params => header_params,
242
- :query_params => query_params,
243
- :form_params => form_params,
244
- :body => post_body,
245
- :auth_names => auth_names,
246
- :return_type => return_type
247
- )
248
-
249
- data, status_code, headers = @api_client.call_api(:POST, local_var_path, new_options)
250
- if @api_client.config.debugging
251
- @api_client.config.logger.debug "API called: EstimatesApi#create_flight_estimate\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
252
- end
253
- return data, status_code, headers
254
- end
255
-
256
181
  # Create an estimate based on mass of CO2
257
182
  # Creates an estimate for the mass of CO2 to be compensated. An order in the `draft` state will also be created, linked to the estimate.
258
183
  # @param create_mass_estimate_request [CreateMassEstimateRequest]
@@ -31,7 +31,7 @@ module Patch
31
31
  # @option config [Configuration] Configuration for initializing the object, default to Configuration.default
32
32
  def initialize(config = Configuration.default)
33
33
  @config = config
34
- @user_agent = "patch-ruby/2.4.0"
34
+ @user_agent = "patch-ruby/2.5.0"
35
35
  @default_headers = {
36
36
  'Content-Type' => 'application/json',
37
37
  'User-Agent' => @user_agent
@@ -21,7 +21,7 @@ module Patch
21
21
  # A boolean indicating if this estimate is a production or demo mode estimate.
22
22
  attr_accessor :production
23
23
 
24
- # The type of estimate. Available types are mass, flight, shipping, and crypto.
24
+ # The type of estimate. Available types are mass, shipping, and crypto.
25
25
  attr_accessor :type
26
26
 
27
27
  # The estimated mass in grams for this estimate.
@@ -11,5 +11,5 @@ OpenAPI Generator version: 5.3.1
11
11
  =end
12
12
 
13
13
  module Patch
14
- VERSION = '2.4.0'
14
+ VERSION = '2.5.0'
15
15
  end
data/lib/patch_ruby.rb CHANGED
@@ -19,7 +19,6 @@ require 'patch_ruby/configuration'
19
19
  # Models
20
20
  require 'patch_ruby/models/create_air_shipping_estimate_request'
21
21
  require 'patch_ruby/models/create_bitcoin_estimate_request'
22
- require 'patch_ruby/models/create_flight_estimate_request'
23
22
  require 'patch_ruby/models/create_mass_estimate_request'
24
23
  require 'patch_ruby/models/create_order_line_item_request'
25
24
  require 'patch_ruby/models/create_order_request'
@@ -19,32 +19,6 @@ RSpec.describe 'Estimates Integration' do
19
19
  expect(estimates.length).not_to be_zero
20
20
  end
21
21
 
22
- it 'supports creating flight estimates' do
23
- distance_m = 10_000_000
24
- flight_estimate = Patch::Estimate.create_flight_estimate(
25
- distance_m: distance_m,
26
- create_order: false
27
- )
28
-
29
- expect(flight_estimate.data.type).to eq 'flight'
30
- expect(flight_estimate.data.mass_g).to be >= 1_000_000
31
- end
32
-
33
- it 'supports creating flight estimates with origin and destination' do
34
- flight_estimate = Patch::Estimate.create_flight_estimate(
35
- origin_airport: "SFO",
36
- destination_airport: "LAX"
37
- )
38
-
39
- flight_estimate_longer = Patch::Estimate.create_flight_estimate(
40
- origin_airport: "SFO",
41
- destination_airport: "JFK"
42
- )
43
-
44
- expect(flight_estimate.data.type).to eq 'flight'
45
- expect(flight_estimate_longer.data.mass_g).to be > 2 * flight_estimate.data.mass_g
46
- end
47
-
48
22
  it 'supports creating bitcoin estimates with partial information' do
49
23
  bitcoin_estimate = Patch::Estimate.create_bitcoin_estimate()
50
24
 
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: patch_ruby
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.4.0
4
+ version: 2.5.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Patch Technology
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-05-16 00:00:00.000000000 Z
11
+ date: 2025-08-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: typhoeus
@@ -103,7 +103,6 @@ files:
103
103
  - lib/patch_ruby/configuration.rb
104
104
  - lib/patch_ruby/models/create_air_shipping_estimate_request.rb
105
105
  - lib/patch_ruby/models/create_bitcoin_estimate_request.rb
106
- - lib/patch_ruby/models/create_flight_estimate_request.rb
107
106
  - lib/patch_ruby/models/create_mass_estimate_request.rb
108
107
  - lib/patch_ruby/models/create_order_line_item_request.rb
109
108
  - lib/patch_ruby/models/create_order_request.rb
@@ -209,47 +208,47 @@ signing_key:
209
208
  specification_version: 4
210
209
  summary: Ruby wrapper for the Patch API
211
210
  test_files:
212
- - spec/api/order_line_items_api_spec.rb
213
- - spec/api/projects_api_spec.rb
214
211
  - spec/api/estimates_api_spec.rb
215
212
  - spec/api/technology_types_api_spec.rb
213
+ - spec/api/projects_api_spec.rb
216
214
  - spec/api/orders_api_spec.rb
215
+ - spec/api/order_line_items_api_spec.rb
217
216
  - spec/api_client_spec.rb
218
217
  - spec/configuration_spec.rb
219
218
  - spec/constants.rb
220
- - spec/factories/meta_index_objects.rb
221
- - spec/factories/technology_type.rb
222
- - spec/factories/orders.rb
223
- - spec/factories/error_responses.rb
224
- - spec/factories/project_responses.rb
225
- - spec/factories/estimate_list_responses.rb
226
- - spec/factories/projects.rb
227
- - spec/factories/order_list_responses.rb
219
+ - spec/factories/project_list_responses.rb
228
220
  - spec/factories/order_responses.rb
229
- - spec/factories/estimate_responses.rb
230
221
  - spec/factories/parent_technology_type.rb
231
- - spec/factories/project_list_responses.rb
232
- - spec/factories/sdgs.rb
222
+ - spec/factories/orders.rb
223
+ - spec/factories/estimate_responses.rb
224
+ - spec/factories/order_list_responses.rb
225
+ - spec/factories/estimates.rb
233
226
  - spec/factories/create_mass_estimate_requests.rb
227
+ - spec/factories/sdgs.rb
228
+ - spec/factories/estimate_list_responses.rb
234
229
  - spec/factories/create_order_requests.rb
235
- - spec/factories/estimates.rb
236
- - spec/integration/projects/technology_types_spec.rb
230
+ - spec/factories/technology_type.rb
231
+ - spec/factories/meta_index_objects.rb
232
+ - spec/factories/project_responses.rb
233
+ - spec/factories/error_responses.rb
234
+ - spec/factories/projects.rb
237
235
  - spec/integration/projects_spec.rb
238
236
  - spec/integration/orders_spec.rb
237
+ - spec/integration/projects/technology_types_spec.rb
239
238
  - spec/integration/estimates_spec.rb
240
- - spec/models/create_mass_estimate_request_spec.rb
241
- - spec/models/create_order_request_spec.rb
242
- - spec/models/meta_index_object_spec.rb
243
- - spec/models/estimate_list_response_spec.rb
244
- - spec/models/order_response_spec.rb
245
- - spec/models/project_spec.rb
246
239
  - spec/models/order_spec.rb
247
- - spec/models/order_list_response_spec.rb
248
- - spec/models/estimate_spec.rb
240
+ - spec/models/project_list_response_spec.rb
241
+ - spec/models/estimate_list_response_spec.rb
242
+ - spec/models/create_order_request_spec.rb
249
243
  - spec/models/estimate_response_spec.rb
244
+ - spec/models/order_response_spec.rb
250
245
  - spec/models/project_response_spec.rb
246
+ - spec/models/estimate_spec.rb
251
247
  - spec/models/error_response_spec.rb
252
- - spec/models/project_list_response_spec.rb
248
+ - spec/models/create_mass_estimate_request_spec.rb
249
+ - spec/models/project_spec.rb
250
+ - spec/models/meta_index_object_spec.rb
251
+ - spec/models/order_list_response_spec.rb
253
252
  - spec/patch_ruby_spec.rb
254
253
  - spec/spec_helper.rb
255
254
  - spec/support/shared/generated_classes.rb
@@ -1,325 +0,0 @@
1
- =begin
2
- #Patch API V2
3
-
4
- #The core API used to integrate with Patch's service
5
-
6
- The version of the OpenAPI document: 2
7
- Contact: engineering@usepatch.com
8
- Generated by: https://openapi-generator.tech
9
- OpenAPI Generator version: 5.3.1
10
-
11
- =end
12
-
13
- require 'date'
14
- require 'time'
15
-
16
- module Patch
17
- class CreateFlightEstimateRequest
18
- attr_accessor :distance_m
19
-
20
- attr_accessor :origin_airport
21
-
22
- attr_accessor :destination_airport
23
-
24
- attr_accessor :aircraft_code
25
-
26
- attr_accessor :cabin_class
27
-
28
- attr_accessor :passenger_count
29
-
30
- attr_accessor :project_id
31
-
32
- attr_accessor :create_order
33
-
34
- # Attribute mapping from ruby-style variable name to JSON key.
35
- def self.attribute_map
36
- {
37
- :'distance_m' => :'distance_m',
38
- :'origin_airport' => :'origin_airport',
39
- :'destination_airport' => :'destination_airport',
40
- :'aircraft_code' => :'aircraft_code',
41
- :'cabin_class' => :'cabin_class',
42
- :'passenger_count' => :'passenger_count',
43
- :'project_id' => :'project_id',
44
- :'create_order' => :'create_order'
45
- }
46
- end
47
-
48
- # Returns all the JSON keys this model knows about
49
- def self.acceptable_attributes
50
- attribute_map.values
51
- end
52
-
53
- # Attribute type mapping.
54
- def self.openapi_types
55
- {
56
- :'distance_m' => :'Integer',
57
- :'origin_airport' => :'String',
58
- :'destination_airport' => :'String',
59
- :'aircraft_code' => :'String',
60
- :'cabin_class' => :'String',
61
- :'passenger_count' => :'Integer',
62
- :'project_id' => :'String',
63
- :'create_order' => :'Boolean'
64
- }
65
- end
66
-
67
- # List of attributes with nullable: true
68
- def self.openapi_nullable
69
- Set.new([
70
- :'distance_m',
71
- :'origin_airport',
72
- :'destination_airport',
73
- :'aircraft_code',
74
- :'cabin_class',
75
- :'passenger_count',
76
- :'project_id',
77
- :'create_order'
78
- ])
79
- end
80
-
81
-
82
- # Allows models with corresponding API classes to delegate API operations to those API classes
83
- # Exposes Model.operation_id which delegates to ModelsApi.new.operation_id
84
- # Eg. Order.create_order delegates to OrdersApi.new.create_order
85
- def self.method_missing(message, *args, &block)
86
- if Object.const_defined?('Patch::CreateFlightEstimateRequestsApi::OPERATIONS') && Patch::CreateFlightEstimateRequestsApi::OPERATIONS.include?(message)
87
- Patch::CreateFlightEstimateRequestsApi.new.send(message, *args)
88
- else
89
- super
90
- end
91
- end
92
-
93
- # Initializes the object
94
- # @param [Hash] attributes Model attributes in the form of hash
95
- def initialize(attributes = {})
96
- if (!attributes.is_a?(Hash))
97
- fail ArgumentError, "The input argument (attributes) must be a hash in `Patch::CreateFlightEstimateRequest` initialize method"
98
- end
99
-
100
- # check to see if the attribute exists and convert string to symbol for hash key
101
- attributes = attributes.each_with_object({}) { |(k, v), h|
102
- if (!self.class.attribute_map.key?(k.to_sym))
103
- fail ArgumentError, "`#{k}` is not a valid attribute in `Patch::CreateFlightEstimateRequest`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
104
- end
105
- h[k.to_sym] = v
106
- }
107
-
108
- if attributes.key?(:'distance_m')
109
- self.distance_m = attributes[:'distance_m']
110
- end
111
-
112
- if attributes.key?(:'origin_airport')
113
- self.origin_airport = attributes[:'origin_airport']
114
- end
115
-
116
- if attributes.key?(:'destination_airport')
117
- self.destination_airport = attributes[:'destination_airport']
118
- end
119
-
120
- if attributes.key?(:'aircraft_code')
121
- self.aircraft_code = attributes[:'aircraft_code']
122
- end
123
-
124
- if attributes.key?(:'cabin_class')
125
- self.cabin_class = attributes[:'cabin_class']
126
- end
127
-
128
- if attributes.key?(:'passenger_count')
129
- self.passenger_count = attributes[:'passenger_count']
130
- end
131
-
132
- if attributes.key?(:'project_id')
133
- self.project_id = attributes[:'project_id']
134
- end
135
-
136
- if attributes.key?(:'create_order')
137
- self.create_order = attributes[:'create_order']
138
- else
139
- self.create_order = false
140
- end
141
- end
142
-
143
- # Show invalid properties with the reasons. Usually used together with valid?
144
- # @return Array for valid properties with the reasons
145
- def list_invalid_properties
146
- invalid_properties = Array.new
147
- if !@distance_m.nil? && @distance_m > 400000000
148
- invalid_properties.push('invalid value for "distance_m", must be smaller than or equal to 400000000.')
149
- end
150
-
151
- if !@distance_m.nil? && @distance_m < 0
152
- invalid_properties.push('invalid value for "distance_m", must be greater than or equal to 0.')
153
- end
154
-
155
- invalid_properties
156
- end
157
-
158
- # Check to see if the all the properties in the model are valid
159
- # @return true if the model is valid
160
- def valid?
161
- return false if !@distance_m.nil? && @distance_m > 400000000
162
- return false if !@distance_m.nil? && @distance_m < 0
163
- true
164
- end
165
-
166
- # Custom attribute writer method with validation
167
- # @param [Object] distance_m Value to be assigned
168
- def distance_m=(distance_m)
169
- if !distance_m.nil? && distance_m > 400000000
170
- fail ArgumentError, 'invalid value for "distance_m", must be smaller than or equal to 400000000.'
171
- end
172
-
173
- if !distance_m.nil? && distance_m < 0
174
- fail ArgumentError, 'invalid value for "distance_m", must be greater than or equal to 0.'
175
- end
176
-
177
- @distance_m = distance_m
178
- end
179
-
180
- # Checks equality by comparing each attribute.
181
- # @param [Object] Object to be compared
182
- def ==(o)
183
- return true if self.equal?(o)
184
- self.class == o.class &&
185
- distance_m == o.distance_m &&
186
- origin_airport == o.origin_airport &&
187
- destination_airport == o.destination_airport &&
188
- aircraft_code == o.aircraft_code &&
189
- cabin_class == o.cabin_class &&
190
- passenger_count == o.passenger_count &&
191
- project_id == o.project_id &&
192
- create_order == o.create_order
193
- end
194
-
195
- # @see the `==` method
196
- # @param [Object] Object to be compared
197
- def eql?(o)
198
- self == o
199
- end
200
-
201
- # Calculates hash code according to all attributes.
202
- # @return [Integer] Hash code
203
- def hash
204
- [distance_m, origin_airport, destination_airport, aircraft_code, cabin_class, passenger_count, project_id, create_order].hash
205
- end
206
-
207
- # Builds the object from hash
208
- # @param [Hash] attributes Model attributes in the form of hash
209
- # @return [Object] Returns the model itself
210
- def self.build_from_hash(attributes)
211
- new.build_from_hash(attributes)
212
- end
213
-
214
- # Builds the object from hash
215
- # @param [Hash] attributes Model attributes in the form of hash
216
- # @return [Object] Returns the model itself
217
- def build_from_hash(attributes)
218
- return nil unless attributes.is_a?(Hash)
219
- self.class.openapi_types.each_pair do |key, type|
220
- if attributes[self.class.attribute_map[key]].nil? && self.class.openapi_nullable.include?(key)
221
- self.send("#{key}=", nil)
222
- elsif type =~ /\AArray<(.*)>/i
223
- # check to ensure the input is an array given that the attribute
224
- # is documented as an array but the input is not
225
- if attributes[self.class.attribute_map[key]].is_a?(Array)
226
- self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
227
- end
228
- elsif !attributes[self.class.attribute_map[key]].nil?
229
- self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
230
- end
231
- end
232
-
233
- self
234
- end
235
-
236
- # Deserializes the data based on type
237
- # @param string type Data type
238
- # @param string value Value to be deserialized
239
- # @return [Object] Deserialized data
240
- def _deserialize(type, value)
241
- case type.to_sym
242
- when :Time
243
- Time.parse(value)
244
- when :Date
245
- Date.parse(value)
246
- when :String
247
- value.to_s
248
- when :Integer
249
- value.to_i
250
- when :Float
251
- value.to_f
252
- when :Boolean
253
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
254
- true
255
- else
256
- false
257
- end
258
- when :Object
259
- # generic object (usually a Hash), return directly
260
- value
261
- when /\AArray<(?<inner_type>.+)>\z/
262
- inner_type = Regexp.last_match[:inner_type]
263
- value.map { |v| _deserialize(inner_type, v) }
264
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
265
- k_type = Regexp.last_match[:k_type]
266
- v_type = Regexp.last_match[:v_type]
267
- {}.tap do |hash|
268
- value.each do |k, v|
269
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
270
- end
271
- end
272
- else # model
273
- # models (e.g. Pet) or oneOf
274
- klass = Patch.const_get(type)
275
- klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
276
- end
277
- end
278
-
279
- # Returns the string representation of the object
280
- # @return [String] String presentation of the object
281
- def to_s
282
- to_hash.to_s
283
- end
284
-
285
- # to_body is an alias to to_hash (backward compatibility)
286
- # @return [Hash] Returns the object in the form of hash
287
- def to_body
288
- to_hash
289
- end
290
-
291
- # Returns the object in the form of hash
292
- # @return [Hash] Returns the object in the form of hash
293
- def to_hash
294
- hash = {}
295
- self.class.attribute_map.each_pair do |attr, param|
296
- value = self.send(attr)
297
- if value.nil?
298
- is_nullable = self.class.openapi_nullable.include?(attr)
299
- next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
300
- end
301
-
302
- hash[param] = _to_hash(value)
303
- end
304
- hash
305
- end
306
-
307
- # Outputs non-array value in the form of hash
308
- # For object, use to_hash. Otherwise, just return the value
309
- # @param [Object] value Any valid value
310
- # @return [Hash] Returns the value in the form of hash
311
- def _to_hash(value)
312
- if value.is_a?(Array)
313
- value.compact.map { |v| _to_hash(v) }
314
- elsif value.is_a?(Hash)
315
- {}.tap do |hash|
316
- value.each { |k, v| hash[k] = _to_hash(v) }
317
- end
318
- elsif value.respond_to? :to_hash
319
- value.to_hash
320
- else
321
- value
322
- end
323
- end
324
- end
325
- end