@cubist-labs/cubesigner-sdk 0.1.50 → 0.2.2

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.
Files changed (47) hide show
  1. package/README.md +66 -13
  2. package/dist/src/client.d.ts +434 -7
  3. package/dist/src/client.js +1022 -18
  4. package/dist/src/ethers/index.d.ts +2 -4
  5. package/dist/src/ethers/index.js +11 -9
  6. package/dist/src/fido.d.ts +76 -0
  7. package/dist/src/fido.js +148 -0
  8. package/dist/src/index.d.ts +102 -30
  9. package/dist/src/index.js +126 -72
  10. package/dist/src/key.d.ts +15 -45
  11. package/dist/src/key.js +31 -93
  12. package/dist/src/mfa.d.ts +85 -14
  13. package/dist/src/mfa.js +158 -40
  14. package/dist/src/org.d.ts +237 -123
  15. package/dist/src/org.js +108 -213
  16. package/dist/src/paginator.d.ts +76 -0
  17. package/dist/src/paginator.js +99 -0
  18. package/dist/src/role.d.ts +76 -74
  19. package/dist/src/role.js +79 -136
  20. package/dist/src/schema.d.ts +1672 -520
  21. package/dist/src/schema.js +1 -1
  22. package/dist/src/schema_types.d.ts +103 -0
  23. package/dist/src/schema_types.js +3 -0
  24. package/dist/src/session/session_manager.js +2 -2
  25. package/dist/src/session/session_storage.js +1 -1
  26. package/dist/src/session/signer_session_manager.d.ts +16 -29
  27. package/dist/src/session/signer_session_manager.js +27 -78
  28. package/dist/src/signer_session.d.ts +232 -125
  29. package/dist/src/signer_session.js +149 -250
  30. package/dist/src/util.d.ts +20 -0
  31. package/dist/src/util.js +31 -2
  32. package/package.json +13 -11
  33. package/src/client.ts +1217 -7
  34. package/src/ethers/index.ts +11 -18
  35. package/src/index.ts +149 -101
  36. package/src/key.ts +28 -121
  37. package/src/mfa.ts +202 -0
  38. package/src/org.ts +126 -275
  39. package/src/paginator.ts +122 -0
  40. package/src/role.ts +108 -181
  41. package/src/schema.ts +1673 -520
  42. package/src/schema_types.ts +103 -0
  43. package/src/session/session_manager.ts +2 -2
  44. package/src/session/session_storage.ts +1 -1
  45. package/src/session/signer_session_manager.ts +38 -108
  46. package/src/signer_session.ts +164 -323
  47. package/src/util.ts +41 -0
@@ -13,76 +13,100 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
13
13
  var __importDefault = (this && this.__importDefault) || function (mod) {
14
14
  return (mod && mod.__esModule) ? mod : { "default": mod };
15
15
  };
16
- var _SignResponse_orgId, _SignResponse_signFn, _SignResponse_resp, _SignResponse_mfaId, _SignerSessionInfo_cs, _SignerSessionInfo_orgId, _SignerSessionInfo_roleId, _SignerSessionInfo_sessionId, _SignerSession_orgId;
16
+ var _CubeSignerResponse_requestFn, _CubeSignerResponse_resp, _CubeSignerResponse_mfaRequired, _SignerSessionInfo_csc, _SignerSessionInfo_sessionId, _SignerSession_csc;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
- exports.SignerSession = exports.SignerSessionInfo = exports.SignResponse = void 0;
18
+ exports.SignerSession = exports.SignerSessionInfo = exports.CubeSignerResponse = exports.mapResponse = void 0;
19
19
  const assert_1 = __importDefault(require("assert"));
20
20
  const _1 = require(".");
21
- const util_1 = require("./util");
21
+ const client_1 = require("./client");
22
22
  const signer_session_manager_1 = require("./session/signer_session_manager");
23
+ /**
24
+ * Takes a {@link Response<U>} and a {@link MapFn<U, V>} function and returns
25
+ * a {@link Response<V>} that maps the value of the original response when its status code is 200.
26
+ *
27
+ * @param {Response<U>} resp Original response
28
+ * @param {Map<U, V>} mapFn Map to apply to the response value when its status code is 200.
29
+ * @return {Response<V>} Response whose value for status code 200 is mapped from U to V
30
+ */
31
+ function mapResponse(resp, mapFn) {
32
+ if (resp.accepted?.MfaRequired) {
33
+ return resp;
34
+ }
35
+ else {
36
+ return mapFn(resp);
37
+ }
38
+ }
39
+ exports.mapResponse = mapResponse;
23
40
  /**
24
41
  * A response of a CubeSigner request.
25
42
  */
26
- class SignResponse {
43
+ class CubeSignerResponse {
27
44
  /** @return {string} The MFA id associated with this request */
28
45
  mfaId() {
29
- return __classPrivateFieldGet(this, _SignResponse_mfaId, "f");
46
+ return __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f").id;
30
47
  }
31
48
  /** @return {boolean} True if this request requires an MFA approval */
32
49
  requiresMfa() {
33
- return __classPrivateFieldGet(this, _SignResponse_mfaId, "f") !== undefined;
50
+ return __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f") !== undefined;
34
51
  }
35
52
  /**
36
53
  * Returns session information to use for any MFA approval requests (if any was included in the response).
37
54
  * @return {ClientSessionInfo | undefined}
38
55
  */
39
56
  mfaSessionInfo() {
40
- return __classPrivateFieldGet(this, _SignResponse_resp, "f").accepted?.MfaRequired?.session ?? undefined;
57
+ return __classPrivateFieldGet(this, _CubeSignerResponse_resp, "f").accepted?.MfaRequired?.session ?? undefined;
41
58
  }
42
- /** @return {U} The signed data */
59
+ /** @return {U} The response data, if no MFA is required */
43
60
  data() {
44
- return __classPrivateFieldGet(this, _SignResponse_resp, "f");
61
+ if (this.requiresMfa()) {
62
+ throw new Error("Cannot call `data()` while MFA is required");
63
+ }
64
+ return __classPrivateFieldGet(this, _CubeSignerResponse_resp, "f");
45
65
  }
46
66
  /**
47
67
  * Approves the MFA request using a given session and a TOTP code.
48
68
  *
49
69
  * @param {SignerSession} session Signer session to use
50
70
  * @param {string} code 6-digit TOTP code
51
- * @return {SignResponse<U>} The result of signing with the approval
71
+ * @return {CubeSignerResponse<U>} The result of signing with the approval
52
72
  */
53
73
  async approveTotp(session, code) {
74
+ (0, assert_1.default)(this.requiresMfa());
54
75
  const mfaId = this.mfaId();
76
+ const mfaOrgId = __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f").org_id;
55
77
  const mfaApproval = await session.totpApprove(mfaId, code);
56
78
  (0, assert_1.default)(mfaApproval.id === mfaId);
57
79
  const mfaConf = mfaApproval.receipt?.confirmation;
58
80
  if (!mfaConf) {
59
81
  return this;
60
82
  }
61
- return await this.signWithMfaApproval(mfaApproval);
83
+ return await this.signWithMfaApproval({ mfaId, mfaOrgId, mfaConf });
62
84
  }
63
85
  /**
64
- * Approves the MFA request using a given `CubeSigner` instance (i.e., its management session).
86
+ * Approves the MFA request using a given `CubeSignerClient` instance (i.e., its session).
65
87
  *
66
88
  * @param {CubeSigner} cs CubeSigner whose session to use
67
- * @return {SignResponse<U>} The result of signing with the approval
89
+ * @return {CubeSignerResponse<U>} The result of signing with the approval
68
90
  */
69
91
  async approve(cs) {
70
- const mfaId = this.mfaId();
71
- const mfaApproval = await _1.Org.mfaApprove(cs, __classPrivateFieldGet(this, _SignResponse_orgId, "f"), mfaId);
92
+ (0, assert_1.default)(this.requiresMfa());
93
+ const mfaId = __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f").id;
94
+ const mfaOrgId = __classPrivateFieldGet(this, _CubeSignerResponse_mfaRequired, "f").org_id;
95
+ const mfaApproval = await cs.mfaApprove(mfaOrgId, mfaId);
72
96
  (0, assert_1.default)(mfaApproval.id === mfaId);
73
97
  const mfaConf = mfaApproval.receipt?.confirmation;
74
98
  if (!mfaConf) {
75
99
  return this;
76
100
  }
77
- return await this.signWithMfaApproval(mfaApproval);
101
+ return await this.signWithMfaApproval({ mfaId, mfaOrgId, mfaConf });
78
102
  }
79
103
  /**
80
- * @param {MfaRequestInfo} mfaInfo The MFA request info with the approval
81
- * @return {Promise<SignResponse<U>>} The result of signing after MFA approval
104
+ * @param {MfaReceipt} mfaReceipt The MFA receipt
105
+ * @return {Promise<CubeSignerResponse<U>>} The result of signing after MFA approval
82
106
  */
83
- async signWithMfaApproval(mfaInfo) {
84
- const headers = SignResponse.getMfaHeaders(this.mfaId(), mfaInfo.receipt.confirmation);
85
- return new SignResponse(__classPrivateFieldGet(this, _SignResponse_orgId, "f"), __classPrivateFieldGet(this, _SignResponse_signFn, "f"), await __classPrivateFieldGet(this, _SignResponse_signFn, "f").call(this, headers));
107
+ async signWithMfaApproval(mfaReceipt) {
108
+ const headers = CubeSignerResponse.getMfaHeaders(mfaReceipt);
109
+ return new CubeSignerResponse(__classPrivateFieldGet(this, _CubeSignerResponse_requestFn, "f"), await __classPrivateFieldGet(this, _CubeSignerResponse_requestFn, "f").call(this, headers));
86
110
  }
87
111
  // --------------------------------------------------------------------------
88
112
  // -- INTERNAL --------------------------------------------------------------
@@ -90,253 +114,150 @@ class SignResponse {
90
114
  /**
91
115
  * Constructor.
92
116
  *
93
- * @param {string} orgId The org id of the corresponding signing request
94
- * @param {SignFn} signFn The signing function that this response is from.
95
- * This argument is used to resend requests with
96
- * different headers if needed.
97
- * @param {U | AcceptedResponse} resp The response as returned by the OpenAPI
98
- * client.
117
+ * @param {RequestFn} requestFn
118
+ * The signing function that this response is from.
119
+ * This argument is used to resend requests with different headers if needed.
120
+ * @param {U | AcceptedResponse} resp The response as returned by the OpenAPI client.
99
121
  */
100
- constructor(orgId, signFn, resp) {
101
- _SignResponse_orgId.set(this, void 0);
102
- _SignResponse_signFn.set(this, void 0);
103
- _SignResponse_resp.set(this, void 0);
122
+ constructor(requestFn, resp) {
123
+ _CubeSignerResponse_requestFn.set(this, void 0);
124
+ _CubeSignerResponse_resp.set(this, void 0);
104
125
  /**
105
126
  * Optional MFA id. Only set if there is an MFA request associated with the
106
127
  * signing request
107
128
  */
108
- _SignResponse_mfaId.set(this, void 0);
109
- __classPrivateFieldSet(this, _SignResponse_orgId, orgId, "f");
110
- __classPrivateFieldSet(this, _SignResponse_signFn, signFn, "f");
111
- __classPrivateFieldSet(this, _SignResponse_resp, resp, "f");
112
- const mfaRequired = __classPrivateFieldGet(this, _SignResponse_resp, "f").accepted?.MfaRequired;
113
- if (mfaRequired) {
114
- __classPrivateFieldSet(this, _SignResponse_mfaId, mfaRequired.id, "f");
115
- }
129
+ _CubeSignerResponse_mfaRequired.set(this, void 0);
130
+ __classPrivateFieldSet(this, _CubeSignerResponse_requestFn, requestFn, "f");
131
+ __classPrivateFieldSet(this, _CubeSignerResponse_resp, resp, "f");
132
+ __classPrivateFieldSet(this, _CubeSignerResponse_mfaRequired, __classPrivateFieldGet(this, _CubeSignerResponse_resp, "f").accepted?.MfaRequired, "f");
133
+ }
134
+ /**
135
+ * Static constructor.
136
+ * @param {RequestFn} requestFn
137
+ * The request function that this response is from.
138
+ * This argument is used to resend requests with different headers if needed.
139
+ * @param {MfaReceipt} mfaReceipt Optional MFA receipt
140
+ * @return {Promise<CubeSignerResponse<U>>} New instance of this class.
141
+ */
142
+ static async create(requestFn, mfaReceipt) {
143
+ const seed = await requestFn(this.getMfaHeaders(mfaReceipt));
144
+ return new CubeSignerResponse(requestFn, seed);
116
145
  }
117
146
  /**
118
- * MFA receipt to attach.
147
+ * Returns HTTP headers containing a given MFA receipt.
119
148
  *
120
- * @param {string} mfaId MFA request id
121
- * @param {string} mfaConf MFA receipt confirmation code
122
- * @return {HeadersInit} Headers
149
+ * @param {MfaReceipt} mfaReceipt MFA receipt
150
+ * @return {HeadersInit} Headers including that receipt
123
151
  */
124
- static getMfaHeaders(mfaId, mfaConf) {
125
- return {
126
- "x-cubist-mfa-id": mfaId,
127
- "x-cubist-mfa-confirmation": mfaConf,
128
- };
152
+ static getMfaHeaders(mfaReceipt) {
153
+ return mfaReceipt
154
+ ? {
155
+ "x-cubist-mfa-id": mfaReceipt.mfaId,
156
+ "x-cubist-mfa-org-id": mfaReceipt.mfaOrgId,
157
+ "x-cubist-mfa-confirmation": mfaReceipt.mfaConf,
158
+ }
159
+ : undefined;
129
160
  }
130
161
  }
131
- exports.SignResponse = SignResponse;
132
- _SignResponse_orgId = new WeakMap(), _SignResponse_signFn = new WeakMap(), _SignResponse_resp = new WeakMap(), _SignResponse_mfaId = new WeakMap();
162
+ exports.CubeSignerResponse = CubeSignerResponse;
163
+ _CubeSignerResponse_requestFn = new WeakMap(), _CubeSignerResponse_resp = new WeakMap(), _CubeSignerResponse_mfaRequired = new WeakMap();
133
164
  /** Signer session info. Can only be used to revoke a token, but not for authentication. */
134
165
  class SignerSessionInfo {
135
- /** Revoke this token */
166
+ /** Revoke this session */
136
167
  async revoke() {
137
- await SignerSession.revoke(__classPrivateFieldGet(this, _SignerSessionInfo_cs, "f"), __classPrivateFieldGet(this, _SignerSessionInfo_orgId, "f"), __classPrivateFieldGet(this, _SignerSessionInfo_roleId, "f"), __classPrivateFieldGet(this, _SignerSessionInfo_sessionId, "f"));
168
+ await __classPrivateFieldGet(this, _SignerSessionInfo_csc, "f").sessionRevoke(__classPrivateFieldGet(this, _SignerSessionInfo_sessionId, "f"));
138
169
  }
139
170
  // --------------------------------------------------------------------------
140
171
  // -- INTERNAL --------------------------------------------------------------
141
172
  // --------------------------------------------------------------------------
142
173
  /**
143
174
  * Internal constructor.
144
- * @param {CubeSigner} cs CubeSigner instance to use when calling `revoke`
145
- * @param {string} orgId Organization ID
146
- * @param {string} roleId Role ID
147
- * @param {string} hash The hash of the token; can be used for revocation but not for auth
175
+ * @param {CubeSignerClient} cs CubeSigner instance to use when calling `revoke`
176
+ * @param {string} sessionId The ID of the session; can be used for revocation but not for auth
148
177
  * @param {string} purpose Session purpose
149
178
  * @internal
150
179
  */
151
- constructor(cs, orgId, roleId, hash, purpose) {
152
- _SignerSessionInfo_cs.set(this, void 0);
153
- _SignerSessionInfo_orgId.set(this, void 0);
154
- _SignerSessionInfo_roleId.set(this, void 0);
180
+ constructor(cs, sessionId, purpose) {
181
+ _SignerSessionInfo_csc.set(this, void 0);
155
182
  _SignerSessionInfo_sessionId.set(this, void 0);
156
- __classPrivateFieldSet(this, _SignerSessionInfo_cs, cs, "f");
157
- __classPrivateFieldSet(this, _SignerSessionInfo_orgId, orgId, "f");
158
- __classPrivateFieldSet(this, _SignerSessionInfo_roleId, roleId, "f");
159
- __classPrivateFieldSet(this, _SignerSessionInfo_sessionId, hash, "f");
183
+ __classPrivateFieldSet(this, _SignerSessionInfo_csc, cs, "f");
184
+ __classPrivateFieldSet(this, _SignerSessionInfo_sessionId, sessionId, "f");
160
185
  this.purpose = purpose;
161
186
  }
162
187
  }
163
188
  exports.SignerSessionInfo = SignerSessionInfo;
164
- _SignerSessionInfo_cs = new WeakMap(), _SignerSessionInfo_orgId = new WeakMap(), _SignerSessionInfo_roleId = new WeakMap(), _SignerSessionInfo_sessionId = new WeakMap();
165
- /** Signer session. */
189
+ _SignerSessionInfo_csc = new WeakMap(), _SignerSessionInfo_sessionId = new WeakMap();
190
+ /**
191
+ * Signer session.
192
+ *
193
+ * @deprecated Use {@link CubeSignerClient} instead.
194
+ */
166
195
  class SignerSession {
196
+ /** Deprecated */
197
+ get sessionMgr() {
198
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").sessionMgr;
199
+ }
200
+ /** Org id */
201
+ get orgId() {
202
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").orgId;
203
+ }
167
204
  /**
168
205
  * Returns the list of keys that this token grants access to.
169
- * @return {Key[]} The list of keys.
206
+ * @return {KeyInfo[]} The list of keys.
170
207
  */
171
208
  async keys() {
172
- const resp = await (await this.sessionMgr.client()).get("/v0/org/{org_id}/token/keys", {
173
- params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f") } },
174
- parseAs: "json",
175
- });
176
- const data = (0, util_1.assertOk)(resp);
177
- return data.keys.map((k) => (0, _1.toKeyInfo)(k));
209
+ const keys = await __classPrivateFieldGet(this, _SignerSession_csc, "f").sessionKeysList();
210
+ return keys.map((k) => (0, _1.toKeyInfo)(k));
178
211
  }
179
- /**
180
- * Approve a pending MFA request using TOTP.
181
- *
182
- * @param {string} mfaId The MFA request to approve
183
- * @param {string} code The TOTP code
184
- * @return {Promise<MfaRequestInfo>} The current status of the MFA request
185
- */
186
- async totpApprove(mfaId, code) {
187
- const resp = await (await this.sessionMgr.client()).patch("/v0/org/{org_id}/mfa/{mfa_id}/totp", {
188
- params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), mfa_id: mfaId } },
189
- body: { code },
190
- parseAs: "json",
191
- });
192
- return (0, util_1.assertOk)(resp);
212
+ /** Approve a pending MFA request using TOTP. */
213
+ get totpApprove() {
214
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").mfaApproveTotp.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
193
215
  }
194
- /**
195
- * Get a pending MFA request by its id.
196
- * @param {CubeSigner} cs Management session to use (this argument will be removed in future versions)
197
- * @param {string} mfaId The id of the MFA request.
198
- * @return {Promise<MfaRequestInfo>} The MFA request.
199
- */
200
- async getMfaInfo(cs, mfaId) {
201
- const resp = await (await cs.management()).get("/v0/org/{org_id}/mfa/{mfa_id}", {
202
- params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), mfa_id: mfaId } },
203
- });
204
- return (0, util_1.assertOk)(resp);
216
+ /** Initiate approval of an existing MFA request using FIDO. */
217
+ get fidoApproveStart() {
218
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").mfaApproveFidoInit.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
205
219
  }
206
- /**
207
- * Submit an EVM sign request.
208
- * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
209
- * @param {EvmSignRequest} req What to sign.
210
- * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature
211
- */
212
- async signEvm(key, req) {
213
- const pubkey = typeof key === "string" ? key : key.materialId;
214
- const sign = async (headers) => {
215
- const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth1/sign/{pubkey}", {
216
- params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
217
- body: req,
218
- headers,
219
- parseAs: "json",
220
- });
221
- return (0, util_1.assertOk)(resp);
222
- };
223
- return new SignResponse(__classPrivateFieldGet(this, _SignerSession_orgId, "f"), sign, await sign());
220
+ /** Get a pending MFA request by its id. */
221
+ get getMfaInfo() {
222
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").mfaGet.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
224
223
  }
225
- /**
226
- * Submit an 'eth2' sign request.
227
- * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
228
- * @param {Eth2SignRequest} req What to sign.
229
- * @return {Promise<Eth2SignResponse | AcceptedResponse>} Signature
230
- */
231
- async signEth2(key, req) {
232
- const pubkey = typeof key === "string" ? key : key.materialId;
233
- const sign = async (headers) => {
234
- const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/sign/{pubkey}", {
235
- params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
236
- body: req,
237
- headers,
238
- parseAs: "json",
239
- });
240
- return (0, util_1.assertOk)(resp);
241
- };
242
- return new SignResponse(__classPrivateFieldGet(this, _SignerSession_orgId, "f"), sign, await sign());
224
+ /** Submit an EVM sign request. */
225
+ get signEvm() {
226
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").signEvm.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
243
227
  }
244
- /**
245
- * Sign a stake request.
246
- * @param {Eth2StakeRequest} req The request to sign.
247
- * @return {Promise<Eth2StakeResponse | AcceptedResponse>} The response.
248
- */
249
- async stake(req) {
250
- const sign = async (headers) => {
251
- const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/stake", {
252
- params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f") } },
253
- body: req,
254
- headers,
255
- parseAs: "json",
256
- });
257
- return (0, util_1.assertOk)(resp);
258
- };
259
- return new SignResponse(__classPrivateFieldGet(this, _SignerSession_orgId, "f"), sign, await sign());
228
+ /** Submit an 'eth2' sign request. */
229
+ get signEth2() {
230
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").signEth2.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
260
231
  }
261
- /**
262
- * Sign an unstake request.
263
- * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
264
- * @param {Eth2UnstakeRequest} req The request to sign.
265
- * @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} The response.
266
- */
267
- async unstake(key, req) {
268
- const pubkey = typeof key === "string" ? key : key.materialId;
269
- const sign = async (headers) => {
270
- const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/unstake/{pubkey}", {
271
- params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
272
- body: req,
273
- headers,
274
- parseAs: "json",
275
- });
276
- return (0, util_1.assertOk)(resp);
277
- };
278
- return new SignResponse(__classPrivateFieldGet(this, _SignerSession_orgId, "f"), sign, await sign());
232
+ /** Sign a stake request. */
233
+ get stake() {
234
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").signStake.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
279
235
  }
280
- /**
281
- * Sign a raw blob.
282
- * @param {Key | string} key The key to sign with (either {@link Key} or its ID).
283
- * @param {BlobSignRequest} req What to sign
284
- * @return {Promise<BlobSignResponse | AcceptedResponse>} The response.
285
- */
286
- async signBlob(key, req) {
287
- const key_id = typeof key === "string" ? key : key.id;
288
- const sign = async (headers) => {
289
- const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/blob/sign/{key_id}", {
290
- params: {
291
- path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), key_id },
292
- },
293
- body: req,
294
- headers,
295
- parseAs: "json",
296
- });
297
- return (0, util_1.assertOk)(resp);
298
- };
299
- return new SignResponse(__classPrivateFieldGet(this, _SignerSession_orgId, "f"), sign, await sign());
236
+ /** Sign an unstake request. */
237
+ get unstake() {
238
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").signUnstake.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
300
239
  }
301
- /**
302
- * Sign a bitcoin message.
303
- * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
304
- * @param {BtcSignRequest} req What to sign
305
- * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.
306
- */
307
- async signBtc(key, req) {
308
- const pubkey = typeof key === "string" ? key : key.materialId;
309
- const sign = async (headers) => {
310
- const resp = await (await this.sessionMgr.client()).post("/v0/org/{org_id}/btc/sign/{pubkey}", {
311
- params: {
312
- path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey },
313
- },
314
- body: req,
315
- headers: headers,
316
- parseAs: "json",
317
- });
318
- return (0, util_1.assertOk)(resp);
319
- };
320
- return new SignResponse(__classPrivateFieldGet(this, _SignerSession_orgId, "f"), sign, await sign());
240
+ /** Sign a raw blob.*/
241
+ get signBlob() {
242
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").signBlob.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
243
+ }
244
+ /** Sign a bitcoin message. */
245
+ get signBtc() {
246
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").signBtc.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
247
+ }
248
+ /** Sign a solana message. */
249
+ get signSolana() {
250
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").signSolana.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
251
+ }
252
+ /** Sign an Avalanche P- or X-chain message. */
253
+ get signAva() {
254
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").signAva.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
321
255
  }
322
256
  /**
323
- * Sign a solana message.
324
- * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
325
- * @param {SolanaSignRequest} req What to sign
326
- * @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.
257
+ * Obtain a proof of authentication.
327
258
  */
328
- async signSolana(key, req) {
329
- const pubkey = typeof key === "string" ? key : key.materialId;
330
- const sign = async (headers) => {
331
- const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/solana/sign/{pubkey}", {
332
- params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
333
- body: req,
334
- headers,
335
- parseAs: "json",
336
- });
337
- return (0, util_1.assertOk)(resp);
338
- };
339
- return new SignResponse(__classPrivateFieldGet(this, _SignerSession_orgId, "f"), sign, await sign());
259
+ get proveIdentity() {
260
+ return __classPrivateFieldGet(this, _SignerSession_csc, "f").identityProve.bind(__classPrivateFieldGet(this, _SignerSession_csc, "f"));
340
261
  }
341
262
  /**
342
263
  * Loads an existing signer session from storage.
@@ -353,32 +274,10 @@ class SignerSession {
353
274
  * @internal
354
275
  */
355
276
  constructor(sessionMgr) {
356
- _SignerSession_orgId.set(this, void 0);
357
- this.sessionMgr = sessionMgr;
358
- __classPrivateFieldSet(this, _SignerSession_orgId, sessionMgr.orgId, "f");
359
- }
360
- // --------------------------------------------------------------------------
361
- // -- INTERNAL --------------------------------------------------------------
362
- // --------------------------------------------------------------------------
363
- /* eslint-disable require-jsdoc */
364
- /**
365
- * Static method for revoking a token (used both from {SignerSession} and {SignerSessionInfo}).
366
- * @param {CubeSigner} cs CubeSigner instance
367
- * @param {string} orgId Organization ID
368
- * @param {string} roleId Role ID
369
- * @param {string} sessionId Signer session ID
370
- * @internal
371
- */
372
- static async revoke(cs, orgId, roleId, sessionId) {
373
- const resp = await (await cs.management()).del("/v0/org/{org_id}/roles/{role_id}/tokens/{session_id}", {
374
- params: {
375
- path: { org_id: orgId, role_id: roleId, session_id: sessionId },
376
- },
377
- parseAs: "json",
378
- });
379
- (0, util_1.assertOk)(resp);
277
+ _SignerSession_csc.set(this, void 0);
278
+ __classPrivateFieldSet(this, _SignerSession_csc, new client_1.CubeSignerClient(sessionMgr), "f");
380
279
  }
381
280
  }
382
281
  exports.SignerSession = SignerSession;
383
- _SignerSession_orgId = new WeakMap();
384
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signer_session.js","sourceRoot":"","sources":["../../src/signer_session.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from \"assert\";\nimport { CubeSigner, Key, toKeyInfo, Org, KeyInfo } from \".\";\nimport { components, paths } from \"./client\";\nimport { assertOk } from \"./util\";\nimport {\n  NewSessionResponse,\n  SignerSessionManager,\n  SignerSessionStorage,\n} from \"./session/signer_session_manager\";\n\n/* eslint-disable */\nexport type EvmSignRequest =\n  paths[\"/v1/org/{org_id}/eth1/sign/{pubkey}\"][\"post\"][\"requestBody\"][\"content\"][\"application/json\"];\nexport type Eth2SignRequest =\n  paths[\"/v1/org/{org_id}/eth2/sign/{pubkey}\"][\"post\"][\"requestBody\"][\"content\"][\"application/json\"];\nexport type Eth2StakeRequest =\n  paths[\"/v1/org/{org_id}/eth2/stake\"][\"post\"][\"requestBody\"][\"content\"][\"application/json\"];\nexport type Eth2UnstakeRequest =\n  paths[\"/v1/org/{org_id}/eth2/unstake/{pubkey}\"][\"post\"][\"requestBody\"][\"content\"][\"application/json\"];\nexport type BlobSignRequest =\n  paths[\"/v1/org/{org_id}/blob/sign/{key_id}\"][\"post\"][\"requestBody\"][\"content\"][\"application/json\"];\nexport type BtcSignRequest =\n  paths[\"/v0/org/{org_id}/btc/sign/{pubkey}\"][\"post\"][\"requestBody\"][\"content\"][\"application/json\"];\nexport type SolanaSignRequest =\n  paths[\"/v1/org/{org_id}/solana/sign/{pubkey}\"][\"post\"][\"requestBody\"][\"content\"][\"application/json\"];\n\nexport type EvmSignResponse =\n  components[\"responses\"][\"Eth1SignResponse\"][\"content\"][\"application/json\"];\nexport type Eth2SignResponse =\n  components[\"responses\"][\"Eth2SignResponse\"][\"content\"][\"application/json\"];\nexport type Eth2StakeResponse =\n  components[\"responses\"][\"StakeResponse\"][\"content\"][\"application/json\"];\nexport type Eth2UnstakeResponse =\n  components[\"responses\"][\"UnstakeResponse\"][\"content\"][\"application/json\"];\nexport type BlobSignResponse =\n  components[\"responses\"][\"BlobSignResponse\"][\"content\"][\"application/json\"];\nexport type BtcSignResponse =\n  components[\"responses\"][\"BtcSignResponse\"][\"content\"][\"application/json\"];\nexport type SolanaSignResponse =\n  components[\"responses\"][\"SolanaSignResponse\"][\"content\"][\"application/json\"];\nexport type MfaRequestInfo =\n  components[\"responses\"][\"MfaRequestInfo\"][\"content\"][\"application/json\"];\n\nexport type AcceptedResponse = components[\"schemas\"][\"AcceptedResponse\"];\nexport type ErrorResponse = components[\"schemas\"][\"ErrorResponse\"];\nexport type BtcSignatureKind = components[\"schemas\"][\"BtcSignatureKind\"];\n/* eslint-enable */\n\n/** MFA request kind */\nexport type MfaType = components[\"schemas\"][\"MfaType\"];\n\ntype SignFn<U> = (headers?: HeadersInit) => Promise<U | AcceptedResponse>;\n\n/**\n * A response of a CubeSigner request.\n */\nexport class SignResponse<U> {\n  readonly #orgId: string;\n  readonly #signFn: SignFn<U>;\n  readonly #resp: U | AcceptedResponse;\n  /**\n   * Optional MFA id. Only set if there is an MFA request associated with the\n   * signing request\n   */\n  #mfaId?: string;\n\n  /** @return {string} The MFA id associated with this request */\n  mfaId(): string {\n    return this.#mfaId!;\n  }\n\n  /** @return {boolean} True if this request requires an MFA approval */\n  requiresMfa(): boolean {\n    return this.#mfaId !== undefined;\n  }\n\n  /**\n   * Returns session information to use for any MFA approval requests (if any was included in the response).\n   * @return {ClientSessionInfo | undefined}\n   */\n  mfaSessionInfo(): NewSessionResponse | undefined {\n    return (this.#resp as AcceptedResponse).accepted?.MfaRequired?.session ?? undefined;\n  }\n\n  /** @return {U} The signed data */\n  data(): U {\n    return this.#resp as U;\n  }\n\n  /**\n   * Approves the MFA request using a given session and a TOTP code.\n   *\n   * @param {SignerSession} session Signer session to use\n   * @param {string} code 6-digit TOTP code\n   * @return {SignResponse<U>} The result of signing with the approval\n   */\n  async approveTotp(session: SignerSession, code: string): Promise<SignResponse<U>> {\n    const mfaId = this.mfaId();\n    const mfaApproval = await session.totpApprove(mfaId, code);\n    assert(mfaApproval.id === mfaId);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.signWithMfaApproval(mfaApproval);\n  }\n\n  /**\n   * Approves the MFA request using a given `CubeSigner` instance (i.e., its management session).\n   *\n   * @param {CubeSigner} cs CubeSigner whose session to use\n   * @return {SignResponse<U>} The result of signing with the approval\n   */\n  async approve(cs: CubeSigner): Promise<SignResponse<U>> {\n    const mfaId = this.mfaId();\n    const mfaApproval = await Org.mfaApprove(cs, this.#orgId, mfaId);\n    assert(mfaApproval.id === mfaId);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.signWithMfaApproval(mfaApproval);\n  }\n\n  /**\n   * @param {MfaRequestInfo} mfaInfo The MFA request info with the approval\n   * @return {Promise<SignResponse<U>>} The result of signing after MFA approval\n   */\n  async signWithMfaApproval(mfaInfo: MfaRequestInfo): Promise<SignResponse<U>> {\n    const headers = SignResponse.getMfaHeaders(this.mfaId(), mfaInfo.receipt!.confirmation);\n    return new SignResponse(this.#orgId, this.#signFn, await this.#signFn(headers));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param {string} orgId The org id of the corresponding signing request\n   * @param {SignFn} signFn The signing function that this response is from.\n   *                        This argument is used to resend requests with\n   *                        different headers if needed.\n   * @param {U | AcceptedResponse} resp The response as returned by the OpenAPI\n   *                                    client.\n   */\n  constructor(orgId: string, signFn: SignFn<U>, resp: U | AcceptedResponse) {\n    this.#orgId = orgId;\n    this.#signFn = signFn;\n    this.#resp = resp;\n\n    const mfaRequired = (this.#resp as AcceptedResponse).accepted?.MfaRequired;\n    if (mfaRequired) {\n      this.#mfaId = mfaRequired.id;\n    }\n  }\n\n  /**\n   * MFA receipt to attach.\n   *\n   * @param {string} mfaId MFA request id\n   * @param {string} mfaConf MFA receipt confirmation code\n   * @return {HeadersInit} Headers\n   */\n  static getMfaHeaders(mfaId: string, mfaConf: string): HeadersInit {\n    return {\n      \"x-cubist-mfa-id\": mfaId,\n      \"x-cubist-mfa-confirmation\": mfaConf,\n    };\n  }\n}\n\n/** Signer session info. Can only be used to revoke a token, but not for authentication. */\nexport class SignerSessionInfo {\n  readonly #cs: CubeSigner;\n  readonly #orgId: string;\n  readonly #roleId: string;\n  readonly #sessionId: string;\n  public readonly purpose: string;\n\n  /** Revoke this token */\n  async revoke() {\n    await SignerSession.revoke(this.#cs, this.#orgId, this.#roleId, this.#sessionId);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Internal constructor.\n   * @param {CubeSigner} cs CubeSigner instance to use when calling `revoke`\n   * @param {string} orgId Organization ID\n   * @param {string} roleId Role ID\n   * @param {string} hash The hash of the token; can be used for revocation but not for auth\n   * @param {string} purpose Session purpose\n   * @internal\n   */\n  constructor(cs: CubeSigner, orgId: string, roleId: string, hash: string, purpose: string) {\n    this.#cs = cs;\n    this.#orgId = orgId;\n    this.#roleId = roleId;\n    this.#sessionId = hash;\n    this.purpose = purpose;\n  }\n}\n\n/** Signer session. */\nexport class SignerSession {\n  sessionMgr: SignerSessionManager;\n  readonly #orgId: string;\n\n  /**\n   * Returns the list of keys that this token grants access to.\n   * @return {Key[]} The list of keys.\n   */\n  async keys(): Promise<KeyInfo[]> {\n    const resp = await (\n      await this.sessionMgr.client()\n    ).get(\"/v0/org/{org_id}/token/keys\", {\n      params: { path: { org_id: this.#orgId } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.keys.map((k) => toKeyInfo(k));\n  }\n\n  /**\n   * Approve a pending MFA request using TOTP.\n   *\n   * @param {string} mfaId The MFA request to approve\n   * @param {string} code The TOTP code\n   * @return {Promise<MfaRequestInfo>} The current status of the MFA request\n   */\n  async totpApprove(mfaId: string, code: string): Promise<MfaRequestInfo> {\n    const resp = await (\n      await this.sessionMgr.client()\n    ).patch(\"/v0/org/{org_id}/mfa/{mfa_id}/totp\", {\n      params: { path: { org_id: this.#orgId, mfa_id: mfaId } },\n      body: { code },\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /**\n   * Get a pending MFA request by its id.\n   * @param {CubeSigner} cs Management session to use (this argument will be removed in future versions)\n   * @param {string} mfaId The id of the MFA request.\n   * @return {Promise<MfaRequestInfo>} The MFA request.\n   */\n  async getMfaInfo(cs: CubeSigner, mfaId: string): Promise<MfaRequestInfo> {\n    const resp = await (\n      await cs.management()\n    ).get(\"/v0/org/{org_id}/mfa/{mfa_id}\", {\n      params: { path: { org_id: this.#orgId, mfa_id: mfaId } },\n    });\n    return assertOk(resp);\n  }\n\n  /**\n   * Submit an EVM sign request.\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {EvmSignRequest} req What to sign.\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature\n   */\n  async signEvm(key: Key | string, req: EvmSignRequest): Promise<SignResponse<EvmSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const resp = await (\n        await this.sessionMgr.client()\n      ).post(\"/v1/org/{org_id}/eth1/sign/{pubkey}\", {\n        params: { path: { org_id: this.#orgId, pubkey } },\n        body: req,\n        headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new SignResponse(this.#orgId, sign, await sign());\n  }\n\n  /**\n   * Submit an 'eth2' sign request.\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {Eth2SignRequest} req What to sign.\n   * @return {Promise<Eth2SignResponse | AcceptedResponse>} Signature\n   */\n  async signEth2(key: Key | string, req: Eth2SignRequest): Promise<SignResponse<Eth2SignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const resp = await (\n        await this.sessionMgr.client()\n      ).post(\"/v1/org/{org_id}/eth2/sign/{pubkey}\", {\n        params: { path: { org_id: this.#orgId, pubkey } },\n        body: req,\n        headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new SignResponse(this.#orgId, sign, await sign());\n  }\n\n  /**\n   * Sign a stake request.\n   * @param {Eth2StakeRequest} req The request to sign.\n   * @return {Promise<Eth2StakeResponse | AcceptedResponse>} The response.\n   */\n  async stake(req: Eth2StakeRequest): Promise<SignResponse<Eth2StakeResponse>> {\n    const sign = async (headers?: HeadersInit) => {\n      const resp = await (\n        await this.sessionMgr.client()\n      ).post(\"/v1/org/{org_id}/eth2/stake\", {\n        params: { path: { org_id: this.#orgId } },\n        body: req,\n        headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new SignResponse(this.#orgId, sign, await sign());\n  }\n\n  /**\n   * Sign an unstake request.\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {Eth2UnstakeRequest} req The request to sign.\n   * @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} The response.\n   */\n  async unstake(\n    key: Key | string,\n    req: Eth2UnstakeRequest,\n  ): Promise<SignResponse<Eth2UnstakeResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const resp = await (\n        await this.sessionMgr.client()\n      ).post(\"/v1/org/{org_id}/eth2/unstake/{pubkey}\", {\n        params: { path: { org_id: this.#orgId, pubkey } },\n        body: req,\n        headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new SignResponse(this.#orgId, sign, await sign());\n  }\n\n  /**\n   * Sign a raw blob.\n   * @param {Key | string} key The key to sign with (either {@link Key} or its ID).\n   * @param {BlobSignRequest} req What to sign\n   * @return {Promise<BlobSignResponse | AcceptedResponse>} The response.\n   */\n  async signBlob(key: Key | string, req: BlobSignRequest): Promise<SignResponse<BlobSignResponse>> {\n    const key_id = typeof key === \"string\" ? (key as string) : key.id;\n    const sign = async (headers?: HeadersInit) => {\n      const resp = await (\n        await this.sessionMgr.client()\n      ).post(\"/v1/org/{org_id}/blob/sign/{key_id}\", {\n        params: {\n          path: { org_id: this.#orgId, key_id },\n        },\n        body: req,\n        headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new SignResponse(this.#orgId, sign, await sign());\n  }\n\n  /**\n   * Sign a bitcoin message.\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {BtcSignRequest} req What to sign\n   * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.\n   */\n  async signBtc(key: Key | string, req: BtcSignRequest): Promise<SignResponse<BtcSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const resp = await (\n        await this.sessionMgr.client()\n      ).post(\"/v0/org/{org_id}/btc/sign/{pubkey}\", {\n        params: {\n          path: { org_id: this.#orgId, pubkey },\n        },\n        body: req,\n        headers: headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new SignResponse(this.#orgId, sign, await sign());\n  }\n\n  /**\n   * Sign a solana message.\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {SolanaSignRequest} req What to sign\n   * @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSolana(\n    key: Key | string,\n    req: SolanaSignRequest,\n  ): Promise<SignResponse<SolanaSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const resp = await (\n        await this.sessionMgr.client()\n      ).post(\"/v1/org/{org_id}/solana/sign/{pubkey}\", {\n        params: { path: { org_id: this.#orgId, pubkey } },\n        body: req,\n        headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new SignResponse(this.#orgId, sign, await sign());\n  }\n\n  /**\n   * Loads an existing signer session from storage.\n   * @param {SignerSessionStorage} storage The session storage to use\n   * @return {Promise<SingerSession>} New signer session\n   */\n  static async loadSignerSession(storage: SignerSessionStorage): Promise<SignerSession> {\n    const manager = await SignerSessionManager.loadFromStorage(storage);\n    return new SignerSession(manager);\n  }\n\n  /**\n   * Constructor.\n   * @param {SignerSessionManager} sessionMgr The session manager to use\n   * @internal\n   */\n  constructor(sessionMgr: SignerSessionManager) {\n    this.sessionMgr = sessionMgr;\n    this.#orgId = sessionMgr.orgId;\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /* eslint-disable require-jsdoc */\n\n  /**\n   * Static method for revoking a token (used both from {SignerSession} and {SignerSessionInfo}).\n   * @param {CubeSigner} cs CubeSigner instance\n   * @param {string} orgId Organization ID\n   * @param {string} roleId Role ID\n   * @param {string} sessionId Signer session ID\n   * @internal\n   */\n  static async revoke(cs: CubeSigner, orgId: string, roleId: string, sessionId: string) {\n    const resp = await (\n      await cs.management()\n    ).del(\"/v0/org/{org_id}/roles/{role_id}/tokens/{session_id}\", {\n      params: {\n        path: { org_id: orgId, role_id: roleId, session_id: sessionId },\n      },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n}\n"]}
282
+ _SignerSession_csc = new WeakMap();
283
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signer_session.js","sourceRoot":"","sources":["../../src/signer_session.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from \"assert\";\nimport { CubeSigner, toKeyInfo, MfaReceipt, KeyInfo } from \".\";\nimport { CubeSignerClient } from \"./client\";\nimport { AcceptedResponse, NewSessionResponse } from \"./schema_types\";\nimport { SignerSessionManager, SignerSessionStorage } from \"./session/signer_session_manager\";\n\ntype Response<U> = U | AcceptedResponse;\ntype RequestFn<U> = (headers?: HeadersInit) => Promise<Response<U>>;\ntype MapFn<U, V> = (u: U) => V;\n\n/**\n * Takes a {@link Response<U>} and a {@link MapFn<U, V>} function and returns\n * a {@link Response<V>} that maps the value of the original response when its status code is 200.\n *\n * @param {Response<U>} resp Original response\n * @param {Map<U, V>} mapFn Map to apply to the response value when its status code is 200.\n * @return {Response<V>} 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\nexport interface MfaRequired {\n  /** Org id */\n  org_id: string;\n  /** MFA request id */\n  id: string;\n  /** Optional MFA session */\n  session?: NewSessionResponse | null;\n}\n\n/**\n * A response of a CubeSigner request.\n */\nexport class CubeSignerResponse<U> {\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\n   * signing request\n   */\n  readonly #mfaRequired?: MfaRequired;\n\n  /** @return {string} The MFA id associated with this request */\n  mfaId(): string {\n    return this.#mfaRequired!.id;\n  }\n\n  /** @return {boolean} 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   * @return {ClientSessionInfo | undefined}\n   */\n  mfaSessionInfo(): NewSessionResponse | undefined {\n    return (this.#resp as AcceptedResponse).accepted?.MfaRequired?.session ?? undefined;\n  }\n\n  /** @return {U} 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   * Approves the MFA request using a given session and a TOTP code.\n   *\n   * @param {SignerSession} session Signer session to use\n   * @param {string} code 6-digit TOTP code\n   * @return {CubeSignerResponse<U>} The result of signing with the approval\n   */\n  async approveTotp(session: SignerSession, code: string): Promise<CubeSignerResponse<U>> {\n    assert(this.requiresMfa());\n    const mfaId = this.mfaId();\n    const mfaOrgId = this.#mfaRequired!.org_id;\n    const mfaApproval = await session.totpApprove(mfaId, code);\n    assert(mfaApproval.id === mfaId);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.signWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Approves the MFA request using a given `CubeSignerClient` instance (i.e., its session).\n   *\n   * @param {CubeSigner} cs CubeSigner whose session to use\n   * @return {CubeSignerResponse<U>} The result of signing with the approval\n   */\n  async approve(cs: CubeSigner): Promise<CubeSignerResponse<U>> {\n    assert(this.requiresMfa());\n    const mfaId = this.#mfaRequired!.id;\n    const mfaOrgId = this.#mfaRequired!.org_id;\n\n    const mfaApproval = await cs.mfaApprove(mfaOrgId, mfaId);\n    assert(mfaApproval.id === mfaId);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.signWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * @param {MfaReceipt} mfaReceipt The MFA receipt\n   * @return {Promise<CubeSignerResponse<U>>} The result of signing after MFA approval\n   */\n  async signWithMfaApproval(mfaReceipt: MfaReceipt): Promise<CubeSignerResponse<U>> {\n    const headers = CubeSignerResponse.getMfaHeaders(mfaReceipt);\n    return new CubeSignerResponse(this.#requestFn, await this.#requestFn(headers));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param {RequestFn} requestFn\n   *    The signing function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param {U | AcceptedResponse} resp The response as returned by the OpenAPI client.\n   */\n  constructor(requestFn: RequestFn<U>, resp: U | AcceptedResponse) {\n    this.#requestFn = requestFn;\n    this.#resp = resp;\n    this.#mfaRequired = (this.#resp as AcceptedResponse).accepted?.MfaRequired;\n  }\n\n  /**\n   * Static constructor.\n   * @param {RequestFn} 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} mfaReceipt Optional MFA receipt\n   * @return {Promise<CubeSignerResponse<U>>} New instance of this class.\n   */\n  static async create<U>(\n    requestFn: RequestFn<U>,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<U>> {\n    const seed = await requestFn(this.getMfaHeaders(mfaReceipt));\n    return new CubeSignerResponse(requestFn, seed);\n  }\n\n  /**\n   * Returns HTTP headers containing a given MFA receipt.\n   *\n   * @param {MfaReceipt} mfaReceipt MFA receipt\n   * @return {HeadersInit} Headers including that receipt\n   */\n  static getMfaHeaders(mfaReceipt?: MfaReceipt): HeadersInit | undefined {\n    return mfaReceipt\n      ? {\n          \"x-cubist-mfa-id\": mfaReceipt.mfaId,\n          \"x-cubist-mfa-org-id\": mfaReceipt.mfaOrgId,\n          \"x-cubist-mfa-confirmation\": mfaReceipt.mfaConf,\n        }\n      : undefined;\n  }\n}\n\n/** Signer session info. Can only be used to revoke a token, but not for authentication. */\nexport class SignerSessionInfo {\n  readonly #csc: CubeSignerClient;\n  readonly #sessionId: string;\n  public readonly purpose: string;\n\n  /** Revoke this session */\n  async revoke() {\n    await this.#csc.sessionRevoke(this.#sessionId);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Internal constructor.\n   * @param {CubeSignerClient} cs CubeSigner instance to use when calling `revoke`\n   * @param {string} sessionId The ID of the session; can be used for revocation but not for auth\n   * @param {string} purpose Session purpose\n   * @internal\n   */\n  constructor(cs: CubeSignerClient, sessionId: string, purpose: string) {\n    this.#csc = cs;\n    this.#sessionId = sessionId;\n    this.purpose = purpose;\n  }\n}\n\n/**\n * Signer session.\n *\n * @deprecated Use {@link CubeSignerClient} instead.\n */\nexport class SignerSession {\n  readonly #csc: CubeSignerClient;\n\n  /** Deprecated */\n  get sessionMgr() {\n    return this.#csc.sessionMgr;\n  }\n\n  /** Org id */\n  get orgId() {\n    return this.#csc.orgId;\n  }\n\n  /**\n   * Returns the list of keys that this token grants access to.\n   * @return {KeyInfo[]} The list of keys.\n   */\n  async keys(): Promise<KeyInfo[]> {\n    const keys = await this.#csc.sessionKeysList();\n    return keys.map((k) => toKeyInfo(k));\n  }\n\n  /** Approve a pending MFA request using TOTP. */\n  get totpApprove() {\n    return this.#csc.mfaApproveTotp.bind(this.#csc);\n  }\n\n  /** Initiate approval of an existing MFA request using FIDO. */\n  get fidoApproveStart() {\n    return this.#csc.mfaApproveFidoInit.bind(this.#csc);\n  }\n\n  /** Get a pending MFA request by its id. */\n  get getMfaInfo() {\n    return this.#csc.mfaGet.bind(this.#csc);\n  }\n\n  /** Submit an EVM sign request. */\n  get signEvm() {\n    return this.#csc.signEvm.bind(this.#csc);\n  }\n\n  /** Submit an 'eth2' sign request. */\n  get signEth2() {\n    return this.#csc.signEth2.bind(this.#csc);\n  }\n\n  /** Sign a stake request. */\n  get stake() {\n    return this.#csc.signStake.bind(this.#csc);\n  }\n\n  /** Sign an unstake request. */\n  get unstake() {\n    return this.#csc.signUnstake.bind(this.#csc);\n  }\n\n  /** Sign a raw blob.*/\n  get signBlob() {\n    return this.#csc.signBlob.bind(this.#csc);\n  }\n\n  /** Sign a bitcoin message. */\n  get signBtc() {\n    return this.#csc.signBtc.bind(this.#csc);\n  }\n\n  /** Sign a solana message. */\n  get signSolana() {\n    return this.#csc.signSolana.bind(this.#csc);\n  }\n\n  /** Sign an Avalanche P- or X-chain message. */\n  get signAva() {\n    return this.#csc.signAva.bind(this.#csc);\n  }\n\n  /**\n   * Obtain a proof of authentication.\n   */\n  get proveIdentity() {\n    return this.#csc.identityProve.bind(this.#csc);\n  }\n\n  /**\n   * Loads an existing signer session from storage.\n   * @param {SignerSessionStorage} storage The session storage to use\n   * @return {Promise<SingerSession>} New signer session\n   */\n  static async loadSignerSession(storage: SignerSessionStorage): Promise<SignerSession> {\n    const manager = await SignerSessionManager.loadFromStorage(storage);\n    return new SignerSession(manager);\n  }\n\n  /**\n   * Constructor.\n   * @param {SignerSessionManager} sessionMgr The session manager to use\n   * @internal\n   */\n  constructor(sessionMgr: SignerSessionManager) {\n    this.#csc = new CubeSignerClient(sessionMgr);\n  }\n}\n"]}