digital_femsa 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (359) hide show
  1. checksums.yaml +7 -0
  2. data/CODE_OF_CONDUCT.md +77 -0
  3. data/CONTRIBUTING.md +19 -0
  4. data/Gemfile +9 -0
  5. data/LICENSE +22 -0
  6. data/Makefile +11 -0
  7. data/README.md +320 -0
  8. data/Rakefile +10 -0
  9. data/VERSION +1 -0
  10. data/config-ruby.json +30 -0
  11. data/digital_femsa.gemspec +41 -0
  12. data/docs/ApiKeyCreateResponse.md +40 -0
  13. data/docs/ApiKeyRequest.md +20 -0
  14. data/docs/ApiKeyResponse.md +38 -0
  15. data/docs/ApiKeyResponseOnDelete.md +34 -0
  16. data/docs/ApiKeyUpdateRequest.md +20 -0
  17. data/docs/ApiKeysApi.md +391 -0
  18. data/docs/BalanceCommonField.md +20 -0
  19. data/docs/BalanceResponse.md +36 -0
  20. data/docs/BalancesApi.md +79 -0
  21. data/docs/ChargeOrderResponse.md +52 -0
  22. data/docs/ChargeOrderResponsePaymentMethod.md +76 -0
  23. data/docs/ChargeRequest.md +22 -0
  24. data/docs/ChargeRequestPaymentMethod.md +22 -0
  25. data/docs/ChargeResponse.md +52 -0
  26. data/docs/ChargeResponseChannel.md +24 -0
  27. data/docs/ChargeResponsePaymentMethod.md +76 -0
  28. data/docs/ChargeResponseRefunds.md +26 -0
  29. data/docs/ChargeResponseRefundsData.md +30 -0
  30. data/docs/ChargeUpdateRequest.md +18 -0
  31. data/docs/ChargesApi.md +241 -0
  32. data/docs/ChargesDataResponse.md +52 -0
  33. data/docs/Checkout.md +34 -0
  34. data/docs/CheckoutOrderTemplate.md +24 -0
  35. data/docs/CheckoutOrderTemplateCustomerInfo.md +49 -0
  36. data/docs/CheckoutRequest.md +30 -0
  37. data/docs/CheckoutResponse.md +58 -0
  38. data/docs/CheckoutsResponse.md +26 -0
  39. data/docs/CompaniesApi.md +159 -0
  40. data/docs/CompanyFiscalInfoAddressResponse.md +34 -0
  41. data/docs/CompanyFiscalInfoResponse.md +30 -0
  42. data/docs/CompanyPayoutDestinationResponse.md +28 -0
  43. data/docs/CompanyResponse.md +32 -0
  44. data/docs/CreateCustomerFiscalEntitiesResponse.md +38 -0
  45. data/docs/CreateCustomerPaymentMethodsRequest.md +47 -0
  46. data/docs/CreateCustomerPaymentMethodsResponse.md +77 -0
  47. data/docs/Customer.md +40 -0
  48. data/docs/CustomerAddress.md +32 -0
  49. data/docs/CustomerAntifraudInfo.md +20 -0
  50. data/docs/CustomerAntifraudInfoResponse.md +20 -0
  51. data/docs/CustomerFiscalEntitiesDataResponse.md +38 -0
  52. data/docs/CustomerFiscalEntitiesRequest.md +28 -0
  53. data/docs/CustomerFiscalEntitiesResponse.md +22 -0
  54. data/docs/CustomerInfo.md +26 -0
  55. data/docs/CustomerInfoJustCustomerId.md +18 -0
  56. data/docs/CustomerInfoJustCustomerIdResponse.md +18 -0
  57. data/docs/CustomerPaymentMethodRequest.md +18 -0
  58. data/docs/CustomerPaymentMethodsData.md +77 -0
  59. data/docs/CustomerPaymentMethodsRequest.md +47 -0
  60. data/docs/CustomerPaymentMethodsResponse.md +26 -0
  61. data/docs/CustomerResponse.md +50 -0
  62. data/docs/CustomerResponseShippingContacts.md +22 -0
  63. data/docs/CustomerShippingContacts.md +32 -0
  64. data/docs/CustomerShippingContactsAddress.md +30 -0
  65. data/docs/CustomerShippingContactsDataResponse.md +38 -0
  66. data/docs/CustomerShippingContactsResponse.md +38 -0
  67. data/docs/CustomerShippingContactsResponseAddress.md +32 -0
  68. data/docs/CustomerUpdateFiscalEntitiesRequest.md +28 -0
  69. data/docs/CustomerUpdateShippingContacts.md +30 -0
  70. data/docs/CustomersApi.md +553 -0
  71. data/docs/CustomersResponse.md +26 -0
  72. data/docs/DeleteApiKeysResponse.md +34 -0
  73. data/docs/Details.md +18 -0
  74. data/docs/DetailsError.md +24 -0
  75. data/docs/DiscountLinesDataResponse.md +28 -0
  76. data/docs/DiscountLinesResponse.md +28 -0
  77. data/docs/DiscountsApi.md +405 -0
  78. data/docs/EmailCheckoutRequest.md +18 -0
  79. data/docs/Error.md +24 -0
  80. data/docs/EventResponse.md +32 -0
  81. data/docs/EventsApi.md +239 -0
  82. data/docs/EventsResendResponse.md +28 -0
  83. data/docs/FiscalEntityAddress.md +30 -0
  84. data/docs/GetApiKeysResponse.md +26 -0
  85. data/docs/GetChargesResponse.md +26 -0
  86. data/docs/GetCompaniesResponse.md +26 -0
  87. data/docs/GetCustomerPaymentMethodDataResponse.md +77 -0
  88. data/docs/GetEventsResponse.md +26 -0
  89. data/docs/GetOrderDiscountLinesResponse.md +26 -0
  90. data/docs/GetOrdersResponse.md +26 -0
  91. data/docs/GetPaymentMethodResponse.md +26 -0
  92. data/docs/GetTransactionsResponse.md +26 -0
  93. data/docs/GetTransfersResponse.md +26 -0
  94. data/docs/GetWebhookKeysResponse.md +26 -0
  95. data/docs/GetWebhooksResponse.md +26 -0
  96. data/docs/LogResponse.md +56 -0
  97. data/docs/LogsApi.md +165 -0
  98. data/docs/LogsResponse.md +26 -0
  99. data/docs/LogsResponseData.md +56 -0
  100. data/docs/OrderCaptureRequest.md +18 -0
  101. data/docs/OrderCustomerInfoResponse.md +28 -0
  102. data/docs/OrderDiscountLinesRequest.md +22 -0
  103. data/docs/OrderFiscalEntityAddressResponse.md +32 -0
  104. data/docs/OrderFiscalEntityRequest.md +28 -0
  105. data/docs/OrderFiscalEntityResponse.md +34 -0
  106. data/docs/OrderNextActionResponse.md +20 -0
  107. data/docs/OrderNextActionResponseRedirectToUrl.md +20 -0
  108. data/docs/OrderRefundRequest.md +22 -0
  109. data/docs/OrderRequest.md +44 -0
  110. data/docs/OrderRequestCustomerInfo.md +49 -0
  111. data/docs/OrderResponse.md +58 -0
  112. data/docs/OrderResponseCharges.md +22 -0
  113. data/docs/OrderResponseCheckout.md +58 -0
  114. data/docs/OrderResponseCustomerInfo.md +30 -0
  115. data/docs/OrderResponseDiscountLines.md +22 -0
  116. data/docs/OrderResponseProducts.md +26 -0
  117. data/docs/OrderResponseShippingContact.md +38 -0
  118. data/docs/OrderTaxRequest.md +22 -0
  119. data/docs/OrderUpdateFiscalEntityRequest.md +28 -0
  120. data/docs/OrderUpdateRequest.md +40 -0
  121. data/docs/OrderUpdateRequestCustomerInfo.md +49 -0
  122. data/docs/OrdersApi.md +627 -0
  123. data/docs/OrdersResponse.md +18 -0
  124. data/docs/Page.md +20 -0
  125. data/docs/Pagination.md +20 -0
  126. data/docs/PaymentLinkApi.md +463 -0
  127. data/docs/PaymentMethod.md +20 -0
  128. data/docs/PaymentMethodCash.md +36 -0
  129. data/docs/PaymentMethodCashRequest.md +20 -0
  130. data/docs/PaymentMethodCashResponse.md +36 -0
  131. data/docs/PaymentMethodResponse.md +26 -0
  132. data/docs/PaymentMethodsApi.md +327 -0
  133. data/docs/Product.md +34 -0
  134. data/docs/ProductDataResponse.md +40 -0
  135. data/docs/ProductOrderResponse.md +40 -0
  136. data/docs/ProductsApi.md +243 -0
  137. data/docs/ShippingContactsApi.md +243 -0
  138. data/docs/ShippingOrderResponse.md +32 -0
  139. data/docs/ShippingRequest.md +26 -0
  140. data/docs/ShippingsApi.md +243 -0
  141. data/docs/SmsCheckoutRequest.md +18 -0
  142. data/docs/TaxesApi.md +243 -0
  143. data/docs/TransactionResponse.md +38 -0
  144. data/docs/TransactionsApi.md +171 -0
  145. data/docs/TransferDestinationResponse.md +32 -0
  146. data/docs/TransferMethodResponse.md +32 -0
  147. data/docs/TransferResponse.md +36 -0
  148. data/docs/TransfersApi.md +165 -0
  149. data/docs/TransfersResponse.md +36 -0
  150. data/docs/UpdateCustomer.md +40 -0
  151. data/docs/UpdateCustomerAntifraudInfo.md +20 -0
  152. data/docs/UpdateCustomerFiscalEntitiesResponse.md +38 -0
  153. data/docs/UpdateCustomerPaymentMethodsResponse.md +77 -0
  154. data/docs/UpdateOrderDiscountLinesRequest.md +22 -0
  155. data/docs/UpdateOrderTaxRequest.md +22 -0
  156. data/docs/UpdateOrderTaxResponse.md +28 -0
  157. data/docs/UpdatePaymentMethods.md +18 -0
  158. data/docs/UpdateProduct.md +34 -0
  159. data/docs/WebhookKeyCreateResponse.md +28 -0
  160. data/docs/WebhookKeyDeleteResponse.md +28 -0
  161. data/docs/WebhookKeyRequest.md +18 -0
  162. data/docs/WebhookKeyResponse.md +30 -0
  163. data/docs/WebhookKeyUpdateRequest.md +18 -0
  164. data/docs/WebhookKeysApi.md +385 -0
  165. data/docs/WebhookLog.md +30 -0
  166. data/docs/WebhookRequest.md +20 -0
  167. data/docs/WebhookResponse.md +36 -0
  168. data/docs/WebhookUpdateRequest.md +22 -0
  169. data/docs/WebhooksApi.md +461 -0
  170. data/gitleaks.toml +0 -0
  171. data/lib/digital_femsa/api/api_keys_api.rb +407 -0
  172. data/lib/digital_femsa/api/balances_api.rb +86 -0
  173. data/lib/digital_femsa/api/charges_api.rb +273 -0
  174. data/lib/digital_femsa/api/companies_api.rb +174 -0
  175. data/lib/digital_femsa/api/customers_api.rb +591 -0
  176. data/lib/digital_femsa/api/discounts_api.rb +447 -0
  177. data/lib/digital_femsa/api/events_api.rb +256 -0
  178. data/lib/digital_femsa/api/logs_api.rb +182 -0
  179. data/lib/digital_femsa/api/orders_api.rb +657 -0
  180. data/lib/digital_femsa/api/payment_link_api.rb +491 -0
  181. data/lib/digital_femsa/api/payment_methods_api.rb +368 -0
  182. data/lib/digital_femsa/api/products_api.rb +275 -0
  183. data/lib/digital_femsa/api/shipping_contacts_api.rb +275 -0
  184. data/lib/digital_femsa/api/shippings_api.rb +275 -0
  185. data/lib/digital_femsa/api/taxes_api.rb +275 -0
  186. data/lib/digital_femsa/api/transactions_api.rb +191 -0
  187. data/lib/digital_femsa/api/transfers_api.rb +182 -0
  188. data/lib/digital_femsa/api/webhook_keys_api.rb +396 -0
  189. data/lib/digital_femsa/api/webhooks_api.rb +477 -0
  190. data/lib/digital_femsa/api_client.rb +442 -0
  191. data/lib/digital_femsa/api_error.rb +58 -0
  192. data/lib/digital_femsa/configuration.rb +382 -0
  193. data/lib/digital_femsa/models/api_key_create_response.rb +333 -0
  194. data/lib/digital_femsa/models/api_key_request.rb +231 -0
  195. data/lib/digital_femsa/models/api_key_response.rb +317 -0
  196. data/lib/digital_femsa/models/api_key_response_on_delete.rb +296 -0
  197. data/lib/digital_femsa/models/api_key_update_request.rb +225 -0
  198. data/lib/digital_femsa/models/balance_common_field.rb +226 -0
  199. data/lib/digital_femsa/models/balance_response.rb +324 -0
  200. data/lib/digital_femsa/models/charge_order_response.rb +373 -0
  201. data/lib/digital_femsa/models/charge_order_response_payment_method.rb +53 -0
  202. data/lib/digital_femsa/models/charge_request.rb +241 -0
  203. data/lib/digital_femsa/models/charge_request_payment_method.rb +241 -0
  204. data/lib/digital_femsa/models/charge_response.rb +371 -0
  205. data/lib/digital_femsa/models/charge_response_channel.rb +241 -0
  206. data/lib/digital_femsa/models/charge_response_payment_method.rb +53 -0
  207. data/lib/digital_femsa/models/charge_response_refunds.rb +281 -0
  208. data/lib/digital_femsa/models/charge_response_refunds_data.rb +298 -0
  209. data/lib/digital_femsa/models/charge_update_request.rb +216 -0
  210. data/lib/digital_femsa/models/charges_data_response.rb +378 -0
  211. data/lib/digital_femsa/models/checkout.rb +340 -0
  212. data/lib/digital_femsa/models/checkout_order_template.rb +301 -0
  213. data/lib/digital_femsa/models/checkout_order_template_customer_info.rb +106 -0
  214. data/lib/digital_femsa/models/checkout_request.rb +284 -0
  215. data/lib/digital_femsa/models/checkout_response.rb +429 -0
  216. data/lib/digital_femsa/models/checkouts_response.rb +280 -0
  217. data/lib/digital_femsa/models/company_fiscal_info_address_response.rb +330 -0
  218. data/lib/digital_femsa/models/company_fiscal_info_response.rb +309 -0
  219. data/lib/digital_femsa/models/company_payout_destination_response.rb +312 -0
  220. data/lib/digital_femsa/models/company_response.rb +318 -0
  221. data/lib/digital_femsa/models/create_customer_fiscal_entities_response.rb +341 -0
  222. data/lib/digital_femsa/models/create_customer_payment_methods_request.rb +105 -0
  223. data/lib/digital_femsa/models/create_customer_payment_methods_response.rb +54 -0
  224. data/lib/digital_femsa/models/customer.rb +374 -0
  225. data/lib/digital_femsa/models/customer_address.rb +301 -0
  226. data/lib/digital_femsa/models/customer_antifraud_info.rb +223 -0
  227. data/lib/digital_femsa/models/customer_antifraud_info_response.rb +223 -0
  228. data/lib/digital_femsa/models/customer_fiscal_entities_data_response.rb +341 -0
  229. data/lib/digital_femsa/models/customer_fiscal_entities_request.rb +268 -0
  230. data/lib/digital_femsa/models/customer_fiscal_entities_response.rb +257 -0
  231. data/lib/digital_femsa/models/customer_info.rb +271 -0
  232. data/lib/digital_femsa/models/customer_info_just_customer_id.rb +221 -0
  233. data/lib/digital_femsa/models/customer_info_just_customer_id_response.rb +214 -0
  234. data/lib/digital_femsa/models/customer_payment_method_request.rb +223 -0
  235. data/lib/digital_femsa/models/customer_payment_methods_data.rb +54 -0
  236. data/lib/digital_femsa/models/customer_payment_methods_request.rb +104 -0
  237. data/lib/digital_femsa/models/customer_payment_methods_response.rb +280 -0
  238. data/lib/digital_femsa/models/customer_response.rb +425 -0
  239. data/lib/digital_femsa/models/customer_response_shipping_contacts.rb +257 -0
  240. data/lib/digital_femsa/models/customer_shipping_contacts.rb +312 -0
  241. data/lib/digital_femsa/models/customer_shipping_contacts_address.rb +271 -0
  242. data/lib/digital_femsa/models/customer_shipping_contacts_data_response.rb +366 -0
  243. data/lib/digital_femsa/models/customer_shipping_contacts_response.rb +328 -0
  244. data/lib/digital_femsa/models/customer_shipping_contacts_response_address.rb +278 -0
  245. data/lib/digital_femsa/models/customer_update_fiscal_entities_request.rb +261 -0
  246. data/lib/digital_femsa/models/customer_update_shipping_contacts.rb +274 -0
  247. data/lib/digital_femsa/models/customers_response.rb +280 -0
  248. data/lib/digital_femsa/models/delete_api_keys_response.rb +301 -0
  249. data/lib/digital_femsa/models/details.rb +216 -0
  250. data/lib/digital_femsa/models/details_error.rb +242 -0
  251. data/lib/digital_femsa/models/discount_lines_data_response.rb +333 -0
  252. data/lib/digital_femsa/models/discount_lines_response.rb +333 -0
  253. data/lib/digital_femsa/models/email_checkout_request.rb +221 -0
  254. data/lib/digital_femsa/models/error.rb +253 -0
  255. data/lib/digital_femsa/models/event_response.rb +301 -0
  256. data/lib/digital_femsa/models/events_resend_response.rb +281 -0
  257. data/lib/digital_femsa/models/fiscal_entity_address.rb +312 -0
  258. data/lib/digital_femsa/models/get_api_keys_response.rb +280 -0
  259. data/lib/digital_femsa/models/get_charges_response.rb +280 -0
  260. data/lib/digital_femsa/models/get_companies_response.rb +280 -0
  261. data/lib/digital_femsa/models/get_customer_payment_method_data_response.rb +54 -0
  262. data/lib/digital_femsa/models/get_events_response.rb +280 -0
  263. data/lib/digital_femsa/models/get_order_discount_lines_response.rb +280 -0
  264. data/lib/digital_femsa/models/get_orders_response.rb +288 -0
  265. data/lib/digital_femsa/models/get_payment_method_response.rb +280 -0
  266. data/lib/digital_femsa/models/get_transactions_response.rb +281 -0
  267. data/lib/digital_femsa/models/get_transfers_response.rb +281 -0
  268. data/lib/digital_femsa/models/get_webhook_keys_response.rb +280 -0
  269. data/lib/digital_femsa/models/get_webhooks_response.rb +280 -0
  270. data/lib/digital_femsa/models/log_response.rb +418 -0
  271. data/lib/digital_femsa/models/logs_response.rb +261 -0
  272. data/lib/digital_femsa/models/logs_response_data.rb +396 -0
  273. data/lib/digital_femsa/models/order_capture_request.rb +241 -0
  274. data/lib/digital_femsa/models/order_customer_info_response.rb +263 -0
  275. data/lib/digital_femsa/models/order_discount_lines_request.rb +276 -0
  276. data/lib/digital_femsa/models/order_fiscal_entity_address_response.rb +328 -0
  277. data/lib/digital_femsa/models/order_fiscal_entity_request.rb +295 -0
  278. data/lib/digital_femsa/models/order_fiscal_entity_response.rb +347 -0
  279. data/lib/digital_femsa/models/order_next_action_response.rb +225 -0
  280. data/lib/digital_femsa/models/order_next_action_response_redirect_to_url.rb +226 -0
  281. data/lib/digital_femsa/models/order_refund_request.rb +247 -0
  282. data/lib/digital_femsa/models/order_request.rb +413 -0
  283. data/lib/digital_femsa/models/order_request_customer_info.rb +106 -0
  284. data/lib/digital_femsa/models/order_response.rb +427 -0
  285. data/lib/digital_femsa/models/order_response_charges.rb +258 -0
  286. data/lib/digital_femsa/models/order_response_checkout.rb +418 -0
  287. data/lib/digital_femsa/models/order_response_customer_info.rb +280 -0
  288. data/lib/digital_femsa/models/order_response_discount_lines.rb +257 -0
  289. data/lib/digital_femsa/models/order_response_products.rb +280 -0
  290. data/lib/digital_femsa/models/order_response_shipping_contact.rb +334 -0
  291. data/lib/digital_femsa/models/order_tax_request.rb +308 -0
  292. data/lib/digital_femsa/models/order_update_fiscal_entity_request.rb +295 -0
  293. data/lib/digital_femsa/models/order_update_request.rb +352 -0
  294. data/lib/digital_femsa/models/order_update_request_customer_info.rb +105 -0
  295. data/lib/digital_femsa/models/orders_response.rb +223 -0
  296. data/lib/digital_femsa/models/page.rb +228 -0
  297. data/lib/digital_femsa/models/pagination.rb +240 -0
  298. data/lib/digital_femsa/models/payment_method.rb +230 -0
  299. data/lib/digital_femsa/models/payment_method_cash.rb +312 -0
  300. data/lib/digital_femsa/models/payment_method_cash_request.rb +238 -0
  301. data/lib/digital_femsa/models/payment_method_cash_response.rb +330 -0
  302. data/lib/digital_femsa/models/payment_method_response.rb +278 -0
  303. data/lib/digital_femsa/models/product.rb +397 -0
  304. data/lib/digital_femsa/models/product_data_response.rb +431 -0
  305. data/lib/digital_femsa/models/product_order_response.rb +431 -0
  306. data/lib/digital_femsa/models/shipping_order_response.rb +336 -0
  307. data/lib/digital_femsa/models/shipping_request.rb +302 -0
  308. data/lib/digital_femsa/models/sms_checkout_request.rb +221 -0
  309. data/lib/digital_femsa/models/transaction_response.rb +412 -0
  310. data/lib/digital_femsa/models/transfer_destination_response.rb +286 -0
  311. data/lib/digital_femsa/models/transfer_method_response.rb +286 -0
  312. data/lib/digital_femsa/models/transfer_response.rb +324 -0
  313. data/lib/digital_femsa/models/transfers_response.rb +324 -0
  314. data/lib/digital_femsa/models/update_customer.rb +353 -0
  315. data/lib/digital_femsa/models/update_customer_antifraud_info.rb +223 -0
  316. data/lib/digital_femsa/models/update_customer_fiscal_entities_response.rb +341 -0
  317. data/lib/digital_femsa/models/update_customer_payment_methods_response.rb +54 -0
  318. data/lib/digital_femsa/models/update_order_discount_lines_request.rb +253 -0
  319. data/lib/digital_femsa/models/update_order_tax_request.rb +294 -0
  320. data/lib/digital_femsa/models/update_order_tax_response.rb +349 -0
  321. data/lib/digital_femsa/models/update_payment_methods.rb +214 -0
  322. data/lib/digital_femsa/models/update_product.rb +349 -0
  323. data/lib/digital_femsa/models/webhook_key_create_response.rb +266 -0
  324. data/lib/digital_femsa/models/webhook_key_delete_response.rb +266 -0
  325. data/lib/digital_femsa/models/webhook_key_request.rb +217 -0
  326. data/lib/digital_femsa/models/webhook_key_response.rb +277 -0
  327. data/lib/digital_femsa/models/webhook_key_update_request.rb +217 -0
  328. data/lib/digital_femsa/models/webhook_log.rb +289 -0
  329. data/lib/digital_femsa/models/webhook_request.rb +261 -0
  330. data/lib/digital_femsa/models/webhook_response.rb +299 -0
  331. data/lib/digital_femsa/models/webhook_update_request.rb +267 -0
  332. data/lib/digital_femsa/version.rb +15 -0
  333. data/lib/digital_femsa.rb +197 -0
  334. data/lib/ssl_data/ca_bundle.crt +4039 -0
  335. data/spec/api/api_keys_api_spec.rb +107 -0
  336. data/spec/api/balances_api_spec.rb +47 -0
  337. data/spec/api/charges_api_spec.rb +80 -0
  338. data/spec/api/companies_api_spec.rb +63 -0
  339. data/spec/api/customers_api_spec.rb +140 -0
  340. data/spec/api/discounts_api_spec.rb +114 -0
  341. data/spec/api/events_api_spec.rb +79 -0
  342. data/spec/api/logs_api_spec.rb +66 -0
  343. data/spec/api/orders_api_spec.rb +153 -0
  344. data/spec/api/payment_link_api_spec.rb +119 -0
  345. data/spec/api/payment_methods_api_spec.rb +99 -0
  346. data/spec/api/products_api_spec.rb +81 -0
  347. data/spec/api/shipping_contacts_api_spec.rb +81 -0
  348. data/spec/api/shippings_api_spec.rb +81 -0
  349. data/spec/api/taxes_api_spec.rb +81 -0
  350. data/spec/api/transactions_api_spec.rb +69 -0
  351. data/spec/api/transfers_api_spec.rb +66 -0
  352. data/spec/api/webhook_keys_api_spec.rb +104 -0
  353. data/spec/api/webhooks_api_spec.rb +118 -0
  354. data/spec/spec_helper.rb +111 -0
  355. data/ssl_data/ca_bundle.crt +4039 -0
  356. data/templates/ruby/CUSTOM_VERSION.mustache +1 -0
  357. data/templates/ruby/api_client.mustache +257 -0
  358. data/templates/ruby/configuration.mustache +481 -0
  359. metadata +488 -0
@@ -0,0 +1,336 @@
1
+ =begin
2
+ #Femsa API
3
+
4
+ #Femsa sdk
5
+
6
+ The version of the OpenAPI document: 2.1.0
7
+ Contact: engineering@femsa.com
8
+ Generated by: https://openapi-generator.tech
9
+ Generator version: 7.5.0
10
+
11
+ =end
12
+
13
+ require 'date'
14
+ require 'time'
15
+
16
+ module DigitalFemsa
17
+ class ShippingOrderResponse
18
+ # Shipping amount in cents
19
+ attr_accessor :amount
20
+
21
+ # Carrier name for the shipment
22
+ attr_accessor :carrier
23
+
24
+ # Tracking number can be used to track the shipment
25
+ attr_accessor :tracking_number
26
+
27
+ # Method of shipment
28
+ attr_accessor :method
29
+
30
+ # Hash where the user can send additional information for each 'shipping'.
31
+ attr_accessor :metadata
32
+
33
+ attr_accessor :id
34
+
35
+ attr_accessor :object
36
+
37
+ attr_accessor :parent_id
38
+
39
+ # Attribute mapping from ruby-style variable name to JSON key.
40
+ def self.attribute_map
41
+ {
42
+ :'amount' => :'amount',
43
+ :'carrier' => :'carrier',
44
+ :'tracking_number' => :'tracking_number',
45
+ :'method' => :'method',
46
+ :'metadata' => :'metadata',
47
+ :'id' => :'id',
48
+ :'object' => :'object',
49
+ :'parent_id' => :'parent_id'
50
+ }
51
+ end
52
+
53
+ # Returns all the JSON keys this model knows about
54
+ def self.acceptable_attributes
55
+ attribute_map.values
56
+ end
57
+
58
+ # Attribute type mapping.
59
+ def self.openapi_types
60
+ {
61
+ :'amount' => :'Integer',
62
+ :'carrier' => :'String',
63
+ :'tracking_number' => :'String',
64
+ :'method' => :'String',
65
+ :'metadata' => :'Hash<String, Object>',
66
+ :'id' => :'String',
67
+ :'object' => :'String',
68
+ :'parent_id' => :'String'
69
+ }
70
+ end
71
+
72
+ # List of attributes with nullable: true
73
+ def self.openapi_nullable
74
+ Set.new([
75
+ ])
76
+ end
77
+
78
+ # List of class defined in allOf (OpenAPI v3)
79
+ def self.openapi_all_of
80
+ [
81
+ :'ShippingRequest'
82
+ ]
83
+ end
84
+
85
+ # Initializes the object
86
+ # @param [Hash] attributes Model attributes in the form of hash
87
+ def initialize(attributes = {})
88
+ if (!attributes.is_a?(Hash))
89
+ fail ArgumentError, "The input argument (attributes) must be a hash in `DigitalFemsa::ShippingOrderResponse` initialize method"
90
+ end
91
+
92
+ # check to see if the attribute exists and convert string to symbol for hash key
93
+ attributes = attributes.each_with_object({}) { |(k, v), h|
94
+ if (!self.class.attribute_map.key?(k.to_sym))
95
+ fail ArgumentError, "`#{k}` is not a valid attribute in `DigitalFemsa::ShippingOrderResponse`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
96
+ end
97
+ h[k.to_sym] = v
98
+ }
99
+
100
+ if attributes.key?(:'amount')
101
+ self.amount = attributes[:'amount']
102
+ else
103
+ self.amount = nil
104
+ end
105
+
106
+ if attributes.key?(:'carrier')
107
+ self.carrier = attributes[:'carrier']
108
+ end
109
+
110
+ if attributes.key?(:'tracking_number')
111
+ self.tracking_number = attributes[:'tracking_number']
112
+ end
113
+
114
+ if attributes.key?(:'method')
115
+ self.method = attributes[:'method']
116
+ end
117
+
118
+ if attributes.key?(:'metadata')
119
+ if (value = attributes[:'metadata']).is_a?(Hash)
120
+ self.metadata = value
121
+ end
122
+ end
123
+
124
+ if attributes.key?(:'id')
125
+ self.id = attributes[:'id']
126
+ end
127
+
128
+ if attributes.key?(:'object')
129
+ self.object = attributes[:'object']
130
+ end
131
+
132
+ if attributes.key?(:'parent_id')
133
+ self.parent_id = attributes[:'parent_id']
134
+ end
135
+ end
136
+
137
+ # Show invalid properties with the reasons. Usually used together with valid?
138
+ # @return Array for valid properties with the reasons
139
+ def list_invalid_properties
140
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
141
+ invalid_properties = Array.new
142
+ if @amount.nil?
143
+ invalid_properties.push('invalid value for "amount", amount cannot be nil.')
144
+ end
145
+
146
+ if @amount < 0
147
+ invalid_properties.push('invalid value for "amount", must be greater than or equal to 0.')
148
+ end
149
+
150
+ if !@metadata.nil? && @metadata.length > 100
151
+ invalid_properties.push('invalid value for "metadata", number of items must be less than or equal to 100.')
152
+ end
153
+
154
+ invalid_properties
155
+ end
156
+
157
+ # Check to see if the all the properties in the model are valid
158
+ # @return true if the model is valid
159
+ def valid?
160
+ warn '[DEPRECATED] the `valid?` method is obsolete'
161
+ return false if @amount.nil?
162
+ return false if @amount < 0
163
+ return false if !@metadata.nil? && @metadata.length > 100
164
+ true
165
+ end
166
+
167
+ # Custom attribute writer method with validation
168
+ # @param [Object] amount Value to be assigned
169
+ def amount=(amount)
170
+ if amount.nil?
171
+ fail ArgumentError, 'amount cannot be nil'
172
+ end
173
+
174
+ if amount < 0
175
+ fail ArgumentError, 'invalid value for "amount", must be greater than or equal to 0.'
176
+ end
177
+
178
+ @amount = amount
179
+ end
180
+
181
+ # Custom attribute writer method with validation
182
+ # @param [Object] metadata Value to be assigned
183
+ def metadata=(metadata)
184
+ if metadata.nil?
185
+ fail ArgumentError, 'metadata cannot be nil'
186
+ end
187
+
188
+ if metadata.length > 100
189
+ fail ArgumentError, 'invalid value for "metadata", number of items must be less than or equal to 100.'
190
+ end
191
+
192
+ @metadata = metadata
193
+ end
194
+
195
+ # Checks equality by comparing each attribute.
196
+ # @param [Object] Object to be compared
197
+ def ==(o)
198
+ return true if self.equal?(o)
199
+ self.class == o.class &&
200
+ amount == o.amount &&
201
+ carrier == o.carrier &&
202
+ tracking_number == o.tracking_number &&
203
+ method == o.method &&
204
+ metadata == o.metadata &&
205
+ id == o.id &&
206
+ object == o.object &&
207
+ parent_id == o.parent_id
208
+ end
209
+
210
+ # @see the `==` method
211
+ # @param [Object] Object to be compared
212
+ def eql?(o)
213
+ self == o
214
+ end
215
+
216
+ # Calculates hash code according to all attributes.
217
+ # @return [Integer] Hash code
218
+ def hash
219
+ [amount, carrier, tracking_number, method, metadata, id, object, parent_id].hash
220
+ end
221
+
222
+ # Builds the object from hash
223
+ # @param [Hash] attributes Model attributes in the form of hash
224
+ # @return [Object] Returns the model itself
225
+ def self.build_from_hash(attributes)
226
+ return nil unless attributes.is_a?(Hash)
227
+ attributes = attributes.transform_keys(&:to_sym)
228
+ transformed_hash = {}
229
+ openapi_types.each_pair do |key, type|
230
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
231
+ transformed_hash["#{key}"] = nil
232
+ elsif type =~ /\AArray<(.*)>/i
233
+ # check to ensure the input is an array given that the attribute
234
+ # is documented as an array but the input is not
235
+ if attributes[attribute_map[key]].is_a?(Array)
236
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
237
+ end
238
+ elsif !attributes[attribute_map[key]].nil?
239
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
240
+ end
241
+ end
242
+ new(transformed_hash)
243
+ end
244
+
245
+ # Deserializes the data based on type
246
+ # @param string type Data type
247
+ # @param string value Value to be deserialized
248
+ # @return [Object] Deserialized data
249
+ def self._deserialize(type, value)
250
+ case type.to_sym
251
+ when :Time
252
+ Time.parse(value)
253
+ when :Date
254
+ Date.parse(value)
255
+ when :String
256
+ value.to_s
257
+ when :Integer
258
+ value.to_i
259
+ when :Float
260
+ value.to_f
261
+ when :Boolean
262
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
263
+ true
264
+ else
265
+ false
266
+ end
267
+ when :Object
268
+ # generic object (usually a Hash), return directly
269
+ value
270
+ when /\AArray<(?<inner_type>.+)>\z/
271
+ inner_type = Regexp.last_match[:inner_type]
272
+ value.map { |v| _deserialize(inner_type, v) }
273
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
274
+ k_type = Regexp.last_match[:k_type]
275
+ v_type = Regexp.last_match[:v_type]
276
+ {}.tap do |hash|
277
+ value.each do |k, v|
278
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
279
+ end
280
+ end
281
+ else # model
282
+ # models (e.g. Pet) or oneOf
283
+ klass = DigitalFemsa.const_get(type)
284
+ klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
285
+ end
286
+ end
287
+
288
+ # Returns the string representation of the object
289
+ # @return [String] String presentation of the object
290
+ def to_s
291
+ to_hash.to_s
292
+ end
293
+
294
+ # to_body is an alias to to_hash (backward compatibility)
295
+ # @return [Hash] Returns the object in the form of hash
296
+ def to_body
297
+ to_hash
298
+ end
299
+
300
+ # Returns the object in the form of hash
301
+ # @return [Hash] Returns the object in the form of hash
302
+ def to_hash
303
+ hash = {}
304
+ self.class.attribute_map.each_pair do |attr, param|
305
+ value = self.send(attr)
306
+ if value.nil?
307
+ is_nullable = self.class.openapi_nullable.include?(attr)
308
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
309
+ end
310
+
311
+ hash[param] = _to_hash(value)
312
+ end
313
+ hash
314
+ end
315
+
316
+ # Outputs non-array value in the form of hash
317
+ # For object, use to_hash. Otherwise, just return the value
318
+ # @param [Object] value Any valid value
319
+ # @return [Hash] Returns the value in the form of hash
320
+ def _to_hash(value)
321
+ if value.is_a?(Array)
322
+ value.compact.map { |v| _to_hash(v) }
323
+ elsif value.is_a?(Hash)
324
+ {}.tap do |hash|
325
+ value.each { |k, v| hash[k] = _to_hash(v) }
326
+ end
327
+ elsif value.respond_to? :to_hash
328
+ value.to_hash
329
+ else
330
+ value
331
+ end
332
+ end
333
+
334
+ end
335
+
336
+ end
@@ -0,0 +1,302 @@
1
+ =begin
2
+ #Femsa API
3
+
4
+ #Femsa sdk
5
+
6
+ The version of the OpenAPI document: 2.1.0
7
+ Contact: engineering@femsa.com
8
+ Generated by: https://openapi-generator.tech
9
+ Generator version: 7.5.0
10
+
11
+ =end
12
+
13
+ require 'date'
14
+ require 'time'
15
+
16
+ module DigitalFemsa
17
+ class ShippingRequest
18
+ # Shipping amount in cents
19
+ attr_accessor :amount
20
+
21
+ # Carrier name for the shipment
22
+ attr_accessor :carrier
23
+
24
+ # Tracking number can be used to track the shipment
25
+ attr_accessor :tracking_number
26
+
27
+ # Method of shipment
28
+ attr_accessor :method
29
+
30
+ # Hash where the user can send additional information for each 'shipping'.
31
+ attr_accessor :metadata
32
+
33
+ # Attribute mapping from ruby-style variable name to JSON key.
34
+ def self.attribute_map
35
+ {
36
+ :'amount' => :'amount',
37
+ :'carrier' => :'carrier',
38
+ :'tracking_number' => :'tracking_number',
39
+ :'method' => :'method',
40
+ :'metadata' => :'metadata'
41
+ }
42
+ end
43
+
44
+ # Returns all the JSON keys this model knows about
45
+ def self.acceptable_attributes
46
+ attribute_map.values
47
+ end
48
+
49
+ # Attribute type mapping.
50
+ def self.openapi_types
51
+ {
52
+ :'amount' => :'Integer',
53
+ :'carrier' => :'String',
54
+ :'tracking_number' => :'String',
55
+ :'method' => :'String',
56
+ :'metadata' => :'Hash<String, Object>'
57
+ }
58
+ end
59
+
60
+ # List of attributes with nullable: true
61
+ def self.openapi_nullable
62
+ Set.new([
63
+ ])
64
+ end
65
+
66
+ # Initializes the object
67
+ # @param [Hash] attributes Model attributes in the form of hash
68
+ def initialize(attributes = {})
69
+ if (!attributes.is_a?(Hash))
70
+ fail ArgumentError, "The input argument (attributes) must be a hash in `DigitalFemsa::ShippingRequest` initialize method"
71
+ end
72
+
73
+ # check to see if the attribute exists and convert string to symbol for hash key
74
+ attributes = attributes.each_with_object({}) { |(k, v), h|
75
+ if (!self.class.attribute_map.key?(k.to_sym))
76
+ fail ArgumentError, "`#{k}` is not a valid attribute in `DigitalFemsa::ShippingRequest`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
77
+ end
78
+ h[k.to_sym] = v
79
+ }
80
+
81
+ if attributes.key?(:'amount')
82
+ self.amount = attributes[:'amount']
83
+ else
84
+ self.amount = nil
85
+ end
86
+
87
+ if attributes.key?(:'carrier')
88
+ self.carrier = attributes[:'carrier']
89
+ end
90
+
91
+ if attributes.key?(:'tracking_number')
92
+ self.tracking_number = attributes[:'tracking_number']
93
+ end
94
+
95
+ if attributes.key?(:'method')
96
+ self.method = attributes[:'method']
97
+ end
98
+
99
+ if attributes.key?(:'metadata')
100
+ if (value = attributes[:'metadata']).is_a?(Hash)
101
+ self.metadata = value
102
+ end
103
+ end
104
+ end
105
+
106
+ # Show invalid properties with the reasons. Usually used together with valid?
107
+ # @return Array for valid properties with the reasons
108
+ def list_invalid_properties
109
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
110
+ invalid_properties = Array.new
111
+ if @amount.nil?
112
+ invalid_properties.push('invalid value for "amount", amount cannot be nil.')
113
+ end
114
+
115
+ if @amount < 0
116
+ invalid_properties.push('invalid value for "amount", must be greater than or equal to 0.')
117
+ end
118
+
119
+ if !@metadata.nil? && @metadata.length > 100
120
+ invalid_properties.push('invalid value for "metadata", number of items must be less than or equal to 100.')
121
+ end
122
+
123
+ invalid_properties
124
+ end
125
+
126
+ # Check to see if the all the properties in the model are valid
127
+ # @return true if the model is valid
128
+ def valid?
129
+ warn '[DEPRECATED] the `valid?` method is obsolete'
130
+ return false if @amount.nil?
131
+ return false if @amount < 0
132
+ return false if !@metadata.nil? && @metadata.length > 100
133
+ true
134
+ end
135
+
136
+ # Custom attribute writer method with validation
137
+ # @param [Object] amount Value to be assigned
138
+ def amount=(amount)
139
+ if amount.nil?
140
+ fail ArgumentError, 'amount cannot be nil'
141
+ end
142
+
143
+ if amount < 0
144
+ fail ArgumentError, 'invalid value for "amount", must be greater than or equal to 0.'
145
+ end
146
+
147
+ @amount = amount
148
+ end
149
+
150
+ # Custom attribute writer method with validation
151
+ # @param [Object] metadata Value to be assigned
152
+ def metadata=(metadata)
153
+ if metadata.nil?
154
+ fail ArgumentError, 'metadata cannot be nil'
155
+ end
156
+
157
+ if metadata.length > 100
158
+ fail ArgumentError, 'invalid value for "metadata", number of items must be less than or equal to 100.'
159
+ end
160
+
161
+ @metadata = metadata
162
+ end
163
+
164
+ # Checks equality by comparing each attribute.
165
+ # @param [Object] Object to be compared
166
+ def ==(o)
167
+ return true if self.equal?(o)
168
+ self.class == o.class &&
169
+ amount == o.amount &&
170
+ carrier == o.carrier &&
171
+ tracking_number == o.tracking_number &&
172
+ method == o.method &&
173
+ metadata == o.metadata
174
+ end
175
+
176
+ # @see the `==` method
177
+ # @param [Object] Object to be compared
178
+ def eql?(o)
179
+ self == o
180
+ end
181
+
182
+ # Calculates hash code according to all attributes.
183
+ # @return [Integer] Hash code
184
+ def hash
185
+ [amount, carrier, tracking_number, method, metadata].hash
186
+ end
187
+
188
+ # Builds the object from hash
189
+ # @param [Hash] attributes Model attributes in the form of hash
190
+ # @return [Object] Returns the model itself
191
+ def self.build_from_hash(attributes)
192
+ return nil unless attributes.is_a?(Hash)
193
+ attributes = attributes.transform_keys(&:to_sym)
194
+ transformed_hash = {}
195
+ openapi_types.each_pair do |key, type|
196
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
197
+ transformed_hash["#{key}"] = nil
198
+ elsif type =~ /\AArray<(.*)>/i
199
+ # check to ensure the input is an array given that the attribute
200
+ # is documented as an array but the input is not
201
+ if attributes[attribute_map[key]].is_a?(Array)
202
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
203
+ end
204
+ elsif !attributes[attribute_map[key]].nil?
205
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
206
+ end
207
+ end
208
+ new(transformed_hash)
209
+ end
210
+
211
+ # Deserializes the data based on type
212
+ # @param string type Data type
213
+ # @param string value Value to be deserialized
214
+ # @return [Object] Deserialized data
215
+ def self._deserialize(type, value)
216
+ case type.to_sym
217
+ when :Time
218
+ Time.parse(value)
219
+ when :Date
220
+ Date.parse(value)
221
+ when :String
222
+ value.to_s
223
+ when :Integer
224
+ value.to_i
225
+ when :Float
226
+ value.to_f
227
+ when :Boolean
228
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
229
+ true
230
+ else
231
+ false
232
+ end
233
+ when :Object
234
+ # generic object (usually a Hash), return directly
235
+ value
236
+ when /\AArray<(?<inner_type>.+)>\z/
237
+ inner_type = Regexp.last_match[:inner_type]
238
+ value.map { |v| _deserialize(inner_type, v) }
239
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
240
+ k_type = Regexp.last_match[:k_type]
241
+ v_type = Regexp.last_match[:v_type]
242
+ {}.tap do |hash|
243
+ value.each do |k, v|
244
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
245
+ end
246
+ end
247
+ else # model
248
+ # models (e.g. Pet) or oneOf
249
+ klass = DigitalFemsa.const_get(type)
250
+ klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
251
+ end
252
+ end
253
+
254
+ # Returns the string representation of the object
255
+ # @return [String] String presentation of the object
256
+ def to_s
257
+ to_hash.to_s
258
+ end
259
+
260
+ # to_body is an alias to to_hash (backward compatibility)
261
+ # @return [Hash] Returns the object in the form of hash
262
+ def to_body
263
+ to_hash
264
+ end
265
+
266
+ # Returns the object in the form of hash
267
+ # @return [Hash] Returns the object in the form of hash
268
+ def to_hash
269
+ hash = {}
270
+ self.class.attribute_map.each_pair do |attr, param|
271
+ value = self.send(attr)
272
+ if value.nil?
273
+ is_nullable = self.class.openapi_nullable.include?(attr)
274
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
275
+ end
276
+
277
+ hash[param] = _to_hash(value)
278
+ end
279
+ hash
280
+ end
281
+
282
+ # Outputs non-array value in the form of hash
283
+ # For object, use to_hash. Otherwise, just return the value
284
+ # @param [Object] value Any valid value
285
+ # @return [Hash] Returns the value in the form of hash
286
+ def _to_hash(value)
287
+ if value.is_a?(Array)
288
+ value.compact.map { |v| _to_hash(v) }
289
+ elsif value.is_a?(Hash)
290
+ {}.tap do |hash|
291
+ value.each { |k, v| hash[k] = _to_hash(v) }
292
+ end
293
+ elsif value.respond_to? :to_hash
294
+ value.to_hash
295
+ else
296
+ value
297
+ end
298
+ end
299
+
300
+ end
301
+
302
+ end