1 | type Stripe = { |
2 | token: string; |
3 | }; |
4 | |
5 | * Post financial connections sessions |
6 | * To launch the Financial Connections authorization flow, create a Session. The session’s client_secret can be used to launch the flow using Stripe.js. |
7 | */ |
8 | export async function main( |
9 | auth: Stripe, |
10 | body: { |
11 | account_holder: { |
12 | account?: string; |
13 | customer?: string; |
14 | type: "account" | "customer"; |
15 | [k: string]: unknown; |
16 | }; |
17 | expand?: string[]; |
18 | filters?: { countries: string[]; [k: string]: unknown }; |
19 | permissions: ( |
20 | | "balances" |
21 | | "ownership" |
22 | | "payment_method" |
23 | | "transactions" |
24 | )[]; |
25 | prefetch?: ("balances" | "ownership" | "transactions")[]; |
26 | return_url?: string; |
27 | } |
28 | ) { |
29 | const url = new URL( |
30 | `https://api.stripe.com/v1/financial_connections/sessions` |
31 | ); |
32 |
|
33 | const response = await fetch(url, { |
34 | method: "POST", |
35 | headers: { |
36 | "Content-Type": "application/x-www-form-urlencoded", |
37 | Authorization: "Bearer " + auth.token, |
38 | }, |
39 | body: encodeParams(body), |
40 | }); |
41 | if (!response.ok) { |
42 | const text = await response.text(); |
43 | throw new Error(`${response.status} ${text}`); |
44 | } |
45 | return await response.json(); |
46 | } |
47 |
|
48 | function encodeParams(o: any) { |
49 | function iter(o: any, path: string) { |
50 | if (Array.isArray(o)) { |
51 | o.forEach(function (a) { |
52 | iter(a, path + "[]"); |
53 | }); |
54 | return; |
55 | } |
56 | if (o !== null && typeof o === "object") { |
57 | Object.keys(o).forEach(function (k) { |
58 | iter(o[k], path + "[" + k + "]"); |
59 | }); |
60 | return; |
61 | } |
62 | data.push(path + "=" + o); |
63 | } |
64 | const data: string[] = []; |
65 | Object.keys(o).forEach(function (k) { |
66 | if (o[k] !== undefined) { |
67 | iter(o[k], k); |
68 | } |
69 | }); |
70 | return new URLSearchParams(data.join("&")); |
71 | } |
72 |
|