cybersource_rest_client 0.0.4

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 +7 -0
  2. data/AuthenticationSDK/Cybersource.gemspec +23 -0
  3. data/AuthenticationSDK/authentication/http/GetSignatureParameter.rb +62 -0
  4. data/AuthenticationSDK/authentication/http/HttpSignatureHeader.rb +50 -0
  5. data/AuthenticationSDK/authentication/jwt/JwtToken.rb +62 -0
  6. data/AuthenticationSDK/authentication/payloadDigest/digest.rb +10 -0
  7. data/AuthenticationSDK/core/Authorization.rb +24 -0
  8. data/AuthenticationSDK/core/ITokenGeneration.rb +4 -0
  9. data/AuthenticationSDK/core/Logger.rb +26 -0
  10. data/AuthenticationSDK/core/MerchantConfig.rb +181 -0
  11. data/AuthenticationSDK/util/ApiException.rb +19 -0
  12. data/AuthenticationSDK/util/Cache.rb +36 -0
  13. data/AuthenticationSDK/util/Constants.rb +134 -0
  14. data/AuthenticationSDK/util/PropertiesUtil.rb +21 -0
  15. data/AuthenticationSDK/util/Utility.rb +31 -0
  16. data/lib/cyberSource_client.rb +286 -0
  17. data/lib/cyberSource_client/api/capture_api.rb +133 -0
  18. data/lib/cyberSource_client/api/credit_api.rb +127 -0
  19. data/lib/cyberSource_client/api/default_api.rb +75 -0
  20. data/lib/cyberSource_client/api/instrument_identifier_api.rb +393 -0
  21. data/lib/cyberSource_client/api/key_generation_api.rb +75 -0
  22. data/lib/cyberSource_client/api/payment_api.rb +127 -0
  23. data/lib/cyberSource_client/api/payment_instrument_api.rb +312 -0
  24. data/lib/cyberSource_client/api/refund_api.rb +191 -0
  25. data/lib/cyberSource_client/api/reversal_api.rb +133 -0
  26. data/lib/cyberSource_client/api/tokenization_api.rb +71 -0
  27. data/lib/cyberSource_client/api/void_api.rb +307 -0
  28. data/lib/cyberSource_client/api_client.rb +437 -0
  29. data/lib/cyberSource_client/api_error.rb +38 -0
  30. data/lib/cyberSource_client/configuration.rb +202 -0
  31. data/lib/cyberSource_client/models/auth_reversal_request.rb +219 -0
  32. data/lib/cyberSource_client/models/body.rb +295 -0
  33. data/lib/cyberSource_client/models/body_1.rb +183 -0
  34. data/lib/cyberSource_client/models/body_2.rb +331 -0
  35. data/lib/cyberSource_client/models/body_3.rb +331 -0
  36. data/lib/cyberSource_client/models/capture_payment_request.rb +267 -0
  37. data/lib/cyberSource_client/models/card_info.rb +214 -0
  38. data/lib/cyberSource_client/models/create_credit_request.rb +267 -0
  39. data/lib/cyberSource_client/models/create_payment_request.rb +285 -0
  40. data/lib/cyberSource_client/models/der_public_key.rb +205 -0
  41. data/lib/cyberSource_client/models/error.rb +192 -0
  42. data/lib/cyberSource_client/models/error_links.rb +205 -0
  43. data/lib/cyberSource_client/models/error_response.rb +192 -0
  44. data/lib/cyberSource_client/models/generate_public_key_request.rb +184 -0
  45. data/lib/cyberSource_client/models/inline_response_200.rb +202 -0
  46. data/lib/cyberSource_client/models/inline_response_200_1.rb +255 -0
  47. data/lib/cyberSource_client/models/inline_response_200_2.rb +377 -0
  48. data/lib/cyberSource_client/models/inline_response_200_2_buyer_information.rb +270 -0
  49. data/lib/cyberSource_client/models/inline_response_200_2_device_information.rb +219 -0
  50. data/lib/cyberSource_client/models/inline_response_200_2_merchant_information.rb +233 -0
  51. data/lib/cyberSource_client/models/inline_response_200_2_order_information.rb +230 -0
  52. data/lib/cyberSource_client/models/inline_response_200_2_order_information_amount_details.rb +385 -0
  53. data/lib/cyberSource_client/models/inline_response_200_2_order_information_bill_to.rb +459 -0
  54. data/lib/cyberSource_client/models/inline_response_200_2_order_information_invoice_details.rb +315 -0
  55. data/lib/cyberSource_client/models/inline_response_200_2_order_information_line_items.rb +564 -0
  56. data/lib/cyberSource_client/models/inline_response_200_2_order_information_ship_to.rb +429 -0
  57. data/lib/cyberSource_client/models/inline_response_200_2_payment_information.rb +192 -0
  58. data/lib/cyberSource_client/models/inline_response_200_2_payment_information_card.rb +274 -0
  59. data/lib/cyberSource_client/models/inline_response_200_2_payment_information_tokenized_card.rb +299 -0
  60. data/lib/cyberSource_client/models/inline_response_200_2_processing_information.rb +199 -0
  61. data/lib/cyberSource_client/models/inline_response_200_2_processor_information.rb +227 -0
  62. data/lib/cyberSource_client/models/inline_response_200_2_processor_information_avs.rb +199 -0
  63. data/lib/cyberSource_client/models/inline_response_200_2_processor_information_card_verification.rb +199 -0
  64. data/lib/cyberSource_client/models/inline_response_200_3.rb +314 -0
  65. data/lib/cyberSource_client/models/inline_response_200_4.rb +350 -0
  66. data/lib/cyberSource_client/models/inline_response_200_4_device_information.rb +199 -0
  67. data/lib/cyberSource_client/models/inline_response_200_4_order_information.rb +230 -0
  68. data/lib/cyberSource_client/models/inline_response_200_4_order_information_amount_details.rb +360 -0
  69. data/lib/cyberSource_client/models/inline_response_200_4_order_information_invoice_details.rb +305 -0
  70. data/lib/cyberSource_client/models/inline_response_200_4_order_information_ship_to.rb +249 -0
  71. data/lib/cyberSource_client/models/inline_response_200_4_processing_information.rb +208 -0
  72. data/lib/cyberSource_client/models/inline_response_200_4_processing_information_authorization_options.rb +199 -0
  73. data/lib/cyberSource_client/models/inline_response_200_5.rb +305 -0
  74. data/lib/cyberSource_client/models/inline_response_200_6.rb +305 -0
  75. data/lib/cyberSource_client/models/inline_response_200_7.rb +295 -0
  76. data/lib/cyberSource_client/models/inline_response_200_8.rb +277 -0
  77. data/lib/cyberSource_client/models/inline_response_200_8__links.rb +219 -0
  78. data/lib/cyberSource_client/models/inline_response_200_8__links_first.rb +184 -0
  79. data/lib/cyberSource_client/models/inline_response_200_8__links_last.rb +184 -0
  80. data/lib/cyberSource_client/models/inline_response_200_8__links_next.rb +184 -0
  81. data/lib/cyberSource_client/models/inline_response_200_8__links_prev.rb +184 -0
  82. data/lib/cyberSource_client/models/inline_response_200_8__links_self.rb +184 -0
  83. data/lib/cyberSource_client/models/inline_response_200_der.rb +205 -0
  84. data/lib/cyberSource_client/models/inline_response_200_jwk.rb +225 -0
  85. data/lib/cyberSource_client/models/inline_response_201.rb +350 -0
  86. data/lib/cyberSource_client/models/inline_response_201_1.rb +332 -0
  87. data/lib/cyberSource_client/models/inline_response_201_1_authorization_information.rb +224 -0
  88. data/lib/cyberSource_client/models/inline_response_201_1_processor_information.rb +324 -0
  89. data/lib/cyberSource_client/models/inline_response_201_1_reversal_amount_details.rb +249 -0
  90. data/lib/cyberSource_client/models/inline_response_201_2.rb +314 -0
  91. data/lib/cyberSource_client/models/inline_response_201_2__links.rb +201 -0
  92. data/lib/cyberSource_client/models/inline_response_201_2_order_information.rb +192 -0
  93. data/lib/cyberSource_client/models/inline_response_201_2_order_information_amount_details.rb +224 -0
  94. data/lib/cyberSource_client/models/inline_response_201_2_processor_information.rb +199 -0
  95. data/lib/cyberSource_client/models/inline_response_201_3.rb +323 -0
  96. data/lib/cyberSource_client/models/inline_response_201_3__links.rb +192 -0
  97. data/lib/cyberSource_client/models/inline_response_201_3_order_information.rb +183 -0
  98. data/lib/cyberSource_client/models/inline_response_201_3_processor_information.rb +224 -0
  99. data/lib/cyberSource_client/models/inline_response_201_3_refund_amount_details.rb +224 -0
  100. data/lib/cyberSource_client/models/inline_response_201_4.rb +323 -0
  101. data/lib/cyberSource_client/models/inline_response_201_4_credit_amount_details.rb +224 -0
  102. data/lib/cyberSource_client/models/inline_response_201_5.rb +280 -0
  103. data/lib/cyberSource_client/models/inline_response_201_5_void_amount_details.rb +219 -0
  104. data/lib/cyberSource_client/models/inline_response_201_6.rb +331 -0
  105. data/lib/cyberSource_client/models/inline_response_201__embedded.rb +183 -0
  106. data/lib/cyberSource_client/models/inline_response_201__embedded_capture.rb +193 -0
  107. data/lib/cyberSource_client/models/inline_response_201__embedded_capture__links.rb +183 -0
  108. data/lib/cyberSource_client/models/inline_response_201__links.rb +201 -0
  109. data/lib/cyberSource_client/models/inline_response_201__links_self.rb +194 -0
  110. data/lib/cyberSource_client/models/inline_response_201_client_reference_information.rb +199 -0
  111. data/lib/cyberSource_client/models/inline_response_201_error_information.rb +239 -0
  112. data/lib/cyberSource_client/models/inline_response_201_error_information_details.rb +228 -0
  113. data/lib/cyberSource_client/models/inline_response_201_order_information.rb +192 -0
  114. data/lib/cyberSource_client/models/inline_response_201_order_information_amount_details.rb +249 -0
  115. data/lib/cyberSource_client/models/inline_response_201_order_information_invoice_details.rb +184 -0
  116. data/lib/cyberSource_client/models/inline_response_201_payment_information.rb +201 -0
  117. data/lib/cyberSource_client/models/inline_response_201_payment_information_account_features.rb +623 -0
  118. data/lib/cyberSource_client/models/inline_response_201_payment_information_card.rb +199 -0
  119. data/lib/cyberSource_client/models/inline_response_201_payment_information_tokenized_card.rb +349 -0
  120. data/lib/cyberSource_client/models/inline_response_201_point_of_sale_information.rb +208 -0
  121. data/lib/cyberSource_client/models/inline_response_201_point_of_sale_information_emv.rb +199 -0
  122. data/lib/cyberSource_client/models/inline_response_201_processor_information.rb +642 -0
  123. data/lib/cyberSource_client/models/inline_response_201_processor_information_avs.rb +224 -0
  124. data/lib/cyberSource_client/models/inline_response_201_processor_information_card_verification.rb +224 -0
  125. data/lib/cyberSource_client/models/inline_response_201_processor_information_consumer_authentication_response.rb +224 -0
  126. data/lib/cyberSource_client/models/inline_response_201_processor_information_customer.rb +199 -0
  127. data/lib/cyberSource_client/models/inline_response_201_processor_information_electronic_verification_results.rb +474 -0
  128. data/lib/cyberSource_client/models/inline_response_201_processor_information_issuer.rb +224 -0
  129. data/lib/cyberSource_client/models/inline_response_201_processor_information_merchant_advice.rb +224 -0
  130. data/lib/cyberSource_client/models/inline_response_400.rb +271 -0
  131. data/lib/cyberSource_client/models/inline_response_400_1.rb +271 -0
  132. data/lib/cyberSource_client/models/inline_response_400_2.rb +271 -0
  133. data/lib/cyberSource_client/models/inline_response_400_3.rb +271 -0
  134. data/lib/cyberSource_client/models/inline_response_400_4.rb +271 -0
  135. data/lib/cyberSource_client/models/inline_response_400_5.rb +259 -0
  136. data/lib/cyberSource_client/models/inline_response_400_6.rb +202 -0
  137. data/lib/cyberSource_client/models/inline_response_409.rb +183 -0
  138. data/lib/cyberSource_client/models/inline_response_409__links.rb +183 -0
  139. data/lib/cyberSource_client/models/inline_response_409__links_payment_instruments.rb +183 -0
  140. data/lib/cyberSource_client/models/inline_response_502.rb +260 -0
  141. data/lib/cyberSource_client/models/inline_response_default.rb +192 -0
  142. data/lib/cyberSource_client/models/inline_response_default__links.rb +205 -0
  143. data/lib/cyberSource_client/models/inline_response_default__links_next.rb +204 -0
  144. data/lib/cyberSource_client/models/inline_response_default_response_status.rb +225 -0
  145. data/lib/cyberSource_client/models/inline_response_default_response_status_details.rb +194 -0
  146. data/lib/cyberSource_client/models/instrumentidentifiers__links.rb +201 -0
  147. data/lib/cyberSource_client/models/instrumentidentifiers__links_self.rb +183 -0
  148. data/lib/cyberSource_client/models/instrumentidentifiers_authorization_options_merchant_initiated_transaction.rb +184 -0
  149. data/lib/cyberSource_client/models/instrumentidentifiers_bank_account.rb +194 -0
  150. data/lib/cyberSource_client/models/instrumentidentifiers_card.rb +184 -0
  151. data/lib/cyberSource_client/models/instrumentidentifiers_details.rb +194 -0
  152. data/lib/cyberSource_client/models/instrumentidentifiers_metadata.rb +184 -0
  153. data/lib/cyberSource_client/models/instrumentidentifiers_processing_information.rb +183 -0
  154. data/lib/cyberSource_client/models/instrumentidentifiers_processing_information_authorization_options.rb +183 -0
  155. data/lib/cyberSource_client/models/instrumentidentifiers_processing_information_authorization_options_initiator.rb +183 -0
  156. data/lib/cyberSource_client/models/json_web_key.rb +225 -0
  157. data/lib/cyberSource_client/models/key_parameters.rb +184 -0
  158. data/lib/cyberSource_client/models/key_result.rb +202 -0
  159. data/lib/cyberSource_client/models/link.rb +204 -0
  160. data/lib/cyberSource_client/models/links.rb +205 -0
  161. data/lib/cyberSource_client/models/oct_create_payment_request.rb +237 -0
  162. data/lib/cyberSource_client/models/paymentinstruments_bank_account.rb +184 -0
  163. data/lib/cyberSource_client/models/paymentinstruments_bill_to.rb +284 -0
  164. data/lib/cyberSource_client/models/paymentinstruments_buyer_information.rb +215 -0
  165. data/lib/cyberSource_client/models/paymentinstruments_buyer_information_issued_by.rb +184 -0
  166. data/lib/cyberSource_client/models/paymentinstruments_buyer_information_personal_identification.rb +203 -0
  167. data/lib/cyberSource_client/models/paymentinstruments_card.rb +278 -0
  168. data/lib/cyberSource_client/models/paymentinstruments_instrument_identifier.rb +295 -0
  169. data/lib/cyberSource_client/models/paymentinstruments_merchant_information.rb +183 -0
  170. data/lib/cyberSource_client/models/paymentinstruments_merchant_information_merchant_descriptor.rb +184 -0
  171. data/lib/cyberSource_client/models/paymentinstruments_processing_information.rb +193 -0
  172. data/lib/cyberSource_client/models/paymentinstruments_processing_information_bank_transfer_options.rb +184 -0
  173. data/lib/cyberSource_client/models/paymentsflexv1tokens_card_info.rb +214 -0
  174. data/lib/cyberSource_client/models/refund_capture_request.rb +267 -0
  175. data/lib/cyberSource_client/models/refund_payment_request.rb +267 -0
  176. data/lib/cyberSource_client/models/response_status.rb +225 -0
  177. data/lib/cyberSource_client/models/response_status_details.rb +194 -0
  178. data/lib/cyberSource_client/models/tokenize_parameters.rb +193 -0
  179. data/lib/cyberSource_client/models/tokenize_request.rb +193 -0
  180. data/lib/cyberSource_client/models/tokenize_result.rb +255 -0
  181. data/lib/cyberSource_client/models/v2credits_point_of_sale_information.rb +183 -0
  182. data/lib/cyberSource_client/models/v2credits_point_of_sale_information_emv.rb +221 -0
  183. data/lib/cyberSource_client/models/v2credits_processing_information.rb +383 -0
  184. data/lib/cyberSource_client/models/v2payments_aggregator_information.rb +233 -0
  185. data/lib/cyberSource_client/models/v2payments_aggregator_information_sub_merchant.rb +424 -0
  186. data/lib/cyberSource_client/models/v2payments_buyer_information.rb +285 -0
  187. data/lib/cyberSource_client/models/v2payments_buyer_information_personal_identification.rb +252 -0
  188. data/lib/cyberSource_client/models/v2payments_client_reference_information.rb +219 -0
  189. data/lib/cyberSource_client/models/v2payments_consumer_authentication_information.rb +374 -0
  190. data/lib/cyberSource_client/models/v2payments_device_information.rb +249 -0
  191. data/lib/cyberSource_client/models/v2payments_merchant_defined_information.rb +224 -0
  192. data/lib/cyberSource_client/models/v2payments_merchant_information.rb +308 -0
  193. data/lib/cyberSource_client/models/v2payments_merchant_information_merchant_descriptor.rb +374 -0
  194. data/lib/cyberSource_client/models/v2payments_order_information.rb +230 -0
  195. data/lib/cyberSource_client/models/v2payments_order_information_amount_details.rb +605 -0
  196. data/lib/cyberSource_client/models/v2payments_order_information_amount_details_amex_additional_amounts.rb +224 -0
  197. data/lib/cyberSource_client/models/v2payments_order_information_amount_details_surcharge.rb +209 -0
  198. data/lib/cyberSource_client/models/v2payments_order_information_amount_details_tax_details.rb +328 -0
  199. data/lib/cyberSource_client/models/v2payments_order_information_bill_to.rb +618 -0
  200. data/lib/cyberSource_client/models/v2payments_order_information_invoice_details.rb +330 -0
  201. data/lib/cyberSource_client/models/v2payments_order_information_invoice_details_transaction_advice_addendum.rb +199 -0
  202. data/lib/cyberSource_client/models/v2payments_order_information_line_items.rb +649 -0
  203. data/lib/cyberSource_client/models/v2payments_order_information_ship_to.rb +474 -0
  204. data/lib/cyberSource_client/models/v2payments_order_information_shipping_details.rb +234 -0
  205. data/lib/cyberSource_client/models/v2payments_payment_information.rb +210 -0
  206. data/lib/cyberSource_client/models/v2payments_payment_information_card.rb +474 -0
  207. data/lib/cyberSource_client/models/v2payments_payment_information_customer.rb +202 -0
  208. data/lib/cyberSource_client/models/v2payments_payment_information_fluid_data.rb +259 -0
  209. data/lib/cyberSource_client/models/v2payments_payment_information_tokenized_card.rb +424 -0
  210. data/lib/cyberSource_client/models/v2payments_point_of_sale_information.rb +440 -0
  211. data/lib/cyberSource_client/models/v2payments_point_of_sale_information_emv.rb +256 -0
  212. data/lib/cyberSource_client/models/v2payments_processing_information.rb +432 -0
  213. data/lib/cyberSource_client/models/v2payments_processing_information_authorization_options.rb +361 -0
  214. data/lib/cyberSource_client/models/v2payments_processing_information_authorization_options_initiator.rb +247 -0
  215. data/lib/cyberSource_client/models/v2payments_processing_information_authorization_options_merchant_initiated_transaction.rb +224 -0
  216. data/lib/cyberSource_client/models/v2payments_processing_information_capture_options.rb +267 -0
  217. data/lib/cyberSource_client/models/v2payments_processing_information_issuer.rb +199 -0
  218. data/lib/cyberSource_client/models/v2payments_processing_information_recurring_options.rb +198 -0
  219. data/lib/cyberSource_client/models/v2payments_recipient_information.rb +249 -0
  220. data/lib/cyberSource_client/models/v2paymentsidcaptures_aggregator_information.rb +233 -0
  221. data/lib/cyberSource_client/models/v2paymentsidcaptures_aggregator_information_sub_merchant.rb +374 -0
  222. data/lib/cyberSource_client/models/v2paymentsidcaptures_buyer_information.rb +224 -0
  223. data/lib/cyberSource_client/models/v2paymentsidcaptures_merchant_information.rb +258 -0
  224. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information.rb +230 -0
  225. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_amount_details.rb +546 -0
  226. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_bill_to.rb +449 -0
  227. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_invoice_details.rb +320 -0
  228. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_ship_to.rb +249 -0
  229. data/lib/cyberSource_client/models/v2paymentsidcaptures_order_information_shipping_details.rb +199 -0
  230. data/lib/cyberSource_client/models/v2paymentsidcaptures_payment_information.rb +183 -0
  231. data/lib/cyberSource_client/models/v2paymentsidcaptures_point_of_sale_information.rb +208 -0
  232. data/lib/cyberSource_client/models/v2paymentsidcaptures_point_of_sale_information_emv.rb +211 -0
  233. data/lib/cyberSource_client/models/v2paymentsidcaptures_processing_information.rb +351 -0
  234. data/lib/cyberSource_client/models/v2paymentsidcaptures_processing_information_authorization_options.rb +249 -0
  235. data/lib/cyberSource_client/models/v2paymentsidcaptures_processing_information_capture_options.rb +242 -0
  236. data/lib/cyberSource_client/models/v2paymentsidrefunds_merchant_information.rb +258 -0
  237. data/lib/cyberSource_client/models/v2paymentsidrefunds_order_information.rb +230 -0
  238. data/lib/cyberSource_client/models/v2paymentsidrefunds_order_information_line_items.rb +639 -0
  239. data/lib/cyberSource_client/models/v2paymentsidrefunds_payment_information.rb +183 -0
  240. data/lib/cyberSource_client/models/v2paymentsidrefunds_payment_information_card.rb +374 -0
  241. data/lib/cyberSource_client/models/v2paymentsidrefunds_point_of_sale_information.rb +183 -0
  242. data/lib/cyberSource_client/models/v2paymentsidrefunds_processing_information.rb +333 -0
  243. data/lib/cyberSource_client/models/v2paymentsidrefunds_processing_information_recurring_options.rb +186 -0
  244. data/lib/cyberSource_client/models/v2paymentsidreversals_client_reference_information.rb +209 -0
  245. data/lib/cyberSource_client/models/v2paymentsidreversals_order_information.rb +185 -0
  246. data/lib/cyberSource_client/models/v2paymentsidreversals_order_information_line_items.rb +233 -0
  247. data/lib/cyberSource_client/models/v2paymentsidreversals_point_of_sale_information.rb +183 -0
  248. data/lib/cyberSource_client/models/v2paymentsidreversals_processing_information.rb +308 -0
  249. data/lib/cyberSource_client/models/v2paymentsidreversals_reversal_information.rb +211 -0
  250. data/lib/cyberSource_client/models/v2paymentsidreversals_reversal_information_amount_details.rb +224 -0
  251. data/lib/cyberSource_client/models/v2payouts_merchant_information.rb +258 -0
  252. data/lib/cyberSource_client/models/v2payouts_merchant_information_merchant_descriptor.rb +324 -0
  253. data/lib/cyberSource_client/models/v2payouts_order_information.rb +192 -0
  254. data/lib/cyberSource_client/models/v2payouts_order_information_amount_details.rb +249 -0
  255. data/lib/cyberSource_client/models/v2payouts_order_information_bill_to.rb +443 -0
  256. data/lib/cyberSource_client/models/v2payouts_payment_information.rb +183 -0
  257. data/lib/cyberSource_client/models/v2payouts_payment_information_card.rb +299 -0
  258. data/lib/cyberSource_client/models/v2payouts_processing_information.rb +283 -0
  259. data/lib/cyberSource_client/models/v2payouts_processing_information_payouts_options.rb +274 -0
  260. data/lib/cyberSource_client/models/v2payouts_recipient_information.rb +433 -0
  261. data/lib/cyberSource_client/models/v2payouts_sender_information.rb +517 -0
  262. data/lib/cyberSource_client/models/v2payouts_sender_information_account.rb +233 -0
  263. data/lib/cyberSource_client/models/void_capture_request.rb +183 -0
  264. data/lib/cyberSource_client/models/void_credit_request.rb +183 -0
  265. data/lib/cyberSource_client/models/void_payment_request.rb +183 -0
  266. data/lib/cyberSource_client/models/void_refund_request.rb +183 -0
  267. data/lib/cyberSource_client/version.rb +15 -0
  268. metadata +572 -0
@@ -0,0 +1,234 @@
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 V2paymentsOrderInformationShippingDetails
17
+ # TBD
18
+ attr_accessor :gift_wrap
19
+
20
+ # Shipping method for the product. Possible values: - lowcost: Lowest-cost service - sameday: Courier or same-day service - oneday: Next-day or overnight service - twoday: Two-day service - threeday: Three-day service - pickup: Store pick-up - other: Other shipping method - none: No shipping method because product is a service or subscription
21
+ attr_accessor :shipping_method
22
+
23
+ # Postal code for the address from which the goods are shipped, which is used to establish nexus. The default is the postal code associated with your CyberSource account. The postal code must consist of 5 to 9 digits. When the billing country is the U.S., the 9-digit postal code must follow this format: `[5 digits][dash][4 digits]` Example 12345-6789 When the billing country is Canada, the 6-digit postal code must follow this format: `[alpha][numeric][alpha][space] [numeric][alpha][numeric]` Example A1B 2C3 This field is frequently used for Level II and Level III transactions.
24
+ attr_accessor :ship_from_postal_code
25
+
26
+ # Attribute mapping from ruby-style variable name to JSON key.
27
+ def self.attribute_map
28
+ {
29
+ :'gift_wrap' => :'giftWrap',
30
+ :'shipping_method' => :'shippingMethod',
31
+ :'ship_from_postal_code' => :'shipFromPostalCode'
32
+ }
33
+ end
34
+
35
+ # Attribute type mapping.
36
+ def self.swagger_types
37
+ {
38
+ :'gift_wrap' => :'BOOLEAN',
39
+ :'shipping_method' => :'String',
40
+ :'ship_from_postal_code' => :'String'
41
+ }
42
+ end
43
+
44
+ # Initializes the object
45
+ # @param [Hash] attributes Model attributes in the form of hash
46
+ def initialize(attributes = {})
47
+ return unless attributes.is_a?(Hash)
48
+
49
+ # convert string to symbol for hash key
50
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
51
+
52
+ if attributes.has_key?(:'giftWrap')
53
+ self.gift_wrap = attributes[:'giftWrap']
54
+ end
55
+
56
+ if attributes.has_key?(:'shippingMethod')
57
+ self.shipping_method = attributes[:'shippingMethod']
58
+ end
59
+
60
+ if attributes.has_key?(:'shipFromPostalCode')
61
+ self.ship_from_postal_code = attributes[:'shipFromPostalCode']
62
+ end
63
+ end
64
+
65
+ # Show invalid properties with the reasons. Usually used together with valid?
66
+ # @return Array for valid properties with the reasons
67
+ def list_invalid_properties
68
+ invalid_properties = Array.new
69
+ if !@shipping_method.nil? && @shipping_method.to_s.length > 10
70
+ invalid_properties.push('invalid value for "shipping_method", the character length must be smaller than or equal to 10.')
71
+ end
72
+
73
+ if !@ship_from_postal_code.nil? && @ship_from_postal_code.to_s.length > 10
74
+ invalid_properties.push('invalid value for "ship_from_postal_code", the character length must be smaller than or equal to 10.')
75
+ end
76
+
77
+ invalid_properties
78
+ end
79
+
80
+ # Check to see if the all the properties in the model are valid
81
+ # @return true if the model is valid
82
+ def valid?
83
+ return false if !@shipping_method.nil? && @shipping_method.to_s.length > 10
84
+ return false if !@ship_from_postal_code.nil? && @ship_from_postal_code.to_s.length > 10
85
+ true
86
+ end
87
+
88
+ # Custom attribute writer method with validation
89
+ # @param [Object] shipping_method Value to be assigned
90
+ def shipping_method=(shipping_method)
91
+ if !shipping_method.nil? && shipping_method.to_s.length > 10
92
+ fail ArgumentError, 'invalid value for "shipping_method", the character length must be smaller than or equal to 10.'
93
+ end
94
+
95
+ @shipping_method = shipping_method
96
+ end
97
+
98
+ # Custom attribute writer method with validation
99
+ # @param [Object] ship_from_postal_code Value to be assigned
100
+ def ship_from_postal_code=(ship_from_postal_code)
101
+ if !ship_from_postal_code.nil? && ship_from_postal_code.to_s.length > 10
102
+ fail ArgumentError, 'invalid value for "ship_from_postal_code", the character length must be smaller than or equal to 10.'
103
+ end
104
+
105
+ @ship_from_postal_code = ship_from_postal_code
106
+ end
107
+
108
+ # Checks equality by comparing each attribute.
109
+ # @param [Object] Object to be compared
110
+ def ==(o)
111
+ return true if self.equal?(o)
112
+ self.class == o.class &&
113
+ gift_wrap == o.gift_wrap &&
114
+ shipping_method == o.shipping_method &&
115
+ ship_from_postal_code == o.ship_from_postal_code
116
+ end
117
+
118
+ # @see the `==` method
119
+ # @param [Object] Object to be compared
120
+ def eql?(o)
121
+ self == o
122
+ end
123
+
124
+ # Calculates hash code according to all attributes.
125
+ # @return [Fixnum] Hash code
126
+ def hash
127
+ [gift_wrap, shipping_method, ship_from_postal_code].hash
128
+ end
129
+
130
+ # Builds the object from hash
131
+ # @param [Hash] attributes Model attributes in the form of hash
132
+ # @return [Object] Returns the model itself
133
+ def build_from_hash(attributes)
134
+ return nil unless attributes.is_a?(Hash)
135
+ self.class.swagger_types.each_pair do |key, type|
136
+ if type =~ /\AArray<(.*)>/i
137
+ # check to ensure the input is an array given that the the attribute
138
+ # is documented as an array but the input is not
139
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
140
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
141
+ end
142
+ elsif !attributes[self.class.attribute_map[key]].nil?
143
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
144
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
145
+ end
146
+
147
+ self
148
+ end
149
+
150
+ # Deserializes the data based on type
151
+ # @param string type Data type
152
+ # @param string value Value to be deserialized
153
+ # @return [Object] Deserialized data
154
+ def _deserialize(type, value)
155
+ case type.to_sym
156
+ when :DateTime
157
+ DateTime.parse(value)
158
+ when :Date
159
+ Date.parse(value)
160
+ when :String
161
+ value.to_s
162
+ when :Integer
163
+ value.to_i
164
+ when :Float
165
+ value.to_f
166
+ when :BOOLEAN
167
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
168
+ true
169
+ else
170
+ false
171
+ end
172
+ when :Object
173
+ # generic object (usually a Hash), return directly
174
+ value
175
+ when /\AArray<(?<inner_type>.+)>\z/
176
+ inner_type = Regexp.last_match[:inner_type]
177
+ value.map { |v| _deserialize(inner_type, v) }
178
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
179
+ k_type = Regexp.last_match[:k_type]
180
+ v_type = Regexp.last_match[:v_type]
181
+ {}.tap do |hash|
182
+ value.each do |k, v|
183
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
184
+ end
185
+ end
186
+ else # model
187
+ temp_model = CyberSource.const_get(type).new
188
+ temp_model.build_from_hash(value)
189
+ end
190
+ end
191
+
192
+ # Returns the string representation of the object
193
+ # @return [String] String presentation of the object
194
+ def to_s
195
+ to_hash.to_s
196
+ end
197
+
198
+ # to_body is an alias to to_hash (backward compatibility)
199
+ # @return [Hash] Returns the object in the form of hash
200
+ def to_body
201
+ to_hash
202
+ end
203
+
204
+ # Returns the object in the form of hash
205
+ # @return [Hash] Returns the object in the form of hash
206
+ def to_hash
207
+ hash = {}
208
+ self.class.attribute_map.each_pair do |attr, param|
209
+ value = self.send(attr)
210
+ next if value.nil?
211
+ hash[param] = _to_hash(value)
212
+ end
213
+ hash
214
+ end
215
+
216
+ # Outputs non-array value in the form of hash
217
+ # For object, use to_hash. Otherwise, just return the value
218
+ # @param [Object] value Any valid value
219
+ # @return [Hash] Returns the value in the form of hash
220
+ def _to_hash(value)
221
+ if value.is_a?(Array)
222
+ value.compact.map { |v| _to_hash(v) }
223
+ elsif value.is_a?(Hash)
224
+ {}.tap do |hash|
225
+ value.each { |k, v| hash[k] = _to_hash(v) }
226
+ end
227
+ elsif value.respond_to? :to_hash
228
+ value.to_hash
229
+ else
230
+ value
231
+ end
232
+ end
233
+ end
234
+ end
@@ -0,0 +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
@@ -0,0 +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