subtain-apimatic-sdk 4.1.1 → 9.1.1

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 (711) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE +28 -0
  3. data/README.md +377 -0
  4. data/lib/advanced_billing/api_helper.rb +10 -0
  5. data/lib/advanced_billing/client.rb +243 -0
  6. data/lib/advanced_billing/configuration.rb +158 -0
  7. data/lib/advanced_billing/controllers/advance_invoice_controller.rb +126 -0
  8. data/lib/advanced_billing/controllers/api_exports_controller.rb +268 -0
  9. data/lib/advanced_billing/controllers/base_controller.rb +71 -0
  10. data/lib/advanced_billing/controllers/billing_portal_controller.rb +165 -0
  11. data/lib/advanced_billing/controllers/components_controller.rb +747 -0
  12. data/lib/advanced_billing/controllers/coupons_controller.rb +691 -0
  13. data/lib/advanced_billing/controllers/custom_fields_controller.rb +465 -0
  14. data/lib/advanced_billing/controllers/customers_controller.rb +255 -0
  15. data/lib/advanced_billing/controllers/events_based_billing_segments_controller.rb +334 -0
  16. data/lib/advanced_billing/controllers/events_controller.rb +229 -0
  17. data/lib/advanced_billing/controllers/insights_controller.rb +168 -0
  18. data/lib/advanced_billing/controllers/invoices_controller.rb +953 -0
  19. data/lib/advanced_billing/controllers/offers_controller.rb +132 -0
  20. data/lib/advanced_billing/controllers/payment_profiles_controller.rb +732 -0
  21. data/lib/advanced_billing/controllers/product_families_controller.rb +187 -0
  22. data/lib/advanced_billing/controllers/product_price_points_controller.rb +422 -0
  23. data/lib/advanced_billing/controllers/products_controller.rb +220 -0
  24. data/lib/advanced_billing/controllers/proforma_invoices_controller.rb +381 -0
  25. data/lib/advanced_billing/controllers/reason_codes_controller.rb +158 -0
  26. data/lib/advanced_billing/controllers/referral_codes_controller.rb +42 -0
  27. data/lib/advanced_billing/controllers/sales_commissions_controller.rb +192 -0
  28. data/lib/advanced_billing/controllers/sites_controller.rb +96 -0
  29. data/lib/advanced_billing/controllers/subscription_components_controller.rb +992 -0
  30. data/lib/advanced_billing/controllers/subscription_group_invoice_account_controller.rb +163 -0
  31. data/lib/advanced_billing/controllers/subscription_group_status_controller.rb +157 -0
  32. data/lib/advanced_billing/controllers/subscription_groups_controller.rb +300 -0
  33. data/lib/advanced_billing/controllers/subscription_invoice_account_controller.rb +226 -0
  34. data/lib/advanced_billing/controllers/subscription_notes_controller.rb +159 -0
  35. data/lib/advanced_billing/controllers/subscription_products_controller.rb +166 -0
  36. data/lib/advanced_billing/controllers/subscription_status_controller.rb +473 -0
  37. data/lib/advanced_billing/controllers/subscriptions_controller.rb +1357 -0
  38. data/lib/advanced_billing/controllers/webhooks_controller.rb +210 -0
  39. data/lib/advanced_billing/exceptions/api_exception.rb +10 -0
  40. data/lib/advanced_billing/exceptions/component_allocation_error_exception.rb +41 -0
  41. data/lib/advanced_billing/exceptions/component_price_point_error_exception.rb +41 -0
  42. data/lib/advanced_billing/exceptions/customer_error_response_exception.rb +34 -0
  43. data/lib/advanced_billing/exceptions/error_list_response_exception.rb +32 -0
  44. data/lib/advanced_billing/exceptions/error_map_response_exception.rb +32 -0
  45. data/lib/advanced_billing/exceptions/event_based_billing_list_segments_errors_exception.rb +32 -0
  46. data/lib/advanced_billing/exceptions/event_based_billing_segment_errors_exception.rb +35 -0
  47. data/lib/advanced_billing/exceptions/event_based_billing_segment_exception.rb +32 -0
  48. data/lib/advanced_billing/exceptions/nested_error_response_exception.rb +32 -0
  49. data/lib/advanced_billing/exceptions/proforma_bad_request_error_response_exception.rb +32 -0
  50. data/lib/advanced_billing/exceptions/refund_prepayment_aggregated_errors_response_exception.rb +33 -0
  51. data/lib/advanced_billing/exceptions/refund_prepayment_base_errors_response_exception.rb +32 -0
  52. data/lib/advanced_billing/exceptions/single_error_response_exception.rb +32 -0
  53. data/lib/advanced_billing/exceptions/single_string_error_response_exception.rb +32 -0
  54. data/lib/advanced_billing/exceptions/subscription_add_coupon_error_exception.rb +42 -0
  55. data/lib/advanced_billing/exceptions/subscription_component_allocation_error_exception.rb +41 -0
  56. data/lib/advanced_billing/exceptions/subscription_group_signup_error_response_exception.rb +32 -0
  57. data/lib/advanced_billing/exceptions/subscription_group_update_error_response_exception.rb +32 -0
  58. data/lib/advanced_billing/exceptions/subscription_remove_coupon_errors_exception.rb +32 -0
  59. data/lib/advanced_billing/exceptions/subscriptions_mrr_error_response_exception.rb +32 -0
  60. data/lib/advanced_billing/exceptions/too_many_management_link_requests_error_exception.rb +32 -0
  61. data/lib/advanced_billing/http/auth/basic_auth.rb +50 -0
  62. data/lib/advanced_billing/http/http_call_back.rb +10 -0
  63. data/lib/advanced_billing/http/http_method_enum.rb +10 -0
  64. data/lib/advanced_billing/http/http_request.rb +10 -0
  65. data/lib/advanced_billing/http/http_response.rb +10 -0
  66. data/lib/advanced_billing/models/account_balance.rb +51 -0
  67. data/lib/advanced_billing/models/account_balances.rb +81 -0
  68. data/lib/advanced_billing/models/ach_agreement.rb +96 -0
  69. data/lib/advanced_billing/models/activate_subscription_request.rb +57 -0
  70. data/lib/advanced_billing/models/add_coupons_request.rb +50 -0
  71. data/lib/advanced_billing/models/add_subscription_to_a_group.rb +62 -0
  72. data/lib/advanced_billing/models/agreement_acceptance.rb +125 -0
  73. data/lib/advanced_billing/models/allocate_components.rb +130 -0
  74. data/lib/advanced_billing/models/allocation.rb +231 -0
  75. data/lib/advanced_billing/models/allocation_expiration_date.rb +50 -0
  76. data/lib/advanced_billing/models/allocation_payment.rb +89 -0
  77. data/lib/advanced_billing/models/allocation_preview.rb +190 -0
  78. data/lib/advanced_billing/models/allocation_preview_item.rb +187 -0
  79. data/lib/advanced_billing/models/allocation_preview_line_item.rb +130 -0
  80. data/lib/advanced_billing/models/allocation_preview_response.rb +49 -0
  81. data/lib/advanced_billing/models/allocation_response.rb +50 -0
  82. data/lib/advanced_billing/models/allocation_settings.rb +74 -0
  83. data/lib/advanced_billing/models/applied_credit_note.rb +69 -0
  84. data/lib/advanced_billing/models/apply_credit_note_event_data.rb +174 -0
  85. data/lib/advanced_billing/models/apply_debit_note_event_data.rb +94 -0
  86. data/lib/advanced_billing/models/apply_payment_event_data.rb +130 -0
  87. data/lib/advanced_billing/models/attribute_error.rb +48 -0
  88. data/lib/advanced_billing/models/auto_invite.rb +23 -0
  89. data/lib/advanced_billing/models/auto_resume.rb +51 -0
  90. data/lib/advanced_billing/models/bank_account.rb +270 -0
  91. data/lib/advanced_billing/models/bank_account_attributes.rb +183 -0
  92. data/lib/advanced_billing/models/bank_account_payment_profile.rb +285 -0
  93. data/lib/advanced_billing/models/bank_account_response.rb +48 -0
  94. data/lib/advanced_billing/models/bank_account_type.rb +23 -0
  95. data/lib/advanced_billing/models/bank_account_vault.rb +32 -0
  96. data/lib/advanced_billing/models/bank_account_verification.rb +61 -0
  97. data/lib/advanced_billing/models/bank_account_verification_request.rb +50 -0
  98. data/lib/advanced_billing/models/base_model.rb +62 -0
  99. data/lib/advanced_billing/models/base_refund_error.rb +50 -0
  100. data/lib/advanced_billing/models/base_string_error.rb +50 -0
  101. data/lib/advanced_billing/models/basic_date_field.rb +23 -0
  102. data/lib/advanced_billing/models/batch_job.rb +91 -0
  103. data/lib/advanced_billing/models/batch_job_response.rb +48 -0
  104. data/lib/advanced_billing/models/billing_address.rb +113 -0
  105. data/lib/advanced_billing/models/billing_manifest.rb +142 -0
  106. data/lib/advanced_billing/models/billing_manifest_item.rb +182 -0
  107. data/lib/advanced_billing/models/breakouts.rb +82 -0
  108. data/lib/advanced_billing/models/bulk_component_s_price_point_assignment.rb +59 -0
  109. data/lib/advanced_billing/models/bulk_create_product_price_points_request.rb +57 -0
  110. data/lib/advanced_billing/models/bulk_create_product_price_points_response.rb +59 -0
  111. data/lib/advanced_billing/models/bulk_create_segments.rb +59 -0
  112. data/lib/advanced_billing/models/bulk_update_segments.rb +59 -0
  113. data/lib/advanced_billing/models/bulk_update_segments_item.rb +80 -0
  114. data/lib/advanced_billing/models/calendar_billing.rb +78 -0
  115. data/lib/advanced_billing/models/cancel_grouped_subscriptions_request.rb +51 -0
  116. data/lib/advanced_billing/models/cancellation_method.rb +30 -0
  117. data/lib/advanced_billing/models/cancellation_options.rb +62 -0
  118. data/lib/advanced_billing/models/cancellation_request.rb +48 -0
  119. data/lib/advanced_billing/models/card_type.rb +56 -0
  120. data/lib/advanced_billing/models/card_type1.rb +116 -0
  121. data/lib/advanced_billing/models/change_invoice_collection_method_event_data.rb +71 -0
  122. data/lib/advanced_billing/models/chargify_ebb.rb +113 -0
  123. data/lib/advanced_billing/models/cleanup_scope.rb +26 -0
  124. data/lib/advanced_billing/models/component.rb +405 -0
  125. data/lib/advanced_billing/models/component_allocation_change.rb +142 -0
  126. data/lib/advanced_billing/models/component_allocation_error_item.rb +77 -0
  127. data/lib/advanced_billing/models/component_cost_data.rb +135 -0
  128. data/lib/advanced_billing/models/component_cost_data_rate_tier.rb +101 -0
  129. data/lib/advanced_billing/models/component_custom_price.rb +81 -0
  130. data/lib/advanced_billing/models/component_kind.rb +32 -0
  131. data/lib/advanced_billing/models/component_kind_path.rb +32 -0
  132. data/lib/advanced_billing/models/component_price.rb +123 -0
  133. data/lib/advanced_billing/models/component_price_point.rb +192 -0
  134. data/lib/advanced_billing/models/component_price_point_error_item.rb +68 -0
  135. data/lib/advanced_billing/models/component_price_point_item.rb +98 -0
  136. data/lib/advanced_billing/models/component_price_point_price.rb +123 -0
  137. data/lib/advanced_billing/models/component_price_point_response.rb +48 -0
  138. data/lib/advanced_billing/models/component_price_points_response.rb +59 -0
  139. data/lib/advanced_billing/models/component_response.rb +48 -0
  140. data/lib/advanced_billing/models/component_s_price_point_assignment.rb +71 -0
  141. data/lib/advanced_billing/models/compounding_strategy.rb +23 -0
  142. data/lib/advanced_billing/models/consolidated_invoice.rb +59 -0
  143. data/lib/advanced_billing/models/count_response.rb +50 -0
  144. data/lib/advanced_billing/models/coupon.rb +367 -0
  145. data/lib/advanced_billing/models/coupon_currency.rb +77 -0
  146. data/lib/advanced_billing/models/coupon_currency_request.rb +57 -0
  147. data/lib/advanced_billing/models/coupon_response.rb +50 -0
  148. data/lib/advanced_billing/models/coupon_restriction.rb +99 -0
  149. data/lib/advanced_billing/models/coupon_subcodes.rb +50 -0
  150. data/lib/advanced_billing/models/coupon_subcodes_response.rb +70 -0
  151. data/lib/advanced_billing/models/coupon_usage.rb +114 -0
  152. data/lib/advanced_billing/models/create_allocation.rb +162 -0
  153. data/lib/advanced_billing/models/create_allocation_request.rb +48 -0
  154. data/lib/advanced_billing/models/create_component_price_point.rb +125 -0
  155. data/lib/advanced_billing/models/create_component_price_point_request.rb +64 -0
  156. data/lib/advanced_billing/models/create_component_price_points_request.rb +64 -0
  157. data/lib/advanced_billing/models/create_currency_price.rb +68 -0
  158. data/lib/advanced_billing/models/create_currency_prices_request.rb +57 -0
  159. data/lib/advanced_billing/models/create_customer.rb +209 -0
  160. data/lib/advanced_billing/models/create_customer_request.rb +48 -0
  161. data/lib/advanced_billing/models/create_ebb_component.rb +65 -0
  162. data/lib/advanced_billing/models/create_invoice.rb +163 -0
  163. data/lib/advanced_billing/models/create_invoice_address.rb +124 -0
  164. data/lib/advanced_billing/models/create_invoice_coupon.rb +115 -0
  165. data/lib/advanced_billing/models/create_invoice_item.rb +185 -0
  166. data/lib/advanced_billing/models/create_invoice_payment.rb +90 -0
  167. data/lib/advanced_billing/models/create_invoice_payment_application.rb +79 -0
  168. data/lib/advanced_billing/models/create_invoice_payment_request.rb +58 -0
  169. data/lib/advanced_billing/models/create_invoice_request.rb +48 -0
  170. data/lib/advanced_billing/models/create_metadata.rb +59 -0
  171. data/lib/advanced_billing/models/create_metadata_request.rb +57 -0
  172. data/lib/advanced_billing/models/create_metafield.rb +103 -0
  173. data/lib/advanced_billing/models/create_metafields_request.rb +64 -0
  174. data/lib/advanced_billing/models/create_metered_component.rb +65 -0
  175. data/lib/advanced_billing/models/create_multi_invoice_payment.rb +134 -0
  176. data/lib/advanced_billing/models/create_multi_invoice_payment_request.rb +48 -0
  177. data/lib/advanced_billing/models/create_offer.rb +116 -0
  178. data/lib/advanced_billing/models/create_offer_component.rb +60 -0
  179. data/lib/advanced_billing/models/create_offer_request.rb +48 -0
  180. data/lib/advanced_billing/models/create_on_off_component.rb +65 -0
  181. data/lib/advanced_billing/models/create_or_update_coupon.rb +85 -0
  182. data/lib/advanced_billing/models/create_or_update_flat_amount_coupon.rb +214 -0
  183. data/lib/advanced_billing/models/create_or_update_percentage_coupon.rb +215 -0
  184. data/lib/advanced_billing/models/create_or_update_product.rb +133 -0
  185. data/lib/advanced_billing/models/create_or_update_product_request.rb +48 -0
  186. data/lib/advanced_billing/models/create_or_update_segment_price.rb +87 -0
  187. data/lib/advanced_billing/models/create_payment.rb +75 -0
  188. data/lib/advanced_billing/models/create_payment_profile.rb +416 -0
  189. data/lib/advanced_billing/models/create_payment_profile_request.rb +49 -0
  190. data/lib/advanced_billing/models/create_payment_profile_response.rb +49 -0
  191. data/lib/advanced_billing/models/create_prepaid_component.rb +65 -0
  192. data/lib/advanced_billing/models/create_prepaid_usage_component_price_point.rb +194 -0
  193. data/lib/advanced_billing/models/create_prepayment.rb +90 -0
  194. data/lib/advanced_billing/models/create_prepayment_request.rb +48 -0
  195. data/lib/advanced_billing/models/create_prepayment_response.rb +48 -0
  196. data/lib/advanced_billing/models/create_product_currency_price.rb +64 -0
  197. data/lib/advanced_billing/models/create_product_currency_prices_request.rb +57 -0
  198. data/lib/advanced_billing/models/create_product_family.rb +61 -0
  199. data/lib/advanced_billing/models/create_product_family_request.rb +49 -0
  200. data/lib/advanced_billing/models/create_product_price_point.rb +182 -0
  201. data/lib/advanced_billing/models/create_product_price_point_request.rb +48 -0
  202. data/lib/advanced_billing/models/create_quantity_based_component.rb +66 -0
  203. data/lib/advanced_billing/models/create_reason_code.rb +66 -0
  204. data/lib/advanced_billing/models/create_reason_code_request.rb +48 -0
  205. data/lib/advanced_billing/models/create_segment.rb +143 -0
  206. data/lib/advanced_billing/models/create_segment_request.rb +48 -0
  207. data/lib/advanced_billing/models/create_subscription.rb +694 -0
  208. data/lib/advanced_billing/models/create_subscription_component.rb +122 -0
  209. data/lib/advanced_billing/models/create_subscription_group.rb +74 -0
  210. data/lib/advanced_billing/models/create_subscription_group_request.rb +49 -0
  211. data/lib/advanced_billing/models/create_subscription_request.rb +48 -0
  212. data/lib/advanced_billing/models/create_usage.rb +72 -0
  213. data/lib/advanced_billing/models/create_usage_request.rb +48 -0
  214. data/lib/advanced_billing/models/created_payment_profile.rb +327 -0
  215. data/lib/advanced_billing/models/created_prepayment.rb +114 -0
  216. data/lib/advanced_billing/models/credit_account_balance_changed.rb +120 -0
  217. data/lib/advanced_billing/models/credit_card_attributes.rb +81 -0
  218. data/lib/advanced_billing/models/credit_card_payment_profile.rb +277 -0
  219. data/lib/advanced_billing/models/credit_note.rb +403 -0
  220. data/lib/advanced_billing/models/credit_note1.rb +405 -0
  221. data/lib/advanced_billing/models/credit_note_application.rb +99 -0
  222. data/lib/advanced_billing/models/credit_note_line_item.rb +246 -0
  223. data/lib/advanced_billing/models/credit_scheme.rb +26 -0
  224. data/lib/advanced_billing/models/credit_scheme_request.rb +48 -0
  225. data/lib/advanced_billing/models/credit_type.rb +27 -0
  226. data/lib/advanced_billing/models/credit_type1.rb +28 -0
  227. data/lib/advanced_billing/models/currency_price.rb +99 -0
  228. data/lib/advanced_billing/models/currency_price_role.rb +26 -0
  229. data/lib/advanced_billing/models/current_vault.rb +99 -0
  230. data/lib/advanced_billing/models/custom_field_value_change.rb +144 -0
  231. data/lib/advanced_billing/models/custom_price_used_for_subscription_create_update.rb +197 -0
  232. data/lib/advanced_billing/models/customer.rb +352 -0
  233. data/lib/advanced_billing/models/customer1.rb +120 -0
  234. data/lib/advanced_billing/models/customer_attributes.rb +241 -0
  235. data/lib/advanced_billing/models/customer_billing_address_change.rb +59 -0
  236. data/lib/advanced_billing/models/customer_change.rb +81 -0
  237. data/lib/advanced_billing/models/customer_changes_preview_response.rb +48 -0
  238. data/lib/advanced_billing/models/customer_custom_fields_change.rb +77 -0
  239. data/lib/advanced_billing/models/customer_error.rb +60 -0
  240. data/lib/advanced_billing/models/customer_payer_change.rb +59 -0
  241. data/lib/advanced_billing/models/customer_response.rb +48 -0
  242. data/lib/advanced_billing/models/customer_shipping_address_change.rb +59 -0
  243. data/lib/advanced_billing/models/deduct_service_credit.rb +80 -0
  244. data/lib/advanced_billing/models/deduct_service_credit_request.rb +48 -0
  245. data/lib/advanced_billing/models/delayed_cancellation_response.rb +50 -0
  246. data/lib/advanced_billing/models/delete_subscription_group_response.rb +59 -0
  247. data/lib/advanced_billing/models/direction.rb +23 -0
  248. data/lib/advanced_billing/models/discount_type.rb +23 -0
  249. data/lib/advanced_billing/models/dunner_data.rb +131 -0
  250. data/lib/advanced_billing/models/dunning_step_data.rb +149 -0
  251. data/lib/advanced_billing/models/dunning_step_reached.rb +96 -0
  252. data/lib/advanced_billing/models/ebb_component.rb +271 -0
  253. data/lib/advanced_billing/models/ebb_event.rb +50 -0
  254. data/lib/advanced_billing/models/enable_webhooks_request.rb +49 -0
  255. data/lib/advanced_billing/models/enable_webhooks_response.rb +51 -0
  256. data/lib/advanced_billing/models/endpoint.rb +88 -0
  257. data/lib/advanced_billing/models/endpoint_response.rb +50 -0
  258. data/lib/advanced_billing/models/errors.rb +59 -0
  259. data/lib/advanced_billing/models/event.rb +145 -0
  260. data/lib/advanced_billing/models/event_based_billing_segment_error.rb +51 -0
  261. data/lib/advanced_billing/models/event_response.rb +48 -0
  262. data/lib/advanced_billing/models/event_type.rb +121 -0
  263. data/lib/advanced_billing/models/extended_interval_unit.rb +26 -0
  264. data/lib/advanced_billing/models/failed_payment_action.rb +37 -0
  265. data/lib/advanced_billing/models/first_charge_type.rb +26 -0
  266. data/lib/advanced_billing/models/full_subscription_group_response.rb +165 -0
  267. data/lib/advanced_billing/models/get_one_time_token_payment_profile.rb +249 -0
  268. data/lib/advanced_billing/models/get_one_time_token_request.rb +49 -0
  269. data/lib/advanced_billing/models/group_billing.rb +85 -0
  270. data/lib/advanced_billing/models/group_settings.rb +76 -0
  271. data/lib/advanced_billing/models/group_target.rb +75 -0
  272. data/lib/advanced_billing/models/group_target_type.rb +32 -0
  273. data/lib/advanced_billing/models/holder_type.rb +23 -0
  274. data/lib/advanced_billing/models/include_not_null.rb +20 -0
  275. data/lib/advanced_billing/models/include_option.rb +23 -0
  276. data/lib/advanced_billing/models/interval_unit.rb +23 -0
  277. data/lib/advanced_billing/models/invoice.rb +712 -0
  278. data/lib/advanced_billing/models/invoice_address.rb +113 -0
  279. data/lib/advanced_billing/models/invoice_balance_item.rb +79 -0
  280. data/lib/advanced_billing/models/invoice_consolidation_level.rb +34 -0
  281. data/lib/advanced_billing/models/invoice_credit.rb +121 -0
  282. data/lib/advanced_billing/models/invoice_custom_field.rb +88 -0
  283. data/lib/advanced_billing/models/invoice_customer.rb +121 -0
  284. data/lib/advanced_billing/models/invoice_date_field.rb +32 -0
  285. data/lib/advanced_billing/models/invoice_discount.rb +177 -0
  286. data/lib/advanced_billing/models/invoice_discount_breakout.rb +80 -0
  287. data/lib/advanced_billing/models/invoice_display_settings.rb +75 -0
  288. data/lib/advanced_billing/models/invoice_event.rb +102 -0
  289. data/lib/advanced_billing/models/invoice_event1.rb +374 -0
  290. data/lib/advanced_billing/models/invoice_event_type.rb +50 -0
  291. data/lib/advanced_billing/models/invoice_issued.rb +252 -0
  292. data/lib/advanced_billing/models/invoice_line_item.rb +321 -0
  293. data/lib/advanced_billing/models/invoice_line_item_component_cost_data.rb +69 -0
  294. data/lib/advanced_billing/models/invoice_line_item_event_data.rb +262 -0
  295. data/lib/advanced_billing/models/invoice_line_item_pricing_detail.rb +69 -0
  296. data/lib/advanced_billing/models/invoice_payer.rb +109 -0
  297. data/lib/advanced_billing/models/invoice_payment.rb +155 -0
  298. data/lib/advanced_billing/models/invoice_payment_application.rb +73 -0
  299. data/lib/advanced_billing/models/invoice_payment_method.rb +129 -0
  300. data/lib/advanced_billing/models/invoice_payment_method_type.rb +35 -0
  301. data/lib/advanced_billing/models/invoice_payment_type.rb +29 -0
  302. data/lib/advanced_billing/models/invoice_previous_balance.rb +78 -0
  303. data/lib/advanced_billing/models/invoice_refund.rb +113 -0
  304. data/lib/advanced_billing/models/invoice_response.rb +48 -0
  305. data/lib/advanced_billing/models/invoice_seller.rb +90 -0
  306. data/lib/advanced_billing/models/invoice_sort_field.rb +41 -0
  307. data/lib/advanced_billing/models/invoice_tax.rb +176 -0
  308. data/lib/advanced_billing/models/invoice_tax_breakout.rb +79 -0
  309. data/lib/advanced_billing/models/invoice_tax_component_breakout.rb +89 -0
  310. data/lib/advanced_billing/models/issue_advance_invoice_request.rb +50 -0
  311. data/lib/advanced_billing/models/issue_invoice_event_data.rb +115 -0
  312. data/lib/advanced_billing/models/issue_invoice_request.rb +63 -0
  313. data/lib/advanced_billing/models/issue_service_credit.rb +80 -0
  314. data/lib/advanced_billing/models/issue_service_credit_request.rb +49 -0
  315. data/lib/advanced_billing/models/item_category.rb +33 -0
  316. data/lib/advanced_billing/models/item_price_point_changed.rb +134 -0
  317. data/lib/advanced_billing/models/item_price_point_data.rb +78 -0
  318. data/lib/advanced_billing/models/list_components_price_points_include.rb +20 -0
  319. data/lib/advanced_billing/models/list_components_price_points_response.rb +57 -0
  320. data/lib/advanced_billing/models/list_credit_notes_response.rb +57 -0
  321. data/lib/advanced_billing/models/list_events_date_field.rb +20 -0
  322. data/lib/advanced_billing/models/list_invoice_events_response.rb +87 -0
  323. data/lib/advanced_billing/models/list_invoices_response.rb +57 -0
  324. data/lib/advanced_billing/models/list_metafields_response.rb +96 -0
  325. data/lib/advanced_billing/models/list_mrr_response.rb +48 -0
  326. data/lib/advanced_billing/models/list_mrr_response_result.rb +116 -0
  327. data/lib/advanced_billing/models/list_offers_response.rb +59 -0
  328. data/lib/advanced_billing/models/list_payment_profile_item.rb +274 -0
  329. data/lib/advanced_billing/models/list_payment_profiles_response.rb +51 -0
  330. data/lib/advanced_billing/models/list_product_price_points_response.rb +57 -0
  331. data/lib/advanced_billing/models/list_products_include.rb +20 -0
  332. data/lib/advanced_billing/models/list_products_price_points_include.rb +20 -0
  333. data/lib/advanced_billing/models/list_public_keys_meta.rb +78 -0
  334. data/lib/advanced_billing/models/list_public_keys_response.rb +68 -0
  335. data/lib/advanced_billing/models/list_sale_rep_item.rb +90 -0
  336. data/lib/advanced_billing/models/list_segments_response.rb +59 -0
  337. data/lib/advanced_billing/models/list_subcription_group_prepayment_item.rb +137 -0
  338. data/lib/advanced_billing/models/list_subscription_components_include.rb +20 -0
  339. data/lib/advanced_billing/models/list_subscription_components_response.rb +57 -0
  340. data/lib/advanced_billing/models/list_subscription_components_sort.rb +23 -0
  341. data/lib/advanced_billing/models/list_subscription_group_prepayment.rb +49 -0
  342. data/lib/advanced_billing/models/list_subscription_group_prepayment_date_field.rb +23 -0
  343. data/lib/advanced_billing/models/list_subscription_group_prepayment_response.rb +57 -0
  344. data/lib/advanced_billing/models/list_subscription_groups_item.rb +141 -0
  345. data/lib/advanced_billing/models/list_subscription_groups_meta.rb +59 -0
  346. data/lib/advanced_billing/models/list_subscription_groups_response.rb +68 -0
  347. data/lib/advanced_billing/models/metadata.rb +98 -0
  348. data/lib/advanced_billing/models/metafield.rb +112 -0
  349. data/lib/advanced_billing/models/metafield_input.rb +32 -0
  350. data/lib/advanced_billing/models/metafield_scope.rb +119 -0
  351. data/lib/advanced_billing/models/metafields.rb +103 -0
  352. data/lib/advanced_billing/models/metafields1.rb +103 -0
  353. data/lib/advanced_billing/models/metered_component.rb +294 -0
  354. data/lib/advanced_billing/models/metered_usage.rb +132 -0
  355. data/lib/advanced_billing/models/movement.rb +138 -0
  356. data/lib/advanced_billing/models/movement_line_item.rb +143 -0
  357. data/lib/advanced_billing/models/mrr.rb +100 -0
  358. data/lib/advanced_billing/models/mrr_movement.rb +79 -0
  359. data/lib/advanced_billing/models/mrr_response.rb +48 -0
  360. data/lib/advanced_billing/models/multi_invoice_payment.rb +90 -0
  361. data/lib/advanced_billing/models/multi_invoice_payment_response.rb +48 -0
  362. data/lib/advanced_billing/models/net_terms.rb +94 -0
  363. data/lib/advanced_billing/models/offer.rb +254 -0
  364. data/lib/advanced_billing/models/offer_discount.rb +68 -0
  365. data/lib/advanced_billing/models/offer_item.rb +130 -0
  366. data/lib/advanced_billing/models/offer_response.rb +50 -0
  367. data/lib/advanced_billing/models/offer_signup_page.rb +96 -0
  368. data/lib/advanced_billing/models/on_off_component.rb +291 -0
  369. data/lib/advanced_billing/models/organization_address.rb +123 -0
  370. data/lib/advanced_billing/models/origin_invoice.rb +69 -0
  371. data/lib/advanced_billing/models/overage_pricing.rb +87 -0
  372. data/lib/advanced_billing/models/override_subscription.rb +100 -0
  373. data/lib/advanced_billing/models/override_subscription_request.rb +48 -0
  374. data/lib/advanced_billing/models/paginated_metadata.rb +96 -0
  375. data/lib/advanced_billing/models/pause_request.rb +50 -0
  376. data/lib/advanced_billing/models/payer_attributes.rb +221 -0
  377. data/lib/advanced_billing/models/payer_error.rb +68 -0
  378. data/lib/advanced_billing/models/payment.rb +80 -0
  379. data/lib/advanced_billing/models/payment_collection_method.rb +32 -0
  380. data/lib/advanced_billing/models/payment_collection_method1.rb +30 -0
  381. data/lib/advanced_billing/models/payment_collection_method_changed.rb +79 -0
  382. data/lib/advanced_billing/models/payment_method_apple_pay_type.rb +60 -0
  383. data/lib/advanced_billing/models/payment_method_bank_account_type.rb +81 -0
  384. data/lib/advanced_billing/models/payment_method_credit_card_type.rb +101 -0
  385. data/lib/advanced_billing/models/payment_method_external_type.rb +87 -0
  386. data/lib/advanced_billing/models/payment_method_nested_data.rb +150 -0
  387. data/lib/advanced_billing/models/payment_method_paypal_type.rb +69 -0
  388. data/lib/advanced_billing/models/payment_profile.rb +287 -0
  389. data/lib/advanced_billing/models/payment_profile_attributes.rb +356 -0
  390. data/lib/advanced_billing/models/payment_profile_response.rb +49 -0
  391. data/lib/advanced_billing/models/payment_related_events.rb +79 -0
  392. data/lib/advanced_billing/models/payment_response.rb +68 -0
  393. data/lib/advanced_billing/models/payment_type.rb +26 -0
  394. data/lib/advanced_billing/models/pending_cancellation_change.rb +79 -0
  395. data/lib/advanced_billing/models/portal_management_link.rb +101 -0
  396. data/lib/advanced_billing/models/pre_payment.rb +74 -0
  397. data/lib/advanced_billing/models/prepaid_component_price_point.rb +108 -0
  398. data/lib/advanced_billing/models/prepaid_configuration.rb +103 -0
  399. data/lib/advanced_billing/models/prepaid_configuration_response.rb +49 -0
  400. data/lib/advanced_billing/models/prepaid_subscription_balance_changed.rb +110 -0
  401. data/lib/advanced_billing/models/prepaid_usage.rb +199 -0
  402. data/lib/advanced_billing/models/prepaid_usage_allocation_detail.rb +80 -0
  403. data/lib/advanced_billing/models/prepaid_usage_component.rb +350 -0
  404. data/lib/advanced_billing/models/prepayment1.rb +131 -0
  405. data/lib/advanced_billing/models/prepayment_account_balance_changed.rb +108 -0
  406. data/lib/advanced_billing/models/prepayment_aggregated_error.rb +69 -0
  407. data/lib/advanced_billing/models/prepayment_method.rb +41 -0
  408. data/lib/advanced_billing/models/prepayment_response.rb +48 -0
  409. data/lib/advanced_billing/models/prepayments_response.rb +59 -0
  410. data/lib/advanced_billing/models/preview_allocations_request.rb +69 -0
  411. data/lib/advanced_billing/models/price.rb +98 -0
  412. data/lib/advanced_billing/models/price_point.rb +172 -0
  413. data/lib/advanced_billing/models/price_point_type.rb +30 -0
  414. data/lib/advanced_billing/models/pricing_scheme.rb +31 -0
  415. data/lib/advanced_billing/models/product.rb +506 -0
  416. data/lib/advanced_billing/models/product_family.rb +120 -0
  417. data/lib/advanced_billing/models/product_family_response.rb +50 -0
  418. data/lib/advanced_billing/models/product_price_point.rb +289 -0
  419. data/lib/advanced_billing/models/product_price_point_currency_price.rb +99 -0
  420. data/lib/advanced_billing/models/product_price_point_response.rb +48 -0
  421. data/lib/advanced_billing/models/product_response.rb +48 -0
  422. data/lib/advanced_billing/models/proforma_custom_field.rb +87 -0
  423. data/lib/advanced_billing/models/proforma_error.rb +51 -0
  424. data/lib/advanced_billing/models/proforma_invoice.rb +463 -0
  425. data/lib/advanced_billing/models/proforma_invoice_credit.rb +80 -0
  426. data/lib/advanced_billing/models/proforma_invoice_discount.rb +108 -0
  427. data/lib/advanced_billing/models/proforma_invoice_discount_breakout.rb +61 -0
  428. data/lib/advanced_billing/models/proforma_invoice_issued.rb +202 -0
  429. data/lib/advanced_billing/models/proforma_invoice_payment.rb +80 -0
  430. data/lib/advanced_billing/models/proforma_invoice_preview.rb +463 -0
  431. data/lib/advanced_billing/models/proforma_invoice_tax.rb +116 -0
  432. data/lib/advanced_billing/models/proforma_invoice_tax_breakout.rb +60 -0
  433. data/lib/advanced_billing/models/proration.rb +52 -0
  434. data/lib/advanced_billing/models/public_key.rb +70 -0
  435. data/lib/advanced_billing/models/public_signup_page.rb +92 -0
  436. data/lib/advanced_billing/models/quantity_based_component.rb +303 -0
  437. data/lib/advanced_billing/models/reactivate_subscription_group_request.rb +60 -0
  438. data/lib/advanced_billing/models/reactivate_subscription_group_response.rb +130 -0
  439. data/lib/advanced_billing/models/reactivate_subscription_request.rb +122 -0
  440. data/lib/advanced_billing/models/reactivation_billing.rb +66 -0
  441. data/lib/advanced_billing/models/reactivation_charge.rb +30 -0
  442. data/lib/advanced_billing/models/read_payment_profile_response.rb +64 -0
  443. data/lib/advanced_billing/models/reason_code.rb +105 -0
  444. data/lib/advanced_billing/models/reason_code_response.rb +48 -0
  445. data/lib/advanced_billing/models/reason_codes_json_response.rb +50 -0
  446. data/lib/advanced_billing/models/record_payment_request.rb +48 -0
  447. data/lib/advanced_billing/models/recurring_scheme.rb +26 -0
  448. data/lib/advanced_billing/models/referral_code.rb +79 -0
  449. data/lib/advanced_billing/models/referral_validation_response.rb +50 -0
  450. data/lib/advanced_billing/models/refund.rb +124 -0
  451. data/lib/advanced_billing/models/refund_consolidated_invoice.rb +125 -0
  452. data/lib/advanced_billing/models/refund_invoice.rb +124 -0
  453. data/lib/advanced_billing/models/refund_invoice_event_data.rb +171 -0
  454. data/lib/advanced_billing/models/refund_invoice_request.rb +64 -0
  455. data/lib/advanced_billing/models/refund_prepayment.rb +106 -0
  456. data/lib/advanced_billing/models/refund_prepayment_aggregated_error.rb +50 -0
  457. data/lib/advanced_billing/models/refund_prepayment_base_refund_error.rb +50 -0
  458. data/lib/advanced_billing/models/refund_prepayment_request.rb +48 -0
  459. data/lib/advanced_billing/models/refund_success.rb +92 -0
  460. data/lib/advanced_billing/models/remove_payment_event_data.rb +131 -0
  461. data/lib/advanced_billing/models/renewal_preview.rb +157 -0
  462. data/lib/advanced_billing/models/renewal_preview_component.rb +91 -0
  463. data/lib/advanced_billing/models/renewal_preview_line_item.rb +161 -0
  464. data/lib/advanced_billing/models/renewal_preview_request.rb +62 -0
  465. data/lib/advanced_billing/models/renewal_preview_response.rb +49 -0
  466. data/lib/advanced_billing/models/replay_webhooks_request.rb +48 -0
  467. data/lib/advanced_billing/models/replay_webhooks_response.rb +50 -0
  468. data/lib/advanced_billing/models/resent_invitation.rb +81 -0
  469. data/lib/advanced_billing/models/resource_type.rb +23 -0
  470. data/lib/advanced_billing/models/restriction_type.rb +23 -0
  471. data/lib/advanced_billing/models/resume_options.rb +75 -0
  472. data/lib/advanced_billing/models/resumption_charge.rb +27 -0
  473. data/lib/advanced_billing/models/revoked_invitation.rb +71 -0
  474. data/lib/advanced_billing/models/sale_rep.rb +97 -0
  475. data/lib/advanced_billing/models/sale_rep_item_mrr.rb +68 -0
  476. data/lib/advanced_billing/models/sale_rep_settings.rb +109 -0
  477. data/lib/advanced_billing/models/sale_rep_subscription.rb +137 -0
  478. data/lib/advanced_billing/models/segment.rb +189 -0
  479. data/lib/advanced_billing/models/segment_price.rb +132 -0
  480. data/lib/advanced_billing/models/segment_response.rb +50 -0
  481. data/lib/advanced_billing/models/seller.rb +89 -0
  482. data/lib/advanced_billing/models/send_invoice_request.rb +72 -0
  483. data/lib/advanced_billing/models/service_credit.rb +90 -0
  484. data/lib/advanced_billing/models/service_credit_response.rb +48 -0
  485. data/lib/advanced_billing/models/service_credit_type.rb +23 -0
  486. data/lib/advanced_billing/models/shipping_address.rb +113 -0
  487. data/lib/advanced_billing/models/signup_proforma_preview.rb +62 -0
  488. data/lib/advanced_billing/models/signup_proforma_preview_response.rb +50 -0
  489. data/lib/advanced_billing/models/site.rb +212 -0
  490. data/lib/advanced_billing/models/site_response.rb +48 -0
  491. data/lib/advanced_billing/models/site_statistics.rb +171 -0
  492. data/lib/advanced_billing/models/site_summary.rb +87 -0
  493. data/lib/advanced_billing/models/snap_day.rb +21 -0
  494. data/lib/advanced_billing/models/sorting_direction.rb +23 -0
  495. data/lib/advanced_billing/models/status.rb +37 -0
  496. data/lib/advanced_billing/models/status1.rb +23 -0
  497. data/lib/advanced_billing/models/subscription.rb +776 -0
  498. data/lib/advanced_billing/models/subscription_bank_account.rb +281 -0
  499. data/lib/advanced_billing/models/subscription_component.rb +400 -0
  500. data/lib/advanced_billing/models/subscription_component_allocation_error_item.rb +59 -0
  501. data/lib/advanced_billing/models/subscription_component_response.rb +50 -0
  502. data/lib/advanced_billing/models/subscription_component_subscription.rb +70 -0
  503. data/lib/advanced_billing/models/subscription_date_field.rb +44 -0
  504. data/lib/advanced_billing/models/subscription_group.rb +94 -0
  505. data/lib/advanced_billing/models/subscription_group_balances.rb +80 -0
  506. data/lib/advanced_billing/models/subscription_group_bank_account.rb +228 -0
  507. data/lib/advanced_billing/models/subscription_group_component_custom_price.rb +105 -0
  508. data/lib/advanced_billing/models/subscription_group_credit_card.rb +266 -0
  509. data/lib/advanced_billing/models/subscription_group_customer.rb +87 -0
  510. data/lib/advanced_billing/models/subscription_group_inlined.rb +92 -0
  511. data/lib/advanced_billing/models/subscription_group_item.rb +147 -0
  512. data/lib/advanced_billing/models/subscription_group_member_error.rb +68 -0
  513. data/lib/advanced_billing/models/subscription_group_payment_profile.rb +79 -0
  514. data/lib/advanced_billing/models/subscription_group_prepayment.rb +72 -0
  515. data/lib/advanced_billing/models/subscription_group_prepayment_method.rb +35 -0
  516. data/lib/advanced_billing/models/subscription_group_prepayment_request.rb +48 -0
  517. data/lib/advanced_billing/models/subscription_group_prepayment_response.rb +90 -0
  518. data/lib/advanced_billing/models/subscription_group_response.rb +49 -0
  519. data/lib/advanced_billing/models/subscription_group_signup.rb +153 -0
  520. data/lib/advanced_billing/models/subscription_group_signup_component.rb +108 -0
  521. data/lib/advanced_billing/models/subscription_group_signup_error.rb +109 -0
  522. data/lib/advanced_billing/models/subscription_group_signup_failure.rb +84 -0
  523. data/lib/advanced_billing/models/subscription_group_signup_failure_data.rb +146 -0
  524. data/lib/advanced_billing/models/subscription_group_signup_item.rb +200 -0
  525. data/lib/advanced_billing/models/subscription_group_signup_request.rb +49 -0
  526. data/lib/advanced_billing/models/subscription_group_signup_response.rb +167 -0
  527. data/lib/advanced_billing/models/subscription_group_signup_success.rb +84 -0
  528. data/lib/advanced_billing/models/subscription_group_signup_success_data.rb +170 -0
  529. data/lib/advanced_billing/models/subscription_group_subscription_error.rb +86 -0
  530. data/lib/advanced_billing/models/subscription_group_update_error.rb +59 -0
  531. data/lib/advanced_billing/models/subscription_include.rb +23 -0
  532. data/lib/advanced_billing/models/subscription_included_coupon.rb +121 -0
  533. data/lib/advanced_billing/models/subscription_list_date_field.rb +20 -0
  534. data/lib/advanced_billing/models/subscription_migration_preview.rb +88 -0
  535. data/lib/advanced_billing/models/subscription_migration_preview_options.rb +158 -0
  536. data/lib/advanced_billing/models/subscription_migration_preview_request.rb +49 -0
  537. data/lib/advanced_billing/models/subscription_migration_preview_response.rb +48 -0
  538. data/lib/advanced_billing/models/subscription_mrr.rb +69 -0
  539. data/lib/advanced_billing/models/subscription_mrr_breakout.rb +58 -0
  540. data/lib/advanced_billing/models/subscription_mrr_response.rb +57 -0
  541. data/lib/advanced_billing/models/subscription_note.rb +97 -0
  542. data/lib/advanced_billing/models/subscription_note_response.rb +48 -0
  543. data/lib/advanced_billing/models/subscription_preview.rb +62 -0
  544. data/lib/advanced_billing/models/subscription_preview_response.rb +49 -0
  545. data/lib/advanced_billing/models/subscription_product_change.rb +80 -0
  546. data/lib/advanced_billing/models/subscription_product_migration.rb +148 -0
  547. data/lib/advanced_billing/models/subscription_product_migration_request.rb +48 -0
  548. data/lib/advanced_billing/models/subscription_purge_type.rb +23 -0
  549. data/lib/advanced_billing/models/subscription_response.rb +50 -0
  550. data/lib/advanced_billing/models/subscription_sort.rb +35 -0
  551. data/lib/advanced_billing/models/subscription_state.rb +53 -0
  552. data/lib/advanced_billing/models/subscription_state_change.rb +81 -0
  553. data/lib/advanced_billing/models/tax_configuration.rb +73 -0
  554. data/lib/advanced_billing/models/tax_configuration_kind.rb +29 -0
  555. data/lib/advanced_billing/models/tax_destination_address.rb +29 -0
  556. data/lib/advanced_billing/models/too_many_management_link_requests.rb +63 -0
  557. data/lib/advanced_billing/models/update_allocation_expiration_date.rb +50 -0
  558. data/lib/advanced_billing/models/update_component.rb +137 -0
  559. data/lib/advanced_billing/models/update_component_price_point.rb +68 -0
  560. data/lib/advanced_billing/models/update_component_price_point_request.rb +51 -0
  561. data/lib/advanced_billing/models/update_component_request.rb +48 -0
  562. data/lib/advanced_billing/models/update_coupon_currency.rb +56 -0
  563. data/lib/advanced_billing/models/update_currency_price.rb +56 -0
  564. data/lib/advanced_billing/models/update_currency_prices_request.rb +57 -0
  565. data/lib/advanced_billing/models/update_customer.rb +211 -0
  566. data/lib/advanced_billing/models/update_customer_request.rb +48 -0
  567. data/lib/advanced_billing/models/update_endpoint.rb +57 -0
  568. data/lib/advanced_billing/models/update_endpoint_request.rb +48 -0
  569. data/lib/advanced_billing/models/update_metadata.rb +68 -0
  570. data/lib/advanced_billing/models/update_metadata_request.rb +50 -0
  571. data/lib/advanced_billing/models/update_metafield.rb +103 -0
  572. data/lib/advanced_billing/models/update_metafields_request.rb +62 -0
  573. data/lib/advanced_billing/models/update_payment_profile.rb +187 -0
  574. data/lib/advanced_billing/models/update_payment_profile_request.rb +49 -0
  575. data/lib/advanced_billing/models/update_payment_profile_response.rb +49 -0
  576. data/lib/advanced_billing/models/update_price.rb +89 -0
  577. data/lib/advanced_billing/models/update_product_price_point.rb +60 -0
  578. data/lib/advanced_billing/models/update_product_price_point_request.rb +48 -0
  579. data/lib/advanced_billing/models/update_reason_code.rb +68 -0
  580. data/lib/advanced_billing/models/update_reason_code_request.rb +48 -0
  581. data/lib/advanced_billing/models/update_segment.rb +74 -0
  582. data/lib/advanced_billing/models/update_segment_request.rb +48 -0
  583. data/lib/advanced_billing/models/update_subscription.rb +270 -0
  584. data/lib/advanced_billing/models/update_subscription_component.rb +70 -0
  585. data/lib/advanced_billing/models/update_subscription_group.rb +50 -0
  586. data/lib/advanced_billing/models/update_subscription_group_request.rb +49 -0
  587. data/lib/advanced_billing/models/update_subscription_note.rb +56 -0
  588. data/lib/advanced_billing/models/update_subscription_note_request.rb +48 -0
  589. data/lib/advanced_billing/models/update_subscription_request.rb +48 -0
  590. data/lib/advanced_billing/models/updated_payment_profile.rb +255 -0
  591. data/lib/advanced_billing/models/upsert_prepaid_configuration.rb +104 -0
  592. data/lib/advanced_billing/models/upsert_prepaid_configuration_request.rb +49 -0
  593. data/lib/advanced_billing/models/usage.rb +141 -0
  594. data/lib/advanced_billing/models/usage_response.rb +48 -0
  595. data/lib/advanced_billing/models/void_invoice.rb +48 -0
  596. data/lib/advanced_billing/models/void_invoice_event_data.rb +111 -0
  597. data/lib/advanced_billing/models/void_invoice_event_data1.rb +100 -0
  598. data/lib/advanced_billing/models/void_invoice_request.rb +48 -0
  599. data/lib/advanced_billing/models/webhook.rb +165 -0
  600. data/lib/advanced_billing/models/webhook_order.rb +23 -0
  601. data/lib/advanced_billing/models/webhook_response.rb +50 -0
  602. data/lib/advanced_billing/models/webhook_status.rb +29 -0
  603. data/lib/advanced_billing/models/webhook_subscription.rb +124 -0
  604. data/lib/advanced_billing/utilities/date_time_helper.rb +11 -0
  605. data/lib/advanced_billing/utilities/file_wrapper.rb +16 -0
  606. data/lib/advanced_billing/utilities/union_type_lookup.rb +1240 -0
  607. data/lib/advanced_billing.rb +669 -0
  608. metadata +614 -111
  609. data/bin/arch +0 -1
  610. data/bin/ash +0 -1
  611. data/bin/base64 +0 -1
  612. data/bin/bbconfig +0 -1
  613. data/bin/busybox +0 -0
  614. data/bin/cat +0 -1
  615. data/bin/chattr +0 -1
  616. data/bin/chgrp +0 -1
  617. data/bin/chmod +0 -1
  618. data/bin/chown +0 -1
  619. data/bin/cp +0 -1
  620. data/bin/date +0 -1
  621. data/bin/dd +0 -1
  622. data/bin/df +0 -1
  623. data/bin/dmesg +0 -1
  624. data/bin/dnsdomainname +0 -1
  625. data/bin/dumpkmap +0 -1
  626. data/bin/echo +0 -1
  627. data/bin/ed +0 -1
  628. data/bin/egrep +0 -1
  629. data/bin/false +0 -1
  630. data/bin/fatattr +0 -1
  631. data/bin/fdflush +0 -1
  632. data/bin/fgrep +0 -1
  633. data/bin/fsync +0 -1
  634. data/bin/getopt +0 -1
  635. data/bin/grep +0 -1
  636. data/bin/gunzip +0 -1
  637. data/bin/gzip +0 -1
  638. data/bin/hostname +0 -1
  639. data/bin/ionice +0 -1
  640. data/bin/iostat +0 -1
  641. data/bin/ipcalc +0 -1
  642. data/bin/kbd_mode +0 -1
  643. data/bin/kill +0 -1
  644. data/bin/link +0 -1
  645. data/bin/linux32 +0 -1
  646. data/bin/linux64 +0 -1
  647. data/bin/ln +0 -1
  648. data/bin/login +0 -1
  649. data/bin/ls +0 -1
  650. data/bin/lsattr +0 -1
  651. data/bin/lzop +0 -1
  652. data/bin/makemime +0 -1
  653. data/bin/mkdir +0 -1
  654. data/bin/mknod +0 -1
  655. data/bin/mktemp +0 -1
  656. data/bin/more +0 -1
  657. data/bin/mount +0 -1
  658. data/bin/mountpoint +0 -1
  659. data/bin/mpstat +0 -1
  660. data/bin/mv +0 -1
  661. data/bin/netstat +0 -1
  662. data/bin/nice +0 -1
  663. data/bin/pidof +0 -0
  664. data/bin/ping +0 -1
  665. data/bin/ping6 +0 -1
  666. data/bin/pipe_progress +0 -1
  667. data/bin/printenv +0 -1
  668. data/bin/ps +0 -0
  669. data/bin/pwait +0 -0
  670. data/bin/pwd +0 -1
  671. data/bin/reformime +0 -1
  672. data/bin/rev +0 -1
  673. data/bin/rm +0 -1
  674. data/bin/rmdir +0 -1
  675. data/bin/run-parts +0 -1
  676. data/bin/sed +0 -1
  677. data/bin/setpriv +0 -1
  678. data/bin/setserial +0 -1
  679. data/bin/sh +0 -1
  680. data/bin/slabtop +0 -0
  681. data/bin/sleep +0 -1
  682. data/bin/stat +0 -1
  683. data/bin/stty +0 -1
  684. data/bin/su +0 -1
  685. data/bin/sync +0 -1
  686. data/bin/tar +0 -1
  687. data/bin/tload +0 -0
  688. data/bin/touch +0 -1
  689. data/bin/true +0 -1
  690. data/bin/umount +0 -1
  691. data/bin/uname +0 -1
  692. data/bin/usleep +0 -1
  693. data/bin/vmstat +0 -0
  694. data/bin/w +0 -0
  695. data/bin/watch +0 -0
  696. data/bin/zcat +0 -1
  697. data/lib/apk/db/installed +0 -3582
  698. data/lib/apk/db/lock +0 -0
  699. data/lib/apk/db/scripts.tar +0 -0
  700. data/lib/apk/db/triggers +0 -2
  701. data/lib/ld-musl-x86_64.so.1 +0 -0
  702. data/lib/libapk.so.3.12.0 +0 -0
  703. data/lib/libc.musl-x86_64.so.1 +0 -1
  704. data/lib/libcrypto.so.1.1 +0 -0
  705. data/lib/libprocps.so.8 +0 -1
  706. data/lib/libprocps.so.8.0.3 +0 -0
  707. data/lib/libssl.so.1.1 +0 -0
  708. data/lib/libz.so +0 -1
  709. data/lib/libz.so.1 +0 -1
  710. data/lib/libz.so.1.2.12 +0 -0
  711. data/lib/sysctl.d/00-alpine.conf +0 -40
@@ -0,0 +1,732 @@
1
+ # advanced_billing
2
+ #
3
+ # This file was automatically generated by APIMATIC v2.0
4
+ # ( https://apimatic.io ).
5
+
6
+ module AdvancedBilling
7
+ # PaymentProfilesController
8
+ class PaymentProfilesController < BaseController
9
+ # Use this endpoint to create a payment profile for a customer.
10
+ # Payment Profiles house the credit card, ACH (Authorize.Net or Stripe
11
+ # only,) or PayPal (Braintree only,) data for a customer. The payment
12
+ # information is attached to the customer within Chargify, as opposed to the
13
+ # Subscription itself.
14
+ # You must include a customer_id so that Chargify will attach it to the
15
+ # customer entry. If no customer_id is included the API will return a 404.
16
+ # ## Create a Payment Profile for ACH usage
17
+ # If you would like to create a payment method that is a Bank Account
18
+ # applicable for ACH payments use the following:
19
+ # ```json
20
+ # {
21
+ # "payment_profile": {
22
+ # "customer_id": [Valid-Customer-ID],
23
+ # "bank_name": "Best Bank",
24
+ # "bank_routing_number": "021000089",
25
+ # "bank_account_number": "111111111111",
26
+ # "bank_account_type": "checking",
27
+ # "bank_account_holder_type": "business",
28
+ # "payment_type": "bank_account"
29
+ # }
30
+ # }
31
+ # ```
32
+ # ## Taxable Subscriptions
33
+ # If your subscriber pays taxes on their purchased product, and you are
34
+ # attempting to create or update the `payment_profile`, complete address
35
+ # information is required. For information on required address formatting to
36
+ # allow your subscriber to be taxed, please see our documentation
37
+ # [here](https://developers.chargify.com/docs/developer-docs/d2e9e34db740e-s
38
+ # ignups#taxes)
39
+ # ## Payment Profile Documentation
40
+ # Full documentation on how Payment Profiles operate within Chargify can be
41
+ # located under the following links:
42
+ # + [Subscriber Payment
43
+ # Details](https://maxio-chargify.zendesk.com/hc/en-us/articles/540521255834
44
+ # 9-Customers-Reference#customers-reference-0-0)
45
+ # + [Self Service
46
+ # Pages](https://maxio-chargify.zendesk.com/hc/en-us/articles/5404759627021)
47
+ # (Allows credit card updates by Subscriber)
48
+ # + [Public Signup Pages payment
49
+ # settings](https://maxio-chargify.zendesk.com/hc/en-us/articles/54052677543
50
+ # 81-Individual-Page-Settings#credit-card-settings)
51
+ # ## Create a Payment Profile with a Chargify.js token
52
+ # ```json
53
+ # {
54
+ # "payment_profile": {
55
+ # "customer_id": 1036,
56
+ # "chargify_token": "tok_w68qcpnftyv53jk33jv6wk3w"
57
+ # }
58
+ # }
59
+ # ```
60
+ # ## Active Payment Methods
61
+ # Creating a new payment profile for a Customer via the API will not make
62
+ # that Payment Profile current for any of the Customer’s Subscriptions. In
63
+ # order to utilize the payment profile as the default, it must be set as the
64
+ # default payment profile for the subscription or subscription group.
65
+ # ## Requirements
66
+ # Either the full_number, expiration_month, and expiration_year or if you
67
+ # have an existing vault_token from your gateway, that vault_token and the
68
+ # current_vault are required.
69
+ # Passing in the vault_token and current_vault are only allowed when
70
+ # creating a new payment profile.
71
+ # ### Taxable Subscriptions
72
+ # If your subscriber pays taxes on their purchased product, and you are
73
+ # attempting to create or update the `payment_profile`, complete address
74
+ # information is required. For information on required address formatting to
75
+ # allow your subscriber to be taxed, please see our documentation
76
+ # [here](https://developers.chargify.com/docs/developer-docs/d2e9e34db740e-s
77
+ # ignups#taxes)
78
+ # ## BraintreeBlue
79
+ # Some merchants use Braintree JavaScript libraries directly and then pass
80
+ # `payment_method_nonce` and/or `paypal_email` to create a payment profile.
81
+ # This implementation is deprecated and does not handle 3D Secure. Instead,
82
+ # we have provided
83
+ # [Chargify.js](https://developers.chargify.com/docs/developer-docs/ZG9jOjE0
84
+ # NjAzNDI0-overview) which is continuously improved and supports Credit
85
+ # Cards (along with 3D Secure), PayPal and ApplePay payment types.
86
+ # ## GoCardless
87
+ # For more information on GoCardless, please view the following resources:
88
+ # + [Full documentation on
89
+ # GoCardless](https://maxio-chargify.zendesk.com/hc/en-us/articles/540450188
90
+ # 9677)
91
+ # + [Using Chargify.js with GoCardless - minimal
92
+ # example](https://developers.chargify.com/docs/developer-docs/ZG9jOjE0NjAzN
93
+ # DIy-examples#minimal-example-with-direct-debit-gocardless-gateway)
94
+ # + [Using Chargify.js with GoCardless - full
95
+ # example](https://developers.chargify.com/docs/developer-docs/ZG9jOjE0NjAzN
96
+ # DIy-examples#full-example-with-direct-debit-gocardless-gateway)
97
+ # ### GoCardless with Local Bank Details
98
+ # Following examples create customer, bank account and mandate in
99
+ # GoCardless:
100
+ # ```json
101
+ # {
102
+ # "payment_profile": {
103
+ # "customer_id": "Valid-Customer-ID",
104
+ # "bank_name": "Royal Bank of France",
105
+ # "bank_account_number": "0000000",
106
+ # "bank_routing_number": "0003",
107
+ # "bank_branch_code": "00006",
108
+ # "payment_type": "bank_account",
109
+ # "billing_address": "20 Place de la Gare",
110
+ # "billing_city": "Colombes",
111
+ # "billing_state": "Île-de-France",
112
+ # "billing_zip": "92700",
113
+ # "billing_country": "FR"
114
+ # }
115
+ # }
116
+ # ```
117
+ # ### GoCardless with IBAN
118
+ # ```json
119
+ # {
120
+ # "payment_profile": {
121
+ # "customer_id": "24907598",
122
+ # "bank_name": "French Bank",
123
+ # "bank_iban": "FR1420041010050500013M02606",
124
+ # "payment_type": "bank_account",
125
+ # "billing_address": "20 Place de la Gare",
126
+ # "billing_city": "Colombes",
127
+ # "billing_state": "Île-de-France",
128
+ # "billing_zip": "92700",
129
+ # "billing_country": "FR"
130
+ # }
131
+ # }
132
+ # ```
133
+ # ### Importing GoCardless
134
+ # If the customer, bank account, and mandate already exist in GoCardless, a
135
+ # payment profile can be created by using the IDs. In order to create masked
136
+ # versions of `bank_account_number` and `bank_routing_number` that are used
137
+ # to display within Chargify Admin UI, you can pass the last four digits for
138
+ # this fields which then will be saved in this form
139
+ # `XXXX[four-provided-digits]`.
140
+ # ```json
141
+ # {
142
+ # "payment_profile": {
143
+ # "customer_id": "24907598",
144
+ # "customer_vault_token": [Existing GoCardless Customer ID]
145
+ # "vault_token": [Existing GoCardless Mandate ID],
146
+ # "current_vault": "gocardless",
147
+ # "bank_name": "French Bank",
148
+ # "bank_account_number": [Last Four Of The Existing Account Number or
149
+ # IBAN if applicable],
150
+ # "bank_routing_number": [Last Four Of The Existing Routing Number],
151
+ # "payment_type": "bank_account",
152
+ # "billing_address": "20 Place de la Gare",
153
+ # "billing_city": "Colombes",
154
+ # "billing_state": "Île-de-France",
155
+ # "billing_zip": "92700",
156
+ # "billing_country": "FR"
157
+ # }
158
+ # }
159
+ # ```
160
+ # ## SEPA Direct Debit
161
+ # For more information on Stripe SEPA Direct Debit, please view the
162
+ # following resources:
163
+ # + [Full documentation on Stripe SEPA Direct
164
+ # Debit](https://maxio-chargify.zendesk.com/hc/en-us/articles/5405050826765-
165
+ # Stripe-SEPA-and-BECS-Direct-Debit)
166
+ # + [Using Chargify.js with Stripe Direct Debit - minimal
167
+ # example](https://developers.chargify.com/docs/developer-docs/ZG9jOjE0NjAzN
168
+ # DIy-examples#minimal-example-with-sepa-or-becs-direct-debit-stripe-gateway
169
+ # )
170
+ # + [Using Chargify.js with Stripe Direct Debit - full
171
+ # example](https://developers.chargify.com/docs/developer-docs/ZG9jOjE0NjAzN
172
+ # DIy-examples#full-example-with-sepa-direct-debit-stripe-gateway)
173
+ # ### Stripe SEPA Direct Debit Payment Profiles
174
+ # The following example creates a customer, bank account and mandate in
175
+ # Stripe:
176
+ # ```json
177
+ # {
178
+ # "payment_profile": {
179
+ # "customer_id": "24907598",
180
+ # "bank_name": "Deutsche bank",
181
+ # "bank_iban": "DE89370400440532013000",
182
+ # "payment_type": "bank_account",
183
+ # "billing_address": "Test",
184
+ # "billing_city": "Berlin",
185
+ # "billing_state": "Brandenburg",
186
+ # "billing_zip": "12345",
187
+ # "billing_country": "DE"
188
+ # }
189
+ # }
190
+ # ```
191
+ # ## Stripe BECS Direct Debit
192
+ # For more information on Stripe BECS Direct Debit, please view the
193
+ # following resources:
194
+ # + [Full documentation on Stripe BECS Direct
195
+ # Debit](https://maxio-chargify.zendesk.com/hc/en-us/articles/5405050826765-
196
+ # Stripe-SEPA-and-BECS-Direct-Debit)
197
+ # + [Using Chargify.js with Stripe BECS Direct Debit - minimal
198
+ # example](https://developers.chargify.com/docs/developer-docs/ZG9jOjE0NjAzN
199
+ # DIy-examples#minimal-example-with-sepa-or-becs-direct-debit-stripe-gateway
200
+ # )
201
+ # + [Using Chargify.js with Stripe BECS Direct Debit - full
202
+ # example](https://developers.chargify.com/docs/developer-docs/ZG9jOjE0NjAzN
203
+ # DIy-examples#full-example-with-sepa-direct-debit-stripe-gateway)
204
+ # ### Stripe BECS Direct Debit Payment Profiles
205
+ # The following example creates a customer, bank account and mandate in
206
+ # Stripe:
207
+ # ```json
208
+ # {
209
+ # "payment_profile": {
210
+ # "customer_id": "24907598",
211
+ # "bank_name": "Australian bank",
212
+ # "bank_branch_code": "000000",
213
+ # "bank_account_number": "000123456"
214
+ # "payment_type": "bank_account",
215
+ # "billing_address": "Test",
216
+ # "billing_city": "Stony Rise",
217
+ # "billing_state": "Tasmania",
218
+ # "billing_zip": "12345",
219
+ # "billing_country": "AU"
220
+ # }
221
+ # }
222
+ # ```
223
+ # ## 3D Secure - Checkout
224
+ # It may happen that a payment needs 3D Secure Authentication when the
225
+ # payment profile is created; this is referred to in our help docs as a
226
+ # [post-authentication
227
+ # flow](https://maxio-chargify.zendesk.com/hc/en-us/articles/5405177432077#p
228
+ # sd2-flows-pre-authentication-and-post-authentication). The server returns
229
+ # `422 Unprocessable Entity` in this case with the following response:
230
+ # ```json
231
+ # {
232
+ # "jsonapi": {
233
+ # "version": "1.0"
234
+ # },
235
+ # "errors": [
236
+ # {
237
+ # "title": "This card requires 3DSecure verification.",
238
+ # "detail": "This card requires 3D secure authentication.
239
+ # Redirect the customer to the URL from the action_link attribute to
240
+ # authenticate. Attach callback_url param to this URL if you want to be
241
+ # notified about the result of 3D Secure authentication. Attach redirect_url
242
+ # param to this URL if you want to redirect a customer back to your page
243
+ # after 3D Secure authentication. Example:
244
+ # https://checkout-test.chargifypay.test/3d-secure/checkout/pay_uerzhsxd5uhk
245
+ # bodx5jhvkg6yeu?one_time_token_id=93&callback_url=http://localhost:4000&red
246
+ # irect_url=https://yourpage.com will do a POST request to
247
+ # https://localhost:4000 after credit card is authenticated and will
248
+ # redirect a customer to https://yourpage.com after 3DS authentication.",
249
+ # "links": {
250
+ # "action_link":
251
+ # "https://checkout-test.chargifypay.test/3d-secure/checkout/pay_uerzhsxd5uh
252
+ # kbodx5jhvkg6yeu?one_time_token_id=93"
253
+ # }
254
+ # }
255
+ # ]
256
+ # }
257
+ # ```
258
+ # To let the customer go through 3D Secure Authentication, they need to be
259
+ # redirected to the URL specified in `action_link`.
260
+ # Optionally, you can specify `callback_url` parameter in the `action_link`
261
+ # URL if you’d like to be notified about the result of 3D Secure
262
+ # Authentication. The `callback_url` will return the following information:
263
+ # - whether the authentication was successful (`success`)
264
+ # - the payment profile ID (`payment_profile_id`)
265
+ # Lastly, you can also specify a `redirect_url` parameter within the
266
+ # `action_link` URL if you’d like to redirect a customer back to your site.
267
+ # It is not possible to use `action_link` in an iframe inside a custom
268
+ # application. You have to redirect the customer directly to the
269
+ # `action_link`, then, to be notified about the result, use `redirect_url`
270
+ # or `callback_url`.
271
+ # The final URL that you send a customer to complete 3D Secure may resemble
272
+ # the following, where the first half is the `action_link` and the second
273
+ # half contains a `redirect_url` and `callback_url`:
274
+ # `https://checkout-test.chargifypay.test/3d-secure/checkout/pay_uerzhsxd5uh
275
+ # kbodx5jhvkg6yeu?one_time_token_id=93&callback_url=http://localhost:4000&re
276
+ # direct_url=https://yourpage.com`
277
+ # ### Example Redirect Flow
278
+ # You may wish to redirect customers to different pages depending on whether
279
+ # their SCA was performed successfully. Here's an example flow to use as a
280
+ # reference:
281
+ # 1. Create a payment profile via API; it requires 3DS
282
+ # 2. You receive a `action_link` in the response.
283
+ # 3. Use this `action_link` to, for example, connect with your internal
284
+ # resources or generate a session_id
285
+ # 4. Include 1 of those attributes inside the `callback_url` and
286
+ # `redirect_url` to be aware which “session” this applies to
287
+ # 5. Redirect the customer to the `action_link` with `callback_url` and
288
+ # `redirect_url` applied
289
+ # 6. After the customer finishes 3DS authentication, we let you know the
290
+ # result by making a request to applied `callback_url`.
291
+ # 7. After that, we redirect the customer to the `redirect_url`; at this
292
+ # point the result of authentication is known
293
+ # 8. Optionally, you can use the applied "msg" param in the `redirect_url`
294
+ # to determine whether it was successful or not
295
+ # @param [CreatePaymentProfileRequest] body Optional parameter: When
296
+ # following the IBAN or the Local Bank details examples, a customer, bank
297
+ # account and mandate will be created in your current vault. If the
298
+ # customer, bank account, and mandate already exist in your vault, follow
299
+ # the Import example to link the payment profile into Chargify.
300
+ # @return [CreatePaymentProfileResponse] response from the API call.
301
+ def create_payment_profile(body: nil)
302
+ new_api_call_builder
303
+ .request(new_request_builder(HttpMethodEnum::POST,
304
+ '/payment_profiles.json',
305
+ Server::DEFAULT)
306
+ .header_param(new_parameter('application/json', key: 'Content-Type'))
307
+ .body_param(new_parameter(body))
308
+ .header_param(new_parameter('application/json', key: 'accept'))
309
+ .body_serializer(proc do |param| param.to_json unless param.nil? end)
310
+ .auth(Single.new('BasicAuth')))
311
+ .response(new_response_handler
312
+ .is_nullify404(true)
313
+ .deserializer(APIHelper.method(:custom_type_deserializer))
314
+ .deserialize_into(CreatePaymentProfileResponse.method(:from_hash))
315
+ .local_error('404',
316
+ 'Not Found',
317
+ APIException))
318
+ .execute
319
+ end
320
+
321
+ # Deletes an unused payment profile.
322
+ # If the payment profile is in use by one or more subscriptions or groups, a
323
+ # 422 and error message will be returned.
324
+ # @param [String] payment_profile_id Required parameter: The Chargify id of
325
+ # the payment profile
326
+ # @return [void] response from the API call.
327
+ def delete_unused_payment_profile(payment_profile_id)
328
+ new_api_call_builder
329
+ .request(new_request_builder(HttpMethodEnum::DELETE,
330
+ '/payment_profiles/{payment_profile_id}.json',
331
+ Server::DEFAULT)
332
+ .template_param(new_parameter(payment_profile_id, key: 'payment_profile_id')
333
+ .is_required(true)
334
+ .should_encode(true))
335
+ .auth(Single.new('BasicAuth')))
336
+ .response(new_response_handler
337
+ .is_nullify404(true)
338
+ .is_response_void(true)
339
+ .local_error('422',
340
+ 'Unprocessable Entity (WebDAV)',
341
+ ErrorListResponseException))
342
+ .execute
343
+ end
344
+
345
+ # This will delete a payment profile belonging to the customer on the
346
+ # subscription.
347
+ # + If the customer has multiple subscriptions, the payment profile will be
348
+ # removed from all of them.
349
+ # + If you delete the default payment profile for a subscription, you will
350
+ # need to specify another payment profile to be the default through the api,
351
+ # or either prompt the user to enter a card in the billing portal or on the
352
+ # self-service page, or visit the Payment Details tab on the subscription in
353
+ # the Admin UI and use the “Add New Credit Card” or “Make Active Payment
354
+ # Method” link, (depending on whether there are other cards present).
355
+ # @param [String] subscription_id Required parameter: The Chargify id of the
356
+ # subscription
357
+ # @param [String] payment_profile_id Required parameter: The Chargify id of
358
+ # the payment profile
359
+ # @return [void] response from the API call.
360
+ def delete_subscriptions_payment_profile(subscription_id,
361
+ payment_profile_id)
362
+ new_api_call_builder
363
+ .request(new_request_builder(HttpMethodEnum::DELETE,
364
+ '/subscriptions/{subscription_id}/payment_profiles/{payment_profile_id}.json',
365
+ Server::DEFAULT)
366
+ .template_param(new_parameter(subscription_id, key: 'subscription_id')
367
+ .is_required(true)
368
+ .should_encode(true))
369
+ .template_param(new_parameter(payment_profile_id, key: 'payment_profile_id')
370
+ .is_required(true)
371
+ .should_encode(true))
372
+ .auth(Single.new('BasicAuth')))
373
+ .response(new_response_handler
374
+ .is_nullify404(true)
375
+ .is_response_void(true))
376
+ .execute
377
+ end
378
+
379
+ # This will delete a Payment Profile belonging to a Subscription Group.
380
+ # **Note**: If the Payment Profile belongs to multiple Subscription Groups
381
+ # and/or Subscriptions, it will be removed from all of them.
382
+ # @param [String] uid Required parameter: The uid of the subscription
383
+ # group
384
+ # @param [String] payment_profile_id Required parameter: The Chargify id of
385
+ # the payment profile
386
+ # @return [void] response from the API call.
387
+ def delete_subscription_group_payment_profile(uid,
388
+ payment_profile_id)
389
+ new_api_call_builder
390
+ .request(new_request_builder(HttpMethodEnum::DELETE,
391
+ '/subscription_groups/{uid}/payment_profiles/{payment_profile_id}.json',
392
+ Server::DEFAULT)
393
+ .template_param(new_parameter(uid, key: 'uid')
394
+ .is_required(true)
395
+ .should_encode(true))
396
+ .template_param(new_parameter(payment_profile_id, key: 'payment_profile_id')
397
+ .is_required(true)
398
+ .should_encode(true))
399
+ .auth(Single.new('BasicAuth')))
400
+ .response(new_response_handler
401
+ .is_nullify404(true)
402
+ .is_response_void(true))
403
+ .execute
404
+ end
405
+
406
+ # One Time Tokens aka Chargify Tokens house the credit card or ACH
407
+ # (Authorize.Net or Stripe only) data for a customer.
408
+ # You can use One Time Tokens while creating a subscription or payment
409
+ # profile instead of passing all bank account or credit card data directly
410
+ # to a given API endpoint.
411
+ # To obtain a One Time Token you have to use
412
+ # [chargify.js](https://developers.chargify.com/docs/developer-docs/ZG9jOjE0
413
+ # NjAzNDI0-overview).
414
+ # @param [String] chargify_token Required parameter: Chargify Token
415
+ # @return [GetOneTimeTokenRequest] response from the API call.
416
+ def read_one_time_token(chargify_token)
417
+ new_api_call_builder
418
+ .request(new_request_builder(HttpMethodEnum::GET,
419
+ '/one_time_tokens/{chargify_token}.json',
420
+ Server::DEFAULT)
421
+ .template_param(new_parameter(chargify_token, key: 'chargify_token')
422
+ .is_required(true)
423
+ .should_encode(true))
424
+ .header_param(new_parameter('application/json', key: 'accept'))
425
+ .auth(Single.new('BasicAuth')))
426
+ .response(new_response_handler
427
+ .is_nullify404(true)
428
+ .deserializer(APIHelper.method(:custom_type_deserializer))
429
+ .deserialize_into(GetOneTimeTokenRequest.method(:from_hash))
430
+ .local_error('404',
431
+ 'Not Found',
432
+ ErrorListResponseException))
433
+ .execute
434
+ end
435
+
436
+ # Using the GET method you can retrieve a Payment Profile identified by its
437
+ # unique ID.
438
+ # Please note that a different JSON object will be returned if the card
439
+ # method on file is a bank account.
440
+ # ### Response for Bank Account
441
+ # Example response for Bank Account:
442
+ # ```
443
+ # {
444
+ # "payment_profile": {
445
+ # "id": 10089892,
446
+ # "first_name": "Chester",
447
+ # "last_name": "Tester",
448
+ # "customer_id": 14543792,
449
+ # "current_vault": "bogus",
450
+ # "vault_token": "0011223344",
451
+ # "billing_address": "456 Juniper Court",
452
+ # "billing_city": "Boulder",
453
+ # "billing_state": "CO",
454
+ # "billing_zip": "80302",
455
+ # "billing_country": "US",
456
+ # "customer_vault_token": null,
457
+ # "billing_address_2": "",
458
+ # "bank_name": "Bank of Kansas City",
459
+ # "masked_bank_routing_number": "XXXX6789",
460
+ # "masked_bank_account_number": "XXXX3344",
461
+ # "bank_account_type": "checking",
462
+ # "bank_account_holder_type": "personal",
463
+ # "payment_type": "bank_account",
464
+ # "site_gateway_setting_id": 1,
465
+ # "gateway_handle": null
466
+ # }
467
+ # }
468
+ # ```
469
+ # @param [String] payment_profile_id Required parameter: The Chargify id of
470
+ # the payment profile
471
+ # @return [ReadPaymentProfileResponse] response from the API call.
472
+ def read_payment_profile(payment_profile_id)
473
+ new_api_call_builder
474
+ .request(new_request_builder(HttpMethodEnum::GET,
475
+ '/payment_profiles/{payment_profile_id}.json',
476
+ Server::DEFAULT)
477
+ .template_param(new_parameter(payment_profile_id, key: 'payment_profile_id')
478
+ .is_required(true)
479
+ .should_encode(true))
480
+ .header_param(new_parameter('application/json', key: 'accept'))
481
+ .auth(Single.new('BasicAuth')))
482
+ .response(new_response_handler
483
+ .is_nullify404(true)
484
+ .deserializer(APIHelper.method(:custom_type_deserializer))
485
+ .deserialize_into(ReadPaymentProfileResponse.method(:from_hash)))
486
+ .execute
487
+ end
488
+
489
+ # ## Partial Card Updates
490
+ # In the event that you are using the Authorize.net, Stripe, Cybersource,
491
+ # Forte or Braintree Blue payment gateways, you can update just the billing
492
+ # and contact information for a payment method. Note the lack of credit-card
493
+ # related data contained in the JSON payload.
494
+ # In this case, the following JSON is acceptable:
495
+ # ```
496
+ # {
497
+ # "payment_profile": {
498
+ # "first_name": "Kelly",
499
+ # "last_name": "Test",
500
+ # "billing_address": "789 Juniper Court",
501
+ # "billing_city": "Boulder",
502
+ # "billing_state": "CO",
503
+ # "billing_zip": "80302",
504
+ # "billing_country": "US",
505
+ # "billing_address_2": null
506
+ # }
507
+ # }
508
+ # ```
509
+ # The result will be that you have updated the billing information for the
510
+ # card, yet retained the original card number data.
511
+ # ## Specific notes on updating payment profiles
512
+ # - Merchants with **Authorize.net**, **Cybersource**, **Forte**,
513
+ # **Braintree Blue** or **Stripe** as their payment gateway can update their
514
+ # Customer’s credit cards without passing in the full credit card number and
515
+ # CVV.
516
+ # - If you are using **Authorize.net**, **Cybersource**, **Forte**,
517
+ # **Braintree Blue** or **Stripe**, Chargify will ignore the credit card
518
+ # number and CVV when processing an update via the API, and attempt a
519
+ # partial update instead. If you wish to change the card number on a payment
520
+ # profile, you will need to create a new payment profile for the given
521
+ # customer.
522
+ # - A Payment Profile cannot be updated with the attributes of another type
523
+ # of Payment Profile. For example, if the payment profile you are attempting
524
+ # to update is a credit card, you cannot pass in bank account attributes
525
+ # (like `bank_account_number`), and vice versa.
526
+ # - Updating a payment profile directly will not trigger an attempt to
527
+ # capture a past-due balance. If this is the intent, update the card details
528
+ # via the Subscription instead.
529
+ # - If you are using Authorize.net or Stripe, you may elect to manually
530
+ # trigger a retry for a past due subscription after a partial update.
531
+ # @param [String] payment_profile_id Required parameter: The Chargify id of
532
+ # the payment profile
533
+ # @param [UpdatePaymentProfileRequest] body Optional parameter: Example:
534
+ # @return [UpdatePaymentProfileResponse] response from the API call.
535
+ def update_payment_profile(payment_profile_id,
536
+ body: nil)
537
+ new_api_call_builder
538
+ .request(new_request_builder(HttpMethodEnum::PUT,
539
+ '/payment_profiles/{payment_profile_id}.json',
540
+ Server::DEFAULT)
541
+ .template_param(new_parameter(payment_profile_id, key: 'payment_profile_id')
542
+ .is_required(true)
543
+ .should_encode(true))
544
+ .header_param(new_parameter('application/json', key: 'Content-Type'))
545
+ .body_param(new_parameter(body))
546
+ .header_param(new_parameter('application/json', key: 'accept'))
547
+ .body_serializer(proc do |param| param.to_json unless param.nil? end)
548
+ .auth(Single.new('BasicAuth')))
549
+ .response(new_response_handler
550
+ .is_nullify404(true)
551
+ .deserializer(APIHelper.method(:custom_type_deserializer))
552
+ .deserialize_into(UpdatePaymentProfileResponse.method(:from_hash)))
553
+ .execute
554
+ end
555
+
556
+ # This will change the default payment profile on the subscription to the
557
+ # existing payment profile with the id specified.
558
+ # You must elect to change the existing payment profile to a new payment
559
+ # profile ID in order to receive a satisfactory response from this endpoint.
560
+ # @param [String] subscription_id Required parameter: The Chargify id of the
561
+ # subscription
562
+ # @param [Integer] payment_profile_id Required parameter: The Chargify id of
563
+ # the payment profile
564
+ # @return [PaymentProfileResponse] response from the API call.
565
+ def update_subscription_default_payment_profile(subscription_id,
566
+ payment_profile_id)
567
+ new_api_call_builder
568
+ .request(new_request_builder(HttpMethodEnum::POST,
569
+ '/subscriptions/{subscription_id}/payment_profiles/{payment_profile_id}/change_payment_profile.json',
570
+ Server::DEFAULT)
571
+ .template_param(new_parameter(subscription_id, key: 'subscription_id')
572
+ .is_required(true)
573
+ .should_encode(true))
574
+ .template_param(new_parameter(payment_profile_id, key: 'payment_profile_id')
575
+ .is_required(true)
576
+ .should_encode(true))
577
+ .header_param(new_parameter('application/json', key: 'accept'))
578
+ .auth(Single.new('BasicAuth')))
579
+ .response(new_response_handler
580
+ .is_nullify404(true)
581
+ .deserializer(APIHelper.method(:custom_type_deserializer))
582
+ .deserialize_into(PaymentProfileResponse.method(:from_hash))
583
+ .local_error('422',
584
+ 'Unprocessable Entity (WebDAV)',
585
+ ErrorListResponseException))
586
+ .execute
587
+ end
588
+
589
+ # This will change the default payment profile on the subscription group to
590
+ # the existing payment profile with the id specified.
591
+ # You must elect to change the existing payment profile to a new payment
592
+ # profile ID in order to receive a satisfactory response from this endpoint.
593
+ # The new payment profile must belong to the subscription group's customer,
594
+ # otherwise you will receive an error.
595
+ # @param [String] uid Required parameter: The uid of the subscription
596
+ # group
597
+ # @param [String] payment_profile_id Required parameter: The Chargify id of
598
+ # the payment profile
599
+ # @return [PaymentProfileResponse] response from the API call.
600
+ def update_subscription_group_default_payment_profile(uid,
601
+ payment_profile_id)
602
+ new_api_call_builder
603
+ .request(new_request_builder(HttpMethodEnum::POST,
604
+ '/subscription_groups/{uid}/payment_profiles/{payment_profile_id}/change_payment_profile.json',
605
+ Server::DEFAULT)
606
+ .template_param(new_parameter(uid, key: 'uid')
607
+ .is_required(true)
608
+ .should_encode(true))
609
+ .template_param(new_parameter(payment_profile_id, key: 'payment_profile_id')
610
+ .is_required(true)
611
+ .should_encode(true))
612
+ .header_param(new_parameter('application/json', key: 'accept'))
613
+ .auth(Single.new('BasicAuth')))
614
+ .response(new_response_handler
615
+ .is_nullify404(true)
616
+ .deserializer(APIHelper.method(:custom_type_deserializer))
617
+ .deserialize_into(PaymentProfileResponse.method(:from_hash))
618
+ .local_error('422',
619
+ 'Unprocessable Entity (WebDAV)',
620
+ ErrorListResponseException))
621
+ .execute
622
+ end
623
+
624
+ # This method will return all of the active `payment_profiles` for a Site,
625
+ # or for one Customer within a site. If no payment profiles are found, this
626
+ # endpoint will return an empty array, not a 404.
627
+ # @param [Integer] page Optional parameter: Result records are organized in
628
+ # pages. By default, the first page of results is displayed. The page
629
+ # parameter specifies a page number of results to fetch. You can start
630
+ # navigating through the pages to consume the results. You do this by
631
+ # passing in a page parameter. Retrieve the next page by adding ?page=2 to
632
+ # the query string. If there are no results to return, then an empty result
633
+ # set will be returned. Use in query `page=1`.
634
+ # @param [Integer] per_page Optional parameter: This parameter indicates how
635
+ # many records to fetch in each request. Default value is 20. The maximum
636
+ # allowed values is 200; any per_page value over 200 will be changed to 200.
637
+ # Use in query `per_page=200`.
638
+ # @param [Integer] customer_id Optional parameter: The ID of the customer
639
+ # for which you wish to list payment profiles
640
+ # @return [Array[ListPaymentProfilesResponse]] response from the API call.
641
+ def list_payment_profiles(options = {})
642
+ new_api_call_builder
643
+ .request(new_request_builder(HttpMethodEnum::GET,
644
+ '/payment_profiles.json',
645
+ Server::DEFAULT)
646
+ .query_param(new_parameter(options['page'], key: 'page'))
647
+ .query_param(new_parameter(options['per_page'], key: 'per_page'))
648
+ .query_param(new_parameter(options['customer_id'], key: 'customer_id'))
649
+ .header_param(new_parameter('application/json', key: 'accept'))
650
+ .auth(Single.new('BasicAuth')))
651
+ .response(new_response_handler
652
+ .is_nullify404(true)
653
+ .deserializer(APIHelper.method(:custom_type_deserializer))
654
+ .deserialize_into(ListPaymentProfilesResponse.method(:from_hash))
655
+ .is_response_array(true))
656
+ .execute
657
+ end
658
+
659
+ # Submit the two small deposit amounts the customer received in their bank
660
+ # account in order to verify the bank account. (Stripe only)
661
+ # @param [Integer] bank_account_id Required parameter: Identifier of the
662
+ # bank account in the system.
663
+ # @param [BankAccountVerificationRequest] body Optional parameter:
664
+ # Example:
665
+ # @return [BankAccountResponse] response from the API call.
666
+ def verify_bank_account(bank_account_id,
667
+ body: nil)
668
+ new_api_call_builder
669
+ .request(new_request_builder(HttpMethodEnum::PUT,
670
+ '/bank_accounts/{bank_account_id}/verification.json',
671
+ Server::DEFAULT)
672
+ .template_param(new_parameter(bank_account_id, key: 'bank_account_id')
673
+ .is_required(true)
674
+ .should_encode(true))
675
+ .header_param(new_parameter('application/json', key: 'Content-Type'))
676
+ .body_param(new_parameter(body))
677
+ .header_param(new_parameter('application/json', key: 'accept'))
678
+ .body_serializer(proc do |param| param.to_json unless param.nil? end)
679
+ .auth(Single.new('BasicAuth')))
680
+ .response(new_response_handler
681
+ .is_nullify404(true)
682
+ .deserializer(APIHelper.method(:custom_type_deserializer))
683
+ .deserialize_into(BankAccountResponse.method(:from_hash))
684
+ .local_error('404',
685
+ 'Not Found',
686
+ APIException)
687
+ .local_error('422',
688
+ 'Unprocessable Entity (WebDAV)',
689
+ ErrorListResponseException))
690
+ .execute
691
+ end
692
+
693
+ # You can send a "request payment update" email to the customer associated
694
+ # with the subscription.
695
+ # If you attempt to send a "request payment update" email more than five
696
+ # times within a 30-minute period, you will receive a `422` response with an
697
+ # error message in the body. This error message will indicate that the
698
+ # request has been rejected due to excessive attempts, and will provide
699
+ # instructions on how to resubmit the request.
700
+ # Additionally, if you attempt to send a "request payment update" email for
701
+ # a subscription that does not exist, you will receive a `404` error
702
+ # response. This error message will indicate that the subscription could not
703
+ # be found, and will provide instructions on how to correct the error and
704
+ # resubmit the request.
705
+ # These error responses are designed to prevent excessive or invalid
706
+ # requests, and to provide clear and helpful information to users who
707
+ # encounter errors during the request process.
708
+ # @param [String] subscription_id Required parameter: The Chargify id of the
709
+ # subscription
710
+ # @return [void] response from the API call.
711
+ def send_request_update_payment_email(subscription_id)
712
+ new_api_call_builder
713
+ .request(new_request_builder(HttpMethodEnum::POST,
714
+ '/subscriptions/{subscription_id}/request_payment_profiles_update.json',
715
+ Server::DEFAULT)
716
+ .template_param(new_parameter(subscription_id, key: 'subscription_id')
717
+ .is_required(true)
718
+ .should_encode(true))
719
+ .auth(Single.new('BasicAuth')))
720
+ .response(new_response_handler
721
+ .is_nullify404(true)
722
+ .is_response_void(true)
723
+ .local_error('404',
724
+ 'Not Found',
725
+ APIException)
726
+ .local_error('422',
727
+ 'Unprocessable Entity (WebDAV)',
728
+ ErrorListResponseException))
729
+ .execute
730
+ end
731
+ end
732
+ end