@cubist-labs/cubesigner-sdk 0.1.26 → 0.1.77
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/README.md +94 -33
- package/dist/src/ethers/index.d.ts +25 -5
- package/dist/src/ethers/index.js +58 -16
- package/dist/src/fido.d.ts +76 -0
- package/dist/src/fido.js +148 -0
- package/dist/src/index.d.ts +148 -35
- package/dist/src/index.js +320 -53
- package/dist/src/key.d.ts +64 -8
- package/dist/src/key.js +91 -19
- package/dist/src/org.d.ts +98 -9
- package/dist/src/org.js +144 -29
- package/dist/src/paginator.d.ts +76 -0
- package/dist/src/paginator.js +99 -0
- package/dist/src/role.d.ts +20 -8
- package/dist/src/role.js +7 -5
- package/dist/src/schema.d.ts +2395 -393
- package/dist/src/schema.js +1 -1
- package/dist/src/session/cognito_manager.d.ts +59 -0
- package/dist/src/session/cognito_manager.js +111 -0
- package/dist/src/session/session_manager.d.ts +15 -0
- package/dist/src/session/session_manager.js +21 -2
- package/dist/src/session/session_storage.js +1 -1
- package/dist/src/session/signer_session_manager.d.ts +24 -12
- package/dist/src/session/signer_session_manager.js +45 -20
- package/dist/src/signer_session.d.ts +136 -38
- package/dist/src/signer_session.js +187 -80
- package/dist/src/util.d.ts +20 -0
- package/dist/src/util.js +31 -2
- package/package.json +12 -7
- package/src/ethers/index.ts +88 -16
- package/src/fido.ts +166 -0
- package/src/index.ts +366 -77
- package/src/key.ts +112 -16
- package/src/org.ts +200 -37
- package/src/paginator.ts +122 -0
- package/src/role.ts +24 -11
- package/src/schema.ts +2458 -449
- package/src/session/{management_session_manager.ts → cognito_manager.ts} +13 -15
- package/src/session/session_manager.ts +25 -1
- package/src/session/session_storage.ts +1 -1
- package/src/session/signer_session_manager.ts +57 -27
- package/src/signer_session.ts +266 -89
- package/src/util.ts +41 -0
- package/src/session/oidc_session_manager.ts +0 -193
|
@@ -13,7 +13,7 @@ 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
|
|
16
|
+
var _SignResponse_signFn, _SignResponse_resp, _SignResponse_mfaRequired, _SignerSessionInfo_cs, _SignerSessionInfo_orgId, _SignerSessionInfo_roleId, _SignerSessionInfo_sessionId, _SignerSession_orgId;
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
exports.SignerSession = exports.SignerSessionInfo = exports.SignResponse = void 0;
|
|
19
19
|
const assert_1 = __importDefault(require("assert"));
|
|
@@ -21,52 +21,72 @@ const _1 = require(".");
|
|
|
21
21
|
const util_1 = require("./util");
|
|
22
22
|
const signer_session_manager_1 = require("./session/signer_session_manager");
|
|
23
23
|
/**
|
|
24
|
-
* A response of a
|
|
24
|
+
* A response of a CubeSigner request.
|
|
25
25
|
*/
|
|
26
26
|
class SignResponse {
|
|
27
|
-
/** @return {
|
|
27
|
+
/** @return {string} The MFA id associated with this request */
|
|
28
|
+
mfaId() {
|
|
29
|
+
return __classPrivateFieldGet(this, _SignResponse_mfaRequired, "f").id;
|
|
30
|
+
}
|
|
31
|
+
/** @return {boolean} True if this request requires an MFA approval */
|
|
28
32
|
requiresMfa() {
|
|
29
|
-
return __classPrivateFieldGet(this,
|
|
33
|
+
return __classPrivateFieldGet(this, _SignResponse_mfaRequired, "f") !== undefined;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Returns session information to use for any MFA approval requests (if any was included in the response).
|
|
37
|
+
* @return {ClientSessionInfo | undefined}
|
|
38
|
+
*/
|
|
39
|
+
mfaSessionInfo() {
|
|
40
|
+
return __classPrivateFieldGet(this, _SignResponse_resp, "f").accepted?.MfaRequired?.session ?? undefined;
|
|
30
41
|
}
|
|
31
42
|
/** @return {U} The signed data */
|
|
32
43
|
data() {
|
|
33
44
|
return __classPrivateFieldGet(this, _SignResponse_resp, "f");
|
|
34
45
|
}
|
|
35
46
|
/**
|
|
36
|
-
* Approves the MFA request using a given
|
|
37
|
-
*
|
|
38
|
-
* Note: This only works for MFA requests that require a single approval.
|
|
47
|
+
* Approves the MFA request using a given session and a TOTP code.
|
|
39
48
|
*
|
|
40
49
|
* @param {SignerSession} session Signer session to use
|
|
41
50
|
* @param {string} code 6-digit TOTP code
|
|
42
51
|
* @return {SignResponse<U>} The result of signing with the approval
|
|
43
52
|
*/
|
|
44
53
|
async approveTotp(session, code) {
|
|
45
|
-
|
|
54
|
+
(0, assert_1.default)(this.requiresMfa());
|
|
55
|
+
const mfaId = this.mfaId();
|
|
56
|
+
const mfaOrgId = __classPrivateFieldGet(this, _SignResponse_mfaRequired, "f").org_id;
|
|
46
57
|
const mfaApproval = await session.totpApprove(mfaId, code);
|
|
47
58
|
(0, assert_1.default)(mfaApproval.id === mfaId);
|
|
48
59
|
const mfaConf = mfaApproval.receipt?.confirmation;
|
|
49
60
|
if (!mfaConf) {
|
|
50
|
-
|
|
61
|
+
return this;
|
|
51
62
|
}
|
|
52
|
-
return await
|
|
63
|
+
return await this.signWithMfaApproval({ mfaId, mfaOrgId, mfaConf });
|
|
53
64
|
}
|
|
54
65
|
/**
|
|
55
|
-
* Approves the MFA request using CubeSigner
|
|
56
|
-
*
|
|
57
|
-
* Note: This only works for MFA requests that require a single approval.
|
|
66
|
+
* Approves the MFA request using a given `CubeSigner` instance (i.e., its management session).
|
|
58
67
|
*
|
|
68
|
+
* @param {CubeSigner} cs CubeSigner whose session to use
|
|
59
69
|
* @return {SignResponse<U>} The result of signing with the approval
|
|
60
70
|
*/
|
|
61
|
-
async approve() {
|
|
62
|
-
|
|
63
|
-
const
|
|
71
|
+
async approve(cs) {
|
|
72
|
+
(0, assert_1.default)(this.requiresMfa());
|
|
73
|
+
const mfaId = __classPrivateFieldGet(this, _SignResponse_mfaRequired, "f").id;
|
|
74
|
+
const mfaOrgId = __classPrivateFieldGet(this, _SignResponse_mfaRequired, "f").org_id;
|
|
75
|
+
const mfaApproval = await _1.Org.mfaApprove(cs, mfaOrgId, mfaId);
|
|
64
76
|
(0, assert_1.default)(mfaApproval.id === mfaId);
|
|
65
77
|
const mfaConf = mfaApproval.receipt?.confirmation;
|
|
66
78
|
if (!mfaConf) {
|
|
67
|
-
|
|
79
|
+
return this;
|
|
68
80
|
}
|
|
69
|
-
return await
|
|
81
|
+
return await this.signWithMfaApproval({ mfaId, mfaOrgId, mfaConf });
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* @param {MfaReceipt} mfaReceipt The MFA receipt
|
|
85
|
+
* @return {Promise<SignResponse<U>>} The result of signing after MFA approval
|
|
86
|
+
*/
|
|
87
|
+
async signWithMfaApproval(mfaReceipt) {
|
|
88
|
+
const headers = SignResponse.getMfaHeaders(mfaReceipt);
|
|
89
|
+
return new SignResponse(__classPrivateFieldGet(this, _SignResponse_signFn, "f"), await __classPrivateFieldGet(this, _SignResponse_signFn, "f").call(this, headers));
|
|
70
90
|
}
|
|
71
91
|
// --------------------------------------------------------------------------
|
|
72
92
|
// -- INTERNAL --------------------------------------------------------------
|
|
@@ -74,46 +94,54 @@ class SignResponse {
|
|
|
74
94
|
/**
|
|
75
95
|
* Constructor.
|
|
76
96
|
*
|
|
77
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for requests
|
|
78
|
-
* @param {string} orgId The org id of the corresponding signing request
|
|
79
97
|
* @param {SignFn} signFn The signing function that this response is from.
|
|
80
98
|
* This argument is used to resend requests with
|
|
81
99
|
* different headers if needed.
|
|
82
100
|
* @param {U | AcceptedResponse} resp The response as returned by the OpenAPI
|
|
83
101
|
* client.
|
|
84
102
|
*/
|
|
85
|
-
constructor(
|
|
86
|
-
_SignResponse_instances.add(this);
|
|
87
|
-
_SignResponse_cs.set(this, void 0);
|
|
88
|
-
_SignResponse_orgId.set(this, void 0);
|
|
103
|
+
constructor(signFn, resp) {
|
|
89
104
|
_SignResponse_signFn.set(this, void 0);
|
|
90
105
|
_SignResponse_resp.set(this, void 0);
|
|
91
|
-
|
|
92
|
-
|
|
106
|
+
/**
|
|
107
|
+
* Optional MFA id. Only set if there is an MFA request associated with the
|
|
108
|
+
* signing request
|
|
109
|
+
*/
|
|
110
|
+
_SignResponse_mfaRequired.set(this, void 0);
|
|
93
111
|
__classPrivateFieldSet(this, _SignResponse_signFn, signFn, "f");
|
|
94
112
|
__classPrivateFieldSet(this, _SignResponse_resp, resp, "f");
|
|
113
|
+
__classPrivateFieldSet(this, _SignResponse_mfaRequired, __classPrivateFieldGet(this, _SignResponse_resp, "f").accepted?.MfaRequired, "f");
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Static constructor.
|
|
117
|
+
* @param {SignFn} signFn The signing function that this response is from.
|
|
118
|
+
* This argument is used to resend requests with
|
|
119
|
+
* different headers if needed.
|
|
120
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
121
|
+
* @return {Promise<SignResponse<U>>} New instance of this class.
|
|
122
|
+
*/
|
|
123
|
+
static async create(signFn, mfaReceipt) {
|
|
124
|
+
const seed = await signFn(this.getMfaHeaders(mfaReceipt));
|
|
125
|
+
return new SignResponse(signFn, seed);
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Returns HTTP headers containing a given MFA receipt.
|
|
129
|
+
*
|
|
130
|
+
* @param {MfaReceipt} mfaReceipt MFA receipt
|
|
131
|
+
* @return {HeadersInit} Headers including that receipt
|
|
132
|
+
*/
|
|
133
|
+
static getMfaHeaders(mfaReceipt) {
|
|
134
|
+
return mfaReceipt
|
|
135
|
+
? {
|
|
136
|
+
"x-cubist-mfa-id": mfaReceipt.mfaId,
|
|
137
|
+
"x-cubist-mfa-org-id": mfaReceipt.mfaOrgId,
|
|
138
|
+
"x-cubist-mfa-confirmation": mfaReceipt.mfaConf,
|
|
139
|
+
}
|
|
140
|
+
: undefined;
|
|
95
141
|
}
|
|
96
142
|
}
|
|
97
143
|
exports.SignResponse = SignResponse;
|
|
98
|
-
|
|
99
|
-
/**
|
|
100
|
-
* @param {string} mfaConf MFA request approval confirmation code
|
|
101
|
-
* @return {Promise<SignResponse<U>>} The result of signing after MFA approval
|
|
102
|
-
*/
|
|
103
|
-
async function _SignResponse_signWithMfaApproval(mfaConf) {
|
|
104
|
-
const mfaId = __classPrivateFieldGet(this, _SignResponse_instances, "m", _SignResponse_mfaId).call(this);
|
|
105
|
-
const headers = {
|
|
106
|
-
"x-cubist-mfa-id": mfaId,
|
|
107
|
-
"x-cubist-mfa-confirmation": mfaConf,
|
|
108
|
-
};
|
|
109
|
-
return new SignResponse(__classPrivateFieldGet(this, _SignResponse_cs, "f"), __classPrivateFieldGet(this, _SignResponse_orgId, "f"), __classPrivateFieldGet(this, _SignResponse_signFn, "f"), await __classPrivateFieldGet(this, _SignResponse_signFn, "f").call(this, headers));
|
|
110
|
-
}, _SignResponse_mfaId = function _SignResponse_mfaId() {
|
|
111
|
-
const mfaRequired = __classPrivateFieldGet(this, _SignResponse_resp, "f").accepted?.MfaRequired;
|
|
112
|
-
if (!mfaRequired) {
|
|
113
|
-
throw new Error("Request does not require MFA approval");
|
|
114
|
-
}
|
|
115
|
-
return mfaRequired.id;
|
|
116
|
-
};
|
|
144
|
+
_SignResponse_signFn = new WeakMap(), _SignResponse_resp = new WeakMap(), _SignResponse_mfaRequired = new WeakMap();
|
|
117
145
|
/** Signer session info. Can only be used to revoke a token, but not for authentication. */
|
|
118
146
|
class SignerSessionInfo {
|
|
119
147
|
/** Revoke this token */
|
|
@@ -148,6 +176,10 @@ exports.SignerSessionInfo = SignerSessionInfo;
|
|
|
148
176
|
_SignerSessionInfo_cs = new WeakMap(), _SignerSessionInfo_orgId = new WeakMap(), _SignerSessionInfo_roleId = new WeakMap(), _SignerSessionInfo_sessionId = new WeakMap();
|
|
149
177
|
/** Signer session. */
|
|
150
178
|
class SignerSession {
|
|
179
|
+
/** Org id */
|
|
180
|
+
get orgId() {
|
|
181
|
+
return __classPrivateFieldGet(this, _SignerSession_orgId, "f");
|
|
182
|
+
}
|
|
151
183
|
/**
|
|
152
184
|
* Returns the list of keys that this token grants access to.
|
|
153
185
|
* @return {Key[]} The list of keys.
|
|
@@ -158,7 +190,7 @@ class SignerSession {
|
|
|
158
190
|
parseAs: "json",
|
|
159
191
|
});
|
|
160
192
|
const data = (0, util_1.assertOk)(resp);
|
|
161
|
-
return data.keys.map((k) =>
|
|
193
|
+
return data.keys.map((k) => (0, _1.toKeyInfo)(k));
|
|
162
194
|
}
|
|
163
195
|
/**
|
|
164
196
|
* Approve a pending MFA request using TOTP.
|
|
@@ -175,13 +207,59 @@ class SignerSession {
|
|
|
175
207
|
});
|
|
176
208
|
return (0, util_1.assertOk)(resp);
|
|
177
209
|
}
|
|
210
|
+
/**
|
|
211
|
+
* Initiate approval of an existing MFA request using FIDO.
|
|
212
|
+
* @param {string} mfaId The MFA request ID.
|
|
213
|
+
* @return {Promise<MfaFidoChallenge>} A challenge that needs to be answered to complete the approval.
|
|
214
|
+
*/
|
|
215
|
+
async fidoApproveStart(mfaId) {
|
|
216
|
+
const client = await this.sessionMgr.client();
|
|
217
|
+
const resp = await client.post("/v0/org/{org_id}/mfa/{mfa_id}/fido", {
|
|
218
|
+
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), mfa_id: mfaId } },
|
|
219
|
+
parseAs: "json",
|
|
220
|
+
});
|
|
221
|
+
const challenge = (0, util_1.assertOk)(resp);
|
|
222
|
+
return new _1.MfaFidoChallenge(this, mfaId, challenge);
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* Complete a previously initiated MFA request approval using FIDO.
|
|
226
|
+
* @param {string} mfaId The MFA request ID
|
|
227
|
+
* @param {string} challengeId The challenge ID
|
|
228
|
+
* @param {PublicKeyCredential} credential The answer to the challenge
|
|
229
|
+
* @return {Promise<MfaRequestInfo>} The current status of the MFA request.
|
|
230
|
+
*/
|
|
231
|
+
async fidoApproveComplete(mfaId, challengeId, credential) {
|
|
232
|
+
const client = await this.sessionMgr.client();
|
|
233
|
+
const resp = await client.patch("/v0/org/{org_id}/mfa/{mfa_id}/fido", {
|
|
234
|
+
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), mfa_id: mfaId } },
|
|
235
|
+
body: {
|
|
236
|
+
challenge_id: challengeId,
|
|
237
|
+
credential,
|
|
238
|
+
},
|
|
239
|
+
parseAs: "json",
|
|
240
|
+
});
|
|
241
|
+
return (0, util_1.assertOk)(resp);
|
|
242
|
+
}
|
|
243
|
+
/**
|
|
244
|
+
* Get a pending MFA request by its id.
|
|
245
|
+
* @param {CubeSigner} cs Management session to use (this argument will be removed in future versions)
|
|
246
|
+
* @param {string} mfaId The id of the MFA request.
|
|
247
|
+
* @return {Promise<MfaRequestInfo>} The MFA request.
|
|
248
|
+
*/
|
|
249
|
+
async getMfaInfo(cs, mfaId) {
|
|
250
|
+
const resp = await (await cs.management()).get("/v0/org/{org_id}/mfa/{mfa_id}", {
|
|
251
|
+
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), mfa_id: mfaId } },
|
|
252
|
+
});
|
|
253
|
+
return (0, util_1.assertOk)(resp);
|
|
254
|
+
}
|
|
178
255
|
/**
|
|
179
256
|
* Submit an EVM sign request.
|
|
180
257
|
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
181
258
|
* @param {EvmSignRequest} req What to sign.
|
|
259
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt.
|
|
182
260
|
* @return {Promise<EvmSignResponse | AcceptedResponse>} Signature
|
|
183
261
|
*/
|
|
184
|
-
async signEvm(key, req) {
|
|
262
|
+
async signEvm(key, req, mfaReceipt) {
|
|
185
263
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
186
264
|
const sign = async (headers) => {
|
|
187
265
|
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth1/sign/{pubkey}", {
|
|
@@ -192,15 +270,16 @@ class SignerSession {
|
|
|
192
270
|
});
|
|
193
271
|
return (0, util_1.assertOk)(resp);
|
|
194
272
|
};
|
|
195
|
-
return
|
|
273
|
+
return await SignResponse.create(sign, mfaReceipt);
|
|
196
274
|
}
|
|
197
275
|
/**
|
|
198
276
|
* Submit an 'eth2' sign request.
|
|
199
277
|
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
200
278
|
* @param {Eth2SignRequest} req What to sign.
|
|
279
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
201
280
|
* @return {Promise<Eth2SignResponse | AcceptedResponse>} Signature
|
|
202
281
|
*/
|
|
203
|
-
async signEth2(key, req) {
|
|
282
|
+
async signEth2(key, req, mfaReceipt) {
|
|
204
283
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
205
284
|
const sign = async (headers) => {
|
|
206
285
|
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/sign/{pubkey}", {
|
|
@@ -211,14 +290,15 @@ class SignerSession {
|
|
|
211
290
|
});
|
|
212
291
|
return (0, util_1.assertOk)(resp);
|
|
213
292
|
};
|
|
214
|
-
return
|
|
293
|
+
return await SignResponse.create(sign, mfaReceipt);
|
|
215
294
|
}
|
|
216
295
|
/**
|
|
217
296
|
* Sign a stake request.
|
|
218
297
|
* @param {Eth2StakeRequest} req The request to sign.
|
|
298
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
219
299
|
* @return {Promise<Eth2StakeResponse | AcceptedResponse>} The response.
|
|
220
300
|
*/
|
|
221
|
-
async stake(req) {
|
|
301
|
+
async stake(req, mfaReceipt) {
|
|
222
302
|
const sign = async (headers) => {
|
|
223
303
|
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/stake", {
|
|
224
304
|
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f") } },
|
|
@@ -228,15 +308,16 @@ class SignerSession {
|
|
|
228
308
|
});
|
|
229
309
|
return (0, util_1.assertOk)(resp);
|
|
230
310
|
};
|
|
231
|
-
return
|
|
311
|
+
return await SignResponse.create(sign, mfaReceipt);
|
|
232
312
|
}
|
|
233
313
|
/**
|
|
234
314
|
* Sign an unstake request.
|
|
235
315
|
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
236
316
|
* @param {Eth2UnstakeRequest} req The request to sign.
|
|
317
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
237
318
|
* @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} The response.
|
|
238
319
|
*/
|
|
239
|
-
async unstake(key, req) {
|
|
320
|
+
async unstake(key, req, mfaReceipt) {
|
|
240
321
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
241
322
|
const sign = async (headers) => {
|
|
242
323
|
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/unstake/{pubkey}", {
|
|
@@ -247,15 +328,16 @@ class SignerSession {
|
|
|
247
328
|
});
|
|
248
329
|
return (0, util_1.assertOk)(resp);
|
|
249
330
|
};
|
|
250
|
-
return
|
|
331
|
+
return await SignResponse.create(sign, mfaReceipt);
|
|
251
332
|
}
|
|
252
333
|
/**
|
|
253
334
|
* Sign a raw blob.
|
|
254
335
|
* @param {Key | string} key The key to sign with (either {@link Key} or its ID).
|
|
255
336
|
* @param {BlobSignRequest} req What to sign
|
|
337
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
256
338
|
* @return {Promise<BlobSignResponse | AcceptedResponse>} The response.
|
|
257
339
|
*/
|
|
258
|
-
async signBlob(key, req) {
|
|
340
|
+
async signBlob(key, req, mfaReceipt) {
|
|
259
341
|
const key_id = typeof key === "string" ? key : key.id;
|
|
260
342
|
const sign = async (headers) => {
|
|
261
343
|
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/blob/sign/{key_id}", {
|
|
@@ -268,15 +350,16 @@ class SignerSession {
|
|
|
268
350
|
});
|
|
269
351
|
return (0, util_1.assertOk)(resp);
|
|
270
352
|
};
|
|
271
|
-
return
|
|
353
|
+
return await SignResponse.create(sign, mfaReceipt);
|
|
272
354
|
}
|
|
273
355
|
/**
|
|
274
356
|
* Sign a bitcoin message.
|
|
275
357
|
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
276
358
|
* @param {BtcSignRequest} req What to sign
|
|
359
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
277
360
|
* @return {Promise<BtcSignResponse | AcceptedResponse>} The response.
|
|
278
361
|
*/
|
|
279
|
-
async signBtc(key, req) {
|
|
362
|
+
async signBtc(key, req, mfaReceipt) {
|
|
280
363
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
281
364
|
const sign = async (headers) => {
|
|
282
365
|
const resp = await (await this.sessionMgr.client()).post("/v0/org/{org_id}/btc/sign/{pubkey}", {
|
|
@@ -289,18 +372,19 @@ class SignerSession {
|
|
|
289
372
|
});
|
|
290
373
|
return (0, util_1.assertOk)(resp);
|
|
291
374
|
};
|
|
292
|
-
return
|
|
375
|
+
return await SignResponse.create(sign, mfaReceipt);
|
|
293
376
|
}
|
|
294
377
|
/**
|
|
295
378
|
* Sign a solana message.
|
|
296
379
|
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
297
380
|
* @param {SolanaSignRequest} req What to sign
|
|
381
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
298
382
|
* @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.
|
|
299
383
|
*/
|
|
300
|
-
async signSolana(key, req) {
|
|
384
|
+
async signSolana(key, req, mfaReceipt) {
|
|
301
385
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
302
386
|
const sign = async (headers) => {
|
|
303
|
-
const resp = await (await this.sessionMgr.client()).post("/
|
|
387
|
+
const resp = await (await this.sessionMgr.client()).post("/v0/org/{org_id}/solana/sign/{pubkey}", {
|
|
304
388
|
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
|
|
305
389
|
body: req,
|
|
306
390
|
headers,
|
|
@@ -308,37 +392,60 @@ class SignerSession {
|
|
|
308
392
|
});
|
|
309
393
|
return (0, util_1.assertOk)(resp);
|
|
310
394
|
};
|
|
311
|
-
return
|
|
395
|
+
return await SignResponse.create(sign, mfaReceipt);
|
|
312
396
|
}
|
|
313
397
|
/**
|
|
314
|
-
*
|
|
315
|
-
* @param {
|
|
316
|
-
* @param {
|
|
317
|
-
* @
|
|
398
|
+
* Sign an Avalanche P- or X-chain message.
|
|
399
|
+
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
400
|
+
* @param {AvaTx} tx Avalanche message (transaction) to sign
|
|
401
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
402
|
+
* @return {Promise<AvaSignResponse | AcceptedResponse>} The response.
|
|
403
|
+
*/
|
|
404
|
+
async signAva(key, tx, mfaReceipt) {
|
|
405
|
+
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
406
|
+
const sign = async (headers) => {
|
|
407
|
+
const req = {
|
|
408
|
+
tx: tx,
|
|
409
|
+
};
|
|
410
|
+
const resp = await (await this.sessionMgr.client()).post("/v0/org/{org_id}/ava/sign/{pubkey}", {
|
|
411
|
+
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
|
|
412
|
+
body: req,
|
|
413
|
+
headers,
|
|
414
|
+
parseAs: "json",
|
|
415
|
+
});
|
|
416
|
+
return (0, util_1.assertOk)(resp);
|
|
417
|
+
};
|
|
418
|
+
return await SignResponse.create(sign, mfaReceipt);
|
|
419
|
+
}
|
|
420
|
+
/**
|
|
421
|
+
* Obtain a proof of authentication.
|
|
422
|
+
*
|
|
423
|
+
* @return {Promise<IdentityProof>} Proof of authentication
|
|
318
424
|
*/
|
|
319
|
-
|
|
320
|
-
const
|
|
321
|
-
|
|
425
|
+
async proveIdentity() {
|
|
426
|
+
const client = await this.sessionMgr.client();
|
|
427
|
+
const resp = await client.post("/v0/org/{org_id}/identity/prove", {
|
|
428
|
+
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f") } },
|
|
429
|
+
parseAs: "json",
|
|
430
|
+
});
|
|
431
|
+
return (0, util_1.assertOk)(resp);
|
|
322
432
|
}
|
|
323
433
|
/**
|
|
324
|
-
* Loads an existing
|
|
325
|
-
* @param {
|
|
326
|
-
* @
|
|
327
|
-
* @return {Promise<SignerSession>} New signer session
|
|
434
|
+
* Loads an existing signer session from storage.
|
|
435
|
+
* @param {SignerSessionStorage} storage The session storage to use
|
|
436
|
+
* @return {Promise<SingerSession>} New signer session
|
|
328
437
|
*/
|
|
329
|
-
static async
|
|
330
|
-
const manager = await
|
|
331
|
-
return new SignerSession(
|
|
438
|
+
static async loadSignerSession(storage) {
|
|
439
|
+
const manager = await signer_session_manager_1.SignerSessionManager.loadFromStorage(storage);
|
|
440
|
+
return new SignerSession(manager);
|
|
332
441
|
}
|
|
333
442
|
/**
|
|
334
443
|
* Constructor.
|
|
335
|
-
* @param {
|
|
336
|
-
* @param {OidcSessionManager | SignerSessionManager} sessionMgr The session manager to use
|
|
444
|
+
* @param {SignerSessionManager} sessionMgr The session manager to use
|
|
337
445
|
* @internal
|
|
338
446
|
*/
|
|
339
|
-
constructor(
|
|
447
|
+
constructor(sessionMgr) {
|
|
340
448
|
_SignerSession_orgId.set(this, void 0);
|
|
341
|
-
this.cs = cs;
|
|
342
449
|
this.sessionMgr = sessionMgr;
|
|
343
450
|
__classPrivateFieldSet(this, _SignerSession_orgId, sessionMgr.orgId, "f");
|
|
344
451
|
}
|
|
@@ -366,4 +473,4 @@ class SignerSession {
|
|
|
366
473
|
}
|
|
367
474
|
exports.SignerSession = SignerSession;
|
|
368
475
|
_SignerSession_orgId = new WeakMap();
|
|
369
|
-
//# 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, OidcSessionManager, OidcSessionStorage, Org } from \".\";\nimport { components, paths } from \"./client\";\nimport { assertOk } from \"./util\";\nimport { SignerSessionManager, SignerSessionStorage } from \"./session/signer_session_manager\";\n\nexport type KeyInfo = components[\"schemas\"][\"KeyInfo\"];\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 signing request.\n */\nexport class SignResponse<U> {\n  readonly #cs: CubeSigner;\n  readonly #orgId: string;\n  readonly #signFn: SignFn<U>;\n  readonly #resp: U | AcceptedResponse;\n\n  /** @return {boolean} True if this signing request requires an MFA approval */\n  requiresMfa(): boolean {\n    return (this.#resp as AcceptedResponse).accepted?.MfaRequired !== 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 signer session and a TOTP code.\n   *\n   * Note: This only works for MFA requests that require a single approval.\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\n    const mfaApproval = await session.totpApprove(mfaId, code);\n    assert(mfaApproval.id === mfaId);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      throw new Error(\"MfaRequest has not been approved yet\");\n    }\n\n    return await this.#signWithMfaApproval(mfaConf!);\n  }\n\n  /**\n   * Approves the MFA request using CubeSigner's management session.\n   *\n   * Note: This only works for MFA requests that require a single approval.\n   *\n   * @return {SignResponse<U>} The result of signing with the approval\n   */\n  async approve(): Promise<SignResponse<U>> {\n    const mfaId = this.#mfaId();\n\n    const mfaApproval = await Org.mfaApprove(this.#cs, this.#orgId, mfaId);\n    assert(mfaApproval.id === mfaId);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      throw new Error(\"MfaRequest has not been approved yet\");\n    }\n\n    return await this.#signWithMfaApproval(mfaConf);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param {CubeSigner} cs The CubeSigner instance to use for requests\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(cs: CubeSigner, orgId: string, signFn: SignFn<U>, resp: U | AcceptedResponse) {\n    this.#cs = cs;\n    this.#orgId = orgId;\n    this.#signFn = signFn;\n    this.#resp = resp;\n  }\n\n  /**\n   * @param {string} mfaConf MFA request approval confirmation code\n   * @return {Promise<SignResponse<U>>} The result of signing after MFA approval\n   */\n  async #signWithMfaApproval(mfaConf: string): Promise<SignResponse<U>> {\n    const mfaId = this.#mfaId();\n\n    const headers = {\n      \"x-cubist-mfa-id\": mfaId,\n      \"x-cubist-mfa-confirmation\": mfaConf,\n    };\n    return new SignResponse(this.#cs, this.#orgId, this.#signFn, await this.#signFn(headers));\n  }\n\n  /**\n   * @return {string} MFA id if MFA is required for this response; throws otherwise.\n   */\n  #mfaId(): string {\n    const mfaRequired = (this.#resp as AcceptedResponse).accepted?.MfaRequired;\n    if (!mfaRequired) {\n      throw new Error(\"Request does not require MFA approval\");\n    }\n    return mfaRequired.id;\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  readonly cs: CubeSigner;\n  sessionMgr: OidcSessionManager | 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<Key[]> {\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: KeyInfo) => new Key(this.cs, this.#orgId, 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   * 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.cs, 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.cs, 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.cs, 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.cs, 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.cs, 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.cs, 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.cs, this.#orgId, sign, await sign());\n  }\n\n  /**\n   * Loads an existing signer session from storage.\n   * @param {CubeSigner} cs The CubeSigner instance\n   * @param {SignerSessionStorage} storage The session storage to use\n   * @return {Promise<SingerSession>} New signer session\n   */\n  static async loadSignerSession(\n    cs: CubeSigner,\n    storage: SignerSessionStorage,\n  ): Promise<SignerSession> {\n    const manager = await SignerSessionManager.loadFromStorage(cs, storage);\n    return new SignerSession(cs, manager);\n  }\n\n  /**\n   * Loads an existing OIDC session from storage\n   * @param {CubeSigner} cs The CubeSigner instance\n   * @param {OidcSessionStorage} storage The storage to use\n   * @return {Promise<SignerSession>} New signer session\n   */\n  static async loadOidcSession(\n    cs: CubeSigner,\n    storage: OidcSessionStorage,\n  ): Promise<SignerSession> {\n    const manager = await OidcSessionManager.loadFromStorage(storage);\n    return new SignerSession(cs, manager);\n  }\n\n  /**\n   * Constructor.\n   * @param {CubeSigner} cs The CubeSigner instance to use for requests\n   * @param {OidcSessionManager | SignerSessionManager} sessionMgr The session manager to use\n   * @internal\n   */\n  constructor(cs: CubeSigner, sessionMgr: OidcSessionManager | SignerSessionManager) {\n    this.cs = cs;\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"]}
|
|
476
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signer_session.js","sourceRoot":"","sources":["../../src/signer_session.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,oDAA4B;AAC5B,wBASW;AAEX,iCAA2C;AAE3C,6EAI0C;AA0E1C;;GAEG;AACH,MAAa,YAAY;IASvB,+DAA+D;IAC/D,KAAK;QACH,OAAO,uBAAA,IAAI,iCAAc,CAAC,EAAE,CAAC;IAC/B,CAAC;IAED,sEAAsE;IACtE,WAAW;QACT,OAAO,uBAAA,IAAI,iCAAa,KAAK,SAAS,CAAC;IACzC,CAAC;IAED;;;OAGG;IACH,cAAc;QACZ,OAAQ,uBAAA,IAAI,0BAA2B,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,IAAI,SAAS,CAAC;IACtF,CAAC;IAED,kCAAkC;IAClC,IAAI;QACF,OAAO,uBAAA,IAAI,0BAAW,CAAC;IACzB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,WAAW,CAAC,OAAsB,EAAE,IAAY;QACpD,IAAA,gBAAM,EAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAC3B,MAAM,QAAQ,GAAG,uBAAA,IAAI,iCAAc,CAAC,MAAM,CAAC;QAC3C,MAAM,WAAW,GAAG,MAAM,OAAO,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAC3D,IAAA,gBAAM,EAAC,WAAW,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;QACjC,MAAM,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,YAAY,CAAC;QAElD,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,IAAI,CAAC;SACb;QAED,OAAO,MAAM,IAAI,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;IACtE,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,OAAO,CAAC,EAAc;QAC1B,IAAA,gBAAM,EAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAC3B,MAAM,KAAK,GAAG,uBAAA,IAAI,iCAAc,CAAC,EAAE,CAAC;QACpC,MAAM,QAAQ,GAAG,uBAAA,IAAI,iCAAc,CAAC,MAAM,CAAC;QAE3C,MAAM,WAAW,GAAG,MAAM,MAAG,CAAC,UAAU,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;QAC9D,IAAA,gBAAM,EAAC,WAAW,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;QACjC,MAAM,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,YAAY,CAAC;QAElD,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,IAAI,CAAC;SACb;QAED,OAAO,MAAM,IAAI,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;IACtE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,mBAAmB,CAAC,UAAsB;QAC9C,MAAM,OAAO,GAAG,YAAY,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QACvD,OAAO,IAAI,YAAY,CAAC,uBAAA,IAAI,4BAAQ,EAAE,MAAM,uBAAA,IAAI,4BAAQ,MAAZ,IAAI,EAAS,OAAO,CAAC,CAAC,CAAC;IACrE,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;;;;OAQG;IACH,YAAY,MAAiB,EAAE,IAA0B;QAjGhD,uCAAmB;QACnB,qCAA4B;QACrC;;;WAGG;QACM,4CAA2B;QA4FlC,uBAAA,IAAI,wBAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,sBAAS,IAAI,MAAA,CAAC;QAClB,uBAAA,IAAI,6BAAiB,uBAAA,IAAI,0BAA2B,CAAC,QAAQ,EAAE,WAAW,MAAA,CAAC;IAC7E,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,KAAK,CAAC,MAAM,CAAI,MAAiB,EAAE,UAAuB;QAC/D,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC;QAC1D,OAAO,IAAI,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IACxC,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,aAAa,CAAC,UAAuB;QAC1C,OAAO,UAAU;YACf,CAAC,CAAC;gBACE,iBAAiB,EAAE,UAAU,CAAC,KAAK;gBACnC,qBAAqB,EAAE,UAAU,CAAC,QAAQ;gBAC1C,2BAA2B,EAAE,UAAU,CAAC,OAAO;aAChD;YACH,CAAC,CAAC,SAAS,CAAC;IAChB,CAAC;CACF;AApID,oCAoIC;;AAED,2FAA2F;AAC3F,MAAa,iBAAiB;IAO5B,wBAAwB;IACxB,KAAK,CAAC,MAAM;QACV,MAAM,aAAa,CAAC,MAAM,CAAC,uBAAA,IAAI,6BAAI,EAAE,uBAAA,IAAI,gCAAO,EAAE,uBAAA,IAAI,iCAAQ,EAAE,uBAAA,IAAI,oCAAW,CAAC,CAAC;IACnF,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;;;;OAQG;IACH,YAAY,EAAc,EAAE,KAAa,EAAE,MAAc,EAAE,IAAY,EAAE,OAAe;QAxB/E,wCAAgB;QAChB,2CAAe;QACf,4CAAgB;QAChB,+CAAmB;QAsB1B,uBAAA,IAAI,yBAAO,EAAE,MAAA,CAAC;QACd,uBAAA,IAAI,4BAAU,KAAK,MAAA,CAAC;QACpB,uBAAA,IAAI,6BAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,gCAAc,IAAI,MAAA,CAAC;QACvB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;CACF;AAhCD,8CAgCC;;AAED,sBAAsB;AACtB,MAAa,aAAa;IAIxB,aAAa;IACb,IAAI,KAAK;QACP,OAAO,uBAAA,IAAI,4BAAO,CAAC;IACrB,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,IAAI;QACR,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,GAAG,CAAC,6BAA6B,EAAE;YACnC,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,EAAE;YACzC,OAAO,EAAE,MAAM;SAChB,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QAC5B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,YAAS,EAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,WAAW,CAAC,KAAa,EAAE,IAAY;QAC3C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,KAAK,CAAC,oCAAoC,EAAE;YAC5C,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE;YACxD,IAAI,EAAE,EAAE,IAAI,EAAE;YACd,OAAO,EAAE,MAAM;SAChB,CAAC,CAAC;QACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,gBAAgB,CAAC,KAAa;QAClC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QAC9C,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,oCAAoC,EAAE;YACnE,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE;YACxD,OAAO,EAAE,MAAM;SAChB,CAAC,CAAC;QACH,MAAM,SAAS,GAAG,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACjC,OAAO,IAAI,mBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;IACtD,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,mBAAmB,CACvB,KAAa,EACb,WAAmB,EACnB,UAA+B;QAE/B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QAC9C,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,oCAAoC,EAAE;YACpE,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE;YACxD,IAAI,EAAE;gBACJ,YAAY,EAAE,WAAW;gBACzB,UAAU;aACX;YACD,OAAO,EAAE,MAAM;SAChB,CAAC,CAAC;QACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,UAAU,CAAC,EAAc,EAAE,KAAa;QAC5C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,EAAE,CAAC,UAAU,EAAE,CACtB,CAAC,GAAG,CAAC,+BAA+B,EAAE;YACrC,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE;SACzD,CAAC,CAAC;QACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CACX,GAAiB,EACjB,GAAmB,EACnB,UAAuB;QAEvB,MAAM,MAAM,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC;QAC1E,MAAM,IAAI,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;YAC3C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,IAAI,CAAC,qCAAqC,EAAE;gBAC5C,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,EAAE;gBACjD,IAAI,EAAE,GAAG;gBACT,OAAO;gBACP,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC;QACF,OAAO,MAAM,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CACZ,GAAiB,EACjB,GAAoB,EACpB,UAAuB;QAEvB,MAAM,MAAM,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC;QAC1E,MAAM,IAAI,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;YAC3C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,IAAI,CAAC,qCAAqC,EAAE;gBAC5C,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,EAAE;gBACjD,IAAI,EAAE,GAAG;gBACT,OAAO;gBACP,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC;QACF,OAAO,MAAM,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,KAAK,CACT,GAAqB,EACrB,UAAuB;QAEvB,MAAM,IAAI,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;YAC3C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,IAAI,CAAC,6BAA6B,EAAE;gBACpC,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,EAAE;gBACzC,IAAI,EAAE,GAAG;gBACT,OAAO;gBACP,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC;QACF,OAAO,MAAM,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CACX,GAAiB,EACjB,GAAuB,EACvB,UAAuB;QAEvB,MAAM,MAAM,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC;QAC1E,MAAM,IAAI,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;YAC3C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,IAAI,CAAC,wCAAwC,EAAE;gBAC/C,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,EAAE;gBACjD,IAAI,EAAE,GAAG;gBACT,OAAO;gBACP,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC;QACF,OAAO,MAAM,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CACZ,GAAiB,EACjB,GAAoB,EACpB,UAAuB;QAEvB,MAAM,MAAM,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC;QAClE,MAAM,IAAI,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;YAC3C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,IAAI,CAAC,qCAAqC,EAAE;gBAC5C,MAAM,EAAE;oBACN,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE;iBACtC;gBACD,IAAI,EAAE,GAAG;gBACT,OAAO;gBACP,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC;QACF,OAAO,MAAM,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CACX,GAAiB,EACjB,GAAmB,EACnB,UAAuB;QAEvB,MAAM,MAAM,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC;QAC1E,MAAM,IAAI,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;YAC3C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,IAAI,CAAC,oCAAoC,EAAE;gBAC3C,MAAM,EAAE;oBACN,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE;iBACtC;gBACD,IAAI,EAAE,GAAG;gBACT,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC;QACF,OAAO,MAAM,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,UAAU,CACd,GAAiB,EACjB,GAAsB,EACtB,UAAuB;QAEvB,MAAM,MAAM,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC;QAC1E,MAAM,IAAI,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;YAC3C,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,IAAI,CAAC,uCAAuC,EAAE;gBAC9C,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,EAAE;gBACjD,IAAI,EAAE,GAAG;gBACT,OAAO;gBACP,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC;QACF,OAAO,MAAM,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CACX,GAAiB,EACjB,EAAS,EACT,UAAuB;QAEvB,MAAM,MAAM,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC;QAC1E,MAAM,IAAI,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;YAC3C,MAAM,GAAG,GAAmB;gBAC1B,EAAE,EAAE,EAAa;aAClB,CAAC;YACF,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAC/B,CAAC,IAAI,CAAC,oCAAoC,EAAE;gBAC3C,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,MAAM,EAAE,EAAE;gBACjD,IAAI,EAAE,GAAG;gBACT,OAAO;gBACP,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC;QACF,OAAO,MAAM,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;IACrD,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,aAAa;QACjB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QAC9C,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,iCAAiC,EAAE;YAChE,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,uBAAA,IAAI,4BAAO,EAAE,EAAE;YACzC,OAAO,EAAE,MAAM;SAChB,CAAC,CAAC;QACH,OAAO,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,iBAAiB,CAAC,OAA6B;QAC1D,MAAM,OAAO,GAAG,MAAM,6CAAoB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QACpE,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC;IAED;;;;OAIG;IACH,YAAY,UAAgC;QAvVnC,uCAAe;QAwVtB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,uBAAA,IAAI,wBAAU,UAAU,CAAC,KAAK,MAAA,CAAC;IACjC,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E,kCAAkC;IAElC;;;;;;;OAOG;IACH,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,EAAc,EAAE,KAAa,EAAE,MAAc,EAAE,SAAiB;QAClF,MAAM,IAAI,GAAG,MAAM,CACjB,MAAM,EAAE,CAAC,UAAU,EAAE,CACtB,CAAC,GAAG,CAAC,sDAAsD,EAAE;YAC5D,MAAM,EAAE;gBACN,IAAI,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE;aAChE;YACD,OAAO,EAAE,MAAM;SAChB,CAAC,CAAC;QACH,IAAA,eAAQ,EAAC,IAAI,CAAC,CAAC;IACjB,CAAC;CACF;AAvXD,sCAuXC","sourcesContent":["import assert from \"assert\";\nimport {\n  CubeSigner,\n  Key,\n  toKeyInfo,\n  Org,\n  KeyInfo,\n  MfaReceipt,\n  IdentityProof,\n  MfaFidoChallenge,\n} from \".\";\nimport { components, paths } from \"./client\";\nimport { JsonMap, assertOk } from \"./util\";\nimport { PublicKeyCredential } from \"./fido\";\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[\"/v0/org/{org_id}/solana/sign/{pubkey}\"][\"post\"][\"requestBody\"][\"content\"][\"application/json\"];\nexport type AvaSignRequest =\n  paths[\"/v0/org/{org_id}/ava/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\"];\nexport type AvaSignResponse =\n  components[\"responses\"][\"AvaSignResponse\"][\"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\n/** Ava P- or X-chain transaction */\nexport type AvaTx = { P: AvaPChainTx } | { X: AvaXChainTx };\n\n/** Ava P-chain transaction */\nexport type AvaPChainTx =\n  | { AddPermissionlessValidator: JsonMap }\n  | { AddSubnetValidator: JsonMap }\n  | { AddValidator: JsonMap }\n  | { CreateChain: JsonMap }\n  | { CreateSubnet: JsonMap }\n  | { Export: JsonMap }\n  | { Import: JsonMap };\n\n/** Ava X-chain transaction */\nexport type AvaXChainTx = { Base: JsonMap } | { Export: JsonMap } | { Import: JsonMap };\n\ntype SignFn<U> = (headers?: HeadersInit) => Promise<U | AcceptedResponse>;\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 SignResponse<U> {\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  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 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    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 `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    assert(this.requiresMfa());\n    const mfaId = this.#mfaRequired!.id;\n    const mfaOrgId = this.#mfaRequired!.org_id;\n\n    const mfaApproval = await Org.mfaApprove(cs, 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<SignResponse<U>>} The result of signing after MFA approval\n   */\n  async signWithMfaApproval(mfaReceipt: MfaReceipt): Promise<SignResponse<U>> {\n    const headers = SignResponse.getMfaHeaders(mfaReceipt);\n    return new SignResponse(this.#signFn, await this.#signFn(headers));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\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(signFn: SignFn<U>, resp: U | AcceptedResponse) {\n    this.#signFn = signFn;\n    this.#resp = resp;\n    this.#mfaRequired = (this.#resp as AcceptedResponse).accepted?.MfaRequired;\n  }\n\n  /**\n   * Static constructor.\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 {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<SignResponse<U>>} New instance of this class.\n   */\n  static async create<U>(signFn: SignFn<U>, mfaReceipt?: MfaReceipt): Promise<SignResponse<U>> {\n    const seed = await signFn(this.getMfaHeaders(mfaReceipt));\n    return new SignResponse(signFn, 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 #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  /** Org id */\n  get orgId() {\n    return this.#orgId;\n  }\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   * Initiate approval of an existing MFA request using FIDO.\n   * @param {string} mfaId The MFA request ID.\n   * @return {Promise<MfaFidoChallenge>} A challenge that needs to be answered to complete the approval.\n   */\n  async fidoApproveStart(mfaId: string): Promise<MfaFidoChallenge> {\n    const client = await this.sessionMgr.client();\n    const resp = await client.post(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", {\n      params: { path: { org_id: this.#orgId, mfa_id: mfaId } },\n      parseAs: \"json\",\n    });\n    const challenge = assertOk(resp);\n    return new MfaFidoChallenge(this, mfaId, challenge);\n  }\n\n  /**\n   * Complete a previously initiated MFA request approval using FIDO.\n   * @param {string} mfaId The MFA request ID\n   * @param {string} challengeId The challenge ID\n   * @param {PublicKeyCredential} credential The answer to the challenge\n   * @return {Promise<MfaRequestInfo>} The current status of the MFA request.\n   */\n  async fidoApproveComplete(\n    mfaId: string,\n    challengeId: string,\n    credential: PublicKeyCredential,\n  ): Promise<MfaRequestInfo> {\n    const client = await this.sessionMgr.client();\n    const resp = await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", {\n      params: { path: { org_id: this.#orgId, mfa_id: mfaId } },\n      body: {\n        challenge_id: challengeId,\n        credential,\n      },\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   * @param {MfaReceipt} mfaReceipt Optional MFA receipt.\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature\n   */\n  async signEvm(\n    key: Key | string,\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): 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 await SignResponse.create(sign, mfaReceipt);\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   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<Eth2SignResponse | AcceptedResponse>} Signature\n   */\n  async signEth2(\n    key: Key | string,\n    req: Eth2SignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): 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 await SignResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign a stake request.\n   * @param {Eth2StakeRequest} req The request to sign.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<Eth2StakeResponse | AcceptedResponse>} The response.\n   */\n  async stake(\n    req: Eth2StakeRequest,\n    mfaReceipt?: MfaReceipt,\n  ): 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 await SignResponse.create(sign, mfaReceipt);\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   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} The response.\n   */\n  async unstake(\n    key: Key | string,\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipt,\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 await SignResponse.create(sign, mfaReceipt);\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   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<BlobSignResponse | AcceptedResponse>} The response.\n   */\n  async signBlob(\n    key: Key | string,\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): 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 await SignResponse.create(sign, mfaReceipt);\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   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.\n   */\n  async signBtc(\n    key: Key | string,\n    req: BtcSignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): 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 await SignResponse.create(sign, mfaReceipt);\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   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSolana(\n    key: Key | string,\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipt,\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(\"/v0/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 await SignResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign an Avalanche P- or X-chain message.\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {AvaTx} tx Avalanche message (transaction) to sign\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signAva(\n    key: Key | string,\n    tx: AvaTx,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<SignResponse<AvaSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const req = <AvaSignRequest>{\n        tx: tx as unknown,\n      };\n      const resp = await (\n        await this.sessionMgr.client()\n      ).post(\"/v0/org/{org_id}/ava/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 await SignResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Obtain a proof of authentication.\n   *\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async proveIdentity(): Promise<IdentityProof> {\n    const client = await this.sessionMgr.client();\n    const resp = await client.post(\"/v0/org/{org_id}/identity/prove\", {\n      params: { path: { org_id: this.#orgId } },\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\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"]}
|