-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstripe.ex
164 lines (124 loc) · 4.38 KB
/
stripe.ex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
defmodule Fly.Stripe do
@moduledoc """
# Stripe API module
This is a thin module meant to look a lot like the ["Stripe for Elixir" library](https://github.com/beam-community/stripity-stripe) ([hex docs](https://hexdocs.pm/stripity_stripe/Stripe.html#content)), which the most commonly used Stripe library for Elixir.
This is meant to help you focus on the problem, rather than learning the Stripe API.
Feel free to modify these modules. For example, add more errors, etc..
There are a few modules:
- Fly.Stripe
- Fly.Stripe.Invoice
- Fly.Stripe.InvoiceItem
## Usage
### Invoice
The Fly.Stripe.Invoice module is documented and we suggest looking there.
```elixir
# create
invoice = Fly.Stripe.Invoice.create(%{customer: "cus_1234567"})
# retrieve
invoice = Fly.Stripe.InvoiceItem.retrieve(
invoice.id,
%{
customer: "cus_1234567"
}
)
```
## InvoiceItem
The Fly.Stripe.InvoiceItem module is documented and we suggest looking there.
```elixir
# create
invoice = Fly.Stripe.Invoice.create(%{customer: "cus_1234567"})
## Note: if you're looking at [the docs for creating an Invoiceitem](https://hexdocs.pm/stripity_stripe/Stripe.Invoiceitem.html#create/2)
## you might notice that currency and customer are required arguments. We're not going to
## enforce that rule with out implementation.
invoice_item = Fly.Stripe.InvoiceItem.create(
%{
invoice: invoice.id,
unit_amount_decimal: 0.1,
quantity: 1
}
)
# retrieve
invoice_item = Fly.Stripe.InvoiceItem.retrieve(
invoice_item.id,
%{
unit_amount_decimal: 2.0,
quantity: 20
}
)
```
## Stubbing, Errors, and Slow Responses
```elixir
# These stubbing strategies are available for both Invoice and InvoiceItem.
# We would suggest using these to prove things work in tests or for
# tinkering in the iex console.
Fly.Stripe.slow_with(1000) do
Fly.Stripe.Invoice.retrieve("inv_1234") # waits 1 second
end
Fly.Stripe.error_with(fn ->
Fly.Stripe.Invoice.retrieve(%{id: "abcd", customer: "cus_1234"})
end, %Fly.Stripe.Error{message: "no error"})
Fly.Stripe.error_with(fn ->
Fly.Stripe.Invoice.retrieve(nil)
end, %Fly.Stripe.Error{message: "uhoh error time"})
** (Fly.Stripe.Error) uh-oh error time
```
"""
@doc """
Delay the execution of a function by a given number of milliseconds
## Examples
iex> Fly.Stripe.slow_with(fn ->
iex> Fly.Stripe.Invoice.create(%{id: "abcd", customer: "cus_1234"})
iex> end, 1000)
{:ok, %Fly.Stripe.Invoice{id: "abcd", customer: "cus_1234"}}
"""
def slow_with(func, time_milliseconds) do
:timer.sleep(time_milliseconds)
func.()
end
@doc """
Replace any errors that occur with the provided error
## Examples
No error:
iex> Fly.Stripe.error_with(fn ->
...> Fly.Stripe.Invoice.create(%{id: "abcd", customer: "cus_1234"})
...> end, %Fly.Stripe.Error{message: "bubble tea"})
{:ok, %Fly.Stripe.Invoice{id: "abcd", customer: "cus_1234"}}
Trigger error:
iex> Fly.Stripe.error_with(fn ->
...> Fly.Stripe.Invoice.retrieve(nil)
...> end, %Fly.Stripe.Error{message: "bubble tea"})
** (Fly.Stripe.Error) bubble tea
"""
def error_with(func, error) do
try do
func.()
rescue
_e -> raise error.__struct__, message: error.message
end
end
@spec create_invoice(customer_id :: String.t()) :: {:error, Error.t()} | {:ok, Invoice.t()}
def create_invoice(customer_id) when is_binary(customer_id) do
api_module(:invoice).create(%{customer: customer_id, total: 0})
end
@spec create_invoice_item(params :: map()) :: {:error, Error.t()} | {:ok, InvoiceItem.t()}
def create_invoice_item(params \\ %{}) do
api_module(:invoice_item).create(params)
end
@doc """
Retrieve the API module to use for a given endpoint
## Examples
iex> Fly.Stripe.api_module(:invoice)
Fly.Stripe.InvoiceMock
iex> Fly.Stripe.api_module(:invoice_item)
Fly.Stripe.InvoiceItemMock
"""
def api_module(:invoice), do: get_endpoint_module(:invoice, Fly.Stripe.Invoice)
def api_module(:invoice_item), do: get_endpoint_module(:invoice_item, Fly.Stripe.InvoiceItem)
defp get_endpoint_module(module, default_module) do
Keyword.get(get_endpoint_config(), module, default_module)
end
# Retrieve the modules configured for Stripe api, based on environment
defp get_endpoint_config() do
Application.get_env(:fly, Fly.Stripe)
end
end