cybersource_rest_client 0.0.67 → 0.0.68

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.
Files changed (84) hide show
  1. checksums.yaml +4 -4
  2. data/lib/cybersource_rest_client/models/card_processing_config_common_acquirer.rb +257 -257
  3. data/lib/cybersource_rest_client/models/card_processing_config_common_merchant_descriptor_information.rb +279 -279
  4. data/lib/cybersource_rest_client/models/commerce_solutions_products_token_management_configuration_information_configurations.rb +200 -190
  5. data/lib/cybersource_rest_client/models/commerce_solutions_products_token_management_configuration_information_configurations_vault.rb +251 -0
  6. data/lib/cybersource_rest_client/models/e_check_config_common_internal_only_processors.rb +267 -263
  7. data/lib/cybersource_rest_client/models/e_check_config_common_processors.rb +273 -271
  8. data/lib/cybersource_rest_client/models/e_check_config_features_account_validation_service_internal_only_processors.rb +193 -191
  9. data/lib/cybersource_rest_client/models/e_check_config_features_account_validation_service_processors.rb +285 -283
  10. data/lib/cybersource_rest_client/models/flexv2sessions_fields.rb +199 -199
  11. data/lib/cybersource_rest_client/models/flexv2sessions_fields_order_information.rb +209 -209
  12. data/lib/cybersource_rest_client/models/flexv2sessions_fields_order_information_amount_details.rb +199 -199
  13. data/lib/cybersource_rest_client/models/flexv2sessions_fields_order_information_amount_details_total_amount.rb +189 -189
  14. data/lib/cybersource_rest_client/models/flexv2sessions_fields_order_information_bill_to.rb +309 -309
  15. data/lib/cybersource_rest_client/models/flexv2sessions_fields_order_information_ship_to.rb +289 -289
  16. data/lib/cybersource_rest_client/models/flexv2sessions_fields_payment_information.rb +189 -189
  17. data/lib/cybersource_rest_client/models/flexv2sessions_fields_payment_information_card.rb +229 -229
  18. data/lib/cybersource_rest_client/models/generate_capture_context_request.rb +13 -13
  19. data/lib/cybersource_rest_client/models/generate_flex_api_capture_context_request.rb +189 -189
  20. data/lib/cybersource_rest_client/models/generate_unified_checkout_capture_context_request.rb +13 -13
  21. data/lib/cybersource_rest_client/models/inline_response_400_1_details.rb +199 -199
  22. data/lib/cybersource_rest_client/models/inline_response_400_2.rb +235 -235
  23. data/lib/cybersource_rest_client/models/inline_response_400_3.rb +235 -235
  24. data/lib/cybersource_rest_client/models/inline_response_400_4.rb +235 -235
  25. data/lib/cybersource_rest_client/models/inline_response_400_5.rb +258 -258
  26. data/lib/cybersource_rest_client/models/inline_response_400_5_fields.rb +213 -213
  27. data/lib/cybersource_rest_client/models/inline_response_400_6_details.rb +201 -201
  28. data/lib/cybersource_rest_client/models/patch_instrument_identifier_request.rb +313 -313
  29. data/lib/cybersource_rest_client/models/post_instrument_identifier_enrollment_request.rb +313 -313
  30. data/lib/cybersource_rest_client/models/post_instrument_identifier_request.rb +313 -313
  31. data/lib/cybersource_rest_client/models/pts_v2_payments_reversals_post201_response.rb +305 -305
  32. data/lib/cybersource_rest_client/models/ptsv2payments_payment_information_card.rb +445 -428
  33. data/lib/cybersource_rest_client/models/ptsv2payments_processing_information.rb +1 -1
  34. data/lib/cybersource_rest_client/models/ptsv2payments_processing_information_japan_payment_options.rb +339 -411
  35. data/lib/cybersource_rest_client/models/ptsv2payments_processing_information_japan_payment_options_bonuses.rb +213 -0
  36. data/lib/cybersource_rest_client/models/ptsv2payments_recipient_information.rb +383 -383
  37. data/lib/cybersource_rest_client/models/ptsv2payments_recurring_payment_information.rb +363 -363
  38. data/lib/cybersource_rest_client/models/ptsv2payments_sender_information.rb +298 -298
  39. data/lib/cybersource_rest_client/models/ptsv2paymentsid_client_reference_information.rb +256 -256
  40. data/lib/cybersource_rest_client/models/riskv1authenticationresults_payment_information.rb +219 -219
  41. data/lib/cybersource_rest_client/models/riskv1authentications_payment_information.rb +219 -219
  42. data/lib/cybersource_rest_client/models/riskv1authentications_payment_information_customer.rb +222 -222
  43. data/lib/cybersource_rest_client/models/riskv1authenticationsetups_payment_information_customer.rb +205 -205
  44. data/lib/cybersource_rest_client/models/riskv1decisions_consumer_authentication_information.rb +795 -795
  45. data/lib/cybersource_rest_client/models/riskv1exportcomplianceinquiries_order_information_line_items.rb +305 -314
  46. data/lib/cybersource_rest_client/models/tms_embedded_instrument_identifier.rb +313 -313
  47. data/lib/cybersource_rest_client/models/tms_network_token_services.rb +239 -0
  48. data/lib/cybersource_rest_client/models/tms_network_token_services_american_express_token_service.rb +253 -0
  49. data/lib/cybersource_rest_client/models/tms_network_token_services_mastercard_digital_enablement_service.rb +227 -0
  50. data/lib/cybersource_rest_client/models/tms_network_token_services_notifications.rb +190 -0
  51. data/lib/cybersource_rest_client/models/tms_network_token_services_payment_credentials.rb +190 -0
  52. data/lib/cybersource_rest_client/models/tms_network_token_services_synchronous_provisioning.rb +190 -0
  53. data/lib/cybersource_rest_client/models/tms_network_token_services_visa_token_service.rb +244 -0
  54. data/lib/cybersource_rest_client/models/tms_nullify.rb +212 -0
  55. data/lib/cybersource_rest_client/models/tms_sensitive_privileges.rb +190 -0
  56. data/lib/cybersource_rest_client/models/tms_token_formats.rb +223 -0
  57. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card.rb +321 -321
  58. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_card.rb +225 -225
  59. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata.rb +189 -189
  60. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art.rb +250 -250
  61. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_background_asset.rb +200 -200
  62. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_background_asset__links.rb +189 -189
  63. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_background_asset__links_self.rb +190 -190
  64. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_brand_logo_asset.rb +200 -200
  65. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_brand_logo_asset__links.rb +189 -189
  66. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_brand_logo_asset__links_self.rb +190 -190
  67. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_co_brand_logo_asset.rb +200 -200
  68. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_co_brand_logo_asset__links.rb +189 -189
  69. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_co_brand_logo_asset__links_self.rb +190 -190
  70. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_combined_asset.rb +200 -200
  71. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_combined_asset__links.rb +189 -189
  72. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_combined_asset__links_self.rb +190 -190
  73. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_icon_asset.rb +200 -200
  74. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_icon_asset__links.rb +189 -189
  75. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_icon_asset__links_self.rb +190 -190
  76. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_issuer_logo_asset.rb +200 -200
  77. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_issuer_logo_asset__links.rb +189 -189
  78. data/lib/cybersource_rest_client/models/tmsv2_tokenized_card_metadata_card_art_issuer_logo_asset__links_self.rb +190 -190
  79. data/lib/cybersource_rest_client/models/token_permissions.rb +223 -0
  80. data/lib/cybersource_rest_client/models/tss_v2_transactions_get200_response_processing_information.rb +326 -326
  81. data/lib/cybersource_rest_client/models/tss_v2_transactions_get200_response_processing_information_japan_payment_options.rb +322 -247
  82. data/lib/cybersource_rest_client/models/tss_v2_transactions_post201_response__embedded_processing_information.rb +241 -241
  83. data/lib/cybersource_rest_client.rb +13 -0
  84. metadata +16 -3
@@ -1,305 +1,305 @@
1
- =begin
2
- #CyberSource Merged Spec
3
-
4
- #All CyberSource API specs merged together. These are available at https://developer.cybersource.com/api/reference/api-reference.html
5
-
6
- OpenAPI spec version: 0.0.1
7
-
8
- Generated by: https://github.com/swagger-api/swagger-codegen.git
9
- Swagger Codegen version: 2.4.38
10
- =end
11
-
12
- require 'date'
13
-
14
- module CyberSource
15
- class PtsV2PaymentsReversalsPost201Response
16
- attr_accessor :_links
17
-
18
- # An unique identification number generated by Cybersource to identify the submitted request. Returned by all services. It is also appended to the endpoint of the resource. On incremental authorizations, this value with be the same as the identification number returned in the original authorization response.
19
- attr_accessor :id
20
-
21
- # Time of request in UTC. Format: `YYYY-MM-DDThh:mm:ssZ` **Example** `2016-08-11T22:47:57Z` equals August 11, 2016, at 22:47:57 (10:47:57 p.m.). The `T` separates the date and the time. The `Z` indicates UTC. Returned by Cybersource for all services.
22
- attr_accessor :submit_time_utc
23
-
24
- # The status of the submitted transaction. Possible values: - REVERSED
25
- attr_accessor :status
26
-
27
- # Reference number for the transaction. Depending on how your Cybersource account is configured, this value could either be provided in the API request or generated by CyberSource. The actual value used in the request to the processor is provided back to you by Cybersource in the response.
28
- attr_accessor :reconciliation_id
29
-
30
- attr_accessor :client_reference_information
31
-
32
- attr_accessor :reversal_amount_details
33
-
34
- attr_accessor :processor_information
35
-
36
- attr_accessor :issuer_information
37
-
38
- attr_accessor :authorization_information
39
-
40
- attr_accessor :point_of_sale_information
41
-
42
- # Attribute mapping from ruby-style variable name to JSON key.
43
- def self.attribute_map
44
- {
45
- :'_links' => :'_links',
46
- :'id' => :'id',
47
- :'submit_time_utc' => :'submitTimeUtc',
48
- :'status' => :'status',
49
- :'reconciliation_id' => :'reconciliationId',
50
- :'client_reference_information' => :'clientReferenceInformation',
51
- :'reversal_amount_details' => :'reversalAmountDetails',
52
- :'processor_information' => :'processorInformation',
53
- :'issuer_information' => :'issuerInformation',
54
- :'authorization_information' => :'authorizationInformation',
55
- :'point_of_sale_information' => :'pointOfSaleInformation'
56
- }
57
- end
58
-
59
- # Attribute mapping from JSON key to ruby-style variable name.
60
- def self.json_map
61
- {
62
- :'_links' => :'_links',
63
- :'id' => :'id',
64
- :'submit_time_utc' => :'submit_time_utc',
65
- :'status' => :'status',
66
- :'reconciliation_id' => :'reconciliation_id',
67
- :'client_reference_information' => :'client_reference_information',
68
- :'reversal_amount_details' => :'reversal_amount_details',
69
- :'processor_information' => :'processor_information',
70
- :'issuer_information' => :'issuer_information',
71
- :'authorization_information' => :'authorization_information',
72
- :'point_of_sale_information' => :'point_of_sale_information'
73
- }
74
- end
75
-
76
- # Attribute type mapping.
77
- def self.swagger_types
78
- {
79
- :'_links' => :'PtsV2IncrementalAuthorizationPatch201ResponseLinks',
80
- :'id' => :'String',
81
- :'submit_time_utc' => :'String',
82
- :'status' => :'String',
83
- :'reconciliation_id' => :'String',
84
- :'client_reference_information' => :'PtsV2PaymentsPost201ResponseClientReferenceInformation',
85
- :'reversal_amount_details' => :'PtsV2PaymentsReversalsPost201ResponseReversalAmountDetails',
86
- :'processor_information' => :'PtsV2PaymentsReversalsPost201ResponseProcessorInformation',
87
- :'issuer_information' => :'PtsV2PaymentsReversalsPost201ResponseIssuerInformation',
88
- :'authorization_information' => :'PtsV2PaymentsReversalsPost201ResponseAuthorizationInformation',
89
- :'point_of_sale_information' => :'Ptsv2paymentsidreversalsPointOfSaleInformation'
90
- }
91
- end
92
-
93
- # Initializes the object
94
- # @param [Hash] attributes Model attributes in the form of hash
95
- def initialize(attributes = {})
96
- return unless attributes.is_a?(Hash)
97
-
98
- # convert string to symbol for hash key
99
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
100
-
101
- if attributes.has_key?(:'_links')
102
- self._links = attributes[:'_links']
103
- end
104
-
105
- if attributes.has_key?(:'id')
106
- self.id = attributes[:'id']
107
- end
108
-
109
- if attributes.has_key?(:'submitTimeUtc')
110
- self.submit_time_utc = attributes[:'submitTimeUtc']
111
- end
112
-
113
- if attributes.has_key?(:'status')
114
- self.status = attributes[:'status']
115
- end
116
-
117
- if attributes.has_key?(:'reconciliationId')
118
- self.reconciliation_id = attributes[:'reconciliationId']
119
- end
120
-
121
- if attributes.has_key?(:'clientReferenceInformation')
122
- self.client_reference_information = attributes[:'clientReferenceInformation']
123
- end
124
-
125
- if attributes.has_key?(:'reversalAmountDetails')
126
- self.reversal_amount_details = attributes[:'reversalAmountDetails']
127
- end
128
-
129
- if attributes.has_key?(:'processorInformation')
130
- self.processor_information = attributes[:'processorInformation']
131
- end
132
-
133
- if attributes.has_key?(:'issuerInformation')
134
- self.issuer_information = attributes[:'issuerInformation']
135
- end
136
-
137
- if attributes.has_key?(:'authorizationInformation')
138
- self.authorization_information = attributes[:'authorizationInformation']
139
- end
140
-
141
- if attributes.has_key?(:'pointOfSaleInformation')
142
- self.point_of_sale_information = attributes[:'pointOfSaleInformation']
143
- end
144
- end
145
-
146
- # Show invalid properties with the reasons. Usually used together with valid?
147
- # @return Array for valid properties with the reasons
148
- def list_invalid_properties
149
- invalid_properties = Array.new
150
- invalid_properties
151
- end
152
-
153
- # Check to see if the all the properties in the model are valid
154
- # @return true if the model is valid
155
- def valid?
156
- true
157
- end
158
-
159
- # Custom attribute writer method with validation
160
- # @param [Object] id Value to be assigned
161
- def id=(id)
162
- @id = id
163
- end
164
-
165
- # Custom attribute writer method with validation
166
- # @param [Object] reconciliation_id Value to be assigned
167
- def reconciliation_id=(reconciliation_id)
168
- @reconciliation_id = reconciliation_id
169
- end
170
-
171
- # Checks equality by comparing each attribute.
172
- # @param [Object] Object to be compared
173
- def ==(o)
174
- return true if self.equal?(o)
175
- self.class == o.class &&
176
- _links == o._links &&
177
- id == o.id &&
178
- submit_time_utc == o.submit_time_utc &&
179
- status == o.status &&
180
- reconciliation_id == o.reconciliation_id &&
181
- client_reference_information == o.client_reference_information &&
182
- reversal_amount_details == o.reversal_amount_details &&
183
- processor_information == o.processor_information &&
184
- issuer_information == o.issuer_information &&
185
- authorization_information == o.authorization_information &&
186
- point_of_sale_information == o.point_of_sale_information
187
- end
188
-
189
- # @see the `==` method
190
- # @param [Object] Object to be compared
191
- def eql?(o)
192
- self == o
193
- end
194
-
195
- # Calculates hash code according to all attributes.
196
- # @return [Fixnum] Hash code
197
- def hash
198
- [_links, id, submit_time_utc, status, reconciliation_id, client_reference_information, reversal_amount_details, processor_information, issuer_information, authorization_information, point_of_sale_information].hash
199
- end
200
-
201
- # Builds the object from hash
202
- # @param [Hash] attributes Model attributes in the form of hash
203
- # @return [Object] Returns the model itself
204
- def build_from_hash(attributes)
205
- return nil unless attributes.is_a?(Hash)
206
- self.class.swagger_types.each_pair do |key, type|
207
- if type =~ /\AArray<(.*)>/i
208
- # check to ensure the input is an array given that the the attribute
209
- # is documented as an array but the input is not
210
- if attributes[self.class.attribute_map[key]].is_a?(Array)
211
- self.send("#{self.class.json_map[key]}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
212
- end
213
- elsif !attributes[self.class.attribute_map[key]].nil?
214
- self.send("#{self.class.json_map[key]}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
215
- end # or else data not found in attributes(hash), not an issue as the data can be optional
216
- end
217
-
218
- self
219
- end
220
-
221
- # Deserializes the data based on type
222
- # @param string type Data type
223
- # @param string value Value to be deserialized
224
- # @return [Object] Deserialized data
225
- def _deserialize(type, value)
226
- case type.to_sym
227
- when :DateTime
228
- DateTime.parse(value)
229
- when :Date
230
- Date.parse(value)
231
- when :String
232
- value.to_s
233
- when :Integer
234
- value.to_i
235
- when :Float
236
- value.to_f
237
- when :BOOLEAN
238
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
239
- true
240
- else
241
- false
242
- end
243
- when :Object
244
- # generic object (usually a Hash), return directly
245
- value
246
- when /\AArray<(?<inner_type>.+)>\z/
247
- inner_type = Regexp.last_match[:inner_type]
248
- value.map { |v| _deserialize(inner_type, v) }
249
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
250
- k_type = Regexp.last_match[:k_type]
251
- v_type = Regexp.last_match[:v_type]
252
- {}.tap do |hash|
253
- value.each do |k, v|
254
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
255
- end
256
- end
257
- else # model
258
- temp_model = CyberSource.const_get(type).new
259
- temp_model.build_from_hash(value)
260
- end
261
- end
262
-
263
- # Returns the string representation of the object
264
- # @return [String] String presentation of the object
265
- def to_s
266
- to_hash.to_s
267
- end
268
-
269
- # to_body is an alias to to_hash (backward compatibility)
270
- # @return [Hash] Returns the object in the form of hash
271
- def to_body
272
- to_hash
273
- end
274
-
275
- # Returns the object in the form of hash
276
- # @return [Hash] Returns the object in the form of hash
277
- def to_hash
278
- hash = {}
279
- self.class.attribute_map.each_pair do |attr, param|
280
- value = self.send(attr)
281
- next if value.nil?
282
- hash[param] = _to_hash(value)
283
- end
284
- hash
285
- end
286
-
287
- # Outputs non-array value in the form of hash
288
- # For object, use to_hash. Otherwise, just return the value
289
- # @param [Object] value Any valid value
290
- # @return [Hash] Returns the value in the form of hash
291
- def _to_hash(value)
292
- if value.is_a?(Array)
293
- value.compact.map { |v| _to_hash(v) }
294
- elsif value.is_a?(Hash)
295
- {}.tap do |hash|
296
- value.each { |k, v| hash[k] = _to_hash(v) }
297
- end
298
- elsif value.respond_to? :to_hash
299
- value.to_hash
300
- else
301
- value
302
- end
303
- end
304
- end
305
- end
1
+ =begin
2
+ #CyberSource Merged Spec
3
+
4
+ #All CyberSource API specs merged together. These are available at https://developer.cybersource.com/api/reference/api-reference.html
5
+
6
+ OpenAPI spec version: 0.0.1
7
+
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+ Swagger Codegen version: 2.4.38
10
+ =end
11
+
12
+ require 'date'
13
+
14
+ module CyberSource
15
+ class PtsV2PaymentsReversalsPost201Response
16
+ attr_accessor :_links
17
+
18
+ # An unique identification number generated by Cybersource to identify the submitted request. Returned by all services. It is also appended to the endpoint of the resource. On incremental authorizations, this value with be the same as the identification number returned in the original authorization response.
19
+ attr_accessor :id
20
+
21
+ # Time of request in UTC. Format: `YYYY-MM-DDThh:mm:ssZ` **Example** `2016-08-11T22:47:57Z` equals August 11, 2016, at 22:47:57 (10:47:57 p.m.). The `T` separates the date and the time. The `Z` indicates UTC. Returned by Cybersource for all services.
22
+ attr_accessor :submit_time_utc
23
+
24
+ # The status of the submitted transaction. Possible values: - REVERSED
25
+ attr_accessor :status
26
+
27
+ # Reference number for the transaction. Depending on how your Cybersource account is configured, this value could either be provided in the API request or generated by CyberSource. The actual value used in the request to the processor is provided back to you by Cybersource in the response.
28
+ attr_accessor :reconciliation_id
29
+
30
+ attr_accessor :client_reference_information
31
+
32
+ attr_accessor :reversal_amount_details
33
+
34
+ attr_accessor :processor_information
35
+
36
+ attr_accessor :issuer_information
37
+
38
+ attr_accessor :authorization_information
39
+
40
+ attr_accessor :point_of_sale_information
41
+
42
+ # Attribute mapping from ruby-style variable name to JSON key.
43
+ def self.attribute_map
44
+ {
45
+ :'_links' => :'_links',
46
+ :'id' => :'id',
47
+ :'submit_time_utc' => :'submitTimeUtc',
48
+ :'status' => :'status',
49
+ :'reconciliation_id' => :'reconciliationId',
50
+ :'client_reference_information' => :'clientReferenceInformation',
51
+ :'reversal_amount_details' => :'reversalAmountDetails',
52
+ :'processor_information' => :'processorInformation',
53
+ :'issuer_information' => :'issuerInformation',
54
+ :'authorization_information' => :'authorizationInformation',
55
+ :'point_of_sale_information' => :'pointOfSaleInformation'
56
+ }
57
+ end
58
+
59
+ # Attribute mapping from JSON key to ruby-style variable name.
60
+ def self.json_map
61
+ {
62
+ :'_links' => :'_links',
63
+ :'id' => :'id',
64
+ :'submit_time_utc' => :'submit_time_utc',
65
+ :'status' => :'status',
66
+ :'reconciliation_id' => :'reconciliation_id',
67
+ :'client_reference_information' => :'client_reference_information',
68
+ :'reversal_amount_details' => :'reversal_amount_details',
69
+ :'processor_information' => :'processor_information',
70
+ :'issuer_information' => :'issuer_information',
71
+ :'authorization_information' => :'authorization_information',
72
+ :'point_of_sale_information' => :'point_of_sale_information'
73
+ }
74
+ end
75
+
76
+ # Attribute type mapping.
77
+ def self.swagger_types
78
+ {
79
+ :'_links' => :'PtsV2IncrementalAuthorizationPatch201ResponseLinks',
80
+ :'id' => :'String',
81
+ :'submit_time_utc' => :'String',
82
+ :'status' => :'String',
83
+ :'reconciliation_id' => :'String',
84
+ :'client_reference_information' => :'PtsV2PaymentsPost201ResponseClientReferenceInformation',
85
+ :'reversal_amount_details' => :'PtsV2PaymentsReversalsPost201ResponseReversalAmountDetails',
86
+ :'processor_information' => :'PtsV2PaymentsReversalsPost201ResponseProcessorInformation',
87
+ :'issuer_information' => :'PtsV2PaymentsReversalsPost201ResponseIssuerInformation',
88
+ :'authorization_information' => :'PtsV2PaymentsReversalsPost201ResponseAuthorizationInformation',
89
+ :'point_of_sale_information' => :'Ptsv2paymentsidreversalsPointOfSaleInformation'
90
+ }
91
+ end
92
+
93
+ # Initializes the object
94
+ # @param [Hash] attributes Model attributes in the form of hash
95
+ def initialize(attributes = {})
96
+ return unless attributes.is_a?(Hash)
97
+
98
+ # convert string to symbol for hash key
99
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
100
+
101
+ if attributes.has_key?(:'_links')
102
+ self._links = attributes[:'_links']
103
+ end
104
+
105
+ if attributes.has_key?(:'id')
106
+ self.id = attributes[:'id']
107
+ end
108
+
109
+ if attributes.has_key?(:'submitTimeUtc')
110
+ self.submit_time_utc = attributes[:'submitTimeUtc']
111
+ end
112
+
113
+ if attributes.has_key?(:'status')
114
+ self.status = attributes[:'status']
115
+ end
116
+
117
+ if attributes.has_key?(:'reconciliationId')
118
+ self.reconciliation_id = attributes[:'reconciliationId']
119
+ end
120
+
121
+ if attributes.has_key?(:'clientReferenceInformation')
122
+ self.client_reference_information = attributes[:'clientReferenceInformation']
123
+ end
124
+
125
+ if attributes.has_key?(:'reversalAmountDetails')
126
+ self.reversal_amount_details = attributes[:'reversalAmountDetails']
127
+ end
128
+
129
+ if attributes.has_key?(:'processorInformation')
130
+ self.processor_information = attributes[:'processorInformation']
131
+ end
132
+
133
+ if attributes.has_key?(:'issuerInformation')
134
+ self.issuer_information = attributes[:'issuerInformation']
135
+ end
136
+
137
+ if attributes.has_key?(:'authorizationInformation')
138
+ self.authorization_information = attributes[:'authorizationInformation']
139
+ end
140
+
141
+ if attributes.has_key?(:'pointOfSaleInformation')
142
+ self.point_of_sale_information = attributes[:'pointOfSaleInformation']
143
+ end
144
+ end
145
+
146
+ # Show invalid properties with the reasons. Usually used together with valid?
147
+ # @return Array for valid properties with the reasons
148
+ def list_invalid_properties
149
+ invalid_properties = Array.new
150
+ invalid_properties
151
+ end
152
+
153
+ # Check to see if the all the properties in the model are valid
154
+ # @return true if the model is valid
155
+ def valid?
156
+ true
157
+ end
158
+
159
+ # Custom attribute writer method with validation
160
+ # @param [Object] id Value to be assigned
161
+ def id=(id)
162
+ @id = id
163
+ end
164
+
165
+ # Custom attribute writer method with validation
166
+ # @param [Object] reconciliation_id Value to be assigned
167
+ def reconciliation_id=(reconciliation_id)
168
+ @reconciliation_id = reconciliation_id
169
+ end
170
+
171
+ # Checks equality by comparing each attribute.
172
+ # @param [Object] Object to be compared
173
+ def ==(o)
174
+ return true if self.equal?(o)
175
+ self.class == o.class &&
176
+ _links == o._links &&
177
+ id == o.id &&
178
+ submit_time_utc == o.submit_time_utc &&
179
+ status == o.status &&
180
+ reconciliation_id == o.reconciliation_id &&
181
+ client_reference_information == o.client_reference_information &&
182
+ reversal_amount_details == o.reversal_amount_details &&
183
+ processor_information == o.processor_information &&
184
+ issuer_information == o.issuer_information &&
185
+ authorization_information == o.authorization_information &&
186
+ point_of_sale_information == o.point_of_sale_information
187
+ end
188
+
189
+ # @see the `==` method
190
+ # @param [Object] Object to be compared
191
+ def eql?(o)
192
+ self == o
193
+ end
194
+
195
+ # Calculates hash code according to all attributes.
196
+ # @return [Fixnum] Hash code
197
+ def hash
198
+ [_links, id, submit_time_utc, status, reconciliation_id, client_reference_information, reversal_amount_details, processor_information, issuer_information, authorization_information, point_of_sale_information].hash
199
+ end
200
+
201
+ # Builds the object from hash
202
+ # @param [Hash] attributes Model attributes in the form of hash
203
+ # @return [Object] Returns the model itself
204
+ def build_from_hash(attributes)
205
+ return nil unless attributes.is_a?(Hash)
206
+ self.class.swagger_types.each_pair do |key, type|
207
+ if type =~ /\AArray<(.*)>/i
208
+ # check to ensure the input is an array given that the the attribute
209
+ # is documented as an array but the input is not
210
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
211
+ self.send("#{self.class.json_map[key]}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
212
+ end
213
+ elsif !attributes[self.class.attribute_map[key]].nil?
214
+ self.send("#{self.class.json_map[key]}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
215
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
216
+ end
217
+
218
+ self
219
+ end
220
+
221
+ # Deserializes the data based on type
222
+ # @param string type Data type
223
+ # @param string value Value to be deserialized
224
+ # @return [Object] Deserialized data
225
+ def _deserialize(type, value)
226
+ case type.to_sym
227
+ when :DateTime
228
+ DateTime.parse(value)
229
+ when :Date
230
+ Date.parse(value)
231
+ when :String
232
+ value.to_s
233
+ when :Integer
234
+ value.to_i
235
+ when :Float
236
+ value.to_f
237
+ when :BOOLEAN
238
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
239
+ true
240
+ else
241
+ false
242
+ end
243
+ when :Object
244
+ # generic object (usually a Hash), return directly
245
+ value
246
+ when /\AArray<(?<inner_type>.+)>\z/
247
+ inner_type = Regexp.last_match[:inner_type]
248
+ value.map { |v| _deserialize(inner_type, v) }
249
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
250
+ k_type = Regexp.last_match[:k_type]
251
+ v_type = Regexp.last_match[:v_type]
252
+ {}.tap do |hash|
253
+ value.each do |k, v|
254
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
255
+ end
256
+ end
257
+ else # model
258
+ temp_model = CyberSource.const_get(type).new
259
+ temp_model.build_from_hash(value)
260
+ end
261
+ end
262
+
263
+ # Returns the string representation of the object
264
+ # @return [String] String presentation of the object
265
+ def to_s
266
+ to_hash.to_s
267
+ end
268
+
269
+ # to_body is an alias to to_hash (backward compatibility)
270
+ # @return [Hash] Returns the object in the form of hash
271
+ def to_body
272
+ to_hash
273
+ end
274
+
275
+ # Returns the object in the form of hash
276
+ # @return [Hash] Returns the object in the form of hash
277
+ def to_hash
278
+ hash = {}
279
+ self.class.attribute_map.each_pair do |attr, param|
280
+ value = self.send(attr)
281
+ next if value.nil?
282
+ hash[param] = _to_hash(value)
283
+ end
284
+ hash
285
+ end
286
+
287
+ # Outputs non-array value in the form of hash
288
+ # For object, use to_hash. Otherwise, just return the value
289
+ # @param [Object] value Any valid value
290
+ # @return [Hash] Returns the value in the form of hash
291
+ def _to_hash(value)
292
+ if value.is_a?(Array)
293
+ value.compact.map { |v| _to_hash(v) }
294
+ elsif value.is_a?(Hash)
295
+ {}.tap do |hash|
296
+ value.each { |k, v| hash[k] = _to_hash(v) }
297
+ end
298
+ elsif value.respond_to? :to_hash
299
+ value.to_hash
300
+ else
301
+ value
302
+ end
303
+ end
304
+ end
305
+ end