@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.
@@ -1 +1 @@
1
- {"version":3,"file":"response.d.ts","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAW,YAAY,EAAE,WAAW,EAAe,MAAM,GAAG,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAqB,MAAM,GAAG,CAAC;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEvD;;;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;AAED;;GAEG;AACH,qBAAa,kBAAkB,CAAC,CAAC;;IAS/B,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;IAOT;;;;;;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,CAAC,GAAG,gBAAgB;IAO5F;;;;;;;;;;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"}
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"}
@@ -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, _CubeSignerResponse_mfaRequired, _CubeSignerResponse_mfaTotpVote, _CubeSignerResponse_mfaVote;
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.accepted?.MfaRequired) {
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 __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f")?.id;
87
+ return this.mfaRequired?.id;
42
88
  }
43
89
  /** @returns The MFA ids associated with this request (if any) */
44
90
  mfaIds() {
45
- return __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f")?.ids ?? [];
91
+ return this.mfaRequired?.ids ?? [];
46
92
  }
47
93
  /** @returns True if this request requires an MFA approval */
48
94
  requiresMfa() {
49
- return __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f") !== undefined;
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 (__classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f") === undefined)
101
+ if (this.mfaRequired === undefined)
56
102
  return;
57
- const session = __classPrivateFieldGet(this, _CubeSignerResponse_resp, "f").accepted?.MfaRequired?.session ?? undefined;
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: __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f").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.requiresMfa()) {
75
- throw new Error("Cannot call `data()` while MFA is required");
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(), _CubeSignerResponse_mfaRequired = new WeakMap(), _CubeSignerResponse_instances = new WeakSet(), _CubeSignerResponse_mfaTotpVote =
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 = __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f").org_id;
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 = __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f").org_id;
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"]}