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,295 @@
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
+ # Fiscal entity of the order, Currently it is a purely informative field
18
+ class OrderUpdateFiscalEntityRequest
19
+ attr_accessor :address
20
+
21
+ # Email of the fiscal entity
22
+ attr_accessor :email
23
+
24
+ # Name of the fiscal entity
25
+ attr_accessor :name
26
+
27
+ # Metadata associated with the fiscal entity
28
+ attr_accessor :metadata
29
+
30
+ # Phone of the fiscal entity
31
+ attr_accessor :phone
32
+
33
+ # Tax ID of the fiscal entity
34
+ attr_accessor :tax_id
35
+
36
+ # Attribute mapping from ruby-style variable name to JSON key.
37
+ def self.attribute_map
38
+ {
39
+ :'address' => :'address',
40
+ :'email' => :'email',
41
+ :'name' => :'name',
42
+ :'metadata' => :'metadata',
43
+ :'phone' => :'phone',
44
+ :'tax_id' => :'tax_id'
45
+ }
46
+ end
47
+
48
+ # Returns all the JSON keys this model knows about
49
+ def self.acceptable_attributes
50
+ attribute_map.values
51
+ end
52
+
53
+ # Attribute type mapping.
54
+ def self.openapi_types
55
+ {
56
+ :'address' => :'FiscalEntityAddress',
57
+ :'email' => :'String',
58
+ :'name' => :'String',
59
+ :'metadata' => :'Hash<String, Object>',
60
+ :'phone' => :'String',
61
+ :'tax_id' => :'String'
62
+ }
63
+ end
64
+
65
+ # List of attributes with nullable: true
66
+ def self.openapi_nullable
67
+ Set.new([
68
+ :'name',
69
+ :'tax_id'
70
+ ])
71
+ end
72
+
73
+ # Initializes the object
74
+ # @param [Hash] attributes Model attributes in the form of hash
75
+ def initialize(attributes = {})
76
+ if (!attributes.is_a?(Hash))
77
+ fail ArgumentError, "The input argument (attributes) must be a hash in `DigitalFemsa::OrderUpdateFiscalEntityRequest` initialize method"
78
+ end
79
+
80
+ # check to see if the attribute exists and convert string to symbol for hash key
81
+ attributes = attributes.each_with_object({}) { |(k, v), h|
82
+ if (!self.class.attribute_map.key?(k.to_sym))
83
+ fail ArgumentError, "`#{k}` is not a valid attribute in `DigitalFemsa::OrderUpdateFiscalEntityRequest`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
84
+ end
85
+ h[k.to_sym] = v
86
+ }
87
+
88
+ if attributes.key?(:'address')
89
+ self.address = attributes[:'address']
90
+ else
91
+ self.address = nil
92
+ end
93
+
94
+ if attributes.key?(:'email')
95
+ self.email = attributes[:'email']
96
+ end
97
+
98
+ if attributes.key?(:'name')
99
+ self.name = attributes[:'name']
100
+ end
101
+
102
+ if attributes.key?(:'metadata')
103
+ if (value = attributes[:'metadata']).is_a?(Hash)
104
+ self.metadata = value
105
+ end
106
+ end
107
+
108
+ if attributes.key?(:'phone')
109
+ self.phone = attributes[:'phone']
110
+ end
111
+
112
+ if attributes.key?(:'tax_id')
113
+ self.tax_id = attributes[:'tax_id']
114
+ end
115
+ end
116
+
117
+ # Show invalid properties with the reasons. Usually used together with valid?
118
+ # @return Array for valid properties with the reasons
119
+ def list_invalid_properties
120
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
121
+ invalid_properties = Array.new
122
+ if @address.nil?
123
+ invalid_properties.push('invalid value for "address", address cannot be nil.')
124
+ end
125
+
126
+ if !@metadata.nil? && @metadata.length > 100
127
+ invalid_properties.push('invalid value for "metadata", number of items must be less than or equal to 100.')
128
+ end
129
+
130
+ invalid_properties
131
+ end
132
+
133
+ # Check to see if the all the properties in the model are valid
134
+ # @return true if the model is valid
135
+ def valid?
136
+ warn '[DEPRECATED] the `valid?` method is obsolete'
137
+ return false if @address.nil?
138
+ return false if !@metadata.nil? && @metadata.length > 100
139
+ true
140
+ end
141
+
142
+ # Custom attribute writer method with validation
143
+ # @param [Object] metadata Value to be assigned
144
+ def metadata=(metadata)
145
+ if metadata.nil?
146
+ fail ArgumentError, 'metadata cannot be nil'
147
+ end
148
+
149
+ if metadata.length > 100
150
+ fail ArgumentError, 'invalid value for "metadata", number of items must be less than or equal to 100.'
151
+ end
152
+
153
+ @metadata = metadata
154
+ end
155
+
156
+ # Checks equality by comparing each attribute.
157
+ # @param [Object] Object to be compared
158
+ def ==(o)
159
+ return true if self.equal?(o)
160
+ self.class == o.class &&
161
+ address == o.address &&
162
+ email == o.email &&
163
+ name == o.name &&
164
+ metadata == o.metadata &&
165
+ phone == o.phone &&
166
+ tax_id == o.tax_id
167
+ end
168
+
169
+ # @see the `==` method
170
+ # @param [Object] Object to be compared
171
+ def eql?(o)
172
+ self == o
173
+ end
174
+
175
+ # Calculates hash code according to all attributes.
176
+ # @return [Integer] Hash code
177
+ def hash
178
+ [address, email, name, metadata, phone, tax_id].hash
179
+ end
180
+
181
+ # Builds the object from hash
182
+ # @param [Hash] attributes Model attributes in the form of hash
183
+ # @return [Object] Returns the model itself
184
+ def self.build_from_hash(attributes)
185
+ return nil unless attributes.is_a?(Hash)
186
+ attributes = attributes.transform_keys(&:to_sym)
187
+ transformed_hash = {}
188
+ openapi_types.each_pair do |key, type|
189
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
190
+ transformed_hash["#{key}"] = nil
191
+ elsif type =~ /\AArray<(.*)>/i
192
+ # check to ensure the input is an array given that the attribute
193
+ # is documented as an array but the input is not
194
+ if attributes[attribute_map[key]].is_a?(Array)
195
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
196
+ end
197
+ elsif !attributes[attribute_map[key]].nil?
198
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
199
+ end
200
+ end
201
+ new(transformed_hash)
202
+ end
203
+
204
+ # Deserializes the data based on type
205
+ # @param string type Data type
206
+ # @param string value Value to be deserialized
207
+ # @return [Object] Deserialized data
208
+ def self._deserialize(type, value)
209
+ case type.to_sym
210
+ when :Time
211
+ Time.parse(value)
212
+ when :Date
213
+ Date.parse(value)
214
+ when :String
215
+ value.to_s
216
+ when :Integer
217
+ value.to_i
218
+ when :Float
219
+ value.to_f
220
+ when :Boolean
221
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
222
+ true
223
+ else
224
+ false
225
+ end
226
+ when :Object
227
+ # generic object (usually a Hash), return directly
228
+ value
229
+ when /\AArray<(?<inner_type>.+)>\z/
230
+ inner_type = Regexp.last_match[:inner_type]
231
+ value.map { |v| _deserialize(inner_type, v) }
232
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
233
+ k_type = Regexp.last_match[:k_type]
234
+ v_type = Regexp.last_match[:v_type]
235
+ {}.tap do |hash|
236
+ value.each do |k, v|
237
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
238
+ end
239
+ end
240
+ else # model
241
+ # models (e.g. Pet) or oneOf
242
+ klass = DigitalFemsa.const_get(type)
243
+ klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
244
+ end
245
+ end
246
+
247
+ # Returns the string representation of the object
248
+ # @return [String] String presentation of the object
249
+ def to_s
250
+ to_hash.to_s
251
+ end
252
+
253
+ # to_body is an alias to to_hash (backward compatibility)
254
+ # @return [Hash] Returns the object in the form of hash
255
+ def to_body
256
+ to_hash
257
+ end
258
+
259
+ # Returns the object in the form of hash
260
+ # @return [Hash] Returns the object in the form of hash
261
+ def to_hash
262
+ hash = {}
263
+ self.class.attribute_map.each_pair do |attr, param|
264
+ value = self.send(attr)
265
+ if value.nil?
266
+ is_nullable = self.class.openapi_nullable.include?(attr)
267
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
268
+ end
269
+
270
+ hash[param] = _to_hash(value)
271
+ end
272
+ hash
273
+ end
274
+
275
+ # Outputs non-array value in the form of hash
276
+ # For object, use to_hash. Otherwise, just return the value
277
+ # @param [Object] value Any valid value
278
+ # @return [Hash] Returns the value in the form of hash
279
+ def _to_hash(value)
280
+ if value.is_a?(Array)
281
+ value.compact.map { |v| _to_hash(v) }
282
+ elsif value.is_a?(Hash)
283
+ {}.tap do |hash|
284
+ value.each { |k, v| hash[k] = _to_hash(v) }
285
+ end
286
+ elsif value.respond_to? :to_hash
287
+ value.to_hash
288
+ else
289
+ value
290
+ end
291
+ end
292
+
293
+ end
294
+
295
+ end
@@ -0,0 +1,352 @@
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
+ # a order
18
+ class OrderUpdateRequest
19
+ attr_accessor :charges
20
+
21
+ attr_accessor :checkout
22
+
23
+ # Currency with which the payment will be made. It uses the 3-letter code of the [International Standard ISO 4217.](https://es.wikipedia.org/wiki/ISO_4217)
24
+ attr_accessor :currency
25
+
26
+ attr_accessor :customer_info
27
+
28
+ # List of [discounts](https://developers.femsa.com/v2.1.0/reference/orderscreatediscountline) that are applied to the order. You must have at least one discount.
29
+ attr_accessor :discount_lines
30
+
31
+ attr_accessor :fiscal_entity
32
+
33
+ # List of [products](https://developers.femsa.com/v2.1.0/reference/orderscreateproduct) that are sold in the order. You must have at least one product.
34
+ attr_accessor :line_items
35
+
36
+ attr_accessor :metadata
37
+
38
+ # Indicates whether the order charges must be preauthorized
39
+ attr_accessor :pre_authorize
40
+
41
+ attr_accessor :shipping_contact
42
+
43
+ # List of [shipping costs](https://developers.femsa.com/v2.1.0/reference/orderscreateshipping). If the online store offers digital products.
44
+ attr_accessor :shipping_lines
45
+
46
+ attr_accessor :tax_lines
47
+
48
+ # Attribute mapping from ruby-style variable name to JSON key.
49
+ def self.attribute_map
50
+ {
51
+ :'charges' => :'charges',
52
+ :'checkout' => :'checkout',
53
+ :'currency' => :'currency',
54
+ :'customer_info' => :'customer_info',
55
+ :'discount_lines' => :'discount_lines',
56
+ :'fiscal_entity' => :'fiscal_entity',
57
+ :'line_items' => :'line_items',
58
+ :'metadata' => :'metadata',
59
+ :'pre_authorize' => :'pre_authorize',
60
+ :'shipping_contact' => :'shipping_contact',
61
+ :'shipping_lines' => :'shipping_lines',
62
+ :'tax_lines' => :'tax_lines'
63
+ }
64
+ end
65
+
66
+ # Returns all the JSON keys this model knows about
67
+ def self.acceptable_attributes
68
+ attribute_map.values
69
+ end
70
+
71
+ # Attribute type mapping.
72
+ def self.openapi_types
73
+ {
74
+ :'charges' => :'Array<ChargeRequest>',
75
+ :'checkout' => :'CheckoutRequest',
76
+ :'currency' => :'String',
77
+ :'customer_info' => :'OrderUpdateRequestCustomerInfo',
78
+ :'discount_lines' => :'Array<OrderDiscountLinesRequest>',
79
+ :'fiscal_entity' => :'OrderUpdateFiscalEntityRequest',
80
+ :'line_items' => :'Array<Product>',
81
+ :'metadata' => :'Hash<String, String>',
82
+ :'pre_authorize' => :'Boolean',
83
+ :'shipping_contact' => :'CustomerShippingContacts',
84
+ :'shipping_lines' => :'Array<ShippingRequest>',
85
+ :'tax_lines' => :'Array<OrderTaxRequest>'
86
+ }
87
+ end
88
+
89
+ # List of attributes with nullable: true
90
+ def self.openapi_nullable
91
+ Set.new([
92
+ ])
93
+ end
94
+
95
+ # Initializes the object
96
+ # @param [Hash] attributes Model attributes in the form of hash
97
+ def initialize(attributes = {})
98
+ if (!attributes.is_a?(Hash))
99
+ fail ArgumentError, "The input argument (attributes) must be a hash in `DigitalFemsa::OrderUpdateRequest` initialize method"
100
+ end
101
+
102
+ # check to see if the attribute exists and convert string to symbol for hash key
103
+ attributes = attributes.each_with_object({}) { |(k, v), h|
104
+ if (!self.class.attribute_map.key?(k.to_sym))
105
+ fail ArgumentError, "`#{k}` is not a valid attribute in `DigitalFemsa::OrderUpdateRequest`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
106
+ end
107
+ h[k.to_sym] = v
108
+ }
109
+
110
+ if attributes.key?(:'charges')
111
+ if (value = attributes[:'charges']).is_a?(Array)
112
+ self.charges = value
113
+ end
114
+ end
115
+
116
+ if attributes.key?(:'checkout')
117
+ self.checkout = attributes[:'checkout']
118
+ end
119
+
120
+ if attributes.key?(:'currency')
121
+ self.currency = attributes[:'currency']
122
+ end
123
+
124
+ if attributes.key?(:'customer_info')
125
+ self.customer_info = attributes[:'customer_info']
126
+ end
127
+
128
+ if attributes.key?(:'discount_lines')
129
+ if (value = attributes[:'discount_lines']).is_a?(Array)
130
+ self.discount_lines = value
131
+ end
132
+ end
133
+
134
+ if attributes.key?(:'fiscal_entity')
135
+ self.fiscal_entity = attributes[:'fiscal_entity']
136
+ end
137
+
138
+ if attributes.key?(:'line_items')
139
+ if (value = attributes[:'line_items']).is_a?(Array)
140
+ self.line_items = value
141
+ end
142
+ end
143
+
144
+ if attributes.key?(:'metadata')
145
+ if (value = attributes[:'metadata']).is_a?(Hash)
146
+ self.metadata = value
147
+ end
148
+ end
149
+
150
+ if attributes.key?(:'pre_authorize')
151
+ self.pre_authorize = attributes[:'pre_authorize']
152
+ else
153
+ self.pre_authorize = false
154
+ end
155
+
156
+ if attributes.key?(:'shipping_contact')
157
+ self.shipping_contact = attributes[:'shipping_contact']
158
+ end
159
+
160
+ if attributes.key?(:'shipping_lines')
161
+ if (value = attributes[:'shipping_lines']).is_a?(Array)
162
+ self.shipping_lines = value
163
+ end
164
+ end
165
+
166
+ if attributes.key?(:'tax_lines')
167
+ if (value = attributes[:'tax_lines']).is_a?(Array)
168
+ self.tax_lines = value
169
+ end
170
+ end
171
+ end
172
+
173
+ # Show invalid properties with the reasons. Usually used together with valid?
174
+ # @return Array for valid properties with the reasons
175
+ def list_invalid_properties
176
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
177
+ invalid_properties = Array.new
178
+ if !@currency.nil? && @currency.to_s.length > 3
179
+ invalid_properties.push('invalid value for "currency", the character length must be smaller than or equal to 3.')
180
+ end
181
+
182
+ invalid_properties
183
+ end
184
+
185
+ # Check to see if the all the properties in the model are valid
186
+ # @return true if the model is valid
187
+ def valid?
188
+ warn '[DEPRECATED] the `valid?` method is obsolete'
189
+ return false if !@currency.nil? && @currency.to_s.length > 3
190
+ true
191
+ end
192
+
193
+ # Custom attribute writer method with validation
194
+ # @param [Object] currency Value to be assigned
195
+ def currency=(currency)
196
+ if currency.nil?
197
+ fail ArgumentError, 'currency cannot be nil'
198
+ end
199
+
200
+ if currency.to_s.length > 3
201
+ fail ArgumentError, 'invalid value for "currency", the character length must be smaller than or equal to 3.'
202
+ end
203
+
204
+ @currency = currency
205
+ end
206
+
207
+ # Checks equality by comparing each attribute.
208
+ # @param [Object] Object to be compared
209
+ def ==(o)
210
+ return true if self.equal?(o)
211
+ self.class == o.class &&
212
+ charges == o.charges &&
213
+ checkout == o.checkout &&
214
+ currency == o.currency &&
215
+ customer_info == o.customer_info &&
216
+ discount_lines == o.discount_lines &&
217
+ fiscal_entity == o.fiscal_entity &&
218
+ line_items == o.line_items &&
219
+ metadata == o.metadata &&
220
+ pre_authorize == o.pre_authorize &&
221
+ shipping_contact == o.shipping_contact &&
222
+ shipping_lines == o.shipping_lines &&
223
+ tax_lines == o.tax_lines
224
+ end
225
+
226
+ # @see the `==` method
227
+ # @param [Object] Object to be compared
228
+ def eql?(o)
229
+ self == o
230
+ end
231
+
232
+ # Calculates hash code according to all attributes.
233
+ # @return [Integer] Hash code
234
+ def hash
235
+ [charges, checkout, currency, customer_info, discount_lines, fiscal_entity, line_items, metadata, pre_authorize, shipping_contact, shipping_lines, tax_lines].hash
236
+ end
237
+
238
+ # Builds the object from hash
239
+ # @param [Hash] attributes Model attributes in the form of hash
240
+ # @return [Object] Returns the model itself
241
+ def self.build_from_hash(attributes)
242
+ return nil unless attributes.is_a?(Hash)
243
+ attributes = attributes.transform_keys(&:to_sym)
244
+ transformed_hash = {}
245
+ openapi_types.each_pair do |key, type|
246
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
247
+ transformed_hash["#{key}"] = nil
248
+ elsif type =~ /\AArray<(.*)>/i
249
+ # check to ensure the input is an array given that the attribute
250
+ # is documented as an array but the input is not
251
+ if attributes[attribute_map[key]].is_a?(Array)
252
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
253
+ end
254
+ elsif !attributes[attribute_map[key]].nil?
255
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
256
+ end
257
+ end
258
+ new(transformed_hash)
259
+ end
260
+
261
+ # Deserializes the data based on type
262
+ # @param string type Data type
263
+ # @param string value Value to be deserialized
264
+ # @return [Object] Deserialized data
265
+ def self._deserialize(type, value)
266
+ case type.to_sym
267
+ when :Time
268
+ Time.parse(value)
269
+ when :Date
270
+ Date.parse(value)
271
+ when :String
272
+ value.to_s
273
+ when :Integer
274
+ value.to_i
275
+ when :Float
276
+ value.to_f
277
+ when :Boolean
278
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
279
+ true
280
+ else
281
+ false
282
+ end
283
+ when :Object
284
+ # generic object (usually a Hash), return directly
285
+ value
286
+ when /\AArray<(?<inner_type>.+)>\z/
287
+ inner_type = Regexp.last_match[:inner_type]
288
+ value.map { |v| _deserialize(inner_type, v) }
289
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
290
+ k_type = Regexp.last_match[:k_type]
291
+ v_type = Regexp.last_match[:v_type]
292
+ {}.tap do |hash|
293
+ value.each do |k, v|
294
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
295
+ end
296
+ end
297
+ else # model
298
+ # models (e.g. Pet) or oneOf
299
+ klass = DigitalFemsa.const_get(type)
300
+ klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
301
+ end
302
+ end
303
+
304
+ # Returns the string representation of the object
305
+ # @return [String] String presentation of the object
306
+ def to_s
307
+ to_hash.to_s
308
+ end
309
+
310
+ # to_body is an alias to to_hash (backward compatibility)
311
+ # @return [Hash] Returns the object in the form of hash
312
+ def to_body
313
+ to_hash
314
+ end
315
+
316
+ # Returns the object in the form of hash
317
+ # @return [Hash] Returns the object in the form of hash
318
+ def to_hash
319
+ hash = {}
320
+ self.class.attribute_map.each_pair do |attr, param|
321
+ value = self.send(attr)
322
+ if value.nil?
323
+ is_nullable = self.class.openapi_nullable.include?(attr)
324
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
325
+ end
326
+
327
+ hash[param] = _to_hash(value)
328
+ end
329
+ hash
330
+ end
331
+
332
+ # Outputs non-array value in the form of hash
333
+ # For object, use to_hash. Otherwise, just return the value
334
+ # @param [Object] value Any valid value
335
+ # @return [Hash] Returns the value in the form of hash
336
+ def _to_hash(value)
337
+ if value.is_a?(Array)
338
+ value.compact.map { |v| _to_hash(v) }
339
+ elsif value.is_a?(Hash)
340
+ {}.tap do |hash|
341
+ value.each { |k, v| hash[k] = _to_hash(v) }
342
+ end
343
+ elsif value.respond_to? :to_hash
344
+ value.to_hash
345
+ else
346
+ value
347
+ end
348
+ end
349
+
350
+ end
351
+
352
+ end