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,210 +1,210 @@
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 V2paymentsPaymentInformation
17
- attr_accessor :card
18
-
19
- attr_accessor :tokenized_card
20
-
21
- attr_accessor :fluid_data
22
-
23
- attr_accessor :customer
24
-
25
- # Attribute mapping from ruby-style variable name to JSON key.
26
- def self.attribute_map
27
- {
28
- :'card' => :'card',
29
- :'tokenized_card' => :'tokenizedCard',
30
- :'fluid_data' => :'fluidData',
31
- :'customer' => :'customer'
32
- }
33
- end
34
-
35
- # Attribute type mapping.
36
- def self.swagger_types
37
- {
38
- :'card' => :'V2paymentsPaymentInformationCard',
39
- :'tokenized_card' => :'V2paymentsPaymentInformationTokenizedCard',
40
- :'fluid_data' => :'V2paymentsPaymentInformationFluidData',
41
- :'customer' => :'V2paymentsPaymentInformationCustomer'
42
- }
43
- end
44
-
45
- # Initializes the object
46
- # @param [Hash] attributes Model attributes in the form of hash
47
- def initialize(attributes = {})
48
- return unless attributes.is_a?(Hash)
49
-
50
- # convert string to symbol for hash key
51
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
52
-
53
- if attributes.has_key?(:'card')
54
- self.card = attributes[:'card']
55
- end
56
-
57
- if attributes.has_key?(:'tokenizedCard')
58
- self.tokenized_card = attributes[:'tokenizedCard']
59
- end
60
-
61
- if attributes.has_key?(:'fluidData')
62
- self.fluid_data = attributes[:'fluidData']
63
- end
64
-
65
- if attributes.has_key?(:'customer')
66
- self.customer = attributes[:'customer']
67
- end
68
- end
69
-
70
- # Show invalid properties with the reasons. Usually used together with valid?
71
- # @return Array for valid properties with the reasons
72
- def list_invalid_properties
73
- invalid_properties = Array.new
74
- invalid_properties
75
- end
76
-
77
- # Check to see if the all the properties in the model are valid
78
- # @return true if the model is valid
79
- def valid?
80
- true
81
- end
82
-
83
- # Checks equality by comparing each attribute.
84
- # @param [Object] Object to be compared
85
- def ==(o)
86
- return true if self.equal?(o)
87
- self.class == o.class &&
88
- card == o.card &&
89
- tokenized_card == o.tokenized_card &&
90
- fluid_data == o.fluid_data &&
91
- customer == o.customer
92
- end
93
-
94
- # @see the `==` method
95
- # @param [Object] Object to be compared
96
- def eql?(o)
97
- self == o
98
- end
99
-
100
- # Calculates hash code according to all attributes.
101
- # @return [Fixnum] Hash code
102
- def hash
103
- [card, tokenized_card, fluid_data, customer].hash
104
- end
105
-
106
- # Builds the object from hash
107
- # @param [Hash] attributes Model attributes in the form of hash
108
- # @return [Object] Returns the model itself
109
- def build_from_hash(attributes)
110
- return nil unless attributes.is_a?(Hash)
111
- self.class.swagger_types.each_pair do |key, type|
112
- if type =~ /\AArray<(.*)>/i
113
- # check to ensure the input is an array given that the the attribute
114
- # is documented as an array but the input is not
115
- if attributes[self.class.attribute_map[key]].is_a?(Array)
116
- self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
117
- end
118
- elsif !attributes[self.class.attribute_map[key]].nil?
119
- self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
120
- end # or else data not found in attributes(hash), not an issue as the data can be optional
121
- end
122
-
123
- self
124
- end
125
-
126
- # Deserializes the data based on type
127
- # @param string type Data type
128
- # @param string value Value to be deserialized
129
- # @return [Object] Deserialized data
130
- def _deserialize(type, value)
131
- case type.to_sym
132
- when :DateTime
133
- DateTime.parse(value)
134
- when :Date
135
- Date.parse(value)
136
- when :String
137
- value.to_s
138
- when :Integer
139
- value.to_i
140
- when :Float
141
- value.to_f
142
- when :BOOLEAN
143
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
144
- true
145
- else
146
- false
147
- end
148
- when :Object
149
- # generic object (usually a Hash), return directly
150
- value
151
- when /\AArray<(?<inner_type>.+)>\z/
152
- inner_type = Regexp.last_match[:inner_type]
153
- value.map { |v| _deserialize(inner_type, v) }
154
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
155
- k_type = Regexp.last_match[:k_type]
156
- v_type = Regexp.last_match[:v_type]
157
- {}.tap do |hash|
158
- value.each do |k, v|
159
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
160
- end
161
- end
162
- else # model
163
- temp_model = CyberSource.const_get(type).new
164
- temp_model.build_from_hash(value)
165
- end
166
- end
167
-
168
- # Returns the string representation of the object
169
- # @return [String] String presentation of the object
170
- def to_s
171
- to_hash.to_s
172
- end
173
-
174
- # to_body is an alias to to_hash (backward compatibility)
175
- # @return [Hash] Returns the object in the form of hash
176
- def to_body
177
- to_hash
178
- end
179
-
180
- # Returns the object in the form of hash
181
- # @return [Hash] Returns the object in the form of hash
182
- def to_hash
183
- hash = {}
184
- self.class.attribute_map.each_pair do |attr, param|
185
- value = self.send(attr)
186
- next if value.nil?
187
- hash[param] = _to_hash(value)
188
- end
189
- hash
190
- end
191
-
192
- # Outputs non-array value in the form of hash
193
- # For object, use to_hash. Otherwise, just return the value
194
- # @param [Object] value Any valid value
195
- # @return [Hash] Returns the value in the form of hash
196
- def _to_hash(value)
197
- if value.is_a?(Array)
198
- value.compact.map { |v| _to_hash(v) }
199
- elsif value.is_a?(Hash)
200
- {}.tap do |hash|
201
- value.each { |k, v| hash[k] = _to_hash(v) }
202
- end
203
- elsif value.respond_to? :to_hash
204
- value.to_hash
205
- else
206
- value
207
- end
208
- end
209
- end
210
- 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 V2paymentsPaymentInformation
17
+ attr_accessor :card
18
+
19
+ attr_accessor :tokenized_card
20
+
21
+ attr_accessor :fluid_data
22
+
23
+ attr_accessor :customer
24
+
25
+ # Attribute mapping from ruby-style variable name to JSON key.
26
+ def self.attribute_map
27
+ {
28
+ :'card' => :'card',
29
+ :'tokenized_card' => :'tokenizedCard',
30
+ :'fluid_data' => :'fluidData',
31
+ :'customer' => :'customer'
32
+ }
33
+ end
34
+
35
+ # Attribute type mapping.
36
+ def self.swagger_types
37
+ {
38
+ :'card' => :'V2paymentsPaymentInformationCard',
39
+ :'tokenized_card' => :'V2paymentsPaymentInformationTokenizedCard',
40
+ :'fluid_data' => :'V2paymentsPaymentInformationFluidData',
41
+ :'customer' => :'V2paymentsPaymentInformationCustomer'
42
+ }
43
+ end
44
+
45
+ # Initializes the object
46
+ # @param [Hash] attributes Model attributes in the form of hash
47
+ def initialize(attributes = {})
48
+ return unless attributes.is_a?(Hash)
49
+
50
+ # convert string to symbol for hash key
51
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
52
+
53
+ if attributes.has_key?(:'card')
54
+ self.card = attributes[:'card']
55
+ end
56
+
57
+ if attributes.has_key?(:'tokenizedCard')
58
+ self.tokenized_card = attributes[:'tokenizedCard']
59
+ end
60
+
61
+ if attributes.has_key?(:'fluidData')
62
+ self.fluid_data = attributes[:'fluidData']
63
+ end
64
+
65
+ if attributes.has_key?(:'customer')
66
+ self.customer = attributes[:'customer']
67
+ end
68
+ end
69
+
70
+ # Show invalid properties with the reasons. Usually used together with valid?
71
+ # @return Array for valid properties with the reasons
72
+ def list_invalid_properties
73
+ invalid_properties = Array.new
74
+ invalid_properties
75
+ end
76
+
77
+ # Check to see if the all the properties in the model are valid
78
+ # @return true if the model is valid
79
+ def valid?
80
+ true
81
+ end
82
+
83
+ # Checks equality by comparing each attribute.
84
+ # @param [Object] Object to be compared
85
+ def ==(o)
86
+ return true if self.equal?(o)
87
+ self.class == o.class &&
88
+ card == o.card &&
89
+ tokenized_card == o.tokenized_card &&
90
+ fluid_data == o.fluid_data &&
91
+ customer == o.customer
92
+ end
93
+
94
+ # @see the `==` method
95
+ # @param [Object] Object to be compared
96
+ def eql?(o)
97
+ self == o
98
+ end
99
+
100
+ # Calculates hash code according to all attributes.
101
+ # @return [Fixnum] Hash code
102
+ def hash
103
+ [card, tokenized_card, fluid_data, customer].hash
104
+ end
105
+
106
+ # Builds the object from hash
107
+ # @param [Hash] attributes Model attributes in the form of hash
108
+ # @return [Object] Returns the model itself
109
+ def build_from_hash(attributes)
110
+ return nil unless attributes.is_a?(Hash)
111
+ self.class.swagger_types.each_pair do |key, type|
112
+ if type =~ /\AArray<(.*)>/i
113
+ # check to ensure the input is an array given that the the attribute
114
+ # is documented as an array but the input is not
115
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
116
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
117
+ end
118
+ elsif !attributes[self.class.attribute_map[key]].nil?
119
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
120
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
121
+ end
122
+
123
+ self
124
+ end
125
+
126
+ # Deserializes the data based on type
127
+ # @param string type Data type
128
+ # @param string value Value to be deserialized
129
+ # @return [Object] Deserialized data
130
+ def _deserialize(type, value)
131
+ case type.to_sym
132
+ when :DateTime
133
+ DateTime.parse(value)
134
+ when :Date
135
+ Date.parse(value)
136
+ when :String
137
+ value.to_s
138
+ when :Integer
139
+ value.to_i
140
+ when :Float
141
+ value.to_f
142
+ when :BOOLEAN
143
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
144
+ true
145
+ else
146
+ false
147
+ end
148
+ when :Object
149
+ # generic object (usually a Hash), return directly
150
+ value
151
+ when /\AArray<(?<inner_type>.+)>\z/
152
+ inner_type = Regexp.last_match[:inner_type]
153
+ value.map { |v| _deserialize(inner_type, v) }
154
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
155
+ k_type = Regexp.last_match[:k_type]
156
+ v_type = Regexp.last_match[:v_type]
157
+ {}.tap do |hash|
158
+ value.each do |k, v|
159
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
160
+ end
161
+ end
162
+ else # model
163
+ temp_model = CyberSource.const_get(type).new
164
+ temp_model.build_from_hash(value)
165
+ end
166
+ end
167
+
168
+ # Returns the string representation of the object
169
+ # @return [String] String presentation of the object
170
+ def to_s
171
+ to_hash.to_s
172
+ end
173
+
174
+ # to_body is an alias to to_hash (backward compatibility)
175
+ # @return [Hash] Returns the object in the form of hash
176
+ def to_body
177
+ to_hash
178
+ end
179
+
180
+ # Returns the object in the form of hash
181
+ # @return [Hash] Returns the object in the form of hash
182
+ def to_hash
183
+ hash = {}
184
+ self.class.attribute_map.each_pair do |attr, param|
185
+ value = self.send(attr)
186
+ next if value.nil?
187
+ hash[param] = _to_hash(value)
188
+ end
189
+ hash
190
+ end
191
+
192
+ # Outputs non-array value in the form of hash
193
+ # For object, use to_hash. Otherwise, just return the value
194
+ # @param [Object] value Any valid value
195
+ # @return [Hash] Returns the value in the form of hash
196
+ def _to_hash(value)
197
+ if value.is_a?(Array)
198
+ value.compact.map { |v| _to_hash(v) }
199
+ elsif value.is_a?(Hash)
200
+ {}.tap do |hash|
201
+ value.each { |k, v| hash[k] = _to_hash(v) }
202
+ end
203
+ elsif value.respond_to? :to_hash
204
+ value.to_hash
205
+ else
206
+ value
207
+ end
208
+ end
209
+ end
210
+ end
@@ -1,474 +1,474 @@
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 V2paymentsPaymentInformationCard
17
- # Customer’s credit card number. Encoded Account Numbers when processing encoded account numbers, use this field for the encoded account number. For processor-specific information, see the customer_cc_number field in [Credit Card Services Using the SCMP API.](http://apps.cybersource.com/library/documentation/dev_guides/CC_Svcs_SCMP_API/html)
18
- attr_accessor :number
19
-
20
- # Two-digit month in which the credit card expires. `Format: MM`. Possible values: 01 through 12. **Encoded Account Numbers** For encoded account numbers (_type_=039), if there is no expiration date on the card, use 12. For processor-specific information, see the customer_cc_expmo field in [Credit Card Services Using the SCMP API.](http://apps.cybersource.com/library/documentation/dev_guides/CC_Svcs_SCMP_API/html)
21
- attr_accessor :expiration_month
22
-
23
- # Four-digit year in which the credit card expires. `Format: YYYY`. **Encoded Account Numbers** For encoded account numbers (_type_=039), if there is no expiration date on the card, use 2021. For processor-specific information, see the customer_cc_expyr field in [Credit Card Services Using the SCMP API.](http://apps.cybersource.com/library/documentation/dev_guides/CC_Svcs_SCMP_API/html)
24
- attr_accessor :expiration_year
25
-
26
- # Type of card to authorize. - 001 Visa - 002 Mastercard - 003 Amex - 004 Discover
27
- attr_accessor :type
28
-
29
- # Flag that specifies the type of account associated with the card. The cardholder provides this information during the payment process. **Cielo** and **Comercio Latino** Possible values: - CREDIT: Credit card - DEBIT: Debit card This field is required for: - Debit transactions on Cielo and Comercio Latino. - Transactions with Brazilian-issued cards on CyberSource through VisaNet.
30
- attr_accessor :use_as
31
-
32
- # Flag that specifies the type of account associated with the card. The cardholder provides this information during the payment process. This field is required in the following cases. - Debit transactions on Cielo and Comercio Latino. - Transactions with Brazilian-issued cards on CyberSource through VisaNet. - Applicable only for CTV. **Note** Combo cards in Brazil contain credit and debit functionality in a single card. Visa systems use a credit bank identification number (BIN) for this type of card. Using the BIN to determine whether a card is debit or credit can cause transactions with these cards to be processed incorrectly. CyberSource strongly recommends that you include this field for combo card transactions. Possible values include the following. - CHECKING: Checking account - CREDIT: Credit card account - SAVING: Saving account - LINE_OF_CREDIT: Line of credit - PREPAID: Prepaid card account - UNIVERSAL: Universal account
33
- attr_accessor :source_account_type
34
-
35
- # Card Verification Number.
36
- attr_accessor :security_code
37
-
38
- # Flag that indicates whether a CVN code was sent. Possible values: - 0 (default): CVN service not requested. CyberSource uses this default value when you do not include _securityCode_ in the request. - 1 (default): CVN service requested and supported. CyberSource uses this default value when you include _securityCode_ in the request. - 2: CVN on credit card is illegible. - 9: CVN was not imprinted on credit card.
39
- attr_accessor :security_code_indicator
40
-
41
- # Identifier for the issuing bank that provided the customer’s encoded account number. Contact your processor for the bank’s ID.
42
- attr_accessor :account_encoder_id
43
-
44
- # Number of times a Maestro (UK Domestic) card has been issued to the account holder. The card might or might not have an issue number. The number can consist of one or two digits, and the first digit might be a zero. When you include this value in your request, include exactly what is printed on the card. A value of 2 is different than a value of 02. Do not include the field, even with a blank value, if the card is not a Maestro (UK Domestic) card. The issue number is not required for Maestro (UK Domestic) transactions.
45
- attr_accessor :issue_number
46
-
47
- # Month of the start of the Maestro (UK Domestic) card validity period. Do not include the field, even with a blank value, if the card is not a Maestro (UK Domestic) card. `Format: MM`. Possible values: 01 through 12. The start date is not required for Maestro (UK Domestic) transactions.
48
- attr_accessor :start_month
49
-
50
- # Year of the start of the Maestro (UK Domestic) card validity period. Do not include the field, even with a blank value, if the card is not a Maestro (UK Domestic) card. `Format: YYYY`. The start date is not required for Maestro (UK Domestic) transactions.
51
- attr_accessor :start_year
52
-
53
- # Attribute mapping from ruby-style variable name to JSON key.
54
- def self.attribute_map
55
- {
56
- :'number' => :'number',
57
- :'expiration_month' => :'expirationMonth',
58
- :'expiration_year' => :'expirationYear',
59
- :'type' => :'type',
60
- :'use_as' => :'useAs',
61
- :'source_account_type' => :'sourceAccountType',
62
- :'security_code' => :'securityCode',
63
- :'security_code_indicator' => :'securityCodeIndicator',
64
- :'account_encoder_id' => :'accountEncoderId',
65
- :'issue_number' => :'issueNumber',
66
- :'start_month' => :'startMonth',
67
- :'start_year' => :'startYear'
68
- }
69
- end
70
-
71
- # Attribute type mapping.
72
- def self.swagger_types
73
- {
74
- :'number' => :'String',
75
- :'expiration_month' => :'String',
76
- :'expiration_year' => :'String',
77
- :'type' => :'String',
78
- :'use_as' => :'String',
79
- :'source_account_type' => :'String',
80
- :'security_code' => :'String',
81
- :'security_code_indicator' => :'String',
82
- :'account_encoder_id' => :'String',
83
- :'issue_number' => :'String',
84
- :'start_month' => :'String',
85
- :'start_year' => :'String'
86
- }
87
- end
88
-
89
- # Initializes the object
90
- # @param [Hash] attributes Model attributes in the form of hash
91
- def initialize(attributes = {})
92
- return unless attributes.is_a?(Hash)
93
-
94
- # convert string to symbol for hash key
95
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
96
-
97
- if attributes.has_key?(:'number')
98
- self.number = attributes[:'number']
99
- end
100
-
101
- if attributes.has_key?(:'expirationMonth')
102
- self.expiration_month = attributes[:'expirationMonth']
103
- end
104
-
105
- if attributes.has_key?(:'expirationYear')
106
- self.expiration_year = attributes[:'expirationYear']
107
- end
108
-
109
- if attributes.has_key?(:'type')
110
- self.type = attributes[:'type']
111
- end
112
-
113
- if attributes.has_key?(:'useAs')
114
- self.use_as = attributes[:'useAs']
115
- end
116
-
117
- if attributes.has_key?(:'sourceAccountType')
118
- self.source_account_type = attributes[:'sourceAccountType']
119
- end
120
-
121
- if attributes.has_key?(:'securityCode')
122
- self.security_code = attributes[:'securityCode']
123
- end
124
-
125
- if attributes.has_key?(:'securityCodeIndicator')
126
- self.security_code_indicator = attributes[:'securityCodeIndicator']
127
- end
128
-
129
- if attributes.has_key?(:'accountEncoderId')
130
- self.account_encoder_id = attributes[:'accountEncoderId']
131
- end
132
-
133
- if attributes.has_key?(:'issueNumber')
134
- self.issue_number = attributes[:'issueNumber']
135
- end
136
-
137
- if attributes.has_key?(:'startMonth')
138
- self.start_month = attributes[:'startMonth']
139
- end
140
-
141
- if attributes.has_key?(:'startYear')
142
- self.start_year = attributes[:'startYear']
143
- end
144
- end
145
-
146
- # Show invalid properties with the reasons. Usually used together with valid?
147
- # @return Array for valid properties with the reasons
148
- def list_invalid_properties
149
- invalid_properties = Array.new
150
- if !@number.nil? && @number.to_s.length > 20
151
- invalid_properties.push('invalid value for "number", the character length must be smaller than or equal to 20.')
152
- end
153
-
154
- if !@expiration_month.nil? && @expiration_month.to_s.length > 2
155
- invalid_properties.push('invalid value for "expiration_month", the character length must be smaller than or equal to 2.')
156
- end
157
-
158
- if !@expiration_year.nil? && @expiration_year.to_s.length > 4
159
- invalid_properties.push('invalid value for "expiration_year", the character length must be smaller than or equal to 4.')
160
- end
161
-
162
- if !@type.nil? && @type.to_s.length > 3
163
- invalid_properties.push('invalid value for "type", the character length must be smaller than or equal to 3.')
164
- end
165
-
166
- if !@use_as.nil? && @use_as.to_s.length > 2
167
- invalid_properties.push('invalid value for "use_as", the character length must be smaller than or equal to 2.')
168
- end
169
-
170
- if !@source_account_type.nil? && @source_account_type.to_s.length > 2
171
- invalid_properties.push('invalid value for "source_account_type", the character length must be smaller than or equal to 2.')
172
- end
173
-
174
- if !@security_code.nil? && @security_code.to_s.length > 4
175
- invalid_properties.push('invalid value for "security_code", the character length must be smaller than or equal to 4.')
176
- end
177
-
178
- if !@security_code_indicator.nil? && @security_code_indicator.to_s.length > 1
179
- invalid_properties.push('invalid value for "security_code_indicator", the character length must be smaller than or equal to 1.')
180
- end
181
-
182
- if !@account_encoder_id.nil? && @account_encoder_id.to_s.length > 3
183
- invalid_properties.push('invalid value for "account_encoder_id", the character length must be smaller than or equal to 3.')
184
- end
185
-
186
- if !@issue_number.nil? && @issue_number.to_s.length > 5
187
- invalid_properties.push('invalid value for "issue_number", the character length must be smaller than or equal to 5.')
188
- end
189
-
190
- if !@start_month.nil? && @start_month.to_s.length > 2
191
- invalid_properties.push('invalid value for "start_month", the character length must be smaller than or equal to 2.')
192
- end
193
-
194
- if !@start_year.nil? && @start_year.to_s.length > 4
195
- invalid_properties.push('invalid value for "start_year", the character length must be smaller than or equal to 4.')
196
- end
197
-
198
- invalid_properties
199
- end
200
-
201
- # Check to see if the all the properties in the model are valid
202
- # @return true if the model is valid
203
- def valid?
204
- return false if !@number.nil? && @number.to_s.length > 20
205
- return false if !@expiration_month.nil? && @expiration_month.to_s.length > 2
206
- return false if !@expiration_year.nil? && @expiration_year.to_s.length > 4
207
- return false if !@type.nil? && @type.to_s.length > 3
208
- return false if !@use_as.nil? && @use_as.to_s.length > 2
209
- return false if !@source_account_type.nil? && @source_account_type.to_s.length > 2
210
- return false if !@security_code.nil? && @security_code.to_s.length > 4
211
- return false if !@security_code_indicator.nil? && @security_code_indicator.to_s.length > 1
212
- return false if !@account_encoder_id.nil? && @account_encoder_id.to_s.length > 3
213
- return false if !@issue_number.nil? && @issue_number.to_s.length > 5
214
- return false if !@start_month.nil? && @start_month.to_s.length > 2
215
- return false if !@start_year.nil? && @start_year.to_s.length > 4
216
- true
217
- end
218
-
219
- # Custom attribute writer method with validation
220
- # @param [Object] number Value to be assigned
221
- def number=(number)
222
- if !number.nil? && number.to_s.length > 20
223
- fail ArgumentError, 'invalid value for "number", the character length must be smaller than or equal to 20.'
224
- end
225
-
226
- @number = number
227
- end
228
-
229
- # Custom attribute writer method with validation
230
- # @param [Object] expiration_month Value to be assigned
231
- def expiration_month=(expiration_month)
232
- if !expiration_month.nil? && expiration_month.to_s.length > 2
233
- fail ArgumentError, 'invalid value for "expiration_month", the character length must be smaller than or equal to 2.'
234
- end
235
-
236
- @expiration_month = expiration_month
237
- end
238
-
239
- # Custom attribute writer method with validation
240
- # @param [Object] expiration_year Value to be assigned
241
- def expiration_year=(expiration_year)
242
- if !expiration_year.nil? && expiration_year.to_s.length > 4
243
- fail ArgumentError, 'invalid value for "expiration_year", the character length must be smaller than or equal to 4.'
244
- end
245
-
246
- @expiration_year = expiration_year
247
- end
248
-
249
- # Custom attribute writer method with validation
250
- # @param [Object] type Value to be assigned
251
- def type=(type)
252
- if !type.nil? && type.to_s.length > 3
253
- fail ArgumentError, 'invalid value for "type", the character length must be smaller than or equal to 3.'
254
- end
255
-
256
- @type = type
257
- end
258
-
259
- # Custom attribute writer method with validation
260
- # @param [Object] use_as Value to be assigned
261
- def use_as=(use_as)
262
- if !use_as.nil? && use_as.to_s.length > 2
263
- fail ArgumentError, 'invalid value for "use_as", the character length must be smaller than or equal to 2.'
264
- end
265
-
266
- @use_as = use_as
267
- end
268
-
269
- # Custom attribute writer method with validation
270
- # @param [Object] source_account_type Value to be assigned
271
- def source_account_type=(source_account_type)
272
- if !source_account_type.nil? && source_account_type.to_s.length > 2
273
- fail ArgumentError, 'invalid value for "source_account_type", the character length must be smaller than or equal to 2.'
274
- end
275
-
276
- @source_account_type = source_account_type
277
- end
278
-
279
- # Custom attribute writer method with validation
280
- # @param [Object] security_code Value to be assigned
281
- def security_code=(security_code)
282
- if !security_code.nil? && security_code.to_s.length > 4
283
- fail ArgumentError, 'invalid value for "security_code", the character length must be smaller than or equal to 4.'
284
- end
285
-
286
- @security_code = security_code
287
- end
288
-
289
- # Custom attribute writer method with validation
290
- # @param [Object] security_code_indicator Value to be assigned
291
- def security_code_indicator=(security_code_indicator)
292
- if !security_code_indicator.nil? && security_code_indicator.to_s.length > 1
293
- fail ArgumentError, 'invalid value for "security_code_indicator", the character length must be smaller than or equal to 1.'
294
- end
295
-
296
- @security_code_indicator = security_code_indicator
297
- end
298
-
299
- # Custom attribute writer method with validation
300
- # @param [Object] account_encoder_id Value to be assigned
301
- def account_encoder_id=(account_encoder_id)
302
- if !account_encoder_id.nil? && account_encoder_id.to_s.length > 3
303
- fail ArgumentError, 'invalid value for "account_encoder_id", the character length must be smaller than or equal to 3.'
304
- end
305
-
306
- @account_encoder_id = account_encoder_id
307
- end
308
-
309
- # Custom attribute writer method with validation
310
- # @param [Object] issue_number Value to be assigned
311
- def issue_number=(issue_number)
312
- if !issue_number.nil? && issue_number.to_s.length > 5
313
- fail ArgumentError, 'invalid value for "issue_number", the character length must be smaller than or equal to 5.'
314
- end
315
-
316
- @issue_number = issue_number
317
- end
318
-
319
- # Custom attribute writer method with validation
320
- # @param [Object] start_month Value to be assigned
321
- def start_month=(start_month)
322
- if !start_month.nil? && start_month.to_s.length > 2
323
- fail ArgumentError, 'invalid value for "start_month", the character length must be smaller than or equal to 2.'
324
- end
325
-
326
- @start_month = start_month
327
- end
328
-
329
- # Custom attribute writer method with validation
330
- # @param [Object] start_year Value to be assigned
331
- def start_year=(start_year)
332
- if !start_year.nil? && start_year.to_s.length > 4
333
- fail ArgumentError, 'invalid value for "start_year", the character length must be smaller than or equal to 4.'
334
- end
335
-
336
- @start_year = start_year
337
- end
338
-
339
- # Checks equality by comparing each attribute.
340
- # @param [Object] Object to be compared
341
- def ==(o)
342
- return true if self.equal?(o)
343
- self.class == o.class &&
344
- number == o.number &&
345
- expiration_month == o.expiration_month &&
346
- expiration_year == o.expiration_year &&
347
- type == o.type &&
348
- use_as == o.use_as &&
349
- source_account_type == o.source_account_type &&
350
- security_code == o.security_code &&
351
- security_code_indicator == o.security_code_indicator &&
352
- account_encoder_id == o.account_encoder_id &&
353
- issue_number == o.issue_number &&
354
- start_month == o.start_month &&
355
- start_year == o.start_year
356
- end
357
-
358
- # @see the `==` method
359
- # @param [Object] Object to be compared
360
- def eql?(o)
361
- self == o
362
- end
363
-
364
- # Calculates hash code according to all attributes.
365
- # @return [Fixnum] Hash code
366
- def hash
367
- [number, expiration_month, expiration_year, type, use_as, source_account_type, security_code, security_code_indicator, account_encoder_id, issue_number, start_month, start_year].hash
368
- end
369
-
370
- # Builds the object from hash
371
- # @param [Hash] attributes Model attributes in the form of hash
372
- # @return [Object] Returns the model itself
373
- def build_from_hash(attributes)
374
- return nil unless attributes.is_a?(Hash)
375
- self.class.swagger_types.each_pair do |key, type|
376
- if type =~ /\AArray<(.*)>/i
377
- # check to ensure the input is an array given that the the attribute
378
- # is documented as an array but the input is not
379
- if attributes[self.class.attribute_map[key]].is_a?(Array)
380
- self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
381
- end
382
- elsif !attributes[self.class.attribute_map[key]].nil?
383
- self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
384
- end # or else data not found in attributes(hash), not an issue as the data can be optional
385
- end
386
-
387
- self
388
- end
389
-
390
- # Deserializes the data based on type
391
- # @param string type Data type
392
- # @param string value Value to be deserialized
393
- # @return [Object] Deserialized data
394
- def _deserialize(type, value)
395
- case type.to_sym
396
- when :DateTime
397
- DateTime.parse(value)
398
- when :Date
399
- Date.parse(value)
400
- when :String
401
- value.to_s
402
- when :Integer
403
- value.to_i
404
- when :Float
405
- value.to_f
406
- when :BOOLEAN
407
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
408
- true
409
- else
410
- false
411
- end
412
- when :Object
413
- # generic object (usually a Hash), return directly
414
- value
415
- when /\AArray<(?<inner_type>.+)>\z/
416
- inner_type = Regexp.last_match[:inner_type]
417
- value.map { |v| _deserialize(inner_type, v) }
418
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
419
- k_type = Regexp.last_match[:k_type]
420
- v_type = Regexp.last_match[:v_type]
421
- {}.tap do |hash|
422
- value.each do |k, v|
423
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
424
- end
425
- end
426
- else # model
427
- temp_model = CyberSource.const_get(type).new
428
- temp_model.build_from_hash(value)
429
- end
430
- end
431
-
432
- # Returns the string representation of the object
433
- # @return [String] String presentation of the object
434
- def to_s
435
- to_hash.to_s
436
- end
437
-
438
- # to_body is an alias to to_hash (backward compatibility)
439
- # @return [Hash] Returns the object in the form of hash
440
- def to_body
441
- to_hash
442
- end
443
-
444
- # Returns the object in the form of hash
445
- # @return [Hash] Returns the object in the form of hash
446
- def to_hash
447
- hash = {}
448
- self.class.attribute_map.each_pair do |attr, param|
449
- value = self.send(attr)
450
- next if value.nil?
451
- hash[param] = _to_hash(value)
452
- end
453
- hash
454
- end
455
-
456
- # Outputs non-array value in the form of hash
457
- # For object, use to_hash. Otherwise, just return the value
458
- # @param [Object] value Any valid value
459
- # @return [Hash] Returns the value in the form of hash
460
- def _to_hash(value)
461
- if value.is_a?(Array)
462
- value.compact.map { |v| _to_hash(v) }
463
- elsif value.is_a?(Hash)
464
- {}.tap do |hash|
465
- value.each { |k, v| hash[k] = _to_hash(v) }
466
- end
467
- elsif value.respond_to? :to_hash
468
- value.to_hash
469
- else
470
- value
471
- end
472
- end
473
- end
474
- 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 V2paymentsPaymentInformationCard
17
+ # Customer’s credit card number. Encoded Account Numbers when processing encoded account numbers, use this field for the encoded account number. For processor-specific information, see the customer_cc_number field in [Credit Card Services Using the SCMP API.](http://apps.cybersource.com/library/documentation/dev_guides/CC_Svcs_SCMP_API/html)
18
+ attr_accessor :number
19
+
20
+ # Two-digit month in which the credit card expires. `Format: MM`. Possible values: 01 through 12. **Encoded Account Numbers** For encoded account numbers (_type_=039), if there is no expiration date on the card, use 12. For processor-specific information, see the customer_cc_expmo field in [Credit Card Services Using the SCMP API.](http://apps.cybersource.com/library/documentation/dev_guides/CC_Svcs_SCMP_API/html)
21
+ attr_accessor :expiration_month
22
+
23
+ # Four-digit year in which the credit card expires. `Format: YYYY`. **Encoded Account Numbers** For encoded account numbers (_type_=039), if there is no expiration date on the card, use 2021. For processor-specific information, see the customer_cc_expyr field in [Credit Card Services Using the SCMP API.](http://apps.cybersource.com/library/documentation/dev_guides/CC_Svcs_SCMP_API/html)
24
+ attr_accessor :expiration_year
25
+
26
+ # Type of card to authorize. - 001 Visa - 002 Mastercard - 003 Amex - 004 Discover
27
+ attr_accessor :type
28
+
29
+ # Flag that specifies the type of account associated with the card. The cardholder provides this information during the payment process. **Cielo** and **Comercio Latino** Possible values: - CREDIT: Credit card - DEBIT: Debit card This field is required for: - Debit transactions on Cielo and Comercio Latino. - Transactions with Brazilian-issued cards on CyberSource through VisaNet.
30
+ attr_accessor :use_as
31
+
32
+ # Flag that specifies the type of account associated with the card. The cardholder provides this information during the payment process. This field is required in the following cases. - Debit transactions on Cielo and Comercio Latino. - Transactions with Brazilian-issued cards on CyberSource through VisaNet. - Applicable only for CTV. **Note** Combo cards in Brazil contain credit and debit functionality in a single card. Visa systems use a credit bank identification number (BIN) for this type of card. Using the BIN to determine whether a card is debit or credit can cause transactions with these cards to be processed incorrectly. CyberSource strongly recommends that you include this field for combo card transactions. Possible values include the following. - CHECKING: Checking account - CREDIT: Credit card account - SAVING: Saving account - LINE_OF_CREDIT: Line of credit - PREPAID: Prepaid card account - UNIVERSAL: Universal account
33
+ attr_accessor :source_account_type
34
+
35
+ # Card Verification Number.
36
+ attr_accessor :security_code
37
+
38
+ # Flag that indicates whether a CVN code was sent. Possible values: - 0 (default): CVN service not requested. CyberSource uses this default value when you do not include _securityCode_ in the request. - 1 (default): CVN service requested and supported. CyberSource uses this default value when you include _securityCode_ in the request. - 2: CVN on credit card is illegible. - 9: CVN was not imprinted on credit card.
39
+ attr_accessor :security_code_indicator
40
+
41
+ # Identifier for the issuing bank that provided the customer’s encoded account number. Contact your processor for the bank’s ID.
42
+ attr_accessor :account_encoder_id
43
+
44
+ # Number of times a Maestro (UK Domestic) card has been issued to the account holder. The card might or might not have an issue number. The number can consist of one or two digits, and the first digit might be a zero. When you include this value in your request, include exactly what is printed on the card. A value of 2 is different than a value of 02. Do not include the field, even with a blank value, if the card is not a Maestro (UK Domestic) card. The issue number is not required for Maestro (UK Domestic) transactions.
45
+ attr_accessor :issue_number
46
+
47
+ # Month of the start of the Maestro (UK Domestic) card validity period. Do not include the field, even with a blank value, if the card is not a Maestro (UK Domestic) card. `Format: MM`. Possible values: 01 through 12. The start date is not required for Maestro (UK Domestic) transactions.
48
+ attr_accessor :start_month
49
+
50
+ # Year of the start of the Maestro (UK Domestic) card validity period. Do not include the field, even with a blank value, if the card is not a Maestro (UK Domestic) card. `Format: YYYY`. The start date is not required for Maestro (UK Domestic) transactions.
51
+ attr_accessor :start_year
52
+
53
+ # Attribute mapping from ruby-style variable name to JSON key.
54
+ def self.attribute_map
55
+ {
56
+ :'number' => :'number',
57
+ :'expiration_month' => :'expirationMonth',
58
+ :'expiration_year' => :'expirationYear',
59
+ :'type' => :'type',
60
+ :'use_as' => :'useAs',
61
+ :'source_account_type' => :'sourceAccountType',
62
+ :'security_code' => :'securityCode',
63
+ :'security_code_indicator' => :'securityCodeIndicator',
64
+ :'account_encoder_id' => :'accountEncoderId',
65
+ :'issue_number' => :'issueNumber',
66
+ :'start_month' => :'startMonth',
67
+ :'start_year' => :'startYear'
68
+ }
69
+ end
70
+
71
+ # Attribute type mapping.
72
+ def self.swagger_types
73
+ {
74
+ :'number' => :'String',
75
+ :'expiration_month' => :'String',
76
+ :'expiration_year' => :'String',
77
+ :'type' => :'String',
78
+ :'use_as' => :'String',
79
+ :'source_account_type' => :'String',
80
+ :'security_code' => :'String',
81
+ :'security_code_indicator' => :'String',
82
+ :'account_encoder_id' => :'String',
83
+ :'issue_number' => :'String',
84
+ :'start_month' => :'String',
85
+ :'start_year' => :'String'
86
+ }
87
+ end
88
+
89
+ # Initializes the object
90
+ # @param [Hash] attributes Model attributes in the form of hash
91
+ def initialize(attributes = {})
92
+ return unless attributes.is_a?(Hash)
93
+
94
+ # convert string to symbol for hash key
95
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
96
+
97
+ if attributes.has_key?(:'number')
98
+ self.number = attributes[:'number']
99
+ end
100
+
101
+ if attributes.has_key?(:'expirationMonth')
102
+ self.expiration_month = attributes[:'expirationMonth']
103
+ end
104
+
105
+ if attributes.has_key?(:'expirationYear')
106
+ self.expiration_year = attributes[:'expirationYear']
107
+ end
108
+
109
+ if attributes.has_key?(:'type')
110
+ self.type = attributes[:'type']
111
+ end
112
+
113
+ if attributes.has_key?(:'useAs')
114
+ self.use_as = attributes[:'useAs']
115
+ end
116
+
117
+ if attributes.has_key?(:'sourceAccountType')
118
+ self.source_account_type = attributes[:'sourceAccountType']
119
+ end
120
+
121
+ if attributes.has_key?(:'securityCode')
122
+ self.security_code = attributes[:'securityCode']
123
+ end
124
+
125
+ if attributes.has_key?(:'securityCodeIndicator')
126
+ self.security_code_indicator = attributes[:'securityCodeIndicator']
127
+ end
128
+
129
+ if attributes.has_key?(:'accountEncoderId')
130
+ self.account_encoder_id = attributes[:'accountEncoderId']
131
+ end
132
+
133
+ if attributes.has_key?(:'issueNumber')
134
+ self.issue_number = attributes[:'issueNumber']
135
+ end
136
+
137
+ if attributes.has_key?(:'startMonth')
138
+ self.start_month = attributes[:'startMonth']
139
+ end
140
+
141
+ if attributes.has_key?(:'startYear')
142
+ self.start_year = attributes[:'startYear']
143
+ end
144
+ end
145
+
146
+ # Show invalid properties with the reasons. Usually used together with valid?
147
+ # @return Array for valid properties with the reasons
148
+ def list_invalid_properties
149
+ invalid_properties = Array.new
150
+ if !@number.nil? && @number.to_s.length > 20
151
+ invalid_properties.push('invalid value for "number", the character length must be smaller than or equal to 20.')
152
+ end
153
+
154
+ if !@expiration_month.nil? && @expiration_month.to_s.length > 2
155
+ invalid_properties.push('invalid value for "expiration_month", the character length must be smaller than or equal to 2.')
156
+ end
157
+
158
+ if !@expiration_year.nil? && @expiration_year.to_s.length > 4
159
+ invalid_properties.push('invalid value for "expiration_year", the character length must be smaller than or equal to 4.')
160
+ end
161
+
162
+ if !@type.nil? && @type.to_s.length > 3
163
+ invalid_properties.push('invalid value for "type", the character length must be smaller than or equal to 3.')
164
+ end
165
+
166
+ if !@use_as.nil? && @use_as.to_s.length > 2
167
+ invalid_properties.push('invalid value for "use_as", the character length must be smaller than or equal to 2.')
168
+ end
169
+
170
+ if !@source_account_type.nil? && @source_account_type.to_s.length > 2
171
+ invalid_properties.push('invalid value for "source_account_type", the character length must be smaller than or equal to 2.')
172
+ end
173
+
174
+ if !@security_code.nil? && @security_code.to_s.length > 4
175
+ invalid_properties.push('invalid value for "security_code", the character length must be smaller than or equal to 4.')
176
+ end
177
+
178
+ if !@security_code_indicator.nil? && @security_code_indicator.to_s.length > 1
179
+ invalid_properties.push('invalid value for "security_code_indicator", the character length must be smaller than or equal to 1.')
180
+ end
181
+
182
+ if !@account_encoder_id.nil? && @account_encoder_id.to_s.length > 3
183
+ invalid_properties.push('invalid value for "account_encoder_id", the character length must be smaller than or equal to 3.')
184
+ end
185
+
186
+ if !@issue_number.nil? && @issue_number.to_s.length > 5
187
+ invalid_properties.push('invalid value for "issue_number", the character length must be smaller than or equal to 5.')
188
+ end
189
+
190
+ if !@start_month.nil? && @start_month.to_s.length > 2
191
+ invalid_properties.push('invalid value for "start_month", the character length must be smaller than or equal to 2.')
192
+ end
193
+
194
+ if !@start_year.nil? && @start_year.to_s.length > 4
195
+ invalid_properties.push('invalid value for "start_year", the character length must be smaller than or equal to 4.')
196
+ end
197
+
198
+ invalid_properties
199
+ end
200
+
201
+ # Check to see if the all the properties in the model are valid
202
+ # @return true if the model is valid
203
+ def valid?
204
+ return false if !@number.nil? && @number.to_s.length > 20
205
+ return false if !@expiration_month.nil? && @expiration_month.to_s.length > 2
206
+ return false if !@expiration_year.nil? && @expiration_year.to_s.length > 4
207
+ return false if !@type.nil? && @type.to_s.length > 3
208
+ return false if !@use_as.nil? && @use_as.to_s.length > 2
209
+ return false if !@source_account_type.nil? && @source_account_type.to_s.length > 2
210
+ return false if !@security_code.nil? && @security_code.to_s.length > 4
211
+ return false if !@security_code_indicator.nil? && @security_code_indicator.to_s.length > 1
212
+ return false if !@account_encoder_id.nil? && @account_encoder_id.to_s.length > 3
213
+ return false if !@issue_number.nil? && @issue_number.to_s.length > 5
214
+ return false if !@start_month.nil? && @start_month.to_s.length > 2
215
+ return false if !@start_year.nil? && @start_year.to_s.length > 4
216
+ true
217
+ end
218
+
219
+ # Custom attribute writer method with validation
220
+ # @param [Object] number Value to be assigned
221
+ def number=(number)
222
+ if !number.nil? && number.to_s.length > 20
223
+ fail ArgumentError, 'invalid value for "number", the character length must be smaller than or equal to 20.'
224
+ end
225
+
226
+ @number = number
227
+ end
228
+
229
+ # Custom attribute writer method with validation
230
+ # @param [Object] expiration_month Value to be assigned
231
+ def expiration_month=(expiration_month)
232
+ if !expiration_month.nil? && expiration_month.to_s.length > 2
233
+ fail ArgumentError, 'invalid value for "expiration_month", the character length must be smaller than or equal to 2.'
234
+ end
235
+
236
+ @expiration_month = expiration_month
237
+ end
238
+
239
+ # Custom attribute writer method with validation
240
+ # @param [Object] expiration_year Value to be assigned
241
+ def expiration_year=(expiration_year)
242
+ if !expiration_year.nil? && expiration_year.to_s.length > 4
243
+ fail ArgumentError, 'invalid value for "expiration_year", the character length must be smaller than or equal to 4.'
244
+ end
245
+
246
+ @expiration_year = expiration_year
247
+ end
248
+
249
+ # Custom attribute writer method with validation
250
+ # @param [Object] type Value to be assigned
251
+ def type=(type)
252
+ if !type.nil? && type.to_s.length > 3
253
+ fail ArgumentError, 'invalid value for "type", the character length must be smaller than or equal to 3.'
254
+ end
255
+
256
+ @type = type
257
+ end
258
+
259
+ # Custom attribute writer method with validation
260
+ # @param [Object] use_as Value to be assigned
261
+ def use_as=(use_as)
262
+ if !use_as.nil? && use_as.to_s.length > 2
263
+ fail ArgumentError, 'invalid value for "use_as", the character length must be smaller than or equal to 2.'
264
+ end
265
+
266
+ @use_as = use_as
267
+ end
268
+
269
+ # Custom attribute writer method with validation
270
+ # @param [Object] source_account_type Value to be assigned
271
+ def source_account_type=(source_account_type)
272
+ if !source_account_type.nil? && source_account_type.to_s.length > 2
273
+ fail ArgumentError, 'invalid value for "source_account_type", the character length must be smaller than or equal to 2.'
274
+ end
275
+
276
+ @source_account_type = source_account_type
277
+ end
278
+
279
+ # Custom attribute writer method with validation
280
+ # @param [Object] security_code Value to be assigned
281
+ def security_code=(security_code)
282
+ if !security_code.nil? && security_code.to_s.length > 4
283
+ fail ArgumentError, 'invalid value for "security_code", the character length must be smaller than or equal to 4.'
284
+ end
285
+
286
+ @security_code = security_code
287
+ end
288
+
289
+ # Custom attribute writer method with validation
290
+ # @param [Object] security_code_indicator Value to be assigned
291
+ def security_code_indicator=(security_code_indicator)
292
+ if !security_code_indicator.nil? && security_code_indicator.to_s.length > 1
293
+ fail ArgumentError, 'invalid value for "security_code_indicator", the character length must be smaller than or equal to 1.'
294
+ end
295
+
296
+ @security_code_indicator = security_code_indicator
297
+ end
298
+
299
+ # Custom attribute writer method with validation
300
+ # @param [Object] account_encoder_id Value to be assigned
301
+ def account_encoder_id=(account_encoder_id)
302
+ if !account_encoder_id.nil? && account_encoder_id.to_s.length > 3
303
+ fail ArgumentError, 'invalid value for "account_encoder_id", the character length must be smaller than or equal to 3.'
304
+ end
305
+
306
+ @account_encoder_id = account_encoder_id
307
+ end
308
+
309
+ # Custom attribute writer method with validation
310
+ # @param [Object] issue_number Value to be assigned
311
+ def issue_number=(issue_number)
312
+ if !issue_number.nil? && issue_number.to_s.length > 5
313
+ fail ArgumentError, 'invalid value for "issue_number", the character length must be smaller than or equal to 5.'
314
+ end
315
+
316
+ @issue_number = issue_number
317
+ end
318
+
319
+ # Custom attribute writer method with validation
320
+ # @param [Object] start_month Value to be assigned
321
+ def start_month=(start_month)
322
+ if !start_month.nil? && start_month.to_s.length > 2
323
+ fail ArgumentError, 'invalid value for "start_month", the character length must be smaller than or equal to 2.'
324
+ end
325
+
326
+ @start_month = start_month
327
+ end
328
+
329
+ # Custom attribute writer method with validation
330
+ # @param [Object] start_year Value to be assigned
331
+ def start_year=(start_year)
332
+ if !start_year.nil? && start_year.to_s.length > 4
333
+ fail ArgumentError, 'invalid value for "start_year", the character length must be smaller than or equal to 4.'
334
+ end
335
+
336
+ @start_year = start_year
337
+ end
338
+
339
+ # Checks equality by comparing each attribute.
340
+ # @param [Object] Object to be compared
341
+ def ==(o)
342
+ return true if self.equal?(o)
343
+ self.class == o.class &&
344
+ number == o.number &&
345
+ expiration_month == o.expiration_month &&
346
+ expiration_year == o.expiration_year &&
347
+ type == o.type &&
348
+ use_as == o.use_as &&
349
+ source_account_type == o.source_account_type &&
350
+ security_code == o.security_code &&
351
+ security_code_indicator == o.security_code_indicator &&
352
+ account_encoder_id == o.account_encoder_id &&
353
+ issue_number == o.issue_number &&
354
+ start_month == o.start_month &&
355
+ start_year == o.start_year
356
+ end
357
+
358
+ # @see the `==` method
359
+ # @param [Object] Object to be compared
360
+ def eql?(o)
361
+ self == o
362
+ end
363
+
364
+ # Calculates hash code according to all attributes.
365
+ # @return [Fixnum] Hash code
366
+ def hash
367
+ [number, expiration_month, expiration_year, type, use_as, source_account_type, security_code, security_code_indicator, account_encoder_id, issue_number, start_month, start_year].hash
368
+ end
369
+
370
+ # Builds the object from hash
371
+ # @param [Hash] attributes Model attributes in the form of hash
372
+ # @return [Object] Returns the model itself
373
+ def build_from_hash(attributes)
374
+ return nil unless attributes.is_a?(Hash)
375
+ self.class.swagger_types.each_pair do |key, type|
376
+ if type =~ /\AArray<(.*)>/i
377
+ # check to ensure the input is an array given that the the attribute
378
+ # is documented as an array but the input is not
379
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
380
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
381
+ end
382
+ elsif !attributes[self.class.attribute_map[key]].nil?
383
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
384
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
385
+ end
386
+
387
+ self
388
+ end
389
+
390
+ # Deserializes the data based on type
391
+ # @param string type Data type
392
+ # @param string value Value to be deserialized
393
+ # @return [Object] Deserialized data
394
+ def _deserialize(type, value)
395
+ case type.to_sym
396
+ when :DateTime
397
+ DateTime.parse(value)
398
+ when :Date
399
+ Date.parse(value)
400
+ when :String
401
+ value.to_s
402
+ when :Integer
403
+ value.to_i
404
+ when :Float
405
+ value.to_f
406
+ when :BOOLEAN
407
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
408
+ true
409
+ else
410
+ false
411
+ end
412
+ when :Object
413
+ # generic object (usually a Hash), return directly
414
+ value
415
+ when /\AArray<(?<inner_type>.+)>\z/
416
+ inner_type = Regexp.last_match[:inner_type]
417
+ value.map { |v| _deserialize(inner_type, v) }
418
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
419
+ k_type = Regexp.last_match[:k_type]
420
+ v_type = Regexp.last_match[:v_type]
421
+ {}.tap do |hash|
422
+ value.each do |k, v|
423
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
424
+ end
425
+ end
426
+ else # model
427
+ temp_model = CyberSource.const_get(type).new
428
+ temp_model.build_from_hash(value)
429
+ end
430
+ end
431
+
432
+ # Returns the string representation of the object
433
+ # @return [String] String presentation of the object
434
+ def to_s
435
+ to_hash.to_s
436
+ end
437
+
438
+ # to_body is an alias to to_hash (backward compatibility)
439
+ # @return [Hash] Returns the object in the form of hash
440
+ def to_body
441
+ to_hash
442
+ end
443
+
444
+ # Returns the object in the form of hash
445
+ # @return [Hash] Returns the object in the form of hash
446
+ def to_hash
447
+ hash = {}
448
+ self.class.attribute_map.each_pair do |attr, param|
449
+ value = self.send(attr)
450
+ next if value.nil?
451
+ hash[param] = _to_hash(value)
452
+ end
453
+ hash
454
+ end
455
+
456
+ # Outputs non-array value in the form of hash
457
+ # For object, use to_hash. Otherwise, just return the value
458
+ # @param [Object] value Any valid value
459
+ # @return [Hash] Returns the value in the form of hash
460
+ def _to_hash(value)
461
+ if value.is_a?(Array)
462
+ value.compact.map { |v| _to_hash(v) }
463
+ elsif value.is_a?(Hash)
464
+ {}.tap do |hash|
465
+ value.each { |k, v| hash[k] = _to_hash(v) }
466
+ end
467
+ elsif value.respond_to? :to_hash
468
+ value.to_hash
469
+ else
470
+ value
471
+ end
472
+ end
473
+ end
474
+ end