Skip to content

Commit 52b87e1

Browse files
committed
updates from upstream
1 parent 9a68614 commit 52b87e1

File tree

6 files changed

+49
-40
lines changed

6 files changed

+49
-40
lines changed

.gitignore

+2-1
Original file line numberDiff line numberDiff line change
@@ -15,4 +15,5 @@ tags
1515

1616
/.idea
1717
*.iml
18-
priv/plts/*.plt
18+
priv/plts/*
19+
/cover

lib/stripe/subscriptions/invoice.ex

+27-19
Original file line numberDiff line numberDiff line change
@@ -29,32 +29,30 @@ defmodule Stripe.Invoice do
2929
attempt_count: non_neg_integer,
3030
attempted: boolean,
3131
auto_advance: boolean,
32-
collection_method: String.t() | nil,
3332
billing_reason: String.t() | nil,
3433
charge: Stripe.id() | Stripe.Charge.t() | nil,
3534
closed: boolean,
36-
collection_method: String.t(),
35+
collection_method: String.t() | nil,
36+
created: Stripe.timestamp(),
3737
currency: String.t(),
38+
custom_fields: custom_fields() | nil,
39+
customer: Stripe.id() | Stripe.Customer.t(),
3840
customer_address: Stripe.Types.address() | nil,
3941
customer_email: String.t() | nil,
4042
customer_name: String.t() | nil,
4143
customer_phone: String.t() | nil,
4244
customer_shipping: Stripe.Types.shipping() | nil,
4345
customer_tax_exempt: String.t() | nil,
4446
customer_tax_ids: Stripe.List.t(map) | nil,
45-
custom_fields: custom_fields() | nil,
46-
customer: Stripe.id() | Stripe.Customer.t(),
47-
created: Stripe.timestamp(),
4847
default_payment_method: String.t() | nil,
4948
default_source: String.t() | nil,
5049
default_tax_rates: Stripe.List.t(map) | nil,
50+
deleted: boolean | nil,
5151
description: String.t() | nil,
5252
discount: Stripe.Discount.t() | nil,
5353
due_date: Stripe.timestamp() | nil,
5454
ending_balance: integer | nil,
55-
finalized_at: Stripe.timestamp() | nil,
5655
footer: String.t() | nil,
57-
forgiven: boolean,
5856
hosted_invoice_url: String.t() | nil,
5957
invoice_pdf: String.t() | nil,
6058
lines: Stripe.List.t(Stripe.LineItem.t()),
@@ -74,12 +72,23 @@ defmodule Stripe.Invoice do
7472
status: String.t() | nil,
7573
status_transitions: status_transitions() | nil,
7674
subscription: Stripe.id() | Stripe.Subscription.t() | nil,
77-
subscription_proration_date: Stripe.timestamp(),
75+
subscription_proration_date: Stripe.timestamp() | nil,
7876
subtotal: integer,
7977
tax: integer | nil,
8078
tax_percent: number | nil,
81-
total_tax_amounts: Stripe.List.t(map) | nil,
79+
threshold_reason:
80+
nil
81+
| %{
82+
amount_gte: integer,
83+
item_reasons: [
84+
%{
85+
line_item_ids: [String.t()],
86+
usage_gte: integer
87+
}
88+
]
89+
},
8290
total: integer,
91+
total_tax_amounts: Stripe.List.t(map) | nil,
8392
webhooks_delivered_at: Stripe.timestamp() | nil
8493
}
8594

@@ -115,32 +124,30 @@ defmodule Stripe.Invoice do
115124
:attempt_count,
116125
:attempted,
117126
:auto_advance,
118-
:collection_method,
119127
:billing_reason,
120128
:charge,
121129
:closed,
122-
:created,
123130
:collection_method,
131+
:created,
132+
:currency,
133+
:custom_fields,
134+
:customer,
124135
:customer_address,
125136
:customer_email,
126137
:customer_name,
127138
:customer_phone,
128139
:customer_shipping,
129140
:customer_tax_exempt,
130141
:customer_tax_ids,
131-
:currency,
132-
:custom_fields,
133-
:customer,
134142
:default_payment_method,
135143
:default_source,
136144
:default_tax_rates,
145+
:deleted,
137146
:description,
138147
:discount,
139148
:due_date,
140149
:ending_balance,
141-
:finalized_at,
142150
:footer,
143-
:forgiven,
144151
:hosted_invoice_url,
145152
:invoice_pdf,
146153
:lines,
@@ -155,17 +162,18 @@ defmodule Stripe.Invoice do
155162
:post_payment_credit_notes_amount,
156163
:pre_payment_credit_notes_amount,
157164
:receipt_number,
158-
:status,
159-
:status_transitions,
160165
:starting_balance,
161166
:statement_descriptor,
167+
:status,
168+
:status_transitions,
162169
:subscription,
163170
:subscription_proration_date,
164171
:subtotal,
165172
:tax,
166173
:tax_percent,
167-
:total_tax_amounts,
174+
:threshold_reason,
168175
:total,
176+
:total_tax_amounts,
169177
:webhooks_delivered_at
170178
]
171179

lib/stripe/subscriptions/price.ex

+16-13
Original file line numberDiff line numberDiff line change
@@ -1,19 +1,28 @@
11
defmodule Stripe.Price do
22
@moduledoc """
33
Work with Stripe price objects.
4+
45
The Prices API adds more flexibility to how you charge customers.
6+
57
It also replaces the Plans API, so Stripe recommends migrating your existing
68
integration to work with prices.
9+
710
To migrate, you need to identify how you use plans, products, and payment
811
flows and then update these parts of your integration to use the Prices API.
12+
913
Migrating to Prices guide: https://stripe.com/docs/billing/migration/migrating-prices
14+
1015
You can:
16+
1117
- Create a price
1218
- Retrieve a price
1319
- Update a price
1420
- List all prices
21+
1522
Stripe API reference: https://stripe.com/docs/api/prices
23+
1624
Example:
25+
1726
```
1827
{
1928
"id": "plan_HJ8MK9HTYgniMM",
@@ -34,10 +43,8 @@ defmodule Stripe.Price do
3443
"trial_period_days": null,
3544
"usage_type": "licensed"
3645
},
37-
"tax_behavior": "unspecified",
3846
"tiers": null,
3947
"tiers_mode": null,
40-
"transform_lookup_key": false,
4148
"transform_quantity": null,
4249
"type": "recurring",
4350
"unit_amount": 999,
@@ -50,11 +57,11 @@ defmodule Stripe.Price do
5057
import Stripe.Request
5158

5259
@type recurring :: %{
53-
optional(:aggregate_usage) => String.t(),
54-
optional(:interval) => String.t(),
55-
optional(:interval_count) => pos_integer,
56-
optional(:trial_period_days) => pos_integer,
57-
optional(:usage_type) => String.t()
60+
aggregate_usage: String.t(),
61+
interval: String.t(),
62+
interval_count: pos_integer,
63+
trial_period_days: pos_integer,
64+
usage_type: String.t()
5865
}
5966

6067
@type price_tier :: %{
@@ -83,10 +90,8 @@ defmodule Stripe.Price do
8390
nickname: String.t(),
8491
product: Stripe.id() | Stripe.Product.t(),
8592
recurring: recurring(),
86-
tax_behavior: String.t(),
8793
tiers: [price_tier()],
8894
tiers_mode: String.t(),
89-
transform_lookup_key: boolean(),
9095
transform_quantity: transform_quantity(),
9196
type: String.t(),
9297
unit_amount: pos_integer,
@@ -106,10 +111,8 @@ defmodule Stripe.Price do
106111
:nickname,
107112
:product,
108113
:recurring,
109-
:tax_behavior,
110114
:tiers,
111115
:tiers_mode,
112-
:transform_lookup_key,
113116
:transform_quantity,
114117
:type,
115118
:unit_amount,
@@ -132,7 +135,6 @@ defmodule Stripe.Price do
132135
optional(:nickname) => String.t(),
133136
optional(:product) => Stripe.id() | Stripe.Product.t(),
134137
optional(:recurring) => recurring(),
135-
optional(:tax_behavior) => String.t(),
136138
optional(:tiers) => [price_tier()],
137139
optional(:tiers_mode) => String.t(),
138140
optional(:billing_scheme) => String.t(),
@@ -164,6 +166,7 @@ defmodule Stripe.Price do
164166

165167
@doc """
166168
Update a price.
169+
167170
Takes the `id` and a map of changes.
168171
"""
169172
@spec update(Stripe.id() | t, params, Stripe.options()) :: {:ok, t} | {:error, Stripe.Error.t()}
@@ -211,4 +214,4 @@ defmodule Stripe.Price do
211214
|> cast_to_id([:product, :ending_before, :starting_after])
212215
|> make_request()
213216
end
214-
end
217+
end

lib/stripe/types.ex

-3
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,6 @@ defmodule Stripe.Types do
6262
reset_billing_cycle_anchor: boolean | nil
6363
}
6464

65-
<<<<<<< HEAD
6665
@type tax :: %{
6766
automatic_tax: String.t(),
6867
ip_address: String.t(),
@@ -79,8 +78,6 @@ defmodule Stripe.Types do
7978
verified_name: String.t() | nil
8079
}
8180

82-
=======
83-
>>>>>>> dc49e40 (Stripe API 2019-12-03 Remove deprecated Customer tax_info)
8481
@type transfer_schedule :: %{
8582
delay_days: non_neg_integer,
8683
interval: String.t(),

lib/stripe/webhook.ex

+1-1
Original file line numberDiff line numberDiff line change
@@ -116,7 +116,7 @@ defmodule Stripe.Webhook do
116116
end
117117

118118
defp compute_signature(payload, secret) do
119-
:crypto.mac(:hmac, :sha256, secret, payload)
119+
hmac(:sha256, secret, payload)
120120
|> Base.encode16(case: :lower)
121121
end
122122

test/stripe/request_test.exs

+3-3
Original file line numberDiff line numberDiff line change
@@ -30,11 +30,11 @@ defmodule Stripe.RequestTest do
3030

3131
describe "new_request/2" do
3232
test "new_request/1 extracts headers from options and puts it on headers" do
33-
new_request = Request.new_request([headers: %{foo: "bar"}])
33+
new_request = Request.new_request(headers: %{foo: "bar"})
3434

3535
assert new_request.headers == %{
36-
foo: "bar"
37-
}
36+
foo: "bar"
37+
}
3838
end
3939
end
4040
end

0 commit comments

Comments
 (0)