recurly 2.17.5 → 4.18.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (280) hide show
  1. checksums.yaml +4 -4
  2. data/.bumpversion.cfg +15 -0
  3. data/.changelog_config.yaml +11 -0
  4. data/.github/ISSUE_TEMPLATE/bug-report.md +30 -0
  5. data/.github/ISSUE_TEMPLATE/question-or-other.md +10 -0
  6. data/.github/workflows/ci.yml +29 -0
  7. data/.github/workflows/docs.yml +28 -0
  8. data/.gitignore +15 -0
  9. data/.rspec +2 -0
  10. data/.yardopts +2 -0
  11. data/CHANGELOG.md +295 -0
  12. data/CODE_OF_CONDUCT.md +130 -0
  13. data/CONTRIBUTING.md +106 -0
  14. data/GETTING_STARTED.md +330 -0
  15. data/Gemfile +4 -0
  16. data/LICENSE.txt +21 -0
  17. data/README.md +9 -148
  18. data/Rakefile +6 -0
  19. data/benchmark.rb +16 -0
  20. data/lib/data/ca-certificates.crt +3466 -0
  21. data/lib/recurly/client/operations.rb +4079 -0
  22. data/lib/recurly/client.rb +400 -0
  23. data/lib/recurly/connection_pool.rb +42 -0
  24. data/lib/recurly/errors/api_errors.rb +90 -0
  25. data/lib/recurly/errors/network_errors.rb +7 -0
  26. data/lib/recurly/errors.rb +51 -0
  27. data/lib/recurly/http.rb +50 -0
  28. data/lib/recurly/pager.rb +136 -0
  29. data/lib/recurly/request.rb +31 -0
  30. data/lib/recurly/requests/account_acquisition_cost.rb +18 -0
  31. data/lib/recurly/requests/account_acquisition_update.rb +26 -0
  32. data/lib/recurly/requests/account_create.rb +98 -0
  33. data/lib/recurly/requests/account_purchase.rb +98 -0
  34. data/lib/recurly/requests/account_update.rb +86 -0
  35. data/lib/recurly/requests/add_on_create.rb +102 -0
  36. data/lib/recurly/requests/add_on_pricing.rb +26 -0
  37. data/lib/recurly/requests/add_on_update.rb +78 -0
  38. data/lib/recurly/requests/address.rb +38 -0
  39. data/lib/recurly/requests/billing_info_create.rb +134 -0
  40. data/lib/recurly/requests/billing_info_verify.rb +14 -0
  41. data/lib/recurly/requests/coupon_bulk_create.rb +14 -0
  42. data/lib/recurly/requests/coupon_create.rb +102 -0
  43. data/lib/recurly/requests/coupon_pricing.rb +18 -0
  44. data/lib/recurly/requests/coupon_redemption_create.rb +22 -0
  45. data/lib/recurly/requests/coupon_update.rb +34 -0
  46. data/lib/recurly/requests/custom_field.rb +18 -0
  47. data/lib/recurly/requests/dunning_campaigns_bulk_update.rb +18 -0
  48. data/lib/recurly/requests/external_refund.rb +22 -0
  49. data/lib/recurly/requests/external_transaction.rb +26 -0
  50. data/lib/recurly/requests/invoice_address.rb +54 -0
  51. data/lib/recurly/requests/invoice_collect.rb +22 -0
  52. data/lib/recurly/requests/invoice_create.rb +42 -0
  53. data/lib/recurly/requests/invoice_refund.rb +34 -0
  54. data/lib/recurly/requests/invoice_update.rb +34 -0
  55. data/lib/recurly/requests/item_create.rb +58 -0
  56. data/lib/recurly/requests/item_update.rb +58 -0
  57. data/lib/recurly/requests/line_item_create.rb +86 -0
  58. data/lib/recurly/requests/line_item_refund.rb +22 -0
  59. data/lib/recurly/requests/measured_unit_create.rb +22 -0
  60. data/lib/recurly/requests/measured_unit_update.rb +22 -0
  61. data/lib/recurly/requests/percentage_tier.rb +18 -0
  62. data/lib/recurly/requests/percentage_tiers_by_currency.rb +18 -0
  63. data/lib/recurly/requests/plan_create.rb +102 -0
  64. data/lib/recurly/requests/plan_hosted_pages.rb +26 -0
  65. data/lib/recurly/requests/plan_pricing.rb +26 -0
  66. data/lib/recurly/requests/plan_update.rb +94 -0
  67. data/lib/recurly/requests/pricing.rb +22 -0
  68. data/lib/recurly/requests/purchase_create.rb +78 -0
  69. data/lib/recurly/requests/shipping_address_create.rb +62 -0
  70. data/lib/recurly/requests/shipping_address_update.rb +66 -0
  71. data/lib/recurly/requests/shipping_fee_create.rb +22 -0
  72. data/lib/recurly/requests/shipping_method_create.rb +26 -0
  73. data/lib/recurly/requests/shipping_method_update.rb +26 -0
  74. data/lib/recurly/requests/shipping_purchase.rb +22 -0
  75. data/lib/recurly/requests/subscription_add_on_create.rb +46 -0
  76. data/lib/recurly/requests/subscription_add_on_percentage_tier.rb +18 -0
  77. data/lib/recurly/requests/subscription_add_on_tier.rb +26 -0
  78. data/lib/recurly/requests/subscription_add_on_update.rb +50 -0
  79. data/lib/recurly/requests/subscription_cancel.rb +14 -0
  80. data/lib/recurly/requests/subscription_change_billing_info_create.rb +14 -0
  81. data/lib/recurly/requests/subscription_change_create.rb +74 -0
  82. data/lib/recurly/requests/subscription_change_shipping_create.rb +30 -0
  83. data/lib/recurly/requests/subscription_create.rb +114 -0
  84. data/lib/recurly/requests/subscription_pause.rb +14 -0
  85. data/lib/recurly/requests/subscription_purchase.rb +70 -0
  86. data/lib/recurly/requests/subscription_shipping_create.rb +30 -0
  87. data/lib/recurly/requests/subscription_shipping_purchase.rb +22 -0
  88. data/lib/recurly/requests/subscription_shipping_update.rb +22 -0
  89. data/lib/recurly/requests/subscription_update.rb +70 -0
  90. data/lib/recurly/requests/tier.rb +22 -0
  91. data/lib/recurly/requests/tier_pricing.rb +22 -0
  92. data/lib/recurly/requests/usage_create.rb +26 -0
  93. data/lib/recurly/requests.rb +8 -0
  94. data/lib/recurly/resource.rb +23 -1092
  95. data/lib/recurly/resources/account.rb +138 -0
  96. data/lib/recurly/resources/account_acquisition.rb +46 -0
  97. data/lib/recurly/resources/account_acquisition_cost.rb +18 -0
  98. data/lib/recurly/resources/account_balance.rb +26 -0
  99. data/lib/recurly/resources/account_balance_amount.rb +22 -0
  100. data/lib/recurly/resources/account_mini.rb +50 -0
  101. data/lib/recurly/resources/account_note.rb +34 -0
  102. data/lib/recurly/resources/add_on.rb +122 -0
  103. data/lib/recurly/resources/add_on_mini.rb +54 -0
  104. data/lib/recurly/resources/add_on_pricing.rb +26 -0
  105. data/lib/recurly/resources/address.rb +38 -0
  106. data/lib/recurly/resources/address_with_name.rb +46 -0
  107. data/lib/recurly/resources/billing_info.rb +74 -0
  108. data/lib/recurly/resources/billing_info_updated_by.rb +18 -0
  109. data/lib/recurly/resources/binary_file.rb +14 -0
  110. data/lib/recurly/resources/coupon.rb +126 -0
  111. data/lib/recurly/resources/coupon_discount.rb +26 -0
  112. data/lib/recurly/resources/coupon_discount_pricing.rb +18 -0
  113. data/lib/recurly/resources/coupon_discount_trial.rb +18 -0
  114. data/lib/recurly/resources/coupon_mini.rb +42 -0
  115. data/lib/recurly/resources/coupon_redemption.rb +54 -0
  116. data/lib/recurly/resources/coupon_redemption_mini.rb +34 -0
  117. data/lib/recurly/resources/credit_payment.rb +66 -0
  118. data/lib/recurly/resources/custom_field.rb +18 -0
  119. data/lib/recurly/resources/custom_field_definition.rb +50 -0
  120. data/lib/recurly/resources/dunning_campaign.rb +50 -0
  121. data/lib/recurly/resources/dunning_campaigns_bulk_update_response.rb +18 -0
  122. data/lib/recurly/resources/dunning_cycle.rb +58 -0
  123. data/lib/recurly/resources/dunning_interval.rb +18 -0
  124. data/lib/recurly/resources/error.rb +22 -0
  125. data/lib/recurly/resources/error_may_have_transaction.rb +26 -0
  126. data/lib/recurly/resources/export_dates.rb +18 -0
  127. data/lib/recurly/resources/export_file.rb +22 -0
  128. data/lib/recurly/resources/export_files.rb +18 -0
  129. data/lib/recurly/resources/fraud_info.rb +22 -0
  130. data/lib/recurly/resources/invoice.rb +162 -0
  131. data/lib/recurly/resources/invoice_address.rb +54 -0
  132. data/lib/recurly/resources/invoice_collection.rb +22 -0
  133. data/lib/recurly/resources/invoice_mini.rb +30 -0
  134. data/lib/recurly/resources/invoice_template.rb +34 -0
  135. data/lib/recurly/resources/item.rb +82 -0
  136. data/lib/recurly/resources/item_mini.rb +34 -0
  137. data/lib/recurly/resources/line_item.rb +206 -0
  138. data/lib/recurly/resources/measured_unit.rb +46 -0
  139. data/lib/recurly/resources/payment_method.rb +70 -0
  140. data/lib/recurly/resources/percentage_tier.rb +18 -0
  141. data/lib/recurly/resources/percentage_tiers_by_currency.rb +18 -0
  142. data/lib/recurly/resources/plan.rb +122 -0
  143. data/lib/recurly/resources/plan_hosted_pages.rb +26 -0
  144. data/lib/recurly/resources/plan_mini.rb +26 -0
  145. data/lib/recurly/resources/plan_pricing.rb +26 -0
  146. data/lib/recurly/resources/pricing.rb +22 -0
  147. data/lib/recurly/resources/settings.rb +22 -0
  148. data/lib/recurly/resources/shipping_address.rb +82 -0
  149. data/lib/recurly/resources/shipping_method.rb +46 -0
  150. data/lib/recurly/resources/shipping_method_mini.rb +26 -0
  151. data/lib/recurly/resources/site.rb +54 -0
  152. data/lib/recurly/resources/subscription.rb +198 -0
  153. data/lib/recurly/resources/subscription_add_on.rb +78 -0
  154. data/lib/recurly/resources/subscription_add_on_percentage_tier.rb +18 -0
  155. data/lib/recurly/resources/subscription_add_on_tier.rb +26 -0
  156. data/lib/recurly/resources/subscription_change.rb +82 -0
  157. data/lib/recurly/resources/subscription_change_billing_info.rb +14 -0
  158. data/lib/recurly/resources/subscription_shipping.rb +26 -0
  159. data/lib/recurly/resources/tax_detail.rb +26 -0
  160. data/lib/recurly/resources/tax_info.rb +26 -0
  161. data/lib/recurly/resources/tier.rb +22 -0
  162. data/lib/recurly/resources/tier_pricing.rb +22 -0
  163. data/lib/recurly/resources/transaction.rb +162 -0
  164. data/lib/recurly/resources/transaction_error.rb +38 -0
  165. data/lib/recurly/resources/transaction_payment_gateway.rb +26 -0
  166. data/lib/recurly/resources/unique_coupon_code.rb +50 -0
  167. data/lib/recurly/resources/unique_coupon_code_params.rb +26 -0
  168. data/lib/recurly/resources/usage.rb +78 -0
  169. data/lib/recurly/resources/user.rb +42 -0
  170. data/lib/recurly/resources.rb +18 -0
  171. data/lib/recurly/schema/file_parser.rb +13 -0
  172. data/lib/recurly/schema/json_parser.rb +72 -0
  173. data/lib/recurly/schema/request_caster.rb +60 -0
  174. data/lib/recurly/schema/resource_caster.rb +46 -0
  175. data/lib/recurly/schema/schema_factory.rb +48 -0
  176. data/lib/recurly/schema/schema_validator.rb +144 -0
  177. data/lib/recurly/schema.rb +156 -0
  178. data/lib/recurly/version.rb +1 -15
  179. data/lib/recurly.rb +15 -138
  180. data/openapi/api.yaml +22879 -0
  181. data/recurly.gemspec +39 -0
  182. data/scripts/build +5 -0
  183. data/scripts/clean +6 -0
  184. data/scripts/format +12 -0
  185. data/scripts/prepare-release +50 -0
  186. data/scripts/release +17 -0
  187. data/scripts/test +15 -0
  188. metadata +217 -217
  189. data/lib/recurly/account.rb +0 -179
  190. data/lib/recurly/account_balance.rb +0 -21
  191. data/lib/recurly/add_on.rb +0 -30
  192. data/lib/recurly/address.rb +0 -25
  193. data/lib/recurly/adjustment.rb +0 -76
  194. data/lib/recurly/api/errors.rb +0 -208
  195. data/lib/recurly/api/net_http_adapter.rb +0 -111
  196. data/lib/recurly/api.rb +0 -101
  197. data/lib/recurly/billing_info.rb +0 -80
  198. data/lib/recurly/coupon.rb +0 -134
  199. data/lib/recurly/credit_payment.rb +0 -32
  200. data/lib/recurly/custom_field.rb +0 -15
  201. data/lib/recurly/delivery.rb +0 -19
  202. data/lib/recurly/error.rb +0 -13
  203. data/lib/recurly/gift_card.rb +0 -82
  204. data/lib/recurly/helper.rb +0 -51
  205. data/lib/recurly/invoice.rb +0 -273
  206. data/lib/recurly/invoice_collection.rb +0 -14
  207. data/lib/recurly/js.rb +0 -14
  208. data/lib/recurly/juris_detail.rb +0 -14
  209. data/lib/recurly/measured_unit.rb +0 -16
  210. data/lib/recurly/money.rb +0 -120
  211. data/lib/recurly/note.rb +0 -14
  212. data/lib/recurly/plan.rb +0 -40
  213. data/lib/recurly/purchase.rb +0 -219
  214. data/lib/recurly/redemption.rb +0 -46
  215. data/lib/recurly/resource/association.rb +0 -16
  216. data/lib/recurly/resource/errors.rb +0 -20
  217. data/lib/recurly/resource/pager.rb +0 -313
  218. data/lib/recurly/shipping_address.rb +0 -26
  219. data/lib/recurly/subscription/add_ons.rb +0 -77
  220. data/lib/recurly/subscription.rb +0 -328
  221. data/lib/recurly/subscription_add_on.rb +0 -50
  222. data/lib/recurly/tax_detail.rb +0 -14
  223. data/lib/recurly/tax_type.rb +0 -12
  224. data/lib/recurly/transaction/errors.rb +0 -107
  225. data/lib/recurly/transaction.rb +0 -129
  226. data/lib/recurly/usage.rb +0 -28
  227. data/lib/recurly/webhook/account_notification.rb +0 -10
  228. data/lib/recurly/webhook/billing_info_updated_notification.rb +0 -6
  229. data/lib/recurly/webhook/canceled_account_notification.rb +0 -6
  230. data/lib/recurly/webhook/canceled_subscription_notification.rb +0 -6
  231. data/lib/recurly/webhook/closed_credit_invoice_notification.rb +0 -6
  232. data/lib/recurly/webhook/closed_invoice_notification.rb +0 -6
  233. data/lib/recurly/webhook/credit_payment_notification.rb +0 -12
  234. data/lib/recurly/webhook/dunning_notification.rb +0 -14
  235. data/lib/recurly/webhook/expired_subscription_notification.rb +0 -6
  236. data/lib/recurly/webhook/failed_charge_invoice_notification.rb +0 -6
  237. data/lib/recurly/webhook/failed_payment_notification.rb +0 -6
  238. data/lib/recurly/webhook/gift_card_notification.rb +0 -8
  239. data/lib/recurly/webhook/invoice_notification.rb +0 -12
  240. data/lib/recurly/webhook/low_balance_gift_card_notification.rb +0 -6
  241. data/lib/recurly/webhook/new_account_notification.rb +0 -6
  242. data/lib/recurly/webhook/new_charge_invoice_notification.rb +0 -6
  243. data/lib/recurly/webhook/new_credit_invoice_notification.rb +0 -6
  244. data/lib/recurly/webhook/new_credit_payment_notification.rb +0 -6
  245. data/lib/recurly/webhook/new_dunning_event_notification.rb +0 -6
  246. data/lib/recurly/webhook/new_invoice_notification.rb +0 -6
  247. data/lib/recurly/webhook/new_subscription_notification.rb +0 -6
  248. data/lib/recurly/webhook/new_usage_notification.rb +0 -8
  249. data/lib/recurly/webhook/notification.rb +0 -18
  250. data/lib/recurly/webhook/paid_charge_invoice_notification.rb +0 -6
  251. data/lib/recurly/webhook/past_due_charge_invoice_notification.rb +0 -6
  252. data/lib/recurly/webhook/past_due_invoice_notification.rb +0 -6
  253. data/lib/recurly/webhook/processing_charge_invoice_notification.rb +0 -6
  254. data/lib/recurly/webhook/processing_credit_invoice_notification.rb +0 -6
  255. data/lib/recurly/webhook/processing_invoice_notification.rb +0 -6
  256. data/lib/recurly/webhook/processing_payment_notification.rb +0 -6
  257. data/lib/recurly/webhook/purchased_gift_card_notification.rb +0 -7
  258. data/lib/recurly/webhook/reactivated_account_notification.rb +0 -6
  259. data/lib/recurly/webhook/redeemed_gift_card_notification.rb +0 -7
  260. data/lib/recurly/webhook/renewed_subscription_notification.rb +0 -6
  261. data/lib/recurly/webhook/reopened_charge_invoice_notification.rb +0 -6
  262. data/lib/recurly/webhook/reopened_credit_invoice_notification.rb +0 -6
  263. data/lib/recurly/webhook/scheduled_payment_notification.rb +0 -6
  264. data/lib/recurly/webhook/subscription_notification.rb +0 -12
  265. data/lib/recurly/webhook/successful_payment_notification.rb +0 -6
  266. data/lib/recurly/webhook/successful_refund_notification.rb +0 -6
  267. data/lib/recurly/webhook/transaction_authorized_notification.rb +0 -6
  268. data/lib/recurly/webhook/transaction_notification.rb +0 -12
  269. data/lib/recurly/webhook/transaction_status_updated_notification.rb +0 -6
  270. data/lib/recurly/webhook/updated_account_notification.rb +0 -6
  271. data/lib/recurly/webhook/updated_balance_gift_card_notification.rb +0 -7
  272. data/lib/recurly/webhook/updated_invoice_notification.rb +0 -6
  273. data/lib/recurly/webhook/updated_subscription_notification.rb +0 -6
  274. data/lib/recurly/webhook/void_payment_notification.rb +0 -6
  275. data/lib/recurly/webhook/voided_credit_invoice_notification.rb +0 -6
  276. data/lib/recurly/webhook/voided_credit_payment_notification.rb +0 -6
  277. data/lib/recurly/webhook.rb +0 -91
  278. data/lib/recurly/xml/nokogiri.rb +0 -60
  279. data/lib/recurly/xml/rexml.rb +0 -52
  280. data/lib/recurly/xml.rb +0 -122
@@ -1,179 +0,0 @@
1
- module Recurly
2
- # Accounts are core to managing your customers inside of Recurly.
3
- # The account object stores the entire Recurly history of your customer and acts as the entry point
4
- # for working with a customer's billing information, subscription data, transactions, invoices and more.
5
- #
6
- # Recurly Documentation: https://dev.recurly.com/docs/account-object
7
- class Account < Resource
8
- # @macro [attach] scope
9
- # @scope class
10
- # @return [Pager<Account>] A pager that yields +$1+ accounts.
11
- scope :active, state: :active
12
- scope :closed, state: :closed
13
- scope :subscriber, state: :subscriber
14
- scope :non_subscriber, state: :non_subscriber
15
- scope :past_due, state: :past_due
16
-
17
- # @return [Pager<Adjustment>, []] A pager that yields Adjustments for persisted
18
- has_many :adjustments
19
-
20
- # @return [Pager<Invoice>, []] A pager that yields Invoices for persisted
21
- has_many :invoices
22
-
23
- # @return [Pager<Subscription>, []] A pager that yields Subscriptions for persisted
24
- has_many :subscriptions
25
-
26
- # @return [Pager<Transaction>, []] A pager that yields Transaction for persisted
27
- has_many :transactions
28
-
29
- # @return [Pager<Note>, []] A pager that yields Note for persisted
30
- has_many :notes
31
-
32
- # @return [Pager<Redemption>, []] A pager that yields Redemptions for persisted
33
- has_many :redemptions
34
-
35
- # @return [Pager<ShippingAddress>, [ShippingAddress], []] A pager that yields ShippingAddresses;
36
- # or a list of ShippingAddresses if set by the programmer
37
- has_many :shipping_addresses, readonly: false
38
-
39
- # @return [BillingInfo, nil]
40
- has_one :billing_info, readonly: false
41
-
42
- # @return [AccountBalance, nil]
43
- has_one :account_balance, readonly: true
44
-
45
- # @return [Pager<CreditPayment>, []]
46
- has_many :credit_payments, class_name: :CreditPayment, readonly: true
47
-
48
- # @return [[CustomField], []]
49
- has_many :custom_fields, class_name: :CustomField, readonly: false
50
-
51
- # Get's the first redemption given a coupon code
52
- # @deprecated Use #{redemptions} instead
53
- # @param coupon_code [String] The coupon code for the redemption
54
- def redemption(coupon_code)
55
- redemptions.detect { |r| r.coupon_code == coupon_code }
56
- end
57
-
58
- define_attribute_methods %w(
59
- account_code
60
- state
61
- username
62
- email
63
- cc_emails
64
- first_name
65
- last_name
66
- company_name
67
- company
68
- phone
69
- accept_language
70
- hosted_login_token
71
- vat_number
72
- address
73
- tax_exempt
74
- exemption_certificate
75
- entity_use_code
76
- created_at
77
- updated_at
78
- closed_at
79
- vat_location_valid
80
- has_live_subscription
81
- has_active_subscription
82
- has_future_subscription
83
- has_canceled_subscription
84
- has_past_due_invoice
85
- has_paused_subscription
86
- preferred_locale
87
- )
88
- alias to_param account_code
89
-
90
- def company_name
91
- super || company
92
- end
93
-
94
- # Creates an invoice from the pending charges on the account.
95
- # Raises an error if it fails.
96
- #
97
- # @return [InvoiceCollection] A newly-created invoice.
98
- # @raise [Invalid] Raised if the account cannot be invoiced.
99
- def invoice!(attrs={})
100
- InvoiceCollection.from_response API.post(invoices.uri, attrs.empty? ? nil : Invoice.to_xml(attrs))
101
- rescue Recurly::API::UnprocessableEntity => e
102
- raise Invalid, e.message
103
- end
104
-
105
- # Builds an invoice from the pending charges on the account but does not persist the invoice.
106
- # Raises an error if it fails.
107
- #
108
- # @return [InvoiceCollection] The newly-built invoice that has not been persisted.
109
- # @raise [Invalid] Raised if the account cannot be invoiced.
110
- def build_invoice
111
- InvoiceCollection.from_response API.post("#{invoices.uri}/preview")
112
- rescue Recurly::API::UnprocessableEntity => e
113
- raise Invalid, e.message
114
- end
115
-
116
- # Reopen an account.
117
- #
118
- # @return [true, false] +true+ when successful, +false+ when unable to
119
- # (e.g., the account is already open), and may raise an exception if the
120
- # attempt fails.
121
- def reopen
122
- return false unless link? :reopen
123
- reload follow_link :reopen
124
- true
125
- end
126
-
127
- # Verify a cvv code for the account's billing info.
128
- #
129
- # @example
130
- # acct = Recurly::Account.find('benjamin-du-monde')
131
- # begin
132
- # # If successful, returned billing_info will contain
133
- # # updated billing info details.
134
- # billing_info = acct.verify_cvv!("504")
135
- # rescue Recurly::API::BadRequest => e
136
- # e.message # => "This credit card has too many cvv check attempts."
137
- # rescue Recurly::Transaction::Error => e
138
- # # this will be the errors coming back from gateway
139
- # e.transaction_error_code # => "fraud_security_code"
140
- # e.gateway_error_code # => "fraud"
141
- # rescue Recurly::Resource::Invalid => e
142
- # e.message # => "verification_value must be three digits"
143
- # end
144
- #
145
- # @param [String] verification_value The CVV code to check
146
- # @return [BillingInfo] The updated billing info
147
- # @raise [Recurly::Transaction::Error] A Transaction Error will be raised if the gateway declines
148
- # the cvv code.
149
- # @raise [API::BadRequest] A BadRequest error will be raised if you attempt to check too many times
150
- # and are locked out.
151
- # @raise [Resource::Invalid] An Invalid Error will be raised if you send an invalid request (such as
152
- # a value that is not a propert verification number).
153
- def verify_cvv!(verification_value)
154
- bi = BillingInfo.new(verification_value: verification_value)
155
- bi.uri = "#{path}/billing_info/verify_cvv"
156
- bi.save!
157
- bi
158
- end
159
-
160
- def changed_attributes
161
- attrs = super
162
- if address.respond_to?(:changed?) && address.changed?
163
- attrs['address'] = address
164
- end
165
- if custom_fields.any?(&:changed?)
166
- attrs['custom_fields'] = custom_fields.select(&:changed?)
167
- end
168
- attrs
169
- end
170
-
171
- private
172
-
173
- def xml_keys
174
- keys = super
175
- keys << 'account_code' if account_code? && !account_code_changed?
176
- keys.sort
177
- end
178
- end
179
- end
@@ -1,21 +0,0 @@
1
- module Recurly
2
- # The AccountBalance object contains some information about the account's balance.
3
- # It exists to give us parity with the v1 API which used to include this information with
4
- # the {Account}. You can get an account's balance by calling {Account#account_balance} on an account instance.
5
- #
6
- # Recurly Documentation: https://dev.recurly.com/docs/lookup-account-balance
7
- class AccountBalance < Resource
8
- # @return [Account, nil]
9
- has_one :account, readonly: true
10
-
11
- define_attribute_methods %w(
12
- past_due
13
- balance_in_cents
14
- )
15
-
16
- # This object does not represent a model on the server side
17
- # so we do not need to expose these methods.
18
- protected(*%w(save save!))
19
- private_class_method(*%w(all find_each first paginate scoped where create! create))
20
- end
21
- end
@@ -1,30 +0,0 @@
1
- module Recurly
2
- class AddOn < Resource
3
- # @return [Plan]
4
- belongs_to :plan
5
-
6
- define_attribute_methods %w(
7
- add_on_code
8
- name
9
- accounting_code
10
- default_quantity
11
- unit_amount_in_cents
12
- display_quantity_on_hosted_page
13
- tax_code
14
- add_on_type
15
- measured_unit_id
16
- optional
17
- usage_type
18
- usage_percentage
19
- revenue_schedule_type
20
- created_at
21
- updated_at
22
- )
23
- alias to_param add_on_code
24
- alias quantity default_quantity
25
-
26
- # Add-ons are only writeable and readable through {Plan} instances.
27
- embedded!
28
- private_class_method :find
29
- end
30
- end
@@ -1,25 +0,0 @@
1
- module Recurly
2
- class Address < Resource
3
- define_attribute_methods %w(
4
- first_name
5
- last_name
6
- name_on_account
7
- company
8
- address1
9
- address2
10
- city
11
- state
12
- zip
13
- country
14
- phone
15
- geo_code
16
- )
17
-
18
- # This ensures every attribute is rendered
19
- # when updating. The Address object does not
20
- # accept partial updates on the server
21
- def xml_keys
22
- attributes.keys
23
- end
24
- end
25
- end
@@ -1,76 +0,0 @@
1
- module Recurly
2
- # The history of your customer's Recurly account can be tracked through adjustments, made up of credits and charges.
3
- #
4
- # Recurly Documentation: https://dev.recurly.com/docs/adjustment-object
5
- class Adjustment < Resource
6
- # @macro [attach] scope
7
- # @scope class
8
- # @return [Pager<Adjustment>] a pager that yields +$1+.
9
- scope :charges, type: 'charge'
10
- scope :credits, type: 'credit'
11
- scope :pending, state: 'pending'
12
- scope :invoiced, state: 'invoiced'
13
-
14
- # @return [Account, nil]
15
- belongs_to :account
16
- # @return [Invoice, nil]
17
- belongs_to :invoice
18
- # @return [Subscription, nil]
19
- belongs_to :subscription
20
-
21
- # @return [Pager<Adjustment>, []]
22
- has_many :credit_adjustments, class_name: :Adjustment, readonly: true
23
-
24
- # @return [ShippingAddress, nil]
25
- has_one :shipping_address, class_name: :ShippingAddress, readonly: false
26
-
27
- define_attribute_methods %w(
28
- uuid
29
- state
30
- description
31
- accounting_code
32
- origin
33
- unit_amount_in_cents
34
- quantity
35
- discount_in_cents
36
- total_in_cents
37
- currency
38
- product_code
39
- start_date
40
- end_date
41
- created_at
42
- updated_at
43
- quantity_remaining
44
- revenue_schedule_type
45
- tax_in_cents
46
- tax_type
47
- tax_region
48
- tax_rate
49
- tax_exempt
50
- tax_code
51
- tax_details
52
- tax_types
53
- proration_rate
54
- credit_reason_code
55
- original_adjustment_uuid
56
- shipping_address_id
57
- )
58
- alias to_param uuid
59
-
60
- # @return ["charge", "credit", nil] The type of adjustment.
61
- attr_reader :type
62
-
63
- # Adjustments should be built through {Account} instances.
64
- #
65
- # @return [Adjustment] A new adjustment.
66
- # @example
67
- # account.adjustments.new attributes
68
- # @see Resource#initialize
69
- def initialize(attributes = {})
70
- super({ :currency => Recurly.default_currency }.merge attributes)
71
- end
72
-
73
- # Adjustments are only writeable through an {Account} instance.
74
- embedded! true
75
- end
76
- end
@@ -1,208 +0,0 @@
1
- require 'cgi'
2
-
3
- module Recurly
4
- class API
5
- # The superclass to all errors that occur when making an API request.
6
- class ResponseError < Error
7
- attr_reader :request
8
- attr_reader :response
9
-
10
- def initialize request, response
11
- @request, @response = request, response
12
- end
13
-
14
- def code
15
- response.code.to_i if response
16
- end
17
-
18
- def to_s
19
- if description
20
- return CGI.unescapeHTML [description, details].compact.join(' ')
21
- end
22
-
23
- return super unless code
24
- "%d %s (%s %s)" % [
25
- code, http_error, request.method, API.base_uri + request.path
26
- ]
27
- end
28
-
29
- def symbol
30
- xml and xml.root and xml.text '/error/symbol'
31
- end
32
-
33
- def description
34
- xml and xml.root and xml.text '/error/description'
35
- end
36
-
37
- def details
38
- xml and xml.root and xml.text '/error/details'
39
- end
40
-
41
- private
42
-
43
- def http_error
44
- Helper.demodulize self.class.name.gsub(/([a-z])([A-Z])/, '\1 \2')
45
- end
46
-
47
- def xml
48
- @xml ||= begin
49
- XML.new(response.body) if response and response.body and not response.body.empty?
50
- rescue Recurly::XML::ParseError
51
- nil
52
- end
53
- end
54
- end
55
-
56
- # === 3xx Redirection
57
- #
58
- # Not an error, per se, but should result in one in the normal course of
59
- # API interaction.
60
- class Redirection < ResponseError
61
- end
62
-
63
- # === 304 Not Modified
64
- #
65
- # Catchably raised when a request is made with an ETag.
66
- class NotModified < ResponseError
67
- end
68
-
69
- # === 4xx Client Error
70
- #
71
- # The superclass to all client errors (responses with status code 4xx).
72
- class ClientError < ResponseError
73
- end
74
-
75
- # === 400 Bad Request
76
- #
77
- # The request was invalid or could not be understood by the server.
78
- # Resubmitting the request will likely result in the same error.
79
- class BadRequest < ClientError
80
- end
81
-
82
- # === 401 Unauthorized
83
- #
84
- # The API key is missing or invalid for the given request.
85
- class Unauthorized < ClientError
86
- def description
87
- response.body.strip
88
- end
89
- end
90
-
91
- # === 402 Payment Required
92
- #
93
- # Your Recurly account is in production mode but is not in good standing.
94
- # Please pay any outstanding invoices.
95
- class PaymentRequired < ClientError
96
- end
97
-
98
- # === 403 Forbidden
99
- #
100
- # The login is attempting to perform an action it does not have privileges
101
- # to access. The login credentials are correct.
102
- class Forbidden < ClientError
103
- end
104
-
105
- # === 404 Not Found
106
- #
107
- # The resource was not found. This may be returned if the given account
108
- # code or subscription plan does not exist. The response body will explain
109
- # which resource was not found.
110
- class NotFound < ClientError
111
- end
112
-
113
- # === 405 Method Not Allowed
114
- #
115
- # A method was attempted where it is not allowed.
116
- #
117
- # If this is raised, there may be a bug with the client library or with
118
- # the server. Please contact support@recurly.com or
119
- # {file a bug}[https://github.com/recurly/recurly-client-ruby/issues].
120
- class MethodNotAllowed < ClientError
121
- end
122
-
123
- # === 406 Not Acceptable
124
- #
125
- # The request content type was not acceptable.
126
- #
127
- # If this is raised, there may be a bug with the client library or with
128
- # the server. Please contact support@recurly.com or
129
- # {file a bug}[https://github.com/recurly/recurly-client-ruby/issues].
130
- class NotAcceptable < ClientError
131
- end
132
-
133
- # === 412 Precondition Failed
134
- #
135
- # The request was unsuccessful because a condition was not met. For
136
- # example, this message may be returned if you attempt to cancel a
137
- # subscription for an account that has no subscription.
138
- class PreconditionFailed < ClientError
139
- end
140
-
141
- # === 415 Unsupported Media Type
142
- #
143
- # The request body was not recognized as XML.
144
- #
145
- # If this is raised, there may be a bug with the client library or with
146
- # the server. Please contact support@recurly.com or
147
- # {file a bug}[https://github.com/recurly/recurly-client-ruby/issues].
148
- class UnsupportedMediaType < ClientError
149
- end
150
-
151
- # === 422 Unprocessable Entity
152
- #
153
- # Could not process a POST or PUT request because the request is invalid.
154
- # See the response body for more details.
155
- class UnprocessableEntity < ClientError
156
- end
157
-
158
- # === 5xx Server Error
159
- #
160
- # The superclass to all server errors (responses with status code 5xx).
161
- class ServerError < ResponseError
162
- end
163
-
164
- # === 500 Internal Server Error
165
- #
166
- # The server encountered an error while processing your request and failed.
167
- class InternalServerError < ServerError
168
- end
169
-
170
- # === 502 Gateway Error
171
- #
172
- # The load balancer or web server had trouble connecting to the Recurly.
173
- # Please try the request again.
174
- class GatewayError < ServerError
175
- end
176
-
177
- # === 503 Service Unavailable
178
- #
179
- # The service is temporarily unavailable. Please try the request again.
180
- class ServiceUnavailable < ServerError
181
- end
182
-
183
- # Error mapping by status code.
184
- ERRORS = Hash.new { |hash, code|
185
- unless hash.key? code
186
- case code
187
- when 400...500 then ClientError
188
- when 500...600 then ServerError
189
- else ResponseError
190
- end
191
- end
192
- }.update(
193
- 304 => NotModified,
194
- 400 => BadRequest,
195
- 401 => Unauthorized,
196
- 402 => PaymentRequired,
197
- 403 => Forbidden,
198
- 404 => NotFound,
199
- 406 => NotAcceptable,
200
- 412 => PreconditionFailed,
201
- 415 => UnsupportedMediaType,
202
- 422 => UnprocessableEntity,
203
- 500 => InternalServerError,
204
- 502 => GatewayError,
205
- 503 => ServiceUnavailable
206
- ).freeze
207
- end
208
- end
@@ -1,111 +0,0 @@
1
- require 'cgi'
2
- require 'net/https'
3
-
4
- module Recurly
5
- class API
6
- module Net
7
- module HTTPAdapter
8
- # A hash of Net::HTTP settings configured before the request.
9
- #
10
- # @return [Hash]
11
- def net_http
12
- @net_http ||= {}
13
- end
14
-
15
- # Used to store any Net::HTTP settings.
16
- #
17
- # @example
18
- # Recurly::API.net_http = {
19
- # :verify_mode => OpenSSL::SSL::VERIFY_PEER,
20
- # :ca_path => "/etc/ssl/certs",
21
- # :ca_file => "/opt/local/share/curl/curl-ca-bundle.crt"
22
- # }
23
- attr_writer :net_http
24
-
25
- private
26
-
27
- METHODS = {
28
- :head => ::Net::HTTP::Head,
29
- :get => ::Net::HTTP::Get,
30
- :post => ::Net::HTTP::Post,
31
- :put => ::Net::HTTP::Put,
32
- :delete => ::Net::HTTP::Delete
33
- }
34
-
35
- def request method, uri, options = {}
36
- head = headers.dup
37
- head.update options[:head] if options[:head]
38
- head.delete_if { |_, value| value.nil? }
39
- uri = base_uri + uri
40
- if options[:params] && !options[:params].empty?
41
- pairs = options[:params].map { |key, value|
42
- "#{CGI.escape key.to_s}=#{CGI.escape value.to_s}"
43
- }
44
- uri += "?#{pairs.join '&'}"
45
- end
46
- self.validate_uri!(uri)
47
- request = METHODS[method].new uri.request_uri, head
48
- request.basic_auth(*[Recurly.api_key, nil].flatten[0, 2])
49
- if options[:body]
50
- request['Content-Type'] = content_type
51
- request.body = options[:body]
52
- end
53
- if options[:etag]
54
- request['If-None-Match'] = options[:etag]
55
- end
56
- if options[:format]
57
- request['Accept'] = FORMATS[options[:format]]
58
- end
59
- if options[:locale]
60
- request['Accept-Language'] = options[:locale]
61
- end
62
- http = ::Net::HTTP.new uri.host, uri.port
63
- http.use_ssl = uri.scheme == 'https'
64
- net_http.each_pair { |key, value| http.send "#{key}=", value }
65
-
66
- if Recurly.logger
67
- Recurly.log :info, "===> %s %s" % [request.method, uri]
68
- headers = request.to_hash
69
- headers['authorization'] &&= ['Basic [FILTERED]']
70
- Recurly.log :debug, headers.inspect
71
- if request.body && !request.body.empty?
72
- Recurly.log :debug, XML.filter(request.body)
73
- end
74
- start_time = Time.now
75
- end
76
-
77
- response = http.start { http.request request }
78
- code = response.code.to_i
79
-
80
- if Recurly.logger
81
- latency = (Time.now - start_time) * 1_000
82
- level = case code
83
- when 200...300 then :info
84
- when 300...400 then :warn
85
- when 400...500 then :error
86
- else :fatal
87
- end
88
- Recurly.log level, "<=== %d %s (%.1fms)" % [
89
- code,
90
- response.class.name[9, response.class.name.length].gsub(
91
- /([a-z])([A-Z])/, '\1 \2'
92
- ),
93
- latency
94
- ]
95
- Recurly.log :debug, response.to_hash.inspect
96
- Recurly.log :debug, response.body if response.body
97
- end
98
-
99
- case code
100
- when 200...300 then response
101
- else raise ERRORS[code].new request, response
102
- end
103
- rescue Errno::ECONNREFUSED => e
104
- raise Error, e.message
105
- end
106
- end
107
- end
108
-
109
- extend Net::HTTPAdapter
110
- end
111
- end