@cubist-labs/cubesigner-sdk 0.4.241 → 0.4.244
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/package.json +1 -1
- package/dist/src/audit_log.d.ts +4 -4
- package/dist/src/audit_log.js +1 -1
- package/dist/src/client/api_client.d.ts +9 -1
- package/dist/src/client/api_client.d.ts.map +1 -1
- package/dist/src/client/api_client.js +21 -1
- package/dist/src/client/base_client.js +2 -2
- package/dist/src/fetch.d.ts.map +1 -1
- package/dist/src/fetch.js +2 -3
- package/dist/src/key.d.ts +17 -1
- package/dist/src/key.d.ts.map +1 -1
- package/dist/src/key.js +17 -1
- package/dist/src/response.d.ts +27 -3
- package/dist/src/response.d.ts.map +1 -1
- package/dist/src/response.js +60 -19
- package/dist/src/schema.d.ts +819 -81
- package/dist/src/schema.d.ts.map +1 -1
- package/dist/src/schema.js +1 -1
- package/dist/src/schema_types.d.ts +10 -1
- package/dist/src/schema_types.d.ts.map +1 -1
- package/dist/src/schema_types.js +1 -1
- package/dist/src/scopes.d.ts.map +1 -1
- package/dist/src/scopes.js +20 -3
- package/package.json +1 -1
- package/src/audit_log.ts +3 -5
- package/src/client/api_client.ts +28 -0
- package/src/client/base_client.ts +1 -1
- package/src/fetch.ts +1 -2
- package/src/key.ts +24 -0
- package/src/response.ts +67 -17
- package/src/schema.ts +879 -90
- package/src/schema_types.ts +11 -1
- package/src/scopes.ts +19 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"response.d.ts","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAW,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"response.d.ts","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAW,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,GAAG,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAqB,MAAM,GAAG,CAAC;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjG;;;GAGG;AACH,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,gBAAgB,CAAC;AAE/C;;;GAGG;AACH,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;AAE3E;;GAEG;AACH,MAAM,MAAM,KAAK,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;AAEtC;;;;;;;GAOG;AACH,wBAAgB,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAMpF;AAaD;;GAEG;AACH,qBAAa,kBAAkB,CAAC,CAAC;;IAK/B;;OAEG;IACH,UAAU,IAAI,aAAa,GAAG,SAAS;IAIvC;;OAEG;IACH,aAAa,IAAI,WAAW,GAAG,SAAS;IAIxC;;OAEG;IACH,YAAY,IAAI,UAAU,GAAG,SAAS;IAItC;;OAEG;IACH,eAAe,IAAI,aAAa,GAAG,SAAS;IAI5C;;OAEG;IACH,SAAS,IAAI,OAAO;IAIpB;;OAEG;IACH,OAAO,KAAK,WAAW,GAEtB;IAED,sEAAsE;IACtE,KAAK,IAAI,MAAM,GAAG,SAAS;IAI3B,iEAAiE;IACjE,MAAM,IAAI,MAAM,EAAE;IAIlB,6DAA6D;IAC7D,WAAW,IAAI,OAAO;IAItB;;OAEG;IACG,SAAS,IAAI,OAAO,CAAC,gBAAgB,GAAG,SAAS,CAAC;IAkBxD,wDAAwD;IACxD,IAAI,IAAI,CAAC;IAST;;;;;;OAMG;IACG,WAAW,CAAC,MAAM,EAAE,gBAAgB,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;IAIzF;;;;;OAKG;IACG,UAAU,CAAC,MAAM,EAAE,gBAAgB,EAAE,IAAI,EAAE,MAAM;IAiCvD;;;;;OAKG;IACG,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;IAIvE;;;;OAIG;IACG,MAAM,CAAC,MAAM,EAAE,gBAAgB;IA6BrC;;;;;OAKG;IACG,mBAAmB,CAAC,UAAU,EAAE,WAAW,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;IASlF;;;;;;;;;OASG;IACH,SAAS,aAAa,GAAG,EAAE,YAAY,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;IAMnF;;;;;;;;;;OAUG;WACU,MAAM,CAAC,CAAC,EACnB,GAAG,EAAE,YAAY,EACjB,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,EACvB,UAAU,CAAC,EAAE,WAAW,GACvB,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;IAKjC;;;;;;OAMG;IACH,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,WAAW,GAAG,WAAW,GAAG,SAAS;CA2BxE"}
|
package/dist/src/response.js
CHANGED
|
@@ -10,7 +10,7 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
10
10
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
11
11
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
12
12
|
};
|
|
13
|
-
var _CubeSignerResponse_instances, _CubeSignerResponse_env, _CubeSignerResponse_requestFn, _CubeSignerResponse_resp,
|
|
13
|
+
var _CubeSignerResponse_instances, _CubeSignerResponse_env, _CubeSignerResponse_requestFn, _CubeSignerResponse_resp, _CubeSignerResponse_mfaTotpVote, _CubeSignerResponse_mfaVote;
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.CubeSignerResponse = void 0;
|
|
16
16
|
exports.mapResponse = mapResponse;
|
|
@@ -25,36 +25,82 @@ const util_1 = require("./util");
|
|
|
25
25
|
* @returns Response whose value for status code 200 is mapped from U to V
|
|
26
26
|
*/
|
|
27
27
|
function mapResponse(resp, mapFn) {
|
|
28
|
-
if (resp
|
|
28
|
+
if (asAccepted(resp) !== undefined) {
|
|
29
29
|
return resp;
|
|
30
30
|
}
|
|
31
31
|
else {
|
|
32
32
|
return mapFn(resp);
|
|
33
33
|
}
|
|
34
34
|
}
|
|
35
|
+
/**
|
|
36
|
+
* @param resp The response to check
|
|
37
|
+
* @returns The {@link AcceptedValue} if the response status code is 202.
|
|
38
|
+
*/
|
|
39
|
+
function asAccepted(resp) {
|
|
40
|
+
const acceptedResp = resp;
|
|
41
|
+
return acceptedResp.error_code === "SignDryRun" || acceptedResp.error_code === "MfaRequired"
|
|
42
|
+
? (acceptedResp.accepted ?? undefined)
|
|
43
|
+
: undefined;
|
|
44
|
+
}
|
|
35
45
|
/**
|
|
36
46
|
* A response of a CubeSigner request.
|
|
37
47
|
*/
|
|
38
48
|
class CubeSignerResponse {
|
|
49
|
+
/**
|
|
50
|
+
* @returns The {@link AcceptedValue} if the response status code is 202.
|
|
51
|
+
*/
|
|
52
|
+
asAccepted() {
|
|
53
|
+
return asAccepted(__classPrivateFieldGet(this, _CubeSignerResponse_resp, "f"));
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* @returns The associated {@link MfaRequired} value, if the response status code is 202 and the response indicates that MFA is required.
|
|
57
|
+
*/
|
|
58
|
+
asMfaRequired() {
|
|
59
|
+
return this.asAccepted()?.MfaRequired ?? undefined;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* @returns The associated {@link SignDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.
|
|
63
|
+
*/
|
|
64
|
+
asSignDryRun() {
|
|
65
|
+
return this.asAccepted()?.SignDryRun ?? undefined;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* @returns The associated {@link BinanceDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.
|
|
69
|
+
*/
|
|
70
|
+
asBinanceDryRun() {
|
|
71
|
+
return this.asAccepted()?.BinanceDryRun ?? undefined;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* @returns Whether this response is a "200 Success" (in which case it is safe to call {@link data})
|
|
75
|
+
*/
|
|
76
|
+
isSuccess() {
|
|
77
|
+
return this.asAccepted() === undefined;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* @returns The underlying {@link MfaRequired} response (if any).
|
|
81
|
+
*/
|
|
82
|
+
get mfaRequired() {
|
|
83
|
+
return this.asAccepted()?.MfaRequired;
|
|
84
|
+
}
|
|
39
85
|
/** @returns The first MFA id associated with this request (if any) */
|
|
40
86
|
mfaId() {
|
|
41
|
-
return
|
|
87
|
+
return this.mfaRequired?.id;
|
|
42
88
|
}
|
|
43
89
|
/** @returns The MFA ids associated with this request (if any) */
|
|
44
90
|
mfaIds() {
|
|
45
|
-
return
|
|
91
|
+
return this.mfaRequired?.ids ?? [];
|
|
46
92
|
}
|
|
47
93
|
/** @returns True if this request requires an MFA approval */
|
|
48
94
|
requiresMfa() {
|
|
49
|
-
return
|
|
95
|
+
return this.mfaRequired !== undefined;
|
|
50
96
|
}
|
|
51
97
|
/**
|
|
52
98
|
* @returns Session information to use for any MFA approval requests (if any was included in the response).
|
|
53
99
|
*/
|
|
54
100
|
async mfaClient() {
|
|
55
|
-
if (
|
|
101
|
+
if (this.mfaRequired === undefined)
|
|
56
102
|
return;
|
|
57
|
-
const session =
|
|
103
|
+
const session = this.asMfaRequired()?.session ?? undefined;
|
|
58
104
|
if (session === undefined)
|
|
59
105
|
return;
|
|
60
106
|
const env = __classPrivateFieldGet(this, _CubeSignerResponse_env, "f");
|
|
@@ -62,7 +108,7 @@ class CubeSignerResponse {
|
|
|
62
108
|
env: {
|
|
63
109
|
"Dev-CubeSignerStack": env,
|
|
64
110
|
},
|
|
65
|
-
org_id:
|
|
111
|
+
org_id: this.mfaRequired.org_id,
|
|
66
112
|
session_exp: session.expiration,
|
|
67
113
|
session_info: session.session_info,
|
|
68
114
|
token: session.token,
|
|
@@ -71,8 +117,8 @@ class CubeSignerResponse {
|
|
|
71
117
|
}
|
|
72
118
|
/** @returns The response data, if no MFA is required */
|
|
73
119
|
data() {
|
|
74
|
-
if (this.
|
|
75
|
-
throw new Error("Cannot call `data()`
|
|
120
|
+
if (!this.isSuccess()) {
|
|
121
|
+
throw new Error("Cannot call `data()` on a 202 Accepted response; use `asMfaRequired()` or `asSignDryRun()`");
|
|
76
122
|
}
|
|
77
123
|
return __classPrivateFieldGet(this, _CubeSignerResponse_resp, "f");
|
|
78
124
|
}
|
|
@@ -140,14 +186,9 @@ class CubeSignerResponse {
|
|
|
140
186
|
_CubeSignerResponse_env.set(this, void 0);
|
|
141
187
|
_CubeSignerResponse_requestFn.set(this, void 0);
|
|
142
188
|
_CubeSignerResponse_resp.set(this, void 0);
|
|
143
|
-
/**
|
|
144
|
-
* Optional MFA id. Only set if there is an MFA request associated with the request
|
|
145
|
-
*/
|
|
146
|
-
_CubeSignerResponse_mfaRequired.set(this, void 0);
|
|
147
189
|
__classPrivateFieldSet(this, _CubeSignerResponse_env, env, "f");
|
|
148
190
|
__classPrivateFieldSet(this, _CubeSignerResponse_requestFn, requestFn, "f");
|
|
149
191
|
__classPrivateFieldSet(this, _CubeSignerResponse_resp, resp, "f");
|
|
150
|
-
__classPrivateFieldSet(this, _CubeSignerResponse_mfaRequired, __classPrivateFieldGet(this, _CubeSignerResponse_resp, "f").accepted?.MfaRequired, "f");
|
|
151
192
|
}
|
|
152
193
|
/**
|
|
153
194
|
* Static constructor.
|
|
@@ -197,7 +238,7 @@ class CubeSignerResponse {
|
|
|
197
238
|
}
|
|
198
239
|
}
|
|
199
240
|
exports.CubeSignerResponse = CubeSignerResponse;
|
|
200
|
-
_CubeSignerResponse_env = new WeakMap(), _CubeSignerResponse_requestFn = new WeakMap(), _CubeSignerResponse_resp = new WeakMap(),
|
|
241
|
+
_CubeSignerResponse_env = new WeakMap(), _CubeSignerResponse_requestFn = new WeakMap(), _CubeSignerResponse_resp = new WeakMap(), _CubeSignerResponse_instances = new WeakSet(), _CubeSignerResponse_mfaTotpVote =
|
|
201
242
|
/**
|
|
202
243
|
* Approve or reject an MFA request using a given session and a TOTP code.
|
|
203
244
|
*
|
|
@@ -211,7 +252,7 @@ async function _CubeSignerResponse_mfaTotpVote(client, code, vote) {
|
|
|
211
252
|
if (mfaId === undefined) {
|
|
212
253
|
return this;
|
|
213
254
|
}
|
|
214
|
-
const mfaOrgId =
|
|
255
|
+
const mfaOrgId = this.mfaRequired.org_id;
|
|
215
256
|
const mfaApproval = await client.apiClient.mfaVoteTotp(mfaId, code, vote);
|
|
216
257
|
const mfaConf = mfaApproval.receipt?.confirmation;
|
|
217
258
|
if (!mfaConf) {
|
|
@@ -231,7 +272,7 @@ async function _CubeSignerResponse_mfaVote(client, mfaVote) {
|
|
|
231
272
|
if (mfaId === undefined) {
|
|
232
273
|
return this;
|
|
233
274
|
}
|
|
234
|
-
const mfaOrgId =
|
|
275
|
+
const mfaOrgId = this.mfaRequired.org_id;
|
|
235
276
|
const mfaApproval = await client.apiClient.mfaVoteCs(mfaId, mfaVote);
|
|
236
277
|
const mfaConf = mfaApproval.receipt?.confirmation;
|
|
237
278
|
if (!mfaConf) {
|
|
@@ -239,4 +280,4 @@ async function _CubeSignerResponse_mfaVote(client, mfaVote) {
|
|
|
239
280
|
}
|
|
240
281
|
return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });
|
|
241
282
|
};
|
|
242
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"response.js","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"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","sourcesContent":["import type { MfaVote, EnvInterface, MfaReceipts, MfaRequired } from \".\";\nimport { CubeSignerClient, isManyMfaReceipts } from \".\";\nimport { encodeToBase64Url } from \"./util\";\nimport type { AcceptedResponse } from \"./schema_types\";\n\n/**\n * Response type, which can be either a value of type {@link U}\n * or {@link AcceptedResponse} (status code 202) which requires MFA.\n */\nexport type Response<U> = U | AcceptedResponse;\n\n/**\n * Request function which optionally takes additional headers\n * (which, for example, can be used to attach an MFA receipt).\n */\nexport type RequestFn<U> = (headers?: HeadersInit) => Promise<Response<U>>;\n\n/**\n * Map function occasionally used to map a response from the API into a higher-level type.\n */\nexport type MapFn<U, V> = (u: U) => V;\n\n/**\n * Take a {@link Response<U>} and a {@link MapFn<U, V>} function and return\n * a {@link Response<V>} that maps the value of the original response when its status code is 200.\n *\n * @param resp Original response\n * @param mapFn Map to apply to the response value when its status code is 200.\n * @returns Response whose value for status code 200 is mapped from U to V\n */\nexport function mapResponse<U, V>(resp: Response<U>, mapFn: MapFn<U, V>): Response<V> {\n  if ((resp as AcceptedResponse).accepted?.MfaRequired) {\n    return resp as AcceptedResponse;\n  } else {\n    return mapFn(resp as U);\n  }\n}\n\n/**\n * A response of a CubeSigner request.\n */\nexport class CubeSignerResponse<U> {\n  readonly #env: EnvInterface;\n  readonly #requestFn: RequestFn<U>;\n  readonly #resp: U | AcceptedResponse;\n  /**\n   * Optional MFA id. Only set if there is an MFA request associated with the request\n   */\n  readonly #mfaRequired?: MfaRequired;\n\n  /** @returns The first MFA id associated with this request (if any) */\n  mfaId(): string | undefined {\n    return this.#mfaRequired?.id;\n  }\n\n  /** @returns The MFA ids associated with this request (if any) */\n  mfaIds(): string[] {\n    return this.#mfaRequired?.ids ?? [];\n  }\n\n  /** @returns True if this request requires an MFA approval */\n  requiresMfa(): boolean {\n    return this.#mfaRequired !== undefined;\n  }\n\n  /**\n   * @returns Session information to use for any MFA approval requests (if any was included in the response).\n   */\n  async mfaClient(): Promise<CubeSignerClient | undefined> {\n    if (this.#mfaRequired === undefined) return;\n    const session = (this.#resp as AcceptedResponse).accepted?.MfaRequired?.session ?? undefined;\n    if (session === undefined) return;\n\n    const env = this.#env;\n    return await CubeSignerClient.create({\n      env: {\n        \"Dev-CubeSignerStack\": env,\n      },\n      org_id: this.#mfaRequired.org_id,\n      session_exp: session.expiration,\n      session_info: session.session_info,\n      token: session.token,\n      refresh_token: session.refresh_token,\n    });\n  }\n\n  /** @returns The response data, if no MFA is required */\n  data(): U {\n    if (this.requiresMfa()) {\n      throw new Error(\"Cannot call `data()` while MFA is required\");\n    }\n    return this.#resp as U;\n  }\n\n  /**\n   * Approve the MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   * @returns The result of resubmitting the request with the approval\n   */\n  async totpApprove(client: CubeSignerClient, code: string): Promise<CubeSignerResponse<U>> {\n    return await this.#mfaTotpVote(client, code, \"approve\");\n  }\n\n  /**\n   * Reject the MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   */\n  async totpReject(client: CubeSignerClient, code: string) {\n    await this.#mfaTotpVote(client, code, \"reject\");\n  }\n\n  /**\n   * Approve or reject an MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   * @param vote Approve or reject\n   * @returns The result of resubmitting the request with the approval\n   */\n  async #mfaTotpVote(\n    client: CubeSignerClient,\n    code: string,\n    vote: MfaVote,\n  ): Promise<CubeSignerResponse<U>> {\n    const mfaId = this.mfaId();\n    if (mfaId === undefined) {\n      return this;\n    }\n\n    const mfaOrgId = this.#mfaRequired!.org_id;\n    const mfaApproval = await client.apiClient.mfaVoteTotp(mfaId, code, vote);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Approve the MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   * @returns The result of resubmitting the request with the approval\n   */\n  async approve(client: CubeSignerClient): Promise<CubeSignerResponse<U>> {\n    return await this.#mfaVote(client, \"approve\");\n  }\n\n  /**\n   * Reject the MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   */\n  async reject(client: CubeSignerClient) {\n    await this.#mfaVote(client, \"reject\");\n  }\n\n  /**\n   * Approve or reject an MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   * @param mfaVote Approve or reject\n   * @returns The result of resubmitting the request with the approval\n   */\n  async #mfaVote(client: CubeSignerClient, mfaVote: MfaVote): Promise<CubeSignerResponse<U>> {\n    const mfaId = this.mfaId();\n    if (mfaId === undefined) {\n      return this;\n    }\n\n    const mfaOrgId = this.#mfaRequired!.org_id;\n\n    const mfaApproval = await client.apiClient.mfaVoteCs(mfaId, mfaVote);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Resubmits the request with a given MFA receipt(s) attached.\n   *\n   * @param mfaReceipt The MFA receipt(s)\n   * @returns The result of signing after MFA approval\n   */\n  async execWithMfaApproval(mfaReceipt: MfaReceipts): Promise<CubeSignerResponse<U>> {\n    const headers = CubeSignerResponse.getMfaHeaders(mfaReceipt);\n    return new CubeSignerResponse(this.#env, this.#requestFn, await this.#requestFn(headers));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param env The environment where the response comes from\n   * @param requestFn\n   *    The function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param resp The response as returned by the OpenAPI client.\n   * @internal\n   */\n  protected constructor(env: EnvInterface, requestFn: RequestFn<U>, resp: U | AcceptedResponse) {\n    this.#env = env;\n    this.#requestFn = requestFn;\n    this.#resp = resp;\n    this.#mfaRequired = (this.#resp as AcceptedResponse).accepted?.MfaRequired;\n  }\n\n  /**\n   * Static constructor.\n   *\n   * @param env The environment where the response comes from\n   * @param requestFn\n   *    The request function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns New instance of this class.\n   * @internal\n   */\n  static async create<U>(\n    env: EnvInterface,\n    requestFn: RequestFn<U>,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<U>> {\n    const seed = await requestFn(this.getMfaHeaders(mfaReceipt));\n    return new CubeSignerResponse(env, requestFn, seed);\n  }\n\n  /**\n   * Return HTTP headers containing a given MFA receipt.\n   *\n   * @param mfaReceipt MFA receipt(s)\n   * @returns Headers including {@link mfaReceipt}\n   * @internal\n   */\n  static getMfaHeaders(mfaReceipt?: MfaReceipts): HeadersInit | undefined {\n    if (mfaReceipt === undefined) {\n      return undefined;\n    }\n\n    const rec = isManyMfaReceipts(mfaReceipt)\n      ? mfaReceipt\n      : {\n          orgId: mfaReceipt.mfaOrgId,\n          receipts: [\n            {\n              id: mfaReceipt.mfaId,\n              confirmation: mfaReceipt.mfaConf,\n            },\n          ],\n        };\n\n    if (rec.receipts.length === 0) {\n      return undefined;\n    }\n\n    const textEncoder = new TextEncoder();\n    return {\n      \"x-cubist-mfa-org-id\": rec.orgId,\n      \"x-cubist-mfa-receipts\": encodeToBase64Url(textEncoder.encode(JSON.stringify(rec.receipts))),\n    };\n  }\n}\n"]}
|
|
283
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"response.js","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"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","sourcesContent":["import type { MfaVote, EnvInterface, MfaReceipts, MfaRequired } from \".\";\nimport { CubeSignerClient, isManyMfaReceipts } from \".\";\nimport { encodeToBase64Url } from \"./util\";\nimport type { AcceptedResponse, AcceptedValue, BinanceDryRun, SignDryRun } from \"./schema_types\";\n\n/**\n * Response type, which can be either a value of type {@link U}\n * or {@link AcceptedResponse} (status code 202) which requires MFA.\n */\nexport type Response<U> = U | AcceptedResponse;\n\n/**\n * Request function which optionally takes additional headers\n * (which, for example, can be used to attach an MFA receipt).\n */\nexport type RequestFn<U> = (headers?: HeadersInit) => Promise<Response<U>>;\n\n/**\n * Map function occasionally used to map a response from the API into a higher-level type.\n */\nexport type MapFn<U, V> = (u: U) => V;\n\n/**\n * Take a {@link Response<U>} and a {@link MapFn<U, V>} function and return\n * a {@link Response<V>} that maps the value of the original response when its status code is 200.\n *\n * @param resp Original response\n * @param mapFn Map to apply to the response value when its status code is 200.\n * @returns Response whose value for status code 200 is mapped from U to V\n */\nexport function mapResponse<U, V>(resp: Response<U>, mapFn: MapFn<U, V>): Response<V> {\n  if (asAccepted(resp) !== undefined) {\n    return resp as AcceptedResponse;\n  } else {\n    return mapFn(resp as U);\n  }\n}\n\n/**\n * @param resp The response to check\n * @returns The {@link AcceptedValue} if the response status code is 202.\n */\nfunction asAccepted<U>(resp: Response<U>): AcceptedValue | undefined {\n  const acceptedResp = resp as AcceptedResponse;\n  return acceptedResp.error_code === \"SignDryRun\" || acceptedResp.error_code === \"MfaRequired\"\n    ? (acceptedResp.accepted ?? undefined)\n    : undefined;\n}\n\n/**\n * A response of a CubeSigner request.\n */\nexport class CubeSignerResponse<U> {\n  readonly #env: EnvInterface;\n  readonly #requestFn: RequestFn<U>;\n  readonly #resp: Response<U>;\n\n  /**\n   * @returns The {@link AcceptedValue} if the response status code is 202.\n   */\n  asAccepted(): AcceptedValue | undefined {\n    return asAccepted(this.#resp);\n  }\n\n  /**\n   * @returns The associated {@link MfaRequired} value, if the response status code is 202 and the response indicates that MFA is required.\n   */\n  asMfaRequired(): MfaRequired | undefined {\n    return this.asAccepted()?.MfaRequired ?? undefined;\n  }\n\n  /**\n   * @returns The associated {@link SignDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.\n   */\n  asSignDryRun(): SignDryRun | undefined {\n    return this.asAccepted()?.SignDryRun ?? undefined;\n  }\n\n  /**\n   * @returns The associated {@link BinanceDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.\n   */\n  asBinanceDryRun(): BinanceDryRun | undefined {\n    return this.asAccepted()?.BinanceDryRun ?? undefined;\n  }\n\n  /**\n   * @returns Whether this response is a \"200 Success\" (in which case it is safe to call {@link data})\n   */\n  isSuccess(): boolean {\n    return this.asAccepted() === undefined;\n  }\n\n  /**\n   * @returns The underlying {@link MfaRequired} response (if any).\n   */\n  private get mfaRequired() {\n    return this.asAccepted()?.MfaRequired;\n  }\n\n  /** @returns The first MFA id associated with this request (if any) */\n  mfaId(): string | undefined {\n    return this.mfaRequired?.id;\n  }\n\n  /** @returns The MFA ids associated with this request (if any) */\n  mfaIds(): string[] {\n    return this.mfaRequired?.ids ?? [];\n  }\n\n  /** @returns True if this request requires an MFA approval */\n  requiresMfa(): boolean {\n    return this.mfaRequired !== undefined;\n  }\n\n  /**\n   * @returns Session information to use for any MFA approval requests (if any was included in the response).\n   */\n  async mfaClient(): Promise<CubeSignerClient | undefined> {\n    if (this.mfaRequired === undefined) return;\n    const session = this.asMfaRequired()?.session ?? undefined;\n    if (session === undefined) return;\n\n    const env = this.#env;\n    return await CubeSignerClient.create({\n      env: {\n        \"Dev-CubeSignerStack\": env,\n      },\n      org_id: this.mfaRequired.org_id,\n      session_exp: session.expiration,\n      session_info: session.session_info,\n      token: session.token,\n      refresh_token: session.refresh_token,\n    });\n  }\n\n  /** @returns The response data, if no MFA is required */\n  data(): U {\n    if (!this.isSuccess()) {\n      throw new Error(\n        \"Cannot call `data()` on a 202 Accepted response; use `asMfaRequired()` or `asSignDryRun()`\",\n      );\n    }\n    return this.#resp as U;\n  }\n\n  /**\n   * Approve the MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   * @returns The result of resubmitting the request with the approval\n   */\n  async totpApprove(client: CubeSignerClient, code: string): Promise<CubeSignerResponse<U>> {\n    return await this.#mfaTotpVote(client, code, \"approve\");\n  }\n\n  /**\n   * Reject the MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   */\n  async totpReject(client: CubeSignerClient, code: string) {\n    await this.#mfaTotpVote(client, code, \"reject\");\n  }\n\n  /**\n   * Approve or reject an MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   * @param vote Approve or reject\n   * @returns The result of resubmitting the request with the approval\n   */\n  async #mfaTotpVote(\n    client: CubeSignerClient,\n    code: string,\n    vote: MfaVote,\n  ): Promise<CubeSignerResponse<U>> {\n    const mfaId = this.mfaId();\n    if (mfaId === undefined) {\n      return this;\n    }\n\n    const mfaOrgId = this.mfaRequired!.org_id;\n    const mfaApproval = await client.apiClient.mfaVoteTotp(mfaId, code, vote);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Approve the MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   * @returns The result of resubmitting the request with the approval\n   */\n  async approve(client: CubeSignerClient): Promise<CubeSignerResponse<U>> {\n    return await this.#mfaVote(client, \"approve\");\n  }\n\n  /**\n   * Reject the MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   */\n  async reject(client: CubeSignerClient) {\n    await this.#mfaVote(client, \"reject\");\n  }\n\n  /**\n   * Approve or reject an MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   * @param mfaVote Approve or reject\n   * @returns The result of resubmitting the request with the approval\n   */\n  async #mfaVote(client: CubeSignerClient, mfaVote: MfaVote): Promise<CubeSignerResponse<U>> {\n    const mfaId = this.mfaId();\n    if (mfaId === undefined) {\n      return this;\n    }\n\n    const mfaOrgId = this.mfaRequired!.org_id;\n\n    const mfaApproval = await client.apiClient.mfaVoteCs(mfaId, mfaVote);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Resubmits the request with a given MFA receipt(s) attached.\n   *\n   * @param mfaReceipt The MFA receipt(s)\n   * @returns The result of signing after MFA approval\n   */\n  async execWithMfaApproval(mfaReceipt: MfaReceipts): Promise<CubeSignerResponse<U>> {\n    const headers = CubeSignerResponse.getMfaHeaders(mfaReceipt);\n    return new CubeSignerResponse(this.#env, this.#requestFn, await this.#requestFn(headers));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param env The environment where the response comes from\n   * @param requestFn\n   *    The function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param resp The response as returned by the OpenAPI client.\n   * @internal\n   */\n  protected constructor(env: EnvInterface, requestFn: RequestFn<U>, resp: Response<U>) {\n    this.#env = env;\n    this.#requestFn = requestFn;\n    this.#resp = resp;\n  }\n\n  /**\n   * Static constructor.\n   *\n   * @param env The environment where the response comes from\n   * @param requestFn\n   *    The request function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns New instance of this class.\n   * @internal\n   */\n  static async create<U>(\n    env: EnvInterface,\n    requestFn: RequestFn<U>,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<U>> {\n    const seed = await requestFn(this.getMfaHeaders(mfaReceipt));\n    return new CubeSignerResponse(env, requestFn, seed);\n  }\n\n  /**\n   * Return HTTP headers containing a given MFA receipt.\n   *\n   * @param mfaReceipt MFA receipt(s)\n   * @returns Headers including {@link mfaReceipt}\n   * @internal\n   */\n  static getMfaHeaders(mfaReceipt?: MfaReceipts): HeadersInit | undefined {\n    if (mfaReceipt === undefined) {\n      return undefined;\n    }\n\n    const rec = isManyMfaReceipts(mfaReceipt)\n      ? mfaReceipt\n      : {\n          orgId: mfaReceipt.mfaOrgId,\n          receipts: [\n            {\n              id: mfaReceipt.mfaId,\n              confirmation: mfaReceipt.mfaConf,\n            },\n          ],\n        };\n\n    if (rec.receipts.length === 0) {\n      return undefined;\n    }\n\n    const textEncoder = new TextEncoder();\n    return {\n      \"x-cubist-mfa-org-id\": rec.orgId,\n      \"x-cubist-mfa-receipts\": encodeToBase64Url(textEncoder.encode(JSON.stringify(rec.receipts))),\n    };\n  }\n}\n"]}
|