cyberSource_client 0.0.2 → 0.0.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (268) hide show
  1. checksums.yaml +5 -5
  2. data/AuthenticationSDK/Cybersource.gemspec +23 -23
  3. data/AuthenticationSDK/authentication/http/GetSignatureParameter.rb +62 -62
  4. data/AuthenticationSDK/authentication/http/HttpSignatureHeader.rb +50 -50
  5. data/AuthenticationSDK/authentication/jwt/JwtToken.rb +62 -62
  6. data/AuthenticationSDK/authentication/payloadDigest/digest.rb +10 -10
  7. data/AuthenticationSDK/core/Authorization.rb +24 -24
  8. data/AuthenticationSDK/core/ITokenGeneration.rb +4 -4
  9. data/AuthenticationSDK/core/Logger.rb +26 -26
  10. data/AuthenticationSDK/core/MerchantConfig.rb +181 -181
  11. data/AuthenticationSDK/util/ApiException.rb +18 -18
  12. data/AuthenticationSDK/util/Cache.rb +36 -36
  13. data/AuthenticationSDK/util/Constants.rb +133 -133
  14. data/AuthenticationSDK/util/PropertiesUtil.rb +21 -21
  15. data/AuthenticationSDK/util/Utility.rb +30 -30
  16. data/lib/cyberSource_client.rb +286 -286
  17. data/lib/cyberSource_client/api/capture_api.rb +133 -133
  18. data/lib/cyberSource_client/api/credit_api.rb +127 -127
  19. data/lib/cyberSource_client/api/default_api.rb +75 -75
  20. data/lib/cyberSource_client/api/instrument_identifier_api.rb +393 -393
  21. data/lib/cyberSource_client/api/key_generation_api.rb +75 -75
  22. data/lib/cyberSource_client/api/payment_api.rb +127 -127
  23. data/lib/cyberSource_client/api/payment_instrument_api.rb +312 -312
  24. data/lib/cyberSource_client/api/refund_api.rb +191 -191
  25. data/lib/cyberSource_client/api/reversal_api.rb +133 -133
  26. data/lib/cyberSource_client/api/tokenization_api.rb +71 -71
  27. data/lib/cyberSource_client/api/void_api.rb +307 -307
  28. data/lib/cyberSource_client/api_client.rb +437 -437
  29. data/lib/cyberSource_client/api_error.rb +38 -38
  30. data/lib/cyberSource_client/configuration.rb +202 -202
  31. data/lib/cyberSource_client/models/auth_reversal_request.rb +219 -219
  32. data/lib/cyberSource_client/models/body.rb +295 -295
  33. data/lib/cyberSource_client/models/body_1.rb +183 -183
  34. data/lib/cyberSource_client/models/body_2.rb +331 -331
  35. data/lib/cyberSource_client/models/body_3.rb +331 -331
  36. data/lib/cyberSource_client/models/capture_payment_request.rb +267 -267
  37. data/lib/cyberSource_client/models/card_info.rb +214 -214
  38. data/lib/cyberSource_client/models/create_credit_request.rb +267 -267
  39. data/lib/cyberSource_client/models/create_payment_request.rb +285 -285
  40. data/lib/cyberSource_client/models/der_public_key.rb +205 -205
  41. data/lib/cyberSource_client/models/error.rb +192 -192
  42. data/lib/cyberSource_client/models/error_links.rb +205 -205
  43. data/lib/cyberSource_client/models/error_response.rb +192 -192
  44. data/lib/cyberSource_client/models/generate_public_key_request.rb +184 -184
  45. data/lib/cyberSource_client/models/inline_response_200.rb +202 -202
  46. data/lib/cyberSource_client/models/inline_response_200_1.rb +255 -255
  47. data/lib/cyberSource_client/models/inline_response_200_2.rb +377 -377
  48. data/lib/cyberSource_client/models/inline_response_200_2_buyer_information.rb +270 -270
  49. data/lib/cyberSource_client/models/inline_response_200_2_device_information.rb +219 -219
  50. data/lib/cyberSource_client/models/inline_response_200_2_merchant_information.rb +233 -233
  51. data/lib/cyberSource_client/models/inline_response_200_2_order_information.rb +230 -230
  52. data/lib/cyberSource_client/models/inline_response_200_2_order_information_amount_details.rb +385 -385
  53. data/lib/cyberSource_client/models/inline_response_200_2_order_information_bill_to.rb +459 -459
  54. data/lib/cyberSource_client/models/inline_response_200_2_order_information_invoice_details.rb +315 -315
  55. data/lib/cyberSource_client/models/inline_response_200_2_order_information_line_items.rb +564 -564
  56. data/lib/cyberSource_client/models/inline_response_200_2_order_information_ship_to.rb +429 -429
  57. data/lib/cyberSource_client/models/inline_response_200_2_payment_information.rb +192 -192
  58. data/lib/cyberSource_client/models/inline_response_200_2_payment_information_card.rb +274 -274
  59. data/lib/cyberSource_client/models/inline_response_200_2_payment_information_tokenized_card.rb +299 -299
  60. data/lib/cyberSource_client/models/inline_response_200_2_processing_information.rb +199 -199
  61. data/lib/cyberSource_client/models/inline_response_200_2_processor_information.rb +227 -227
  62. data/lib/cyberSource_client/models/inline_response_200_2_processor_information_avs.rb +199 -199
  63. data/lib/cyberSource_client/models/inline_response_200_2_processor_information_card_verification.rb +199 -199
  64. data/lib/cyberSource_client/models/inline_response_200_3.rb +314 -314
  65. data/lib/cyberSource_client/models/inline_response_200_4.rb +350 -350
  66. data/lib/cyberSource_client/models/inline_response_200_4_device_information.rb +199 -199
  67. data/lib/cyberSource_client/models/inline_response_200_4_order_information.rb +230 -230
  68. data/lib/cyberSource_client/models/inline_response_200_4_order_information_amount_details.rb +360 -360
  69. data/lib/cyberSource_client/models/inline_response_200_4_order_information_invoice_details.rb +305 -305
  70. data/lib/cyberSource_client/models/inline_response_200_4_order_information_ship_to.rb +249 -249
  71. data/lib/cyberSource_client/models/inline_response_200_4_processing_information.rb +208 -208
  72. data/lib/cyberSource_client/models/inline_response_200_4_processing_information_authorization_options.rb +199 -199
  73. data/lib/cyberSource_client/models/inline_response_200_5.rb +305 -305
  74. data/lib/cyberSource_client/models/inline_response_200_6.rb +305 -305
  75. data/lib/cyberSource_client/models/inline_response_200_7.rb +295 -295
  76. data/lib/cyberSource_client/models/inline_response_200_8.rb +277 -277
  77. data/lib/cyberSource_client/models/inline_response_200_8__links.rb +219 -219
  78. data/lib/cyberSource_client/models/inline_response_200_8__links_first.rb +184 -184
  79. data/lib/cyberSource_client/models/inline_response_200_8__links_last.rb +184 -184
  80. data/lib/cyberSource_client/models/inline_response_200_8__links_next.rb +184 -184
  81. data/lib/cyberSource_client/models/inline_response_200_8__links_prev.rb +184 -184
  82. data/lib/cyberSource_client/models/inline_response_200_8__links_self.rb +184 -184
  83. data/lib/cyberSource_client/models/inline_response_200_der.rb +205 -205
  84. data/lib/cyberSource_client/models/inline_response_200_jwk.rb +225 -225
  85. data/lib/cyberSource_client/models/inline_response_201.rb +350 -350
  86. data/lib/cyberSource_client/models/inline_response_201_1.rb +332 -332
  87. data/lib/cyberSource_client/models/inline_response_201_1_authorization_information.rb +224 -224
  88. data/lib/cyberSource_client/models/inline_response_201_1_processor_information.rb +324 -324
  89. data/lib/cyberSource_client/models/inline_response_201_1_reversal_amount_details.rb +249 -249
  90. data/lib/cyberSource_client/models/inline_response_201_2.rb +314 -314
  91. data/lib/cyberSource_client/models/inline_response_201_2__links.rb +201 -201
  92. data/lib/cyberSource_client/models/inline_response_201_2_order_information.rb +192 -192
  93. data/lib/cyberSource_client/models/inline_response_201_2_order_information_amount_details.rb +224 -224
  94. data/lib/cyberSource_client/models/inline_response_201_2_processor_information.rb +199 -199
  95. data/lib/cyberSource_client/models/inline_response_201_3.rb +323 -323
  96. data/lib/cyberSource_client/models/inline_response_201_3__links.rb +192 -192
  97. data/lib/cyberSource_client/models/inline_response_201_3_order_information.rb +183 -183
  98. data/lib/cyberSource_client/models/inline_response_201_3_processor_information.rb +224 -224
  99. data/lib/cyberSource_client/models/inline_response_201_3_refund_amount_details.rb +224 -224
  100. data/lib/cyberSource_client/models/inline_response_201_4.rb +323 -323
  101. data/lib/cyberSource_client/models/inline_response_201_4_credit_amount_details.rb +224 -224
  102. data/lib/cyberSource_client/models/inline_response_201_5.rb +280 -280
  103. data/lib/cyberSource_client/models/inline_response_201_5_void_amount_details.rb +219 -219
  104. data/lib/cyberSource_client/models/inline_response_201_6.rb +331 -331
  105. data/lib/cyberSource_client/models/inline_response_201__embedded.rb +183 -183
  106. data/lib/cyberSource_client/models/inline_response_201__embedded_capture.rb +193 -193
  107. data/lib/cyberSource_client/models/inline_response_201__embedded_capture__links.rb +183 -183
  108. data/lib/cyberSource_client/models/inline_response_201__links.rb +201 -201
  109. data/lib/cyberSource_client/models/inline_response_201__links_self.rb +194 -194
  110. data/lib/cyberSource_client/models/inline_response_201_client_reference_information.rb +199 -199
  111. data/lib/cyberSource_client/models/inline_response_201_error_information.rb +239 -239
  112. data/lib/cyberSource_client/models/inline_response_201_error_information_details.rb +228 -228
  113. data/lib/cyberSource_client/models/inline_response_201_order_information.rb +192 -192
  114. data/lib/cyberSource_client/models/inline_response_201_order_information_amount_details.rb +249 -249
  115. data/lib/cyberSource_client/models/inline_response_201_order_information_invoice_details.rb +184 -184
  116. data/lib/cyberSource_client/models/inline_response_201_payment_information.rb +201 -201
  117. data/lib/cyberSource_client/models/inline_response_201_payment_information_account_features.rb +623 -623
  118. data/lib/cyberSource_client/models/inline_response_201_payment_information_card.rb +199 -199
  119. data/lib/cyberSource_client/models/inline_response_201_payment_information_tokenized_card.rb +349 -349
  120. data/lib/cyberSource_client/models/inline_response_201_point_of_sale_information.rb +208 -208
  121. data/lib/cyberSource_client/models/inline_response_201_point_of_sale_information_emv.rb +199 -199
  122. data/lib/cyberSource_client/models/inline_response_201_processor_information.rb +642 -642
  123. data/lib/cyberSource_client/models/inline_response_201_processor_information_avs.rb +224 -224
  124. data/lib/cyberSource_client/models/inline_response_201_processor_information_card_verification.rb +224 -224
  125. data/lib/cyberSource_client/models/inline_response_201_processor_information_consumer_authentication_response.rb +224 -224
  126. data/lib/cyberSource_client/models/inline_response_201_processor_information_customer.rb +199 -199
  127. data/lib/cyberSource_client/models/inline_response_201_processor_information_electronic_verification_results.rb +474 -474
  128. data/lib/cyberSource_client/models/inline_response_201_processor_information_issuer.rb +224 -224
  129. data/lib/cyberSource_client/models/inline_response_201_processor_information_merchant_advice.rb +224 -224
  130. data/lib/cyberSource_client/models/inline_response_400.rb +271 -271
  131. data/lib/cyberSource_client/models/inline_response_400_1.rb +271 -271
  132. data/lib/cyberSource_client/models/inline_response_400_2.rb +271 -271
  133. data/lib/cyberSource_client/models/inline_response_400_3.rb +271 -271
  134. data/lib/cyberSource_client/models/inline_response_400_4.rb +271 -271
  135. data/lib/cyberSource_client/models/inline_response_400_5.rb +259 -259
  136. data/lib/cyberSource_client/models/inline_response_400_6.rb +202 -202
  137. data/lib/cyberSource_client/models/inline_response_409.rb +183 -183
  138. data/lib/cyberSource_client/models/inline_response_409__links.rb +183 -183
  139. data/lib/cyberSource_client/models/inline_response_409__links_payment_instruments.rb +183 -183
  140. data/lib/cyberSource_client/models/inline_response_502.rb +260 -260
  141. data/lib/cyberSource_client/models/inline_response_default.rb +192 -192
  142. data/lib/cyberSource_client/models/inline_response_default__links.rb +205 -205
  143. data/lib/cyberSource_client/models/inline_response_default__links_next.rb +204 -204
  144. data/lib/cyberSource_client/models/inline_response_default_response_status.rb +225 -225
  145. data/lib/cyberSource_client/models/inline_response_default_response_status_details.rb +194 -194
  146. data/lib/cyberSource_client/models/instrumentidentifiers__links.rb +201 -201
  147. data/lib/cyberSource_client/models/instrumentidentifiers__links_self.rb +183 -183
  148. data/lib/cyberSource_client/models/instrumentidentifiers_authorization_options_merchant_initiated_transaction.rb +184 -184
  149. data/lib/cyberSource_client/models/instrumentidentifiers_bank_account.rb +194 -194
  150. data/lib/cyberSource_client/models/instrumentidentifiers_card.rb +184 -184
  151. data/lib/cyberSource_client/models/instrumentidentifiers_details.rb +194 -194
  152. data/lib/cyberSource_client/models/instrumentidentifiers_metadata.rb +184 -184
  153. data/lib/cyberSource_client/models/instrumentidentifiers_processing_information.rb +183 -183
  154. data/lib/cyberSource_client/models/instrumentidentifiers_processing_information_authorization_options.rb +183 -183
  155. data/lib/cyberSource_client/models/instrumentidentifiers_processing_information_authorization_options_initiator.rb +183 -183
  156. data/lib/cyberSource_client/models/json_web_key.rb +225 -225
  157. data/lib/cyberSource_client/models/key_parameters.rb +184 -184
  158. data/lib/cyberSource_client/models/key_result.rb +202 -202
  159. data/lib/cyberSource_client/models/link.rb +204 -204
  160. data/lib/cyberSource_client/models/links.rb +205 -205
  161. data/lib/cyberSource_client/models/oct_create_payment_request.rb +237 -237
  162. data/lib/cyberSource_client/models/paymentinstruments_bank_account.rb +184 -184
  163. data/lib/cyberSource_client/models/paymentinstruments_bill_to.rb +284 -284
  164. data/lib/cyberSource_client/models/paymentinstruments_buyer_information.rb +215 -215
  165. data/lib/cyberSource_client/models/paymentinstruments_buyer_information_issued_by.rb +184 -184
  166. data/lib/cyberSource_client/models/paymentinstruments_buyer_information_personal_identification.rb +203 -203
  167. data/lib/cyberSource_client/models/paymentinstruments_card.rb +278 -278
  168. data/lib/cyberSource_client/models/paymentinstruments_instrument_identifier.rb +295 -295
  169. data/lib/cyberSource_client/models/paymentinstruments_merchant_information.rb +183 -183
  170. data/lib/cyberSource_client/models/paymentinstruments_merchant_information_merchant_descriptor.rb +184 -184
  171. data/lib/cyberSource_client/models/paymentinstruments_processing_information.rb +193 -193
  172. data/lib/cyberSource_client/models/paymentinstruments_processing_information_bank_transfer_options.rb +184 -184
  173. data/lib/cyberSource_client/models/paymentsflexv1tokens_card_info.rb +214 -214
  174. data/lib/cyberSource_client/models/refund_capture_request.rb +267 -267
  175. data/lib/cyberSource_client/models/refund_payment_request.rb +267 -267
  176. data/lib/cyberSource_client/models/response_status.rb +225 -225
  177. data/lib/cyberSource_client/models/response_status_details.rb +194 -194
  178. data/lib/cyberSource_client/models/tokenize_parameters.rb +193 -193
  179. data/lib/cyberSource_client/models/tokenize_request.rb +193 -193
  180. data/lib/cyberSource_client/models/tokenize_result.rb +255 -255
  181. data/lib/cyberSource_client/models/v2credits_point_of_sale_information.rb +183 -183
  182. data/lib/cyberSource_client/models/v2credits_point_of_sale_information_emv.rb +221 -221
  183. data/lib/cyberSource_client/models/v2credits_processing_information.rb +383 -383
  184. data/lib/cyberSource_client/models/v2payments_aggregator_information.rb +233 -233
  185. data/lib/cyberSource_client/models/v2payments_aggregator_information_sub_merchant.rb +424 -424
  186. data/lib/cyberSource_client/models/v2payments_buyer_information.rb +285 -285
  187. data/lib/cyberSource_client/models/v2payments_buyer_information_personal_identification.rb +252 -252
  188. data/lib/cyberSource_client/models/v2payments_client_reference_information.rb +219 -219
  189. data/lib/cyberSource_client/models/v2payments_consumer_authentication_information.rb +374 -374
  190. data/lib/cyberSource_client/models/v2payments_device_information.rb +249 -249
  191. data/lib/cyberSource_client/models/v2payments_merchant_defined_information.rb +224 -224
  192. data/lib/cyberSource_client/models/v2payments_merchant_information.rb +308 -308
  193. data/lib/cyberSource_client/models/v2payments_merchant_information_merchant_descriptor.rb +374 -374
  194. data/lib/cyberSource_client/models/v2payments_order_information.rb +230 -230
  195. data/lib/cyberSource_client/models/v2payments_order_information_amount_details.rb +605 -605
  196. data/lib/cyberSource_client/models/v2payments_order_information_amount_details_amex_additional_amounts.rb +224 -224
  197. data/lib/cyberSource_client/models/v2payments_order_information_amount_details_surcharge.rb +209 -209
  198. data/lib/cyberSource_client/models/v2payments_order_information_amount_details_tax_details.rb +328 -328
  199. data/lib/cyberSource_client/models/v2payments_order_information_bill_to.rb +618 -618
  200. data/lib/cyberSource_client/models/v2payments_order_information_invoice_details.rb +330 -330
  201. data/lib/cyberSource_client/models/v2payments_order_information_invoice_details_transaction_advice_addendum.rb +199 -199
  202. data/lib/cyberSource_client/models/v2payments_order_information_line_items.rb +649 -649
  203. data/lib/cyberSource_client/models/v2payments_order_information_ship_to.rb +474 -474
  204. data/lib/cyberSource_client/models/v2payments_order_information_shipping_details.rb +234 -234
  205. data/lib/cyberSource_client/models/v2payments_payment_information.rb +210 -210
  206. data/lib/cyberSource_client/models/v2payments_payment_information_card.rb +474 -474
  207. data/lib/cyberSource_client/models/v2payments_payment_information_customer.rb +202 -202
  208. data/lib/cyberSource_client/models/v2payments_payment_information_fluid_data.rb +259 -259
  209. data/lib/cyberSource_client/models/v2payments_payment_information_tokenized_card.rb +424 -424
  210. data/lib/cyberSource_client/models/v2payments_point_of_sale_information.rb +440 -440
  211. data/lib/cyberSource_client/models/v2payments_point_of_sale_information_emv.rb +256 -256
  212. data/lib/cyberSource_client/models/v2payments_processing_information.rb +432 -432
  213. data/lib/cyberSource_client/models/v2payments_processing_information_authorization_options.rb +361 -361
  214. data/lib/cyberSource_client/models/v2payments_processing_information_authorization_options_initiator.rb +247 -247
  215. data/lib/cyberSource_client/models/{v2payments_processing_information_authorization_options_initiator_merchant_initiated_transaction.rb → v2payments_processing_information_authorization_options_merchant_initiated_transaction.rb} +224 -224
  216. data/lib/cyberSource_client/models/v2payments_processing_information_capture_options.rb +267 -267
  217. data/lib/cyberSource_client/models/v2payments_processing_information_issuer.rb +199 -199
  218. data/lib/cyberSource_client/models/v2payments_processing_information_recurring_options.rb +198 -198
  219. data/lib/cyberSource_client/models/v2payments_recipient_information.rb +249 -249
  220. data/lib/cyberSource_client/models/v2paymentsidcaptures_aggregator_information.rb +233 -233
  221. data/lib/cyberSource_client/models/v2paymentsidcaptures_aggregator_information_sub_merchant.rb +374 -374
  222. data/lib/cyberSource_client/models/v2paymentsidcaptures_buyer_information.rb +224 -224
  223. data/lib/cyberSource_client/models/v2paymentsidcaptures_merchant_information.rb +258 -258
  224. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information.rb +230 -230
  225. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_amount_details.rb +546 -546
  226. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_bill_to.rb +449 -449
  227. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_invoice_details.rb +320 -320
  228. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_ship_to.rb +249 -249
  229. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_shipping_details.rb +199 -199
  230. data/lib/cyberSource_client/models/v2paymentsidcaptures_payment_information.rb +183 -183
  231. data/lib/cyberSource_client/models/v2paymentsidcaptures_point_of_sale_information.rb +208 -208
  232. data/lib/cyberSource_client/models/v2paymentsidcaptures_point_of_sale_information_emv.rb +211 -211
  233. data/lib/cyberSource_client/models/v2paymentsidcaptures_processing_information.rb +351 -351
  234. data/lib/cyberSource_client/models/v2paymentsidcaptures_processing_information_authorization_options.rb +249 -249
  235. data/lib/cyberSource_client/models/v2paymentsidcaptures_processing_information_capture_options.rb +242 -242
  236. data/lib/cyberSource_client/models/v2paymentsidrefunds_merchant_information.rb +258 -258
  237. data/lib/cyberSource_client/models/v2paymentsidrefunds_order_information.rb +230 -230
  238. data/lib/cyberSource_client/models/v2paymentsidrefunds_order_information_line_items.rb +639 -639
  239. data/lib/cyberSource_client/models/v2paymentsidrefunds_payment_information.rb +183 -183
  240. data/lib/cyberSource_client/models/v2paymentsidrefunds_payment_information_card.rb +374 -374
  241. data/lib/cyberSource_client/models/v2paymentsidrefunds_point_of_sale_information.rb +183 -183
  242. data/lib/cyberSource_client/models/v2paymentsidrefunds_processing_information.rb +333 -333
  243. data/lib/cyberSource_client/models/v2paymentsidrefunds_processing_information_recurring_options.rb +186 -186
  244. data/lib/cyberSource_client/models/v2paymentsidreversals_client_reference_information.rb +209 -209
  245. data/lib/cyberSource_client/models/v2paymentsidreversals_order_information.rb +185 -185
  246. data/lib/cyberSource_client/models/v2paymentsidreversals_order_information_line_items.rb +233 -233
  247. data/lib/cyberSource_client/models/v2paymentsidreversals_point_of_sale_information.rb +183 -183
  248. data/lib/cyberSource_client/models/v2paymentsidreversals_processing_information.rb +308 -308
  249. data/lib/cyberSource_client/models/v2paymentsidreversals_reversal_information.rb +211 -211
  250. data/lib/cyberSource_client/models/v2paymentsidreversals_reversal_information_amount_details.rb +224 -224
  251. data/lib/cyberSource_client/models/v2payouts_merchant_information.rb +258 -258
  252. data/lib/cyberSource_client/models/v2payouts_merchant_information_merchant_descriptor.rb +324 -324
  253. data/lib/cyberSource_client/models/v2payouts_order_information.rb +192 -192
  254. data/lib/cyberSource_client/models/v2payouts_order_information_amount_details.rb +249 -249
  255. data/lib/cyberSource_client/models/v2payouts_order_information_bill_to.rb +443 -443
  256. data/lib/cyberSource_client/models/v2payouts_payment_information.rb +183 -183
  257. data/lib/cyberSource_client/models/v2payouts_payment_information_card.rb +299 -299
  258. data/lib/cyberSource_client/models/v2payouts_processing_information.rb +283 -283
  259. data/lib/cyberSource_client/models/v2payouts_processing_information_payouts_options.rb +274 -274
  260. data/lib/cyberSource_client/models/v2payouts_recipient_information.rb +433 -433
  261. data/lib/cyberSource_client/models/v2payouts_sender_information.rb +517 -517
  262. data/lib/cyberSource_client/models/v2payouts_sender_information_account.rb +233 -233
  263. data/lib/cyberSource_client/models/void_capture_request.rb +183 -183
  264. data/lib/cyberSource_client/models/void_credit_request.rb +183 -183
  265. data/lib/cyberSource_client/models/void_payment_request.rb +183 -183
  266. data/lib/cyberSource_client/models/void_refund_request.rb +183 -183
  267. data/lib/cyberSource_client/version.rb +15 -15
  268. metadata +4 -4
@@ -1,199 +1,199 @@
1
- =begin
2
- #CyberSource Flex API
3
-
4
- #Simple PAN tokenization service
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.2.3
10
-
11
- =end
12
-
13
- require 'date'
14
-
15
- module CyberSource
16
- class V2paymentsOrderInformationInvoiceDetailsTransactionAdviceAddendum
17
- # Four Transaction Advice Addendum (TAA) fields. These fields are used to display descriptive information about a transaction on the customer’s American Express card statement. When you send TAA fields, start with amexdata_taa1, then ...taa2, and so on. Skipping a TAA field causes subsequent TAA fields to be ignored. To use these fields, contact CyberSource Customer Support to have your account enabled for this feature.
18
- attr_accessor :data
19
-
20
- # Attribute mapping from ruby-style variable name to JSON key.
21
- def self.attribute_map
22
- {
23
- :'data' => :'data'
24
- }
25
- end
26
-
27
- # Attribute type mapping.
28
- def self.swagger_types
29
- {
30
- :'data' => :'String'
31
- }
32
- end
33
-
34
- # Initializes the object
35
- # @param [Hash] attributes Model attributes in the form of hash
36
- def initialize(attributes = {})
37
- return unless attributes.is_a?(Hash)
38
-
39
- # convert string to symbol for hash key
40
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
41
-
42
- if attributes.has_key?(:'data')
43
- self.data = attributes[:'data']
44
- end
45
- end
46
-
47
- # Show invalid properties with the reasons. Usually used together with valid?
48
- # @return Array for valid properties with the reasons
49
- def list_invalid_properties
50
- invalid_properties = Array.new
51
- if !@data.nil? && @data.to_s.length > 40
52
- invalid_properties.push('invalid value for "data", the character length must be smaller than or equal to 40.')
53
- end
54
-
55
- invalid_properties
56
- end
57
-
58
- # Check to see if the all the properties in the model are valid
59
- # @return true if the model is valid
60
- def valid?
61
- return false if !@data.nil? && @data.to_s.length > 40
62
- true
63
- end
64
-
65
- # Custom attribute writer method with validation
66
- # @param [Object] data Value to be assigned
67
- def data=(data)
68
- if !data.nil? && data.to_s.length > 40
69
- fail ArgumentError, 'invalid value for "data", the character length must be smaller than or equal to 40.'
70
- end
71
-
72
- @data = data
73
- end
74
-
75
- # Checks equality by comparing each attribute.
76
- # @param [Object] Object to be compared
77
- def ==(o)
78
- return true if self.equal?(o)
79
- self.class == o.class &&
80
- data == o.data
81
- end
82
-
83
- # @see the `==` method
84
- # @param [Object] Object to be compared
85
- def eql?(o)
86
- self == o
87
- end
88
-
89
- # Calculates hash code according to all attributes.
90
- # @return [Fixnum] Hash code
91
- def hash
92
- [data].hash
93
- end
94
-
95
- # Builds the object from hash
96
- # @param [Hash] attributes Model attributes in the form of hash
97
- # @return [Object] Returns the model itself
98
- def build_from_hash(attributes)
99
- return nil unless attributes.is_a?(Hash)
100
- self.class.swagger_types.each_pair do |key, type|
101
- if type =~ /\AArray<(.*)>/i
102
- # check to ensure the input is an array given that the the attribute
103
- # is documented as an array but the input is not
104
- if attributes[self.class.attribute_map[key]].is_a?(Array)
105
- self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
106
- end
107
- elsif !attributes[self.class.attribute_map[key]].nil?
108
- self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
109
- end # or else data not found in attributes(hash), not an issue as the data can be optional
110
- end
111
-
112
- self
113
- end
114
-
115
- # Deserializes the data based on type
116
- # @param string type Data type
117
- # @param string value Value to be deserialized
118
- # @return [Object] Deserialized data
119
- def _deserialize(type, value)
120
- case type.to_sym
121
- when :DateTime
122
- DateTime.parse(value)
123
- when :Date
124
- Date.parse(value)
125
- when :String
126
- value.to_s
127
- when :Integer
128
- value.to_i
129
- when :Float
130
- value.to_f
131
- when :BOOLEAN
132
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
133
- true
134
- else
135
- false
136
- end
137
- when :Object
138
- # generic object (usually a Hash), return directly
139
- value
140
- when /\AArray<(?<inner_type>.+)>\z/
141
- inner_type = Regexp.last_match[:inner_type]
142
- value.map { |v| _deserialize(inner_type, v) }
143
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
144
- k_type = Regexp.last_match[:k_type]
145
- v_type = Regexp.last_match[:v_type]
146
- {}.tap do |hash|
147
- value.each do |k, v|
148
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
149
- end
150
- end
151
- else # model
152
- temp_model = CyberSource.const_get(type).new
153
- temp_model.build_from_hash(value)
154
- end
155
- end
156
-
157
- # Returns the string representation of the object
158
- # @return [String] String presentation of the object
159
- def to_s
160
- to_hash.to_s
161
- end
162
-
163
- # to_body is an alias to to_hash (backward compatibility)
164
- # @return [Hash] Returns the object in the form of hash
165
- def to_body
166
- to_hash
167
- end
168
-
169
- # Returns the object in the form of hash
170
- # @return [Hash] Returns the object in the form of hash
171
- def to_hash
172
- hash = {}
173
- self.class.attribute_map.each_pair do |attr, param|
174
- value = self.send(attr)
175
- next if value.nil?
176
- hash[param] = _to_hash(value)
177
- end
178
- hash
179
- end
180
-
181
- # Outputs non-array value in the form of hash
182
- # For object, use to_hash. Otherwise, just return the value
183
- # @param [Object] value Any valid value
184
- # @return [Hash] Returns the value in the form of hash
185
- def _to_hash(value)
186
- if value.is_a?(Array)
187
- value.compact.map { |v| _to_hash(v) }
188
- elsif value.is_a?(Hash)
189
- {}.tap do |hash|
190
- value.each { |k, v| hash[k] = _to_hash(v) }
191
- end
192
- elsif value.respond_to? :to_hash
193
- value.to_hash
194
- else
195
- value
196
- end
197
- end
198
- end
199
- end
1
+ =begin
2
+ #CyberSource Flex API
3
+
4
+ #Simple PAN tokenization service
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.2.3
10
+
11
+ =end
12
+
13
+ require 'date'
14
+
15
+ module CyberSource
16
+ class V2paymentsOrderInformationInvoiceDetailsTransactionAdviceAddendum
17
+ # Four Transaction Advice Addendum (TAA) fields. These fields are used to display descriptive information about a transaction on the customer’s American Express card statement. When you send TAA fields, start with amexdata_taa1, then ...taa2, and so on. Skipping a TAA field causes subsequent TAA fields to be ignored. To use these fields, contact CyberSource Customer Support to have your account enabled for this feature.
18
+ attr_accessor :data
19
+
20
+ # Attribute mapping from ruby-style variable name to JSON key.
21
+ def self.attribute_map
22
+ {
23
+ :'data' => :'data'
24
+ }
25
+ end
26
+
27
+ # Attribute type mapping.
28
+ def self.swagger_types
29
+ {
30
+ :'data' => :'String'
31
+ }
32
+ end
33
+
34
+ # Initializes the object
35
+ # @param [Hash] attributes Model attributes in the form of hash
36
+ def initialize(attributes = {})
37
+ return unless attributes.is_a?(Hash)
38
+
39
+ # convert string to symbol for hash key
40
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
41
+
42
+ if attributes.has_key?(:'data')
43
+ self.data = attributes[:'data']
44
+ end
45
+ end
46
+
47
+ # Show invalid properties with the reasons. Usually used together with valid?
48
+ # @return Array for valid properties with the reasons
49
+ def list_invalid_properties
50
+ invalid_properties = Array.new
51
+ if !@data.nil? && @data.to_s.length > 40
52
+ invalid_properties.push('invalid value for "data", the character length must be smaller than or equal to 40.')
53
+ end
54
+
55
+ invalid_properties
56
+ end
57
+
58
+ # Check to see if the all the properties in the model are valid
59
+ # @return true if the model is valid
60
+ def valid?
61
+ return false if !@data.nil? && @data.to_s.length > 40
62
+ true
63
+ end
64
+
65
+ # Custom attribute writer method with validation
66
+ # @param [Object] data Value to be assigned
67
+ def data=(data)
68
+ if !data.nil? && data.to_s.length > 40
69
+ fail ArgumentError, 'invalid value for "data", the character length must be smaller than or equal to 40.'
70
+ end
71
+
72
+ @data = data
73
+ end
74
+
75
+ # Checks equality by comparing each attribute.
76
+ # @param [Object] Object to be compared
77
+ def ==(o)
78
+ return true if self.equal?(o)
79
+ self.class == o.class &&
80
+ data == o.data
81
+ end
82
+
83
+ # @see the `==` method
84
+ # @param [Object] Object to be compared
85
+ def eql?(o)
86
+ self == o
87
+ end
88
+
89
+ # Calculates hash code according to all attributes.
90
+ # @return [Fixnum] Hash code
91
+ def hash
92
+ [data].hash
93
+ end
94
+
95
+ # Builds the object from hash
96
+ # @param [Hash] attributes Model attributes in the form of hash
97
+ # @return [Object] Returns the model itself
98
+ def build_from_hash(attributes)
99
+ return nil unless attributes.is_a?(Hash)
100
+ self.class.swagger_types.each_pair do |key, type|
101
+ if type =~ /\AArray<(.*)>/i
102
+ # check to ensure the input is an array given that the the attribute
103
+ # is documented as an array but the input is not
104
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
105
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
106
+ end
107
+ elsif !attributes[self.class.attribute_map[key]].nil?
108
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
109
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
110
+ end
111
+
112
+ self
113
+ end
114
+
115
+ # Deserializes the data based on type
116
+ # @param string type Data type
117
+ # @param string value Value to be deserialized
118
+ # @return [Object] Deserialized data
119
+ def _deserialize(type, value)
120
+ case type.to_sym
121
+ when :DateTime
122
+ DateTime.parse(value)
123
+ when :Date
124
+ Date.parse(value)
125
+ when :String
126
+ value.to_s
127
+ when :Integer
128
+ value.to_i
129
+ when :Float
130
+ value.to_f
131
+ when :BOOLEAN
132
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
133
+ true
134
+ else
135
+ false
136
+ end
137
+ when :Object
138
+ # generic object (usually a Hash), return directly
139
+ value
140
+ when /\AArray<(?<inner_type>.+)>\z/
141
+ inner_type = Regexp.last_match[:inner_type]
142
+ value.map { |v| _deserialize(inner_type, v) }
143
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
144
+ k_type = Regexp.last_match[:k_type]
145
+ v_type = Regexp.last_match[:v_type]
146
+ {}.tap do |hash|
147
+ value.each do |k, v|
148
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
149
+ end
150
+ end
151
+ else # model
152
+ temp_model = CyberSource.const_get(type).new
153
+ temp_model.build_from_hash(value)
154
+ end
155
+ end
156
+
157
+ # Returns the string representation of the object
158
+ # @return [String] String presentation of the object
159
+ def to_s
160
+ to_hash.to_s
161
+ end
162
+
163
+ # to_body is an alias to to_hash (backward compatibility)
164
+ # @return [Hash] Returns the object in the form of hash
165
+ def to_body
166
+ to_hash
167
+ end
168
+
169
+ # Returns the object in the form of hash
170
+ # @return [Hash] Returns the object in the form of hash
171
+ def to_hash
172
+ hash = {}
173
+ self.class.attribute_map.each_pair do |attr, param|
174
+ value = self.send(attr)
175
+ next if value.nil?
176
+ hash[param] = _to_hash(value)
177
+ end
178
+ hash
179
+ end
180
+
181
+ # Outputs non-array value in the form of hash
182
+ # For object, use to_hash. Otherwise, just return the value
183
+ # @param [Object] value Any valid value
184
+ # @return [Hash] Returns the value in the form of hash
185
+ def _to_hash(value)
186
+ if value.is_a?(Array)
187
+ value.compact.map { |v| _to_hash(v) }
188
+ elsif value.is_a?(Hash)
189
+ {}.tap do |hash|
190
+ value.each { |k, v| hash[k] = _to_hash(v) }
191
+ end
192
+ elsif value.respond_to? :to_hash
193
+ value.to_hash
194
+ else
195
+ value
196
+ end
197
+ end
198
+ end
199
+ end
@@ -1,649 +1,649 @@
1
- =begin
2
- #CyberSource Flex API
3
-
4
- #Simple PAN tokenization service
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.2.3
10
-
11
- =end
12
-
13
- require 'date'
14
-
15
- module CyberSource
16
- class V2paymentsOrderInformationLineItems
17
- # Type of product. This value is used to determine the category that the product is in: electronic, handling, physical, service, or shipping. The default value is **default**. For a payment, when you set this field to a value other than default or any of the values related to shipping and handling, below fields _quantity_, _productName_, and _productSKU_ are required.
18
- attr_accessor :product_code
19
-
20
- # For PAYMENT and CAPTURE API, this field is required when above _productCode_ is not **default** or one of the values related to shipping and handling.
21
- attr_accessor :product_name
22
-
23
- # Identification code for the product. For PAYMENT and CAPTURE API, this field is required when above _productCode_ is not **default** or one of the values related to shipping and/or handling.
24
- attr_accessor :product_sku
25
-
26
- # For a payment or capture, this field is required when _productCode_ is not **default** or one of the values related to shipping and handling.
27
- attr_accessor :quantity
28
-
29
- # Per-item price of the product. This value cannot be negative. You can include a decimal point (.), but you cannot include any other special characters. CyberSource truncates the amount to the correct number of decimal places. For processor-specific information, see the amount field in [Credit Card Services Using the SCMP API.](http://apps.cybersource.com/library/documentation/dev_guides/CC_Svcs_SCMP_API/html)
30
- attr_accessor :unit_price
31
-
32
- # Unit of measure, or unit of measure code, for the item.
33
- attr_accessor :unit_of_measure
34
-
35
- # Total amount for the item. Normally calculated as the unit price x quantity.
36
- attr_accessor :total_amount
37
-
38
- # Total tax to apply to the product. This value cannot be negative. The tax amount and the offer amount must be in the same currency. The tax amount field is additive. The following example uses a two-exponent currency such as USD: 1. You include each line item in your request. ..- 1st line item has amount=10.00, quantity=1, and taxAmount=0.80 ..- 2nd line item has amount=20.00, quantity=1, and taxAmount=1.60 2. The total amount authorized will be 32.40, not 30.00 with 2.40 of tax included. This field is frequently used for Level II and Level III transactions.
39
- attr_accessor :tax_amount
40
-
41
- # Tax rate applied to the item. See \"Numbered Elements,\" page 14. Visa: Valid range is 0.01 to 0.99 (1% to 99%, with only whole percentage values accepted; values with additional decimal places will be truncated). Mastercard: Valid range is 0.00001 to 0.99999 (0.001% to 99.999%).
42
- attr_accessor :tax_rate
43
-
44
- # Flag to indicate how you handle discount at the line item level. - 0: no line level discount provided - 1: tax was calculated on the post-discount line item total - 2: tax was calculated on the pre-discount line item total `Note` Visa will inset 0 (zero) if an invalid value is included in this field. This field relates to the value in the _lineItems[].discountAmount_ field.
45
- attr_accessor :tax_applied_after_discount
46
-
47
- # Flag to indicate whether tax is exempted or not included. - 0: tax not included - 1: tax included - 2: transaction is not subject to tax
48
- attr_accessor :tax_status_indicator
49
-
50
- # Type of tax being applied to the item. Possible values: Below values are used by **RBS WorldPay Atlanta**, **FDC Nashville Global**, **Litle** - 0000: unknown tax type - 0001: federal/national sales tax - 0002: state sales tax - 0003: city sales tax - 0004: local sales tax - 0005: municipal sales tax - 0006: other tax - 0010: value-added tax - 0011: goods and services tax - 0012: provincial sales tax - 0013: harmonized sales tax - 0014: Quebec sales tax (QST) - 0020: room tax - 0021: occupancy tax - 0022: energy tax - Blank: Tax not supported on line item.
51
- attr_accessor :tax_type_code
52
-
53
- # Flag that indicates whether the tax amount is included in the Line Item Total.
54
- attr_accessor :amount_includes_tax
55
-
56
- # Flag to indicate whether the purchase is categorized as goods or services. Possible values: - 00: goods - 01: services
57
- attr_accessor :type_of_supply
58
-
59
- # Commodity code or International description code used to classify the item. Contact your acquirer for a list of codes.
60
- attr_accessor :commodity_code
61
-
62
- # Discount applied to the item.
63
- attr_accessor :discount_amount
64
-
65
- # Flag that indicates whether the amount is discounted. If you do not provide a value but you set Discount Amount to a value greater than zero, then CyberSource sets this field to **true**.
66
- attr_accessor :discount_applied
67
-
68
- # Rate the item is discounted. Maximum of 2 decimal places. Example 5.25 (=5.25%)
69
- attr_accessor :discount_rate
70
-
71
- # Field to support an invoice number for a transaction. You must specify the number of line items that will include an invoice number. By default, the first line item will include an invoice number field. The invoice number field can be included for up to 10 line items.
72
- attr_accessor :invoice_number
73
-
74
- attr_accessor :tax_details
75
-
76
- # TODO
77
- attr_accessor :fulfillment_type
78
-
79
- # Attribute mapping from ruby-style variable name to JSON key.
80
- def self.attribute_map
81
- {
82
- :'product_code' => :'productCode',
83
- :'product_name' => :'productName',
84
- :'product_sku' => :'productSku',
85
- :'quantity' => :'quantity',
86
- :'unit_price' => :'unitPrice',
87
- :'unit_of_measure' => :'unitOfMeasure',
88
- :'total_amount' => :'totalAmount',
89
- :'tax_amount' => :'taxAmount',
90
- :'tax_rate' => :'taxRate',
91
- :'tax_applied_after_discount' => :'taxAppliedAfterDiscount',
92
- :'tax_status_indicator' => :'taxStatusIndicator',
93
- :'tax_type_code' => :'taxTypeCode',
94
- :'amount_includes_tax' => :'amountIncludesTax',
95
- :'type_of_supply' => :'typeOfSupply',
96
- :'commodity_code' => :'commodityCode',
97
- :'discount_amount' => :'discountAmount',
98
- :'discount_applied' => :'discountApplied',
99
- :'discount_rate' => :'discountRate',
100
- :'invoice_number' => :'invoiceNumber',
101
- :'tax_details' => :'taxDetails',
102
- :'fulfillment_type' => :'fulfillmentType'
103
- }
104
- end
105
-
106
- # Attribute type mapping.
107
- def self.swagger_types
108
- {
109
- :'product_code' => :'String',
110
- :'product_name' => :'String',
111
- :'product_sku' => :'String',
112
- :'quantity' => :'Float',
113
- :'unit_price' => :'String',
114
- :'unit_of_measure' => :'String',
115
- :'total_amount' => :'String',
116
- :'tax_amount' => :'String',
117
- :'tax_rate' => :'String',
118
- :'tax_applied_after_discount' => :'String',
119
- :'tax_status_indicator' => :'String',
120
- :'tax_type_code' => :'String',
121
- :'amount_includes_tax' => :'BOOLEAN',
122
- :'type_of_supply' => :'String',
123
- :'commodity_code' => :'String',
124
- :'discount_amount' => :'String',
125
- :'discount_applied' => :'BOOLEAN',
126
- :'discount_rate' => :'String',
127
- :'invoice_number' => :'String',
128
- :'tax_details' => :'Array<V2paymentsOrderInformationAmountDetailsTaxDetails>',
129
- :'fulfillment_type' => :'String'
130
- }
131
- end
132
-
133
- # Initializes the object
134
- # @param [Hash] attributes Model attributes in the form of hash
135
- def initialize(attributes = {})
136
- return unless attributes.is_a?(Hash)
137
-
138
- # convert string to symbol for hash key
139
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
140
-
141
- if attributes.has_key?(:'productCode')
142
- self.product_code = attributes[:'productCode']
143
- end
144
-
145
- if attributes.has_key?(:'productName')
146
- self.product_name = attributes[:'productName']
147
- end
148
-
149
- if attributes.has_key?(:'productSku')
150
- self.product_sku = attributes[:'productSku']
151
- end
152
-
153
- if attributes.has_key?(:'quantity')
154
- self.quantity = attributes[:'quantity']
155
- end
156
-
157
- if attributes.has_key?(:'unitPrice')
158
- self.unit_price = attributes[:'unitPrice']
159
- end
160
-
161
- if attributes.has_key?(:'unitOfMeasure')
162
- self.unit_of_measure = attributes[:'unitOfMeasure']
163
- end
164
-
165
- if attributes.has_key?(:'totalAmount')
166
- self.total_amount = attributes[:'totalAmount']
167
- end
168
-
169
- if attributes.has_key?(:'taxAmount')
170
- self.tax_amount = attributes[:'taxAmount']
171
- end
172
-
173
- if attributes.has_key?(:'taxRate')
174
- self.tax_rate = attributes[:'taxRate']
175
- end
176
-
177
- if attributes.has_key?(:'taxAppliedAfterDiscount')
178
- self.tax_applied_after_discount = attributes[:'taxAppliedAfterDiscount']
179
- end
180
-
181
- if attributes.has_key?(:'taxStatusIndicator')
182
- self.tax_status_indicator = attributes[:'taxStatusIndicator']
183
- end
184
-
185
- if attributes.has_key?(:'taxTypeCode')
186
- self.tax_type_code = attributes[:'taxTypeCode']
187
- end
188
-
189
- if attributes.has_key?(:'amountIncludesTax')
190
- self.amount_includes_tax = attributes[:'amountIncludesTax']
191
- end
192
-
193
- if attributes.has_key?(:'typeOfSupply')
194
- self.type_of_supply = attributes[:'typeOfSupply']
195
- end
196
-
197
- if attributes.has_key?(:'commodityCode')
198
- self.commodity_code = attributes[:'commodityCode']
199
- end
200
-
201
- if attributes.has_key?(:'discountAmount')
202
- self.discount_amount = attributes[:'discountAmount']
203
- end
204
-
205
- if attributes.has_key?(:'discountApplied')
206
- self.discount_applied = attributes[:'discountApplied']
207
- end
208
-
209
- if attributes.has_key?(:'discountRate')
210
- self.discount_rate = attributes[:'discountRate']
211
- end
212
-
213
- if attributes.has_key?(:'invoiceNumber')
214
- self.invoice_number = attributes[:'invoiceNumber']
215
- end
216
-
217
- if attributes.has_key?(:'taxDetails')
218
- if (value = attributes[:'taxDetails']).is_a?(Array)
219
- self.tax_details = value
220
- end
221
- end
222
-
223
- if attributes.has_key?(:'fulfillmentType')
224
- self.fulfillment_type = attributes[:'fulfillmentType']
225
- end
226
- end
227
-
228
- # Show invalid properties with the reasons. Usually used together with valid?
229
- # @return Array for valid properties with the reasons
230
- def list_invalid_properties
231
- invalid_properties = Array.new
232
- if !@product_code.nil? && @product_code.to_s.length > 255
233
- invalid_properties.push('invalid value for "product_code", the character length must be smaller than or equal to 255.')
234
- end
235
-
236
- if !@product_name.nil? && @product_name.to_s.length > 255
237
- invalid_properties.push('invalid value for "product_name", the character length must be smaller than or equal to 255.')
238
- end
239
-
240
- if !@product_sku.nil? && @product_sku.to_s.length > 255
241
- invalid_properties.push('invalid value for "product_sku", the character length must be smaller than or equal to 255.')
242
- end
243
-
244
- if !@quantity.nil? && @quantity > 9999999999
245
- invalid_properties.push('invalid value for "quantity", must be smaller than or equal to 9999999999.')
246
- end
247
-
248
- if !@quantity.nil? && @quantity < 1
249
- invalid_properties.push('invalid value for "quantity", must be greater than or equal to 1.')
250
- end
251
-
252
- if !@unit_price.nil? && @unit_price.to_s.length > 15
253
- invalid_properties.push('invalid value for "unit_price", the character length must be smaller than or equal to 15.')
254
- end
255
-
256
- if !@unit_of_measure.nil? && @unit_of_measure.to_s.length > 12
257
- invalid_properties.push('invalid value for "unit_of_measure", the character length must be smaller than or equal to 12.')
258
- end
259
-
260
- if !@total_amount.nil? && @total_amount.to_s.length > 13
261
- invalid_properties.push('invalid value for "total_amount", the character length must be smaller than or equal to 13.')
262
- end
263
-
264
- if !@tax_amount.nil? && @tax_amount.to_s.length > 15
265
- invalid_properties.push('invalid value for "tax_amount", the character length must be smaller than or equal to 15.')
266
- end
267
-
268
- if !@tax_rate.nil? && @tax_rate.to_s.length > 7
269
- invalid_properties.push('invalid value for "tax_rate", the character length must be smaller than or equal to 7.')
270
- end
271
-
272
- if !@tax_applied_after_discount.nil? && @tax_applied_after_discount.to_s.length > 1
273
- invalid_properties.push('invalid value for "tax_applied_after_discount", the character length must be smaller than or equal to 1.')
274
- end
275
-
276
- if !@tax_status_indicator.nil? && @tax_status_indicator.to_s.length > 1
277
- invalid_properties.push('invalid value for "tax_status_indicator", the character length must be smaller than or equal to 1.')
278
- end
279
-
280
- if !@tax_type_code.nil? && @tax_type_code.to_s.length > 4
281
- invalid_properties.push('invalid value for "tax_type_code", the character length must be smaller than or equal to 4.')
282
- end
283
-
284
- if !@type_of_supply.nil? && @type_of_supply.to_s.length > 2
285
- invalid_properties.push('invalid value for "type_of_supply", the character length must be smaller than or equal to 2.')
286
- end
287
-
288
- if !@commodity_code.nil? && @commodity_code.to_s.length > 15
289
- invalid_properties.push('invalid value for "commodity_code", the character length must be smaller than or equal to 15.')
290
- end
291
-
292
- if !@discount_amount.nil? && @discount_amount.to_s.length > 13
293
- invalid_properties.push('invalid value for "discount_amount", the character length must be smaller than or equal to 13.')
294
- end
295
-
296
- if !@discount_rate.nil? && @discount_rate.to_s.length > 6
297
- invalid_properties.push('invalid value for "discount_rate", the character length must be smaller than or equal to 6.')
298
- end
299
-
300
- if !@invoice_number.nil? && @invoice_number.to_s.length > 23
301
- invalid_properties.push('invalid value for "invoice_number", the character length must be smaller than or equal to 23.')
302
- end
303
-
304
- invalid_properties
305
- end
306
-
307
- # Check to see if the all the properties in the model are valid
308
- # @return true if the model is valid
309
- def valid?
310
- return false if !@product_code.nil? && @product_code.to_s.length > 255
311
- return false if !@product_name.nil? && @product_name.to_s.length > 255
312
- return false if !@product_sku.nil? && @product_sku.to_s.length > 255
313
- return false if !@quantity.nil? && @quantity > 9999999999
314
- return false if !@quantity.nil? && @quantity < 1
315
- return false if !@unit_price.nil? && @unit_price.to_s.length > 15
316
- return false if !@unit_of_measure.nil? && @unit_of_measure.to_s.length > 12
317
- return false if !@total_amount.nil? && @total_amount.to_s.length > 13
318
- return false if !@tax_amount.nil? && @tax_amount.to_s.length > 15
319
- return false if !@tax_rate.nil? && @tax_rate.to_s.length > 7
320
- return false if !@tax_applied_after_discount.nil? && @tax_applied_after_discount.to_s.length > 1
321
- return false if !@tax_status_indicator.nil? && @tax_status_indicator.to_s.length > 1
322
- return false if !@tax_type_code.nil? && @tax_type_code.to_s.length > 4
323
- return false if !@type_of_supply.nil? && @type_of_supply.to_s.length > 2
324
- return false if !@commodity_code.nil? && @commodity_code.to_s.length > 15
325
- return false if !@discount_amount.nil? && @discount_amount.to_s.length > 13
326
- return false if !@discount_rate.nil? && @discount_rate.to_s.length > 6
327
- return false if !@invoice_number.nil? && @invoice_number.to_s.length > 23
328
- true
329
- end
330
-
331
- # Custom attribute writer method with validation
332
- # @param [Object] product_code Value to be assigned
333
- def product_code=(product_code)
334
- if !product_code.nil? && product_code.to_s.length > 255
335
- fail ArgumentError, 'invalid value for "product_code", the character length must be smaller than or equal to 255.'
336
- end
337
-
338
- @product_code = product_code
339
- end
340
-
341
- # Custom attribute writer method with validation
342
- # @param [Object] product_name Value to be assigned
343
- def product_name=(product_name)
344
- if !product_name.nil? && product_name.to_s.length > 255
345
- fail ArgumentError, 'invalid value for "product_name", the character length must be smaller than or equal to 255.'
346
- end
347
-
348
- @product_name = product_name
349
- end
350
-
351
- # Custom attribute writer method with validation
352
- # @param [Object] product_sku Value to be assigned
353
- def product_sku=(product_sku)
354
- if !product_sku.nil? && product_sku.to_s.length > 255
355
- fail ArgumentError, 'invalid value for "product_sku", the character length must be smaller than or equal to 255.'
356
- end
357
-
358
- @product_sku = product_sku
359
- end
360
-
361
- # Custom attribute writer method with validation
362
- # @param [Object] quantity Value to be assigned
363
- def quantity=(quantity)
364
- if !quantity.nil? && quantity > 9999999999
365
- fail ArgumentError, 'invalid value for "quantity", must be smaller than or equal to 9999999999.'
366
- end
367
-
368
- if !quantity.nil? && quantity < 1
369
- fail ArgumentError, 'invalid value for "quantity", must be greater than or equal to 1.'
370
- end
371
-
372
- @quantity = quantity
373
- end
374
-
375
- # Custom attribute writer method with validation
376
- # @param [Object] unit_price Value to be assigned
377
- def unit_price=(unit_price)
378
- if !unit_price.nil? && unit_price.to_s.length > 15
379
- fail ArgumentError, 'invalid value for "unit_price", the character length must be smaller than or equal to 15.'
380
- end
381
-
382
- @unit_price = unit_price
383
- end
384
-
385
- # Custom attribute writer method with validation
386
- # @param [Object] unit_of_measure Value to be assigned
387
- def unit_of_measure=(unit_of_measure)
388
- if !unit_of_measure.nil? && unit_of_measure.to_s.length > 12
389
- fail ArgumentError, 'invalid value for "unit_of_measure", the character length must be smaller than or equal to 12.'
390
- end
391
-
392
- @unit_of_measure = unit_of_measure
393
- end
394
-
395
- # Custom attribute writer method with validation
396
- # @param [Object] total_amount Value to be assigned
397
- def total_amount=(total_amount)
398
- if !total_amount.nil? && total_amount.to_s.length > 13
399
- fail ArgumentError, 'invalid value for "total_amount", the character length must be smaller than or equal to 13.'
400
- end
401
-
402
- @total_amount = total_amount
403
- end
404
-
405
- # Custom attribute writer method with validation
406
- # @param [Object] tax_amount Value to be assigned
407
- def tax_amount=(tax_amount)
408
- if !tax_amount.nil? && tax_amount.to_s.length > 15
409
- fail ArgumentError, 'invalid value for "tax_amount", the character length must be smaller than or equal to 15.'
410
- end
411
-
412
- @tax_amount = tax_amount
413
- end
414
-
415
- # Custom attribute writer method with validation
416
- # @param [Object] tax_rate Value to be assigned
417
- def tax_rate=(tax_rate)
418
- if !tax_rate.nil? && tax_rate.to_s.length > 7
419
- fail ArgumentError, 'invalid value for "tax_rate", the character length must be smaller than or equal to 7.'
420
- end
421
-
422
- @tax_rate = tax_rate
423
- end
424
-
425
- # Custom attribute writer method with validation
426
- # @param [Object] tax_applied_after_discount Value to be assigned
427
- def tax_applied_after_discount=(tax_applied_after_discount)
428
- if !tax_applied_after_discount.nil? && tax_applied_after_discount.to_s.length > 1
429
- fail ArgumentError, 'invalid value for "tax_applied_after_discount", the character length must be smaller than or equal to 1.'
430
- end
431
-
432
- @tax_applied_after_discount = tax_applied_after_discount
433
- end
434
-
435
- # Custom attribute writer method with validation
436
- # @param [Object] tax_status_indicator Value to be assigned
437
- def tax_status_indicator=(tax_status_indicator)
438
- if !tax_status_indicator.nil? && tax_status_indicator.to_s.length > 1
439
- fail ArgumentError, 'invalid value for "tax_status_indicator", the character length must be smaller than or equal to 1.'
440
- end
441
-
442
- @tax_status_indicator = tax_status_indicator
443
- end
444
-
445
- # Custom attribute writer method with validation
446
- # @param [Object] tax_type_code Value to be assigned
447
- def tax_type_code=(tax_type_code)
448
- if !tax_type_code.nil? && tax_type_code.to_s.length > 4
449
- fail ArgumentError, 'invalid value for "tax_type_code", the character length must be smaller than or equal to 4.'
450
- end
451
-
452
- @tax_type_code = tax_type_code
453
- end
454
-
455
- # Custom attribute writer method with validation
456
- # @param [Object] type_of_supply Value to be assigned
457
- def type_of_supply=(type_of_supply)
458
- if !type_of_supply.nil? && type_of_supply.to_s.length > 2
459
- fail ArgumentError, 'invalid value for "type_of_supply", the character length must be smaller than or equal to 2.'
460
- end
461
-
462
- @type_of_supply = type_of_supply
463
- end
464
-
465
- # Custom attribute writer method with validation
466
- # @param [Object] commodity_code Value to be assigned
467
- def commodity_code=(commodity_code)
468
- if !commodity_code.nil? && commodity_code.to_s.length > 15
469
- fail ArgumentError, 'invalid value for "commodity_code", the character length must be smaller than or equal to 15.'
470
- end
471
-
472
- @commodity_code = commodity_code
473
- end
474
-
475
- # Custom attribute writer method with validation
476
- # @param [Object] discount_amount Value to be assigned
477
- def discount_amount=(discount_amount)
478
- if !discount_amount.nil? && discount_amount.to_s.length > 13
479
- fail ArgumentError, 'invalid value for "discount_amount", the character length must be smaller than or equal to 13.'
480
- end
481
-
482
- @discount_amount = discount_amount
483
- end
484
-
485
- # Custom attribute writer method with validation
486
- # @param [Object] discount_rate Value to be assigned
487
- def discount_rate=(discount_rate)
488
- if !discount_rate.nil? && discount_rate.to_s.length > 6
489
- fail ArgumentError, 'invalid value for "discount_rate", the character length must be smaller than or equal to 6.'
490
- end
491
-
492
- @discount_rate = discount_rate
493
- end
494
-
495
- # Custom attribute writer method with validation
496
- # @param [Object] invoice_number Value to be assigned
497
- def invoice_number=(invoice_number)
498
- if !invoice_number.nil? && invoice_number.to_s.length > 23
499
- fail ArgumentError, 'invalid value for "invoice_number", the character length must be smaller than or equal to 23.'
500
- end
501
-
502
- @invoice_number = invoice_number
503
- end
504
-
505
- # Checks equality by comparing each attribute.
506
- # @param [Object] Object to be compared
507
- def ==(o)
508
- return true if self.equal?(o)
509
- self.class == o.class &&
510
- product_code == o.product_code &&
511
- product_name == o.product_name &&
512
- product_sku == o.product_sku &&
513
- quantity == o.quantity &&
514
- unit_price == o.unit_price &&
515
- unit_of_measure == o.unit_of_measure &&
516
- total_amount == o.total_amount &&
517
- tax_amount == o.tax_amount &&
518
- tax_rate == o.tax_rate &&
519
- tax_applied_after_discount == o.tax_applied_after_discount &&
520
- tax_status_indicator == o.tax_status_indicator &&
521
- tax_type_code == o.tax_type_code &&
522
- amount_includes_tax == o.amount_includes_tax &&
523
- type_of_supply == o.type_of_supply &&
524
- commodity_code == o.commodity_code &&
525
- discount_amount == o.discount_amount &&
526
- discount_applied == o.discount_applied &&
527
- discount_rate == o.discount_rate &&
528
- invoice_number == o.invoice_number &&
529
- tax_details == o.tax_details &&
530
- fulfillment_type == o.fulfillment_type
531
- end
532
-
533
- # @see the `==` method
534
- # @param [Object] Object to be compared
535
- def eql?(o)
536
- self == o
537
- end
538
-
539
- # Calculates hash code according to all attributes.
540
- # @return [Fixnum] Hash code
541
- def hash
542
- [product_code, product_name, product_sku, quantity, unit_price, unit_of_measure, total_amount, tax_amount, tax_rate, tax_applied_after_discount, tax_status_indicator, tax_type_code, amount_includes_tax, type_of_supply, commodity_code, discount_amount, discount_applied, discount_rate, invoice_number, tax_details, fulfillment_type].hash
543
- end
544
-
545
- # Builds the object from hash
546
- # @param [Hash] attributes Model attributes in the form of hash
547
- # @return [Object] Returns the model itself
548
- def build_from_hash(attributes)
549
- return nil unless attributes.is_a?(Hash)
550
- self.class.swagger_types.each_pair do |key, type|
551
- if type =~ /\AArray<(.*)>/i
552
- # check to ensure the input is an array given that the the attribute
553
- # is documented as an array but the input is not
554
- if attributes[self.class.attribute_map[key]].is_a?(Array)
555
- self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
556
- end
557
- elsif !attributes[self.class.attribute_map[key]].nil?
558
- self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
559
- end # or else data not found in attributes(hash), not an issue as the data can be optional
560
- end
561
-
562
- self
563
- end
564
-
565
- # Deserializes the data based on type
566
- # @param string type Data type
567
- # @param string value Value to be deserialized
568
- # @return [Object] Deserialized data
569
- def _deserialize(type, value)
570
- case type.to_sym
571
- when :DateTime
572
- DateTime.parse(value)
573
- when :Date
574
- Date.parse(value)
575
- when :String
576
- value.to_s
577
- when :Integer
578
- value.to_i
579
- when :Float
580
- value.to_f
581
- when :BOOLEAN
582
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
583
- true
584
- else
585
- false
586
- end
587
- when :Object
588
- # generic object (usually a Hash), return directly
589
- value
590
- when /\AArray<(?<inner_type>.+)>\z/
591
- inner_type = Regexp.last_match[:inner_type]
592
- value.map { |v| _deserialize(inner_type, v) }
593
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
594
- k_type = Regexp.last_match[:k_type]
595
- v_type = Regexp.last_match[:v_type]
596
- {}.tap do |hash|
597
- value.each do |k, v|
598
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
599
- end
600
- end
601
- else # model
602
- temp_model = CyberSource.const_get(type).new
603
- temp_model.build_from_hash(value)
604
- end
605
- end
606
-
607
- # Returns the string representation of the object
608
- # @return [String] String presentation of the object
609
- def to_s
610
- to_hash.to_s
611
- end
612
-
613
- # to_body is an alias to to_hash (backward compatibility)
614
- # @return [Hash] Returns the object in the form of hash
615
- def to_body
616
- to_hash
617
- end
618
-
619
- # Returns the object in the form of hash
620
- # @return [Hash] Returns the object in the form of hash
621
- def to_hash
622
- hash = {}
623
- self.class.attribute_map.each_pair do |attr, param|
624
- value = self.send(attr)
625
- next if value.nil?
626
- hash[param] = _to_hash(value)
627
- end
628
- hash
629
- end
630
-
631
- # Outputs non-array value in the form of hash
632
- # For object, use to_hash. Otherwise, just return the value
633
- # @param [Object] value Any valid value
634
- # @return [Hash] Returns the value in the form of hash
635
- def _to_hash(value)
636
- if value.is_a?(Array)
637
- value.compact.map { |v| _to_hash(v) }
638
- elsif value.is_a?(Hash)
639
- {}.tap do |hash|
640
- value.each { |k, v| hash[k] = _to_hash(v) }
641
- end
642
- elsif value.respond_to? :to_hash
643
- value.to_hash
644
- else
645
- value
646
- end
647
- end
648
- end
649
- end
1
+ =begin
2
+ #CyberSource Flex API
3
+
4
+ #Simple PAN tokenization service
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.2.3
10
+
11
+ =end
12
+
13
+ require 'date'
14
+
15
+ module CyberSource
16
+ class V2paymentsOrderInformationLineItems
17
+ # Type of product. This value is used to determine the category that the product is in: electronic, handling, physical, service, or shipping. The default value is **default**. For a payment, when you set this field to a value other than default or any of the values related to shipping and handling, below fields _quantity_, _productName_, and _productSKU_ are required.
18
+ attr_accessor :product_code
19
+
20
+ # For PAYMENT and CAPTURE API, this field is required when above _productCode_ is not **default** or one of the values related to shipping and handling.
21
+ attr_accessor :product_name
22
+
23
+ # Identification code for the product. For PAYMENT and CAPTURE API, this field is required when above _productCode_ is not **default** or one of the values related to shipping and/or handling.
24
+ attr_accessor :product_sku
25
+
26
+ # For a payment or capture, this field is required when _productCode_ is not **default** or one of the values related to shipping and handling.
27
+ attr_accessor :quantity
28
+
29
+ # Per-item price of the product. This value cannot be negative. You can include a decimal point (.), but you cannot include any other special characters. CyberSource truncates the amount to the correct number of decimal places. For processor-specific information, see the amount field in [Credit Card Services Using the SCMP API.](http://apps.cybersource.com/library/documentation/dev_guides/CC_Svcs_SCMP_API/html)
30
+ attr_accessor :unit_price
31
+
32
+ # Unit of measure, or unit of measure code, for the item.
33
+ attr_accessor :unit_of_measure
34
+
35
+ # Total amount for the item. Normally calculated as the unit price x quantity.
36
+ attr_accessor :total_amount
37
+
38
+ # Total tax to apply to the product. This value cannot be negative. The tax amount and the offer amount must be in the same currency. The tax amount field is additive. The following example uses a two-exponent currency such as USD: 1. You include each line item in your request. ..- 1st line item has amount=10.00, quantity=1, and taxAmount=0.80 ..- 2nd line item has amount=20.00, quantity=1, and taxAmount=1.60 2. The total amount authorized will be 32.40, not 30.00 with 2.40 of tax included. This field is frequently used for Level II and Level III transactions.
39
+ attr_accessor :tax_amount
40
+
41
+ # Tax rate applied to the item. See \"Numbered Elements,\" page 14. Visa: Valid range is 0.01 to 0.99 (1% to 99%, with only whole percentage values accepted; values with additional decimal places will be truncated). Mastercard: Valid range is 0.00001 to 0.99999 (0.001% to 99.999%).
42
+ attr_accessor :tax_rate
43
+
44
+ # Flag to indicate how you handle discount at the line item level. - 0: no line level discount provided - 1: tax was calculated on the post-discount line item total - 2: tax was calculated on the pre-discount line item total `Note` Visa will inset 0 (zero) if an invalid value is included in this field. This field relates to the value in the _lineItems[].discountAmount_ field.
45
+ attr_accessor :tax_applied_after_discount
46
+
47
+ # Flag to indicate whether tax is exempted or not included. - 0: tax not included - 1: tax included - 2: transaction is not subject to tax
48
+ attr_accessor :tax_status_indicator
49
+
50
+ # Type of tax being applied to the item. Possible values: Below values are used by **RBS WorldPay Atlanta**, **FDC Nashville Global**, **Litle** - 0000: unknown tax type - 0001: federal/national sales tax - 0002: state sales tax - 0003: city sales tax - 0004: local sales tax - 0005: municipal sales tax - 0006: other tax - 0010: value-added tax - 0011: goods and services tax - 0012: provincial sales tax - 0013: harmonized sales tax - 0014: Quebec sales tax (QST) - 0020: room tax - 0021: occupancy tax - 0022: energy tax - Blank: Tax not supported on line item.
51
+ attr_accessor :tax_type_code
52
+
53
+ # Flag that indicates whether the tax amount is included in the Line Item Total.
54
+ attr_accessor :amount_includes_tax
55
+
56
+ # Flag to indicate whether the purchase is categorized as goods or services. Possible values: - 00: goods - 01: services
57
+ attr_accessor :type_of_supply
58
+
59
+ # Commodity code or International description code used to classify the item. Contact your acquirer for a list of codes.
60
+ attr_accessor :commodity_code
61
+
62
+ # Discount applied to the item.
63
+ attr_accessor :discount_amount
64
+
65
+ # Flag that indicates whether the amount is discounted. If you do not provide a value but you set Discount Amount to a value greater than zero, then CyberSource sets this field to **true**.
66
+ attr_accessor :discount_applied
67
+
68
+ # Rate the item is discounted. Maximum of 2 decimal places. Example 5.25 (=5.25%)
69
+ attr_accessor :discount_rate
70
+
71
+ # Field to support an invoice number for a transaction. You must specify the number of line items that will include an invoice number. By default, the first line item will include an invoice number field. The invoice number field can be included for up to 10 line items.
72
+ attr_accessor :invoice_number
73
+
74
+ attr_accessor :tax_details
75
+
76
+ # TODO
77
+ attr_accessor :fulfillment_type
78
+
79
+ # Attribute mapping from ruby-style variable name to JSON key.
80
+ def self.attribute_map
81
+ {
82
+ :'product_code' => :'productCode',
83
+ :'product_name' => :'productName',
84
+ :'product_sku' => :'productSku',
85
+ :'quantity' => :'quantity',
86
+ :'unit_price' => :'unitPrice',
87
+ :'unit_of_measure' => :'unitOfMeasure',
88
+ :'total_amount' => :'totalAmount',
89
+ :'tax_amount' => :'taxAmount',
90
+ :'tax_rate' => :'taxRate',
91
+ :'tax_applied_after_discount' => :'taxAppliedAfterDiscount',
92
+ :'tax_status_indicator' => :'taxStatusIndicator',
93
+ :'tax_type_code' => :'taxTypeCode',
94
+ :'amount_includes_tax' => :'amountIncludesTax',
95
+ :'type_of_supply' => :'typeOfSupply',
96
+ :'commodity_code' => :'commodityCode',
97
+ :'discount_amount' => :'discountAmount',
98
+ :'discount_applied' => :'discountApplied',
99
+ :'discount_rate' => :'discountRate',
100
+ :'invoice_number' => :'invoiceNumber',
101
+ :'tax_details' => :'taxDetails',
102
+ :'fulfillment_type' => :'fulfillmentType'
103
+ }
104
+ end
105
+
106
+ # Attribute type mapping.
107
+ def self.swagger_types
108
+ {
109
+ :'product_code' => :'String',
110
+ :'product_name' => :'String',
111
+ :'product_sku' => :'String',
112
+ :'quantity' => :'Float',
113
+ :'unit_price' => :'String',
114
+ :'unit_of_measure' => :'String',
115
+ :'total_amount' => :'String',
116
+ :'tax_amount' => :'String',
117
+ :'tax_rate' => :'String',
118
+ :'tax_applied_after_discount' => :'String',
119
+ :'tax_status_indicator' => :'String',
120
+ :'tax_type_code' => :'String',
121
+ :'amount_includes_tax' => :'BOOLEAN',
122
+ :'type_of_supply' => :'String',
123
+ :'commodity_code' => :'String',
124
+ :'discount_amount' => :'String',
125
+ :'discount_applied' => :'BOOLEAN',
126
+ :'discount_rate' => :'String',
127
+ :'invoice_number' => :'String',
128
+ :'tax_details' => :'Array<V2paymentsOrderInformationAmountDetailsTaxDetails>',
129
+ :'fulfillment_type' => :'String'
130
+ }
131
+ end
132
+
133
+ # Initializes the object
134
+ # @param [Hash] attributes Model attributes in the form of hash
135
+ def initialize(attributes = {})
136
+ return unless attributes.is_a?(Hash)
137
+
138
+ # convert string to symbol for hash key
139
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
140
+
141
+ if attributes.has_key?(:'productCode')
142
+ self.product_code = attributes[:'productCode']
143
+ end
144
+
145
+ if attributes.has_key?(:'productName')
146
+ self.product_name = attributes[:'productName']
147
+ end
148
+
149
+ if attributes.has_key?(:'productSku')
150
+ self.product_sku = attributes[:'productSku']
151
+ end
152
+
153
+ if attributes.has_key?(:'quantity')
154
+ self.quantity = attributes[:'quantity']
155
+ end
156
+
157
+ if attributes.has_key?(:'unitPrice')
158
+ self.unit_price = attributes[:'unitPrice']
159
+ end
160
+
161
+ if attributes.has_key?(:'unitOfMeasure')
162
+ self.unit_of_measure = attributes[:'unitOfMeasure']
163
+ end
164
+
165
+ if attributes.has_key?(:'totalAmount')
166
+ self.total_amount = attributes[:'totalAmount']
167
+ end
168
+
169
+ if attributes.has_key?(:'taxAmount')
170
+ self.tax_amount = attributes[:'taxAmount']
171
+ end
172
+
173
+ if attributes.has_key?(:'taxRate')
174
+ self.tax_rate = attributes[:'taxRate']
175
+ end
176
+
177
+ if attributes.has_key?(:'taxAppliedAfterDiscount')
178
+ self.tax_applied_after_discount = attributes[:'taxAppliedAfterDiscount']
179
+ end
180
+
181
+ if attributes.has_key?(:'taxStatusIndicator')
182
+ self.tax_status_indicator = attributes[:'taxStatusIndicator']
183
+ end
184
+
185
+ if attributes.has_key?(:'taxTypeCode')
186
+ self.tax_type_code = attributes[:'taxTypeCode']
187
+ end
188
+
189
+ if attributes.has_key?(:'amountIncludesTax')
190
+ self.amount_includes_tax = attributes[:'amountIncludesTax']
191
+ end
192
+
193
+ if attributes.has_key?(:'typeOfSupply')
194
+ self.type_of_supply = attributes[:'typeOfSupply']
195
+ end
196
+
197
+ if attributes.has_key?(:'commodityCode')
198
+ self.commodity_code = attributes[:'commodityCode']
199
+ end
200
+
201
+ if attributes.has_key?(:'discountAmount')
202
+ self.discount_amount = attributes[:'discountAmount']
203
+ end
204
+
205
+ if attributes.has_key?(:'discountApplied')
206
+ self.discount_applied = attributes[:'discountApplied']
207
+ end
208
+
209
+ if attributes.has_key?(:'discountRate')
210
+ self.discount_rate = attributes[:'discountRate']
211
+ end
212
+
213
+ if attributes.has_key?(:'invoiceNumber')
214
+ self.invoice_number = attributes[:'invoiceNumber']
215
+ end
216
+
217
+ if attributes.has_key?(:'taxDetails')
218
+ if (value = attributes[:'taxDetails']).is_a?(Array)
219
+ self.tax_details = value
220
+ end
221
+ end
222
+
223
+ if attributes.has_key?(:'fulfillmentType')
224
+ self.fulfillment_type = attributes[:'fulfillmentType']
225
+ end
226
+ end
227
+
228
+ # Show invalid properties with the reasons. Usually used together with valid?
229
+ # @return Array for valid properties with the reasons
230
+ def list_invalid_properties
231
+ invalid_properties = Array.new
232
+ if !@product_code.nil? && @product_code.to_s.length > 255
233
+ invalid_properties.push('invalid value for "product_code", the character length must be smaller than or equal to 255.')
234
+ end
235
+
236
+ if !@product_name.nil? && @product_name.to_s.length > 255
237
+ invalid_properties.push('invalid value for "product_name", the character length must be smaller than or equal to 255.')
238
+ end
239
+
240
+ if !@product_sku.nil? && @product_sku.to_s.length > 255
241
+ invalid_properties.push('invalid value for "product_sku", the character length must be smaller than or equal to 255.')
242
+ end
243
+
244
+ if !@quantity.nil? && @quantity > 9999999999
245
+ invalid_properties.push('invalid value for "quantity", must be smaller than or equal to 9999999999.')
246
+ end
247
+
248
+ if !@quantity.nil? && @quantity < 1
249
+ invalid_properties.push('invalid value for "quantity", must be greater than or equal to 1.')
250
+ end
251
+
252
+ if !@unit_price.nil? && @unit_price.to_s.length > 15
253
+ invalid_properties.push('invalid value for "unit_price", the character length must be smaller than or equal to 15.')
254
+ end
255
+
256
+ if !@unit_of_measure.nil? && @unit_of_measure.to_s.length > 12
257
+ invalid_properties.push('invalid value for "unit_of_measure", the character length must be smaller than or equal to 12.')
258
+ end
259
+
260
+ if !@total_amount.nil? && @total_amount.to_s.length > 13
261
+ invalid_properties.push('invalid value for "total_amount", the character length must be smaller than or equal to 13.')
262
+ end
263
+
264
+ if !@tax_amount.nil? && @tax_amount.to_s.length > 15
265
+ invalid_properties.push('invalid value for "tax_amount", the character length must be smaller than or equal to 15.')
266
+ end
267
+
268
+ if !@tax_rate.nil? && @tax_rate.to_s.length > 7
269
+ invalid_properties.push('invalid value for "tax_rate", the character length must be smaller than or equal to 7.')
270
+ end
271
+
272
+ if !@tax_applied_after_discount.nil? && @tax_applied_after_discount.to_s.length > 1
273
+ invalid_properties.push('invalid value for "tax_applied_after_discount", the character length must be smaller than or equal to 1.')
274
+ end
275
+
276
+ if !@tax_status_indicator.nil? && @tax_status_indicator.to_s.length > 1
277
+ invalid_properties.push('invalid value for "tax_status_indicator", the character length must be smaller than or equal to 1.')
278
+ end
279
+
280
+ if !@tax_type_code.nil? && @tax_type_code.to_s.length > 4
281
+ invalid_properties.push('invalid value for "tax_type_code", the character length must be smaller than or equal to 4.')
282
+ end
283
+
284
+ if !@type_of_supply.nil? && @type_of_supply.to_s.length > 2
285
+ invalid_properties.push('invalid value for "type_of_supply", the character length must be smaller than or equal to 2.')
286
+ end
287
+
288
+ if !@commodity_code.nil? && @commodity_code.to_s.length > 15
289
+ invalid_properties.push('invalid value for "commodity_code", the character length must be smaller than or equal to 15.')
290
+ end
291
+
292
+ if !@discount_amount.nil? && @discount_amount.to_s.length > 13
293
+ invalid_properties.push('invalid value for "discount_amount", the character length must be smaller than or equal to 13.')
294
+ end
295
+
296
+ if !@discount_rate.nil? && @discount_rate.to_s.length > 6
297
+ invalid_properties.push('invalid value for "discount_rate", the character length must be smaller than or equal to 6.')
298
+ end
299
+
300
+ if !@invoice_number.nil? && @invoice_number.to_s.length > 23
301
+ invalid_properties.push('invalid value for "invoice_number", the character length must be smaller than or equal to 23.')
302
+ end
303
+
304
+ invalid_properties
305
+ end
306
+
307
+ # Check to see if the all the properties in the model are valid
308
+ # @return true if the model is valid
309
+ def valid?
310
+ return false if !@product_code.nil? && @product_code.to_s.length > 255
311
+ return false if !@product_name.nil? && @product_name.to_s.length > 255
312
+ return false if !@product_sku.nil? && @product_sku.to_s.length > 255
313
+ return false if !@quantity.nil? && @quantity > 9999999999
314
+ return false if !@quantity.nil? && @quantity < 1
315
+ return false if !@unit_price.nil? && @unit_price.to_s.length > 15
316
+ return false if !@unit_of_measure.nil? && @unit_of_measure.to_s.length > 12
317
+ return false if !@total_amount.nil? && @total_amount.to_s.length > 13
318
+ return false if !@tax_amount.nil? && @tax_amount.to_s.length > 15
319
+ return false if !@tax_rate.nil? && @tax_rate.to_s.length > 7
320
+ return false if !@tax_applied_after_discount.nil? && @tax_applied_after_discount.to_s.length > 1
321
+ return false if !@tax_status_indicator.nil? && @tax_status_indicator.to_s.length > 1
322
+ return false if !@tax_type_code.nil? && @tax_type_code.to_s.length > 4
323
+ return false if !@type_of_supply.nil? && @type_of_supply.to_s.length > 2
324
+ return false if !@commodity_code.nil? && @commodity_code.to_s.length > 15
325
+ return false if !@discount_amount.nil? && @discount_amount.to_s.length > 13
326
+ return false if !@discount_rate.nil? && @discount_rate.to_s.length > 6
327
+ return false if !@invoice_number.nil? && @invoice_number.to_s.length > 23
328
+ true
329
+ end
330
+
331
+ # Custom attribute writer method with validation
332
+ # @param [Object] product_code Value to be assigned
333
+ def product_code=(product_code)
334
+ if !product_code.nil? && product_code.to_s.length > 255
335
+ fail ArgumentError, 'invalid value for "product_code", the character length must be smaller than or equal to 255.'
336
+ end
337
+
338
+ @product_code = product_code
339
+ end
340
+
341
+ # Custom attribute writer method with validation
342
+ # @param [Object] product_name Value to be assigned
343
+ def product_name=(product_name)
344
+ if !product_name.nil? && product_name.to_s.length > 255
345
+ fail ArgumentError, 'invalid value for "product_name", the character length must be smaller than or equal to 255.'
346
+ end
347
+
348
+ @product_name = product_name
349
+ end
350
+
351
+ # Custom attribute writer method with validation
352
+ # @param [Object] product_sku Value to be assigned
353
+ def product_sku=(product_sku)
354
+ if !product_sku.nil? && product_sku.to_s.length > 255
355
+ fail ArgumentError, 'invalid value for "product_sku", the character length must be smaller than or equal to 255.'
356
+ end
357
+
358
+ @product_sku = product_sku
359
+ end
360
+
361
+ # Custom attribute writer method with validation
362
+ # @param [Object] quantity Value to be assigned
363
+ def quantity=(quantity)
364
+ if !quantity.nil? && quantity > 9999999999
365
+ fail ArgumentError, 'invalid value for "quantity", must be smaller than or equal to 9999999999.'
366
+ end
367
+
368
+ if !quantity.nil? && quantity < 1
369
+ fail ArgumentError, 'invalid value for "quantity", must be greater than or equal to 1.'
370
+ end
371
+
372
+ @quantity = quantity
373
+ end
374
+
375
+ # Custom attribute writer method with validation
376
+ # @param [Object] unit_price Value to be assigned
377
+ def unit_price=(unit_price)
378
+ if !unit_price.nil? && unit_price.to_s.length > 15
379
+ fail ArgumentError, 'invalid value for "unit_price", the character length must be smaller than or equal to 15.'
380
+ end
381
+
382
+ @unit_price = unit_price
383
+ end
384
+
385
+ # Custom attribute writer method with validation
386
+ # @param [Object] unit_of_measure Value to be assigned
387
+ def unit_of_measure=(unit_of_measure)
388
+ if !unit_of_measure.nil? && unit_of_measure.to_s.length > 12
389
+ fail ArgumentError, 'invalid value for "unit_of_measure", the character length must be smaller than or equal to 12.'
390
+ end
391
+
392
+ @unit_of_measure = unit_of_measure
393
+ end
394
+
395
+ # Custom attribute writer method with validation
396
+ # @param [Object] total_amount Value to be assigned
397
+ def total_amount=(total_amount)
398
+ if !total_amount.nil? && total_amount.to_s.length > 13
399
+ fail ArgumentError, 'invalid value for "total_amount", the character length must be smaller than or equal to 13.'
400
+ end
401
+
402
+ @total_amount = total_amount
403
+ end
404
+
405
+ # Custom attribute writer method with validation
406
+ # @param [Object] tax_amount Value to be assigned
407
+ def tax_amount=(tax_amount)
408
+ if !tax_amount.nil? && tax_amount.to_s.length > 15
409
+ fail ArgumentError, 'invalid value for "tax_amount", the character length must be smaller than or equal to 15.'
410
+ end
411
+
412
+ @tax_amount = tax_amount
413
+ end
414
+
415
+ # Custom attribute writer method with validation
416
+ # @param [Object] tax_rate Value to be assigned
417
+ def tax_rate=(tax_rate)
418
+ if !tax_rate.nil? && tax_rate.to_s.length > 7
419
+ fail ArgumentError, 'invalid value for "tax_rate", the character length must be smaller than or equal to 7.'
420
+ end
421
+
422
+ @tax_rate = tax_rate
423
+ end
424
+
425
+ # Custom attribute writer method with validation
426
+ # @param [Object] tax_applied_after_discount Value to be assigned
427
+ def tax_applied_after_discount=(tax_applied_after_discount)
428
+ if !tax_applied_after_discount.nil? && tax_applied_after_discount.to_s.length > 1
429
+ fail ArgumentError, 'invalid value for "tax_applied_after_discount", the character length must be smaller than or equal to 1.'
430
+ end
431
+
432
+ @tax_applied_after_discount = tax_applied_after_discount
433
+ end
434
+
435
+ # Custom attribute writer method with validation
436
+ # @param [Object] tax_status_indicator Value to be assigned
437
+ def tax_status_indicator=(tax_status_indicator)
438
+ if !tax_status_indicator.nil? && tax_status_indicator.to_s.length > 1
439
+ fail ArgumentError, 'invalid value for "tax_status_indicator", the character length must be smaller than or equal to 1.'
440
+ end
441
+
442
+ @tax_status_indicator = tax_status_indicator
443
+ end
444
+
445
+ # Custom attribute writer method with validation
446
+ # @param [Object] tax_type_code Value to be assigned
447
+ def tax_type_code=(tax_type_code)
448
+ if !tax_type_code.nil? && tax_type_code.to_s.length > 4
449
+ fail ArgumentError, 'invalid value for "tax_type_code", the character length must be smaller than or equal to 4.'
450
+ end
451
+
452
+ @tax_type_code = tax_type_code
453
+ end
454
+
455
+ # Custom attribute writer method with validation
456
+ # @param [Object] type_of_supply Value to be assigned
457
+ def type_of_supply=(type_of_supply)
458
+ if !type_of_supply.nil? && type_of_supply.to_s.length > 2
459
+ fail ArgumentError, 'invalid value for "type_of_supply", the character length must be smaller than or equal to 2.'
460
+ end
461
+
462
+ @type_of_supply = type_of_supply
463
+ end
464
+
465
+ # Custom attribute writer method with validation
466
+ # @param [Object] commodity_code Value to be assigned
467
+ def commodity_code=(commodity_code)
468
+ if !commodity_code.nil? && commodity_code.to_s.length > 15
469
+ fail ArgumentError, 'invalid value for "commodity_code", the character length must be smaller than or equal to 15.'
470
+ end
471
+
472
+ @commodity_code = commodity_code
473
+ end
474
+
475
+ # Custom attribute writer method with validation
476
+ # @param [Object] discount_amount Value to be assigned
477
+ def discount_amount=(discount_amount)
478
+ if !discount_amount.nil? && discount_amount.to_s.length > 13
479
+ fail ArgumentError, 'invalid value for "discount_amount", the character length must be smaller than or equal to 13.'
480
+ end
481
+
482
+ @discount_amount = discount_amount
483
+ end
484
+
485
+ # Custom attribute writer method with validation
486
+ # @param [Object] discount_rate Value to be assigned
487
+ def discount_rate=(discount_rate)
488
+ if !discount_rate.nil? && discount_rate.to_s.length > 6
489
+ fail ArgumentError, 'invalid value for "discount_rate", the character length must be smaller than or equal to 6.'
490
+ end
491
+
492
+ @discount_rate = discount_rate
493
+ end
494
+
495
+ # Custom attribute writer method with validation
496
+ # @param [Object] invoice_number Value to be assigned
497
+ def invoice_number=(invoice_number)
498
+ if !invoice_number.nil? && invoice_number.to_s.length > 23
499
+ fail ArgumentError, 'invalid value for "invoice_number", the character length must be smaller than or equal to 23.'
500
+ end
501
+
502
+ @invoice_number = invoice_number
503
+ end
504
+
505
+ # Checks equality by comparing each attribute.
506
+ # @param [Object] Object to be compared
507
+ def ==(o)
508
+ return true if self.equal?(o)
509
+ self.class == o.class &&
510
+ product_code == o.product_code &&
511
+ product_name == o.product_name &&
512
+ product_sku == o.product_sku &&
513
+ quantity == o.quantity &&
514
+ unit_price == o.unit_price &&
515
+ unit_of_measure == o.unit_of_measure &&
516
+ total_amount == o.total_amount &&
517
+ tax_amount == o.tax_amount &&
518
+ tax_rate == o.tax_rate &&
519
+ tax_applied_after_discount == o.tax_applied_after_discount &&
520
+ tax_status_indicator == o.tax_status_indicator &&
521
+ tax_type_code == o.tax_type_code &&
522
+ amount_includes_tax == o.amount_includes_tax &&
523
+ type_of_supply == o.type_of_supply &&
524
+ commodity_code == o.commodity_code &&
525
+ discount_amount == o.discount_amount &&
526
+ discount_applied == o.discount_applied &&
527
+ discount_rate == o.discount_rate &&
528
+ invoice_number == o.invoice_number &&
529
+ tax_details == o.tax_details &&
530
+ fulfillment_type == o.fulfillment_type
531
+ end
532
+
533
+ # @see the `==` method
534
+ # @param [Object] Object to be compared
535
+ def eql?(o)
536
+ self == o
537
+ end
538
+
539
+ # Calculates hash code according to all attributes.
540
+ # @return [Fixnum] Hash code
541
+ def hash
542
+ [product_code, product_name, product_sku, quantity, unit_price, unit_of_measure, total_amount, tax_amount, tax_rate, tax_applied_after_discount, tax_status_indicator, tax_type_code, amount_includes_tax, type_of_supply, commodity_code, discount_amount, discount_applied, discount_rate, invoice_number, tax_details, fulfillment_type].hash
543
+ end
544
+
545
+ # Builds the object from hash
546
+ # @param [Hash] attributes Model attributes in the form of hash
547
+ # @return [Object] Returns the model itself
548
+ def build_from_hash(attributes)
549
+ return nil unless attributes.is_a?(Hash)
550
+ self.class.swagger_types.each_pair do |key, type|
551
+ if type =~ /\AArray<(.*)>/i
552
+ # check to ensure the input is an array given that the the attribute
553
+ # is documented as an array but the input is not
554
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
555
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
556
+ end
557
+ elsif !attributes[self.class.attribute_map[key]].nil?
558
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
559
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
560
+ end
561
+
562
+ self
563
+ end
564
+
565
+ # Deserializes the data based on type
566
+ # @param string type Data type
567
+ # @param string value Value to be deserialized
568
+ # @return [Object] Deserialized data
569
+ def _deserialize(type, value)
570
+ case type.to_sym
571
+ when :DateTime
572
+ DateTime.parse(value)
573
+ when :Date
574
+ Date.parse(value)
575
+ when :String
576
+ value.to_s
577
+ when :Integer
578
+ value.to_i
579
+ when :Float
580
+ value.to_f
581
+ when :BOOLEAN
582
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
583
+ true
584
+ else
585
+ false
586
+ end
587
+ when :Object
588
+ # generic object (usually a Hash), return directly
589
+ value
590
+ when /\AArray<(?<inner_type>.+)>\z/
591
+ inner_type = Regexp.last_match[:inner_type]
592
+ value.map { |v| _deserialize(inner_type, v) }
593
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
594
+ k_type = Regexp.last_match[:k_type]
595
+ v_type = Regexp.last_match[:v_type]
596
+ {}.tap do |hash|
597
+ value.each do |k, v|
598
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
599
+ end
600
+ end
601
+ else # model
602
+ temp_model = CyberSource.const_get(type).new
603
+ temp_model.build_from_hash(value)
604
+ end
605
+ end
606
+
607
+ # Returns the string representation of the object
608
+ # @return [String] String presentation of the object
609
+ def to_s
610
+ to_hash.to_s
611
+ end
612
+
613
+ # to_body is an alias to to_hash (backward compatibility)
614
+ # @return [Hash] Returns the object in the form of hash
615
+ def to_body
616
+ to_hash
617
+ end
618
+
619
+ # Returns the object in the form of hash
620
+ # @return [Hash] Returns the object in the form of hash
621
+ def to_hash
622
+ hash = {}
623
+ self.class.attribute_map.each_pair do |attr, param|
624
+ value = self.send(attr)
625
+ next if value.nil?
626
+ hash[param] = _to_hash(value)
627
+ end
628
+ hash
629
+ end
630
+
631
+ # Outputs non-array value in the form of hash
632
+ # For object, use to_hash. Otherwise, just return the value
633
+ # @param [Object] value Any valid value
634
+ # @return [Hash] Returns the value in the form of hash
635
+ def _to_hash(value)
636
+ if value.is_a?(Array)
637
+ value.compact.map { |v| _to_hash(v) }
638
+ elsif value.is_a?(Hash)
639
+ {}.tap do |hash|
640
+ value.each { |k, v| hash[k] = _to_hash(v) }
641
+ end
642
+ elsif value.respond_to? :to_hash
643
+ value.to_hash
644
+ else
645
+ value
646
+ end
647
+ end
648
+ end
649
+ end