stripe 9.4.0.pre.beta.3 → 9.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (41) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +44 -213
  3. data/OPENAPI_VERSION +1 -1
  4. data/README.md +0 -11
  5. data/VERSION +1 -1
  6. data/lib/stripe/api_operations/request.rb +0 -2
  7. data/lib/stripe/api_version.rb +0 -1
  8. data/lib/stripe/object_types.rb +1 -17
  9. data/lib/stripe/resources/financial_connections/account.rb +0 -39
  10. data/lib/stripe/resources/issuing/token.rb +14 -0
  11. data/lib/stripe/resources/payment_method_configuration.rb +14 -1
  12. data/lib/stripe/resources/quote.rb +0 -94
  13. data/lib/stripe/resources/setup_intent.rb +11 -12
  14. data/lib/stripe/resources/subscription_schedule.rb +0 -18
  15. data/lib/stripe/resources/terminal/reader.rb +0 -54
  16. data/lib/stripe/resources/token.rb +11 -11
  17. data/lib/stripe/resources.rb +1 -17
  18. data/lib/stripe/stripe_client.rb +26 -60
  19. data/lib/stripe/stripe_configuration.rb +0 -2
  20. data/lib/stripe/util.rb +1 -8
  21. data/lib/stripe/version.rb +1 -1
  22. data/lib/stripe.rb +0 -46
  23. metadata +5 -22
  24. data/lib/stripe/request_signing_authenticator.rb +0 -83
  25. data/lib/stripe/resources/capital/financing_offer.rb +0 -32
  26. data/lib/stripe/resources/capital/financing_summary.rb +0 -12
  27. data/lib/stripe/resources/capital/financing_transaction.rb +0 -13
  28. data/lib/stripe/resources/confirmation_token.rb +0 -11
  29. data/lib/stripe/resources/customer_session.rb +0 -12
  30. data/lib/stripe/resources/financial_connections/inferred_balance.rb +0 -13
  31. data/lib/stripe/resources/financial_connections/transaction.rb +0 -13
  32. data/lib/stripe/resources/gift_cards/card.rb +0 -25
  33. data/lib/stripe/resources/gift_cards/transaction.rb +0 -56
  34. data/lib/stripe/resources/issuing/personalization_design.rb +0 -77
  35. data/lib/stripe/resources/issuing/physical_bundle.rb +0 -13
  36. data/lib/stripe/resources/order.rb +0 -89
  37. data/lib/stripe/resources/quote_phase.rb +0 -29
  38. data/lib/stripe/resources/quote_preview_invoice.rb +0 -42
  39. data/lib/stripe/resources/quote_preview_schedule.rb +0 -10
  40. data/lib/stripe/resources/tax/form.rb +0 -39
  41. data/lib/stripe/resources/tax/registration.rb +0 -19
data/lib/stripe.rb CHANGED
@@ -13,7 +13,6 @@ require "set"
13
13
  require "socket"
14
14
  require "uri"
15
15
  require "forwardable"
16
- require "base64"
17
16
 
18
17
  # Version
19
18
  require "stripe/api_version"
@@ -45,7 +44,6 @@ require "stripe/api_resource_test_helpers"
45
44
  require "stripe/singleton_api_resource"
46
45
  require "stripe/webhook"
47
46
  require "stripe/stripe_configuration"
48
- require "stripe/request_signing_authenticator"
49
47
 
50
48
  # Named API resources
51
49
  require "stripe/resources"
@@ -72,7 +70,6 @@ module Stripe
72
70
 
73
71
  # User configurable options
74
72
  def_delegators :@config, :api_key, :api_key=
75
- def_delegators :@config, :authenticator, :authenticator=
76
73
  def_delegators :@config, :api_version, :api_version=
77
74
  def_delegators :@config, :stripe_account, :stripe_account=
78
75
  def_delegators :@config, :api_base, :api_base=
@@ -119,49 +116,6 @@ module Stripe
119
116
  version: version,
120
117
  }
121
118
  end
122
-
123
- class Preview
124
- def self._get_default_opts(opts)
125
- { api_mode: :preview }.merge(opts)
126
- end
127
-
128
- def self.get(url, opts = {})
129
- Stripe.raw_request(:get, url, {}, _get_default_opts(opts))
130
- end
131
-
132
- def self.post(url, params = {}, opts = {})
133
- Stripe.raw_request(:post, url, params, _get_default_opts(opts))
134
- end
135
-
136
- def self.delete(url, opts = {})
137
- Stripe.raw_request(:delete, url, {}, _get_default_opts(opts))
138
- end
139
- end
140
-
141
- class RawRequest
142
- include Stripe::APIOperations::Request
143
-
144
- def initialize
145
- @opts = {}
146
- end
147
-
148
- def execute(method, url, params = {}, opts = {})
149
- resp, = execute_resource_request(method, url, params, opts)
150
-
151
- resp
152
- end
153
- end
154
-
155
- # Sends a request to Stripe REST API
156
- def self.raw_request(method, url, params = {}, opts = {})
157
- req = RawRequest.new
158
- req.execute(method, url, params, opts)
159
- end
160
-
161
- def self.deserialize(data)
162
- data = JSON.parse(data) if data.is_a?(String)
163
- Util.convert_to_stripe_object(data, {})
164
- end
165
119
  end
166
120
 
167
121
  Stripe.log_level = ENV["STRIPE_LOG"] unless ENV["STRIPE_LOG"].nil?
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: stripe
3
3
  version: !ruby/object:Gem::Version
4
- version: 9.4.0.pre.beta.3
4
+ version: 9.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Stripe
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-09-29 00:00:00.000000000 Z
11
+ date: 2023-10-05 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: Stripe is the easiest way to accept payments online. See https://stripe.com
14
14
  for details.
@@ -50,7 +50,6 @@ files:
50
50
  - lib/stripe/multipart_encoder.rb
51
51
  - lib/stripe/oauth.rb
52
52
  - lib/stripe/object_types.rb
53
- - lib/stripe/request_signing_authenticator.rb
54
53
  - lib/stripe/resources.rb
55
54
  - lib/stripe/resources/account.rb
56
55
  - lib/stripe/resources/account_link.rb
@@ -66,14 +65,10 @@ files:
66
65
  - lib/stripe/resources/billing_portal/configuration.rb
67
66
  - lib/stripe/resources/billing_portal/session.rb
68
67
  - lib/stripe/resources/capability.rb
69
- - lib/stripe/resources/capital/financing_offer.rb
70
- - lib/stripe/resources/capital/financing_summary.rb
71
- - lib/stripe/resources/capital/financing_transaction.rb
72
68
  - lib/stripe/resources/card.rb
73
69
  - lib/stripe/resources/cash_balance.rb
74
70
  - lib/stripe/resources/charge.rb
75
71
  - lib/stripe/resources/checkout/session.rb
76
- - lib/stripe/resources/confirmation_token.rb
77
72
  - lib/stripe/resources/country_spec.rb
78
73
  - lib/stripe/resources/coupon.rb
79
74
  - lib/stripe/resources/credit_note.rb
@@ -81,7 +76,6 @@ files:
81
76
  - lib/stripe/resources/customer.rb
82
77
  - lib/stripe/resources/customer_balance_transaction.rb
83
78
  - lib/stripe/resources/customer_cash_balance_transaction.rb
84
- - lib/stripe/resources/customer_session.rb
85
79
  - lib/stripe/resources/discount.rb
86
80
  - lib/stripe/resources/dispute.rb
87
81
  - lib/stripe/resources/ephemeral_key.rb
@@ -92,12 +86,8 @@ files:
92
86
  - lib/stripe/resources/financial_connections/account.rb
93
87
  - lib/stripe/resources/financial_connections/account_owner.rb
94
88
  - lib/stripe/resources/financial_connections/account_ownership.rb
95
- - lib/stripe/resources/financial_connections/inferred_balance.rb
96
89
  - lib/stripe/resources/financial_connections/session.rb
97
- - lib/stripe/resources/financial_connections/transaction.rb
98
90
  - lib/stripe/resources/funding_instructions.rb
99
- - lib/stripe/resources/gift_cards/card.rb
100
- - lib/stripe/resources/gift_cards/transaction.rb
101
91
  - lib/stripe/resources/identity/verification_report.rb
102
92
  - lib/stripe/resources/identity/verification_session.rb
103
93
  - lib/stripe/resources/invoice.rb
@@ -107,13 +97,11 @@ files:
107
97
  - lib/stripe/resources/issuing/card.rb
108
98
  - lib/stripe/resources/issuing/cardholder.rb
109
99
  - lib/stripe/resources/issuing/dispute.rb
110
- - lib/stripe/resources/issuing/personalization_design.rb
111
- - lib/stripe/resources/issuing/physical_bundle.rb
100
+ - lib/stripe/resources/issuing/token.rb
112
101
  - lib/stripe/resources/issuing/transaction.rb
113
102
  - lib/stripe/resources/line_item.rb
114
103
  - lib/stripe/resources/login_link.rb
115
104
  - lib/stripe/resources/mandate.rb
116
- - lib/stripe/resources/order.rb
117
105
  - lib/stripe/resources/payment_intent.rb
118
106
  - lib/stripe/resources/payment_link.rb
119
107
  - lib/stripe/resources/payment_method.rb
@@ -126,9 +114,6 @@ files:
126
114
  - lib/stripe/resources/product.rb
127
115
  - lib/stripe/resources/promotion_code.rb
128
116
  - lib/stripe/resources/quote.rb
129
- - lib/stripe/resources/quote_phase.rb
130
- - lib/stripe/resources/quote_preview_invoice.rb
131
- - lib/stripe/resources/quote_preview_schedule.rb
132
117
  - lib/stripe/resources/radar/early_fraud_warning.rb
133
118
  - lib/stripe/resources/radar/value_list.rb
134
119
  - lib/stripe/resources/radar/value_list_item.rb
@@ -149,8 +134,6 @@ files:
149
134
  - lib/stripe/resources/subscription_schedule.rb
150
135
  - lib/stripe/resources/tax/calculation.rb
151
136
  - lib/stripe/resources/tax/calculation_line_item.rb
152
- - lib/stripe/resources/tax/form.rb
153
- - lib/stripe/resources/tax/registration.rb
154
137
  - lib/stripe/resources/tax/settings.rb
155
138
  - lib/stripe/resources/tax/transaction.rb
156
139
  - lib/stripe/resources/tax/transaction_line_item.rb
@@ -210,9 +193,9 @@ required_ruby_version: !ruby/object:Gem::Requirement
210
193
  version: 2.3.0
211
194
  required_rubygems_version: !ruby/object:Gem::Requirement
212
195
  requirements:
213
- - - ">"
196
+ - - ">="
214
197
  - !ruby/object:Gem::Version
215
- version: 1.3.1
198
+ version: '0'
216
199
  requirements: []
217
200
  rubygems_version: 3.3.26
218
201
  signing_key:
@@ -1,83 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Stripe
4
- class RequestSigningAuthenticator
5
- AUTHORIZATION_HEADER_NAME = "Authorization"
6
- CONTENT_TYPE_HEADER_NAME = "Content-Type"
7
- STRIPE_CONTEXT_HEADER_NAME = "Stripe-Context"
8
- STRIPE_ACCOUNT_HEADER_NAME = "Stripe-Account"
9
- CONTENT_DIGEST_HEADER_NAME = "Content-Digest"
10
- SIGNATURE_INPUT_HEADER_NAME = "Signature-Input"
11
- SIGNATURE_HEADER_NAME = "Signature"
12
-
13
- attr_reader :auth_token, :sign_lambda
14
-
15
- def initialize(auth_token, sign_lambda)
16
- unless auth_token.is_a?(String)
17
- raise ArgumentError, "auth_token must be a string"
18
- end
19
- unless sign_lambda.is_a?(Proc)
20
- raise ArgumentError, "sign_lambda must be a lambda"
21
- end
22
-
23
- @auth_token = auth_token
24
- @sign_lambda = sign_lambda
25
- end
26
-
27
- def authenticate(method, headers, body)
28
- covered_headers = [CONTENT_TYPE_HEADER_NAME,
29
- CONTENT_DIGEST_HEADER_NAME,
30
- STRIPE_CONTEXT_HEADER_NAME,
31
- STRIPE_ACCOUNT_HEADER_NAME,
32
- AUTHORIZATION_HEADER_NAME,]
33
-
34
- headers[AUTHORIZATION_HEADER_NAME] = "STRIPE-V2-SIG #{auth_token}"
35
-
36
- if method == :get
37
- covered_headers -= [CONTENT_TYPE_HEADER_NAME,
38
- CONTENT_DIGEST_HEADER_NAME,]
39
- else
40
- content = body || ""
41
- headers[CONTENT_DIGEST_HEADER_NAME] =
42
- %(sha-256=:#{content_digest(content)}:)
43
- end
44
-
45
- covered_headers_formatted = covered_headers
46
- .map { |string| %("#{string.downcase}") }
47
- .join(" ")
48
-
49
- signature_input = "(#{covered_headers_formatted});created=#{created_time}"
50
-
51
- inputs = covered_headers
52
- .map { |header| %("#{header.downcase}": #{headers[header]}) }
53
- .join("\n")
54
-
55
- signature_base = %(#{inputs}\n"@signature-params": #{signature_input})
56
- .encode(Encoding::UTF_8)
57
-
58
- headers[SIGNATURE_INPUT_HEADER_NAME] = "sig1=#{signature_input}"
59
-
60
- headers[SIGNATURE_HEADER_NAME] =
61
- "sig1=:#{encoded_signature(signature_base)}:"
62
- end
63
-
64
- private def sign(signature_base)
65
- @sign_lambda.call(signature_base)
66
- end
67
-
68
- private def encoded_signature(signature_base)
69
- Base64.strict_encode64(sign(signature_base))
70
- rescue StandardError
71
- raise AuthenticationError, "Encountered '#{e.message} (#{e.class})' "\
72
- "when calculating request signature."
73
- end
74
-
75
- private def content_digest(content)
76
- Base64.strict_encode64(OpenSSL::Digest.new("SHA256").digest(content))
77
- end
78
-
79
- private def created_time
80
- Time.now.to_i
81
- end
82
- end
83
- end
@@ -1,32 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module Capital
6
- # This is an object representing an offer of financing from
7
- # Stripe Capital to a Connect subaccount.
8
- class FinancingOffer < APIResource
9
- extend Stripe::APIOperations::List
10
-
11
- OBJECT_NAME = "capital.financing_offer"
12
-
13
- def mark_delivered(params = {}, opts = {})
14
- request_stripe_object(
15
- method: :post,
16
- path: format("/v1/capital/financing_offers/%<financing_offer>s/mark_delivered", { financing_offer: CGI.escape(self["id"]) }),
17
- params: params,
18
- opts: opts
19
- )
20
- end
21
-
22
- def self.mark_delivered(financing_offer, params = {}, opts = {})
23
- request_stripe_object(
24
- method: :post,
25
- path: format("/v1/capital/financing_offers/%<financing_offer>s/mark_delivered", { financing_offer: CGI.escape(financing_offer) }),
26
- params: params,
27
- opts: opts
28
- )
29
- end
30
- end
31
- end
32
- end
@@ -1,12 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module Capital
6
- # A financing object describes an account's current financing state. Used by Connect
7
- # platforms to read the state of Capital offered to their connected accounts.
8
- class FinancingSummary < SingletonAPIResource
9
- OBJECT_NAME = "capital.financing_summary"
10
- end
11
- end
12
- end
@@ -1,13 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module Capital
6
- # This is an object representing the details of a transaction on a Capital financing object.
7
- class FinancingTransaction < APIResource
8
- extend Stripe::APIOperations::List
9
-
10
- OBJECT_NAME = "capital.financing_transaction"
11
- end
12
- end
13
- end
@@ -1,11 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- # ConfirmationTokens help transport client side data collected by Stripe JS over
6
- # to your server for confirming a PaymentIntent or SetupIntent. If the confirmation
7
- # is successful, values present on the ConfirmationToken are written onto the Intent.
8
- class ConfirmationToken < APIResource
9
- OBJECT_NAME = "confirmation_token"
10
- end
11
- end
@@ -1,12 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- # A customer session allows you to grant client access to Stripe's frontend SDKs (like StripeJs)
6
- # control over a customer.
7
- class CustomerSession < APIResource
8
- extend Stripe::APIOperations::Create
9
-
10
- OBJECT_NAME = "customer_session"
11
- end
12
- end
@@ -1,13 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module FinancialConnections
6
- # A historical balance for the account on a particular day. It may be sourced from a balance snapshot provided by a financial institution, or inferred using transactions data.
7
- class InferredBalance < APIResource
8
- extend Stripe::APIOperations::List
9
-
10
- OBJECT_NAME = "financial_connections.account_inferred_balance"
11
- end
12
- end
13
- end
@@ -1,13 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module FinancialConnections
6
- # A Transaction represents a real transaction that affects a Financial Connections Account balance.
7
- class Transaction < APIResource
8
- extend Stripe::APIOperations::List
9
-
10
- OBJECT_NAME = "financial_connections.transaction"
11
- end
12
- end
13
- end
@@ -1,25 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module GiftCards
6
- # A gift card represents a single gift card owned by a customer, including the
7
- # remaining balance, gift card code, and whether or not it is active.
8
- class Card < APIResource
9
- extend Stripe::APIOperations::Create
10
- extend Stripe::APIOperations::List
11
- include Stripe::APIOperations::Save
12
-
13
- OBJECT_NAME = "gift_cards.card"
14
-
15
- def self.validate(params = {}, opts = {})
16
- request_stripe_object(
17
- method: :post,
18
- path: "/v1/gift_cards/cards/validate",
19
- params: params,
20
- opts: opts
21
- )
22
- end
23
- end
24
- end
25
- end
@@ -1,56 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module GiftCards
6
- # A gift card transaction represents a single transaction on a referenced gift card.
7
- # A transaction is in one of three states, `confirmed`, `held` or `canceled`. A `confirmed`
8
- # transaction is one that has added/deducted funds. A `held` transaction has created a
9
- # temporary hold on funds, which can then be cancelled or confirmed. A `held` transaction
10
- # can be confirmed into a `confirmed` transaction, or canceled into a `canceled` transaction.
11
- # A `canceled` transaction has no effect on a gift card's balance.
12
- class Transaction < APIResource
13
- extend Stripe::APIOperations::Create
14
- extend Stripe::APIOperations::List
15
- include Stripe::APIOperations::Save
16
-
17
- OBJECT_NAME = "gift_cards.transaction"
18
-
19
- def cancel(params = {}, opts = {})
20
- request_stripe_object(
21
- method: :post,
22
- path: format("/v1/gift_cards/transactions/%<id>s/cancel", { id: CGI.escape(self["id"]) }),
23
- params: params,
24
- opts: opts
25
- )
26
- end
27
-
28
- def confirm(params = {}, opts = {})
29
- request_stripe_object(
30
- method: :post,
31
- path: format("/v1/gift_cards/transactions/%<id>s/confirm", { id: CGI.escape(self["id"]) }),
32
- params: params,
33
- opts: opts
34
- )
35
- end
36
-
37
- def self.cancel(id, params = {}, opts = {})
38
- request_stripe_object(
39
- method: :post,
40
- path: format("/v1/gift_cards/transactions/%<id>s/cancel", { id: CGI.escape(id) }),
41
- params: params,
42
- opts: opts
43
- )
44
- end
45
-
46
- def self.confirm(id, params = {}, opts = {})
47
- request_stripe_object(
48
- method: :post,
49
- path: format("/v1/gift_cards/transactions/%<id>s/confirm", { id: CGI.escape(id) }),
50
- params: params,
51
- opts: opts
52
- )
53
- end
54
- end
55
- end
56
- end
@@ -1,77 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module Issuing
6
- # A Personalization Design is a logical grouping of a Physical Bundle, card logo, and carrier text that represents a product line.
7
- class PersonalizationDesign < APIResource
8
- extend Stripe::APIOperations::Create
9
- extend Stripe::APIOperations::List
10
- include Stripe::APIOperations::Save
11
-
12
- OBJECT_NAME = "issuing.personalization_design"
13
-
14
- def test_helpers
15
- TestHelpers.new(self)
16
- end
17
-
18
- class TestHelpers < APIResourceTestHelpers
19
- RESOURCE_CLASS = PersonalizationDesign
20
-
21
- def self.activate(personalization_design, params = {}, opts = {})
22
- request_stripe_object(
23
- method: :post,
24
- path: format("/v1/test_helpers/issuing/personalization_designs/%<personalization_design>s/activate", { personalization_design: CGI.escape(personalization_design) }),
25
- params: params,
26
- opts: opts
27
- )
28
- end
29
-
30
- def self.deactivate(personalization_design, params = {}, opts = {})
31
- request_stripe_object(
32
- method: :post,
33
- path: format("/v1/test_helpers/issuing/personalization_designs/%<personalization_design>s/deactivate", { personalization_design: CGI.escape(personalization_design) }),
34
- params: params,
35
- opts: opts
36
- )
37
- end
38
-
39
- def self.reject(personalization_design, params = {}, opts = {})
40
- request_stripe_object(
41
- method: :post,
42
- path: format("/v1/test_helpers/issuing/personalization_designs/%<personalization_design>s/reject", { personalization_design: CGI.escape(personalization_design) }),
43
- params: params,
44
- opts: opts
45
- )
46
- end
47
-
48
- def activate(params = {}, opts = {})
49
- @resource.request_stripe_object(
50
- method: :post,
51
- path: format("/v1/test_helpers/issuing/personalization_designs/%<personalization_design>s/activate", { personalization_design: CGI.escape(@resource["id"]) }),
52
- params: params,
53
- opts: opts
54
- )
55
- end
56
-
57
- def deactivate(params = {}, opts = {})
58
- @resource.request_stripe_object(
59
- method: :post,
60
- path: format("/v1/test_helpers/issuing/personalization_designs/%<personalization_design>s/deactivate", { personalization_design: CGI.escape(@resource["id"]) }),
61
- params: params,
62
- opts: opts
63
- )
64
- end
65
-
66
- def reject(params = {}, opts = {})
67
- @resource.request_stripe_object(
68
- method: :post,
69
- path: format("/v1/test_helpers/issuing/personalization_designs/%<personalization_design>s/reject", { personalization_design: CGI.escape(@resource["id"]) }),
70
- params: params,
71
- opts: opts
72
- )
73
- end
74
- end
75
- end
76
- end
77
- end
@@ -1,13 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- module Issuing
6
- # A Physical Bundle represents the bundle of physical items - card stock, carrier letter, and envelope - that is shipped to a cardholder when you create a physical card.
7
- class PhysicalBundle < APIResource
8
- extend Stripe::APIOperations::List
9
-
10
- OBJECT_NAME = "issuing.physical_bundle"
11
- end
12
- end
13
- end
@@ -1,89 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- # An Order describes a purchase being made by a customer, including the
6
- # products & quantities being purchased, the order status, the payment information,
7
- # and the billing/shipping details.
8
- #
9
- # Related guide: [Orders overview](https://stripe.com/docs/orders)
10
- class Order < APIResource
11
- extend Stripe::APIOperations::Create
12
- extend Stripe::APIOperations::List
13
- include Stripe::APIOperations::Save
14
-
15
- OBJECT_NAME = "order"
16
-
17
- def cancel(params = {}, opts = {})
18
- request_stripe_object(
19
- method: :post,
20
- path: format("/v1/orders/%<id>s/cancel", { id: CGI.escape(self["id"]) }),
21
- params: params,
22
- opts: opts
23
- )
24
- end
25
-
26
- def list_line_items(params = {}, opts = {})
27
- request_stripe_object(
28
- method: :get,
29
- path: format("/v1/orders/%<id>s/line_items", { id: CGI.escape(self["id"]) }),
30
- params: params,
31
- opts: opts
32
- )
33
- end
34
-
35
- def reopen(params = {}, opts = {})
36
- request_stripe_object(
37
- method: :post,
38
- path: format("/v1/orders/%<id>s/reopen", { id: CGI.escape(self["id"]) }),
39
- params: params,
40
- opts: opts
41
- )
42
- end
43
-
44
- def submit(params = {}, opts = {})
45
- request_stripe_object(
46
- method: :post,
47
- path: format("/v1/orders/%<id>s/submit", { id: CGI.escape(self["id"]) }),
48
- params: params,
49
- opts: opts
50
- )
51
- end
52
-
53
- def self.cancel(id, params = {}, opts = {})
54
- request_stripe_object(
55
- method: :post,
56
- path: format("/v1/orders/%<id>s/cancel", { id: CGI.escape(id) }),
57
- params: params,
58
- opts: opts
59
- )
60
- end
61
-
62
- def self.list_line_items(id, params = {}, opts = {})
63
- request_stripe_object(
64
- method: :get,
65
- path: format("/v1/orders/%<id>s/line_items", { id: CGI.escape(id) }),
66
- params: params,
67
- opts: opts
68
- )
69
- end
70
-
71
- def self.reopen(id, params = {}, opts = {})
72
- request_stripe_object(
73
- method: :post,
74
- path: format("/v1/orders/%<id>s/reopen", { id: CGI.escape(id) }),
75
- params: params,
76
- opts: opts
77
- )
78
- end
79
-
80
- def self.submit(id, params = {}, opts = {})
81
- request_stripe_object(
82
- method: :post,
83
- path: format("/v1/orders/%<id>s/submit", { id: CGI.escape(id) }),
84
- params: params,
85
- opts: opts
86
- )
87
- end
88
- end
89
- end
@@ -1,29 +0,0 @@
1
- # File generated from our OpenAPI spec
2
- # frozen_string_literal: true
3
-
4
- module Stripe
5
- # A quote phase describes the line items, coupons, and trialing status of a subscription for a predefined time period.
6
- class QuotePhase < APIResource
7
- extend Stripe::APIOperations::List
8
-
9
- OBJECT_NAME = "quote_phase"
10
-
11
- def list_line_items(params = {}, opts = {})
12
- request_stripe_object(
13
- method: :get,
14
- path: format("/v1/quote_phases/%<quote_phase>s/line_items", { quote_phase: CGI.escape(self["id"]) }),
15
- params: params,
16
- opts: opts
17
- )
18
- end
19
-
20
- def self.list_line_items(quote_phase, params = {}, opts = {})
21
- request_stripe_object(
22
- method: :get,
23
- path: format("/v1/quote_phases/%<quote_phase>s/line_items", { quote_phase: CGI.escape(quote_phase) }),
24
- params: params,
25
- opts: opts
26
- )
27
- end
28
- end
29
- end