-
Notifications
You must be signed in to change notification settings - Fork 0
/
Client.ts
118 lines (110 loc) · 4.54 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
108
109
110
111
112
113
114
115
116
117
118
/**
* This file was auto-generated by Fern from our API Definition.
*/
import * as environments from "../../../../environments";
import * as core from "../../../../core";
import * as Crossmint from "../../../index";
import urlJoin from "url-join";
import * as serializers from "../../../../serialization/index";
import * as errors from "../../../../errors/index";
export declare namespace Actions {
interface Options {
environment?: core.Supplier<environments.CrossmintEnvironment | string>;
apiKey?: core.Supplier<string | undefined>;
/** Override the Authorization header */
clientSecret?: core.Supplier<string | undefined>;
fetcher?: core.FetchFunction;
}
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;
/** Override the Authorization header */
clientSecret?: string | undefined;
}
}
export class Actions {
constructor(protected readonly _options: Actions.Options = {}) {}
/**
* Use this API to poll for the status of asynchonous actions such as NFT mints, transfers, etc.
*
* **API scope required**: `nfts.create`
*
* @param {string} actionId - The actionId.
* @param {Actions.RequestOptions} requestOptions - Request-specific configuration.
*
* @throws {@link Crossmint.ForbiddenError}
* @throws {@link Crossmint.NotFoundError}
*
* @example
* await client.actions.getActionStatus("actionId")
*/
public async getActionStatus(
actionId: string,
requestOptions?: Actions.RequestOptions
): Promise<Crossmint.GetActionStatusResponse> {
const _response = await (this._options.fetcher ?? core.fetcher)({
url: urlJoin(
(await core.Supplier.get(this._options.environment)) ?? environments.CrossmintEnvironment.Staging,
`2022-06-09/actions/${encodeURIComponent(actionId)}`
),
method: "GET",
headers: {
"X-Fern-Language": "JavaScript",
"X-Fern-SDK-Name": "@crossmint/autogen-sdk-ts",
"X-Fern-SDK-Version": "0.2.3",
"X-Fern-Runtime": core.RUNTIME.type,
"X-Fern-Runtime-Version": core.RUNTIME.version,
...(await this._getCustomAuthorizationHeaders()),
},
contentType: "application/json",
requestType: "json",
timeoutMs: requestOptions?.timeoutInSeconds != null ? requestOptions.timeoutInSeconds * 1000 : 60000,
maxRetries: requestOptions?.maxRetries,
abortSignal: requestOptions?.abortSignal,
});
if (_response.ok) {
return serializers.GetActionStatusResponse.parseOrThrow(_response.body, {
unrecognizedObjectKeys: "passthrough",
allowUnrecognizedUnionMembers: true,
allowUnrecognizedEnumValues: true,
skipValidation: true,
breadcrumbsPrefix: ["response"],
});
}
if (_response.error.reason === "status-code") {
switch (_response.error.statusCode) {
case 403:
throw new Crossmint.ForbiddenError(_response.error.body);
case 404:
throw new Crossmint.NotFoundError(_response.error.body);
default:
throw new errors.CrossmintError({
statusCode: _response.error.statusCode,
body: _response.error.body,
});
}
}
switch (_response.error.reason) {
case "non-json":
throw new errors.CrossmintError({
statusCode: _response.error.statusCode,
body: _response.error.rawBody,
});
case "timeout":
throw new errors.CrossmintTimeoutError();
case "unknown":
throw new errors.CrossmintError({
message: _response.error.errorMessage,
});
}
}
protected async _getCustomAuthorizationHeaders() {
const clientSecretValue = await core.Supplier.get(this._options.clientSecret);
const apiKeyValue = await core.Supplier.get(this._options.apiKey);
return { Authorization: clientSecretValue, "X-API-KEY": apiKeyValue };
}
}