-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathClient.ts
107 lines (99 loc) · 4.08 KB
/
Client.ts
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
/**
* This file was auto-generated by Fern from our API Definition.
*/
import * as environments from "../../../../environments";
import * as core from "../../../../core";
import * as Stripe from "../../../index";
import urlJoin from "url-join";
import * as errors from "../../../../errors/index";
export declare namespace LoginLink {
export interface Options {
environment?: core.Supplier<environments.StripeEnvironment | string>;
/** Specify a custom URL to connect the client to. */
baseUrl?: core.Supplier<string>;
token: core.Supplier<core.BearerToken>;
}
export interface RequestOptions {
/** The maximum time to wait for a response in seconds. */
timeoutInSeconds?: number;
/** The number of times to retry the request. Defaults to 2. */
maxRetries?: number;
/** A hook to abort the request. */
abortSignal?: AbortSignal;
/** Additional headers to include in the request. */
headers?: Record<string, string>;
}
}
export class LoginLink {
constructor(protected readonly _options: LoginLink.Options) {}
/**
* <p>Creates a login link for a connected account to access the Express Dashboard.</p>
*
* <p><strong>You can only create login links for accounts that use the <a href="/connect/express-dashboard">Express Dashboard</a> and are connected to your platform</strong>.</p>
*
* @param {string} account
* @param {Stripe.LoginLinkCreateRequest} request
* @param {LoginLink.RequestOptions} requestOptions - Request-specific configuration.
*
* @example
* await client.loginLink.create("account")
*/
public async create(
account: string,
request: Stripe.LoginLinkCreateRequest = {},
requestOptions?: LoginLink.RequestOptions,
): Promise<Stripe.LoginLink> {
const _response = await core.fetcher({
url: urlJoin(
(await core.Supplier.get(this._options.baseUrl)) ??
(await core.Supplier.get(this._options.environment)) ??
environments.StripeEnvironment.Default,
`v1/accounts/${encodeURIComponent(account)}/login_links`,
),
method: "POST",
headers: {
Authorization: await this._getAuthorizationHeader(),
"X-Fern-Language": "JavaScript",
"X-Fern-SDK-Name": "@fern-api/stripe",
"X-Fern-SDK-Version": "1.0.1",
"User-Agent": "@fern-api/stripe/1.0.1",
"X-Fern-Runtime": core.RUNTIME.type,
"X-Fern-Runtime-Version": core.RUNTIME.version,
...requestOptions?.headers,
},
contentType: "application/x-www-form-urlencoded",
requestType: "json",
body: request,
timeoutMs: requestOptions?.timeoutInSeconds != null ? requestOptions.timeoutInSeconds * 1000 : 60000,
maxRetries: requestOptions?.maxRetries,
abortSignal: requestOptions?.abortSignal,
});
if (_response.ok) {
return _response.body as Stripe.LoginLink;
}
if (_response.error.reason === "status-code") {
throw new errors.StripeError({
statusCode: _response.error.statusCode,
body: _response.error.body,
});
}
switch (_response.error.reason) {
case "non-json":
throw new errors.StripeError({
statusCode: _response.error.statusCode,
body: _response.error.rawBody,
});
case "timeout":
throw new errors.StripeTimeoutError(
"Timeout exceeded when calling POST /v1/accounts/{account}/login_links.",
);
case "unknown":
throw new errors.StripeError({
message: _response.error.errorMessage,
});
}
}
protected async _getAuthorizationHeader(): Promise<string> {
return `Bearer ${await core.Supplier.get(this._options.token)}`;
}
}