@cubist-labs/cubesigner-sdk 0.1.77 → 0.2.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/package.json +68 -0
- package/dist/src/api.d.ts +493 -0
- package/dist/src/api.js +1166 -0
- package/dist/src/client.d.ts +534 -10
- package/dist/src/client.js +355 -19
- package/dist/src/ethers/index.d.ts +34 -9
- package/dist/src/ethers/index.js +63 -19
- package/dist/src/index.d.ts +51 -70
- package/dist/src/index.js +83 -237
- package/dist/src/key.d.ts +35 -64
- package/dist/src/key.js +32 -96
- package/dist/src/mfa.d.ts +85 -14
- package/dist/src/mfa.js +146 -40
- package/dist/src/org.d.ts +42 -194
- package/dist/src/org.js +52 -336
- package/dist/src/paginator.js +1 -1
- package/dist/src/response.d.ts +101 -0
- package/dist/src/response.js +164 -0
- package/dist/src/role.d.ts +87 -83
- package/dist/src/role.js +79 -136
- package/dist/src/schema.d.ts +936 -28
- package/dist/src/schema.js +1 -1
- package/dist/src/schema_types.d.ts +109 -0
- package/dist/src/schema_types.js +3 -0
- package/dist/src/session/cognito_manager.d.ts +15 -3
- package/dist/src/session/cognito_manager.js +23 -5
- package/dist/src/session/session_manager.d.ts +1 -1
- package/dist/src/session/session_manager.js +3 -11
- package/dist/src/session/session_storage.js +1 -1
- package/dist/src/session/signer_session_manager.d.ts +10 -29
- package/dist/src/session/signer_session_manager.js +21 -80
- package/dist/src/signer_session.d.ts +15 -252
- package/dist/src/signer_session.js +25 -424
- package/dist/src/user_export.d.ts +52 -0
- package/dist/src/user_export.js +129 -0
- package/dist/src/util.d.ts +15 -0
- package/dist/src/util.js +33 -11
- package/package.json +13 -11
- package/src/api.ts +1395 -0
- package/src/client.ts +413 -12
- package/src/ethers/index.ts +74 -28
- package/src/index.ts +96 -273
- package/src/key.ts +36 -131
- package/src/{fido.ts → mfa.ts} +62 -38
- package/src/org.ts +54 -405
- package/src/response.ts +196 -0
- package/src/role.ts +113 -184
- package/src/schema.ts +936 -28
- package/src/schema_types.ts +110 -0
- package/src/session/cognito_manager.ts +33 -6
- package/src/session/session_manager.ts +2 -8
- package/src/session/signer_session_manager.ts +29 -110
- package/src/signer_session.ts +22 -597
- package/src/user_export.ts +116 -0
- package/src/util.ts +29 -10
|
@@ -10,426 +10,43 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
10
10
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
11
11
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
12
12
|
};
|
|
13
|
-
var
|
|
14
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
|
-
};
|
|
16
|
-
var _SignResponse_signFn, _SignResponse_resp, _SignResponse_mfaRequired, _SignerSessionInfo_cs, _SignerSessionInfo_orgId, _SignerSessionInfo_roleId, _SignerSessionInfo_sessionId, _SignerSession_orgId;
|
|
13
|
+
var _SignerSessionInfo_csc, _SignerSessionInfo_sessionId;
|
|
17
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
exports.SignerSession = exports.SignerSessionInfo =
|
|
19
|
-
const
|
|
20
|
-
const
|
|
21
|
-
const util_1 = require("./util");
|
|
15
|
+
exports.SignerSession = exports.SignerSessionInfo = void 0;
|
|
16
|
+
const client_1 = require("./client");
|
|
17
|
+
const key_1 = require("./key");
|
|
22
18
|
const signer_session_manager_1 = require("./session/signer_session_manager");
|
|
23
|
-
/**
|
|
24
|
-
* A response of a CubeSigner request.
|
|
25
|
-
*/
|
|
26
|
-
class SignResponse {
|
|
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 */
|
|
32
|
-
requiresMfa() {
|
|
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;
|
|
41
|
-
}
|
|
42
|
-
/** @return {U} The signed data */
|
|
43
|
-
data() {
|
|
44
|
-
return __classPrivateFieldGet(this, _SignResponse_resp, "f");
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Approves the MFA request using a given session and a TOTP code.
|
|
48
|
-
*
|
|
49
|
-
* @param {SignerSession} session Signer session to use
|
|
50
|
-
* @param {string} code 6-digit TOTP code
|
|
51
|
-
* @return {SignResponse<U>} The result of signing with the approval
|
|
52
|
-
*/
|
|
53
|
-
async approveTotp(session, code) {
|
|
54
|
-
(0, assert_1.default)(this.requiresMfa());
|
|
55
|
-
const mfaId = this.mfaId();
|
|
56
|
-
const mfaOrgId = __classPrivateFieldGet(this, _SignResponse_mfaRequired, "f").org_id;
|
|
57
|
-
const mfaApproval = await session.totpApprove(mfaId, code);
|
|
58
|
-
(0, assert_1.default)(mfaApproval.id === mfaId);
|
|
59
|
-
const mfaConf = mfaApproval.receipt?.confirmation;
|
|
60
|
-
if (!mfaConf) {
|
|
61
|
-
return this;
|
|
62
|
-
}
|
|
63
|
-
return await this.signWithMfaApproval({ mfaId, mfaOrgId, mfaConf });
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* Approves the MFA request using a given `CubeSigner` instance (i.e., its management session).
|
|
67
|
-
*
|
|
68
|
-
* @param {CubeSigner} cs CubeSigner whose session to use
|
|
69
|
-
* @return {SignResponse<U>} The result of signing with the approval
|
|
70
|
-
*/
|
|
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);
|
|
76
|
-
(0, assert_1.default)(mfaApproval.id === mfaId);
|
|
77
|
-
const mfaConf = mfaApproval.receipt?.confirmation;
|
|
78
|
-
if (!mfaConf) {
|
|
79
|
-
return this;
|
|
80
|
-
}
|
|
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));
|
|
90
|
-
}
|
|
91
|
-
// --------------------------------------------------------------------------
|
|
92
|
-
// -- INTERNAL --------------------------------------------------------------
|
|
93
|
-
// --------------------------------------------------------------------------
|
|
94
|
-
/**
|
|
95
|
-
* Constructor.
|
|
96
|
-
*
|
|
97
|
-
* @param {SignFn} signFn The signing function that this response is from.
|
|
98
|
-
* This argument is used to resend requests with
|
|
99
|
-
* different headers if needed.
|
|
100
|
-
* @param {U | AcceptedResponse} resp The response as returned by the OpenAPI
|
|
101
|
-
* client.
|
|
102
|
-
*/
|
|
103
|
-
constructor(signFn, resp) {
|
|
104
|
-
_SignResponse_signFn.set(this, void 0);
|
|
105
|
-
_SignResponse_resp.set(this, void 0);
|
|
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);
|
|
111
|
-
__classPrivateFieldSet(this, _SignResponse_signFn, signFn, "f");
|
|
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;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
exports.SignResponse = SignResponse;
|
|
144
|
-
_SignResponse_signFn = new WeakMap(), _SignResponse_resp = new WeakMap(), _SignResponse_mfaRequired = new WeakMap();
|
|
145
19
|
/** Signer session info. Can only be used to revoke a token, but not for authentication. */
|
|
146
20
|
class SignerSessionInfo {
|
|
147
|
-
/** Revoke this
|
|
21
|
+
/** Revoke this session */
|
|
148
22
|
async revoke() {
|
|
149
|
-
await
|
|
23
|
+
await __classPrivateFieldGet(this, _SignerSessionInfo_csc, "f").sessionRevoke(__classPrivateFieldGet(this, _SignerSessionInfo_sessionId, "f"));
|
|
150
24
|
}
|
|
151
25
|
// --------------------------------------------------------------------------
|
|
152
26
|
// -- INTERNAL --------------------------------------------------------------
|
|
153
27
|
// --------------------------------------------------------------------------
|
|
154
28
|
/**
|
|
155
29
|
* Internal constructor.
|
|
156
|
-
* @param {
|
|
157
|
-
* @param {string}
|
|
158
|
-
* @param {string} roleId Role ID
|
|
159
|
-
* @param {string} hash The hash of the token; can be used for revocation but not for auth
|
|
30
|
+
* @param {CubeSignerClient} cs CubeSigner instance to use when calling `revoke`
|
|
31
|
+
* @param {string} sessionId The ID of the session; can be used for revocation but not for auth
|
|
160
32
|
* @param {string} purpose Session purpose
|
|
161
33
|
* @internal
|
|
162
34
|
*/
|
|
163
|
-
constructor(cs,
|
|
164
|
-
|
|
165
|
-
_SignerSessionInfo_orgId.set(this, void 0);
|
|
166
|
-
_SignerSessionInfo_roleId.set(this, void 0);
|
|
35
|
+
constructor(cs, sessionId, purpose) {
|
|
36
|
+
_SignerSessionInfo_csc.set(this, void 0);
|
|
167
37
|
_SignerSessionInfo_sessionId.set(this, void 0);
|
|
168
|
-
__classPrivateFieldSet(this,
|
|
169
|
-
__classPrivateFieldSet(this,
|
|
170
|
-
__classPrivateFieldSet(this, _SignerSessionInfo_roleId, roleId, "f");
|
|
171
|
-
__classPrivateFieldSet(this, _SignerSessionInfo_sessionId, hash, "f");
|
|
38
|
+
__classPrivateFieldSet(this, _SignerSessionInfo_csc, cs, "f");
|
|
39
|
+
__classPrivateFieldSet(this, _SignerSessionInfo_sessionId, sessionId, "f");
|
|
172
40
|
this.purpose = purpose;
|
|
173
41
|
}
|
|
174
42
|
}
|
|
175
43
|
exports.SignerSessionInfo = SignerSessionInfo;
|
|
176
|
-
|
|
177
|
-
/**
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
}
|
|
183
|
-
/**
|
|
184
|
-
* Returns the list of keys that this token grants access to.
|
|
185
|
-
* @return {Key[]} The list of keys.
|
|
186
|
-
*/
|
|
187
|
-
async keys() {
|
|
188
|
-
const resp = await (await this.sessionMgr.client()).get("/v0/org/{org_id}/token/keys", {
|
|
189
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f") } },
|
|
190
|
-
parseAs: "json",
|
|
191
|
-
});
|
|
192
|
-
const data = (0, util_1.assertOk)(resp);
|
|
193
|
-
return data.keys.map((k) => (0, _1.toKeyInfo)(k));
|
|
194
|
-
}
|
|
195
|
-
/**
|
|
196
|
-
* Approve a pending MFA request using TOTP.
|
|
197
|
-
*
|
|
198
|
-
* @param {string} mfaId The MFA request to approve
|
|
199
|
-
* @param {string} code The TOTP code
|
|
200
|
-
* @return {Promise<MfaRequestInfo>} The current status of the MFA request
|
|
201
|
-
*/
|
|
202
|
-
async totpApprove(mfaId, code) {
|
|
203
|
-
const resp = await (await this.sessionMgr.client()).patch("/v0/org/{org_id}/mfa/{mfa_id}/totp", {
|
|
204
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), mfa_id: mfaId } },
|
|
205
|
-
body: { code },
|
|
206
|
-
parseAs: "json",
|
|
207
|
-
});
|
|
208
|
-
return (0, util_1.assertOk)(resp);
|
|
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
|
-
}
|
|
255
|
-
/**
|
|
256
|
-
* Submit an EVM sign request.
|
|
257
|
-
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
258
|
-
* @param {EvmSignRequest} req What to sign.
|
|
259
|
-
* @param {MfaReceipt} mfaReceipt Optional MFA receipt.
|
|
260
|
-
* @return {Promise<EvmSignResponse | AcceptedResponse>} Signature
|
|
261
|
-
*/
|
|
262
|
-
async signEvm(key, req, mfaReceipt) {
|
|
263
|
-
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
264
|
-
const sign = async (headers) => {
|
|
265
|
-
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth1/sign/{pubkey}", {
|
|
266
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
|
|
267
|
-
body: req,
|
|
268
|
-
headers,
|
|
269
|
-
parseAs: "json",
|
|
270
|
-
});
|
|
271
|
-
return (0, util_1.assertOk)(resp);
|
|
272
|
-
};
|
|
273
|
-
return await SignResponse.create(sign, mfaReceipt);
|
|
274
|
-
}
|
|
275
|
-
/**
|
|
276
|
-
* Submit an 'eth2' sign request.
|
|
277
|
-
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
278
|
-
* @param {Eth2SignRequest} req What to sign.
|
|
279
|
-
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
280
|
-
* @return {Promise<Eth2SignResponse | AcceptedResponse>} Signature
|
|
281
|
-
*/
|
|
282
|
-
async signEth2(key, req, mfaReceipt) {
|
|
283
|
-
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
284
|
-
const sign = async (headers) => {
|
|
285
|
-
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/sign/{pubkey}", {
|
|
286
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
|
|
287
|
-
body: req,
|
|
288
|
-
headers,
|
|
289
|
-
parseAs: "json",
|
|
290
|
-
});
|
|
291
|
-
return (0, util_1.assertOk)(resp);
|
|
292
|
-
};
|
|
293
|
-
return await SignResponse.create(sign, mfaReceipt);
|
|
294
|
-
}
|
|
295
|
-
/**
|
|
296
|
-
* Sign a stake request.
|
|
297
|
-
* @param {Eth2StakeRequest} req The request to sign.
|
|
298
|
-
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
299
|
-
* @return {Promise<Eth2StakeResponse | AcceptedResponse>} The response.
|
|
300
|
-
*/
|
|
301
|
-
async stake(req, mfaReceipt) {
|
|
302
|
-
const sign = async (headers) => {
|
|
303
|
-
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/stake", {
|
|
304
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f") } },
|
|
305
|
-
body: req,
|
|
306
|
-
headers,
|
|
307
|
-
parseAs: "json",
|
|
308
|
-
});
|
|
309
|
-
return (0, util_1.assertOk)(resp);
|
|
310
|
-
};
|
|
311
|
-
return await SignResponse.create(sign, mfaReceipt);
|
|
312
|
-
}
|
|
313
|
-
/**
|
|
314
|
-
* Sign an unstake request.
|
|
315
|
-
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
316
|
-
* @param {Eth2UnstakeRequest} req The request to sign.
|
|
317
|
-
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
318
|
-
* @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} The response.
|
|
319
|
-
*/
|
|
320
|
-
async unstake(key, req, mfaReceipt) {
|
|
321
|
-
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
322
|
-
const sign = async (headers) => {
|
|
323
|
-
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/eth2/unstake/{pubkey}", {
|
|
324
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
|
|
325
|
-
body: req,
|
|
326
|
-
headers,
|
|
327
|
-
parseAs: "json",
|
|
328
|
-
});
|
|
329
|
-
return (0, util_1.assertOk)(resp);
|
|
330
|
-
};
|
|
331
|
-
return await SignResponse.create(sign, mfaReceipt);
|
|
332
|
-
}
|
|
333
|
-
/**
|
|
334
|
-
* Sign a raw blob.
|
|
335
|
-
* @param {Key | string} key The key to sign with (either {@link Key} or its ID).
|
|
336
|
-
* @param {BlobSignRequest} req What to sign
|
|
337
|
-
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
338
|
-
* @return {Promise<BlobSignResponse | AcceptedResponse>} The response.
|
|
339
|
-
*/
|
|
340
|
-
async signBlob(key, req, mfaReceipt) {
|
|
341
|
-
const key_id = typeof key === "string" ? key : key.id;
|
|
342
|
-
const sign = async (headers) => {
|
|
343
|
-
const resp = await (await this.sessionMgr.client()).post("/v1/org/{org_id}/blob/sign/{key_id}", {
|
|
344
|
-
params: {
|
|
345
|
-
path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), key_id },
|
|
346
|
-
},
|
|
347
|
-
body: req,
|
|
348
|
-
headers,
|
|
349
|
-
parseAs: "json",
|
|
350
|
-
});
|
|
351
|
-
return (0, util_1.assertOk)(resp);
|
|
352
|
-
};
|
|
353
|
-
return await SignResponse.create(sign, mfaReceipt);
|
|
354
|
-
}
|
|
355
|
-
/**
|
|
356
|
-
* Sign a bitcoin message.
|
|
357
|
-
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
358
|
-
* @param {BtcSignRequest} req What to sign
|
|
359
|
-
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
360
|
-
* @return {Promise<BtcSignResponse | AcceptedResponse>} The response.
|
|
361
|
-
*/
|
|
362
|
-
async signBtc(key, req, mfaReceipt) {
|
|
363
|
-
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
364
|
-
const sign = async (headers) => {
|
|
365
|
-
const resp = await (await this.sessionMgr.client()).post("/v0/org/{org_id}/btc/sign/{pubkey}", {
|
|
366
|
-
params: {
|
|
367
|
-
path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey },
|
|
368
|
-
},
|
|
369
|
-
body: req,
|
|
370
|
-
headers: headers,
|
|
371
|
-
parseAs: "json",
|
|
372
|
-
});
|
|
373
|
-
return (0, util_1.assertOk)(resp);
|
|
374
|
-
};
|
|
375
|
-
return await SignResponse.create(sign, mfaReceipt);
|
|
376
|
-
}
|
|
377
|
-
/**
|
|
378
|
-
* Sign a solana message.
|
|
379
|
-
* @param {Key | string} key The key to sign with (either {@link Key} or its material ID).
|
|
380
|
-
* @param {SolanaSignRequest} req What to sign
|
|
381
|
-
* @param {MfaReceipt} mfaReceipt Optional MFA receipt
|
|
382
|
-
* @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.
|
|
383
|
-
*/
|
|
384
|
-
async signSolana(key, req, mfaReceipt) {
|
|
385
|
-
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
386
|
-
const sign = async (headers) => {
|
|
387
|
-
const resp = await (await this.sessionMgr.client()).post("/v0/org/{org_id}/solana/sign/{pubkey}", {
|
|
388
|
-
params: { path: { org_id: __classPrivateFieldGet(this, _SignerSession_orgId, "f"), pubkey } },
|
|
389
|
-
body: req,
|
|
390
|
-
headers,
|
|
391
|
-
parseAs: "json",
|
|
392
|
-
});
|
|
393
|
-
return (0, util_1.assertOk)(resp);
|
|
394
|
-
};
|
|
395
|
-
return await SignResponse.create(sign, mfaReceipt);
|
|
396
|
-
}
|
|
397
|
-
/**
|
|
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
|
|
424
|
-
*/
|
|
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);
|
|
432
|
-
}
|
|
44
|
+
_SignerSessionInfo_csc = new WeakMap(), _SignerSessionInfo_sessionId = new WeakMap();
|
|
45
|
+
/**
|
|
46
|
+
* Signer session.
|
|
47
|
+
* Extends {@link CubeSignerClient} and provides a few convenience methods on top.
|
|
48
|
+
*/
|
|
49
|
+
class SignerSession extends client_1.CubeSignerClient {
|
|
433
50
|
/**
|
|
434
51
|
* Loads an existing signer session from storage.
|
|
435
52
|
* @param {SignerSessionStorage} storage The session storage to use
|
|
@@ -445,32 +62,16 @@ class SignerSession {
|
|
|
445
62
|
* @internal
|
|
446
63
|
*/
|
|
447
64
|
constructor(sessionMgr) {
|
|
448
|
-
|
|
449
|
-
this.sessionMgr = sessionMgr;
|
|
450
|
-
__classPrivateFieldSet(this, _SignerSession_orgId, sessionMgr.orgId, "f");
|
|
65
|
+
super(sessionMgr);
|
|
451
66
|
}
|
|
452
|
-
// --------------------------------------------------------------------------
|
|
453
|
-
// -- INTERNAL --------------------------------------------------------------
|
|
454
|
-
// --------------------------------------------------------------------------
|
|
455
|
-
/* eslint-disable require-jsdoc */
|
|
456
67
|
/**
|
|
457
|
-
*
|
|
458
|
-
* @
|
|
459
|
-
* @param {string} orgId Organization ID
|
|
460
|
-
* @param {string} roleId Role ID
|
|
461
|
-
* @param {string} sessionId Signer session ID
|
|
462
|
-
* @internal
|
|
68
|
+
* Returns the list of keys that this token grants access to.
|
|
69
|
+
* @return {KeyInfo[]} The list of keys.
|
|
463
70
|
*/
|
|
464
|
-
|
|
465
|
-
const
|
|
466
|
-
|
|
467
|
-
path: { org_id: orgId, role_id: roleId, session_id: sessionId },
|
|
468
|
-
},
|
|
469
|
-
parseAs: "json",
|
|
470
|
-
});
|
|
471
|
-
(0, util_1.assertOk)(resp);
|
|
71
|
+
async keys() {
|
|
72
|
+
const keys = await this.sessionKeysList();
|
|
73
|
+
return keys.map((k) => (0, key_1.toKeyInfo)(k));
|
|
472
74
|
}
|
|
473
75
|
}
|
|
474
76
|
exports.SignerSession = SignerSession;
|
|
475
|
-
|
|
476
|
-
//# 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 {\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"]}
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmVyX3Nlc3Npb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2lnbmVyX3Nlc3Npb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscUNBQTRDO0FBQzVDLCtCQUEyQztBQUMzQyw2RUFBOEY7QUFFOUYsMkZBQTJGO0FBQzNGLE1BQWEsaUJBQWlCO0lBSzVCLDBCQUEwQjtJQUMxQixLQUFLLENBQUMsTUFBTTtRQUNWLE1BQU0sdUJBQUEsSUFBSSw4QkFBSyxDQUFDLGFBQWEsQ0FBQyx1QkFBQSxJQUFJLG9DQUFXLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQsNkVBQTZFO0lBQzdFLDZFQUE2RTtJQUM3RSw2RUFBNkU7SUFFN0U7Ozs7OztPQU1HO0lBQ0gsWUFBWSxFQUFvQixFQUFFLFNBQWlCLEVBQUUsT0FBZTtRQXBCM0QseUNBQXVCO1FBQ3ZCLCtDQUFtQjtRQW9CMUIsdUJBQUEsSUFBSSwwQkFBUSxFQUFFLE1BQUEsQ0FBQztRQUNmLHVCQUFBLElBQUksZ0NBQWMsU0FBUyxNQUFBLENBQUM7UUFDNUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDekIsQ0FBQztDQUNGO0FBMUJELDhDQTBCQzs7QUFFRDs7O0dBR0c7QUFDSCxNQUFhLGFBQWMsU0FBUSx5QkFBZ0I7SUFDakQ7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyxLQUFLLENBQUMsaUJBQWlCLENBQUMsT0FBNkI7UUFDMUQsTUFBTSxPQUFPLEdBQUcsTUFBTSw2Q0FBb0IsQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDcEUsT0FBTyxJQUFJLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILFlBQVksVUFBZ0M7UUFDMUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3BCLENBQUM7SUFFRDs7O09BR0c7SUFDSCxLQUFLLENBQUMsSUFBSTtRQUNSLE1BQU0sSUFBSSxHQUFHLE1BQU0sSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQzFDLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBQSxlQUFTLEVBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2QyxDQUFDO0NBQ0Y7QUE1QkQsc0NBNEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ3ViZVNpZ25lckNsaWVudCB9IGZyb20gXCIuL2NsaWVudFwiO1xuaW1wb3J0IHsgS2V5SW5mbywgdG9LZXlJbmZvIH0gZnJvbSBcIi4va2V5XCI7XG5pbXBvcnQgeyBTaWduZXJTZXNzaW9uTWFuYWdlciwgU2lnbmVyU2Vzc2lvblN0b3JhZ2UgfSBmcm9tIFwiLi9zZXNzaW9uL3NpZ25lcl9zZXNzaW9uX21hbmFnZXJcIjtcblxuLyoqIFNpZ25lciBzZXNzaW9uIGluZm8uIENhbiBvbmx5IGJlIHVzZWQgdG8gcmV2b2tlIGEgdG9rZW4sIGJ1dCBub3QgZm9yIGF1dGhlbnRpY2F0aW9uLiAqL1xuZXhwb3J0IGNsYXNzIFNpZ25lclNlc3Npb25JbmZvIHtcbiAgcmVhZG9ubHkgI2NzYzogQ3ViZVNpZ25lckNsaWVudDtcbiAgcmVhZG9ubHkgI3Nlc3Npb25JZDogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgcHVycG9zZTogc3RyaW5nO1xuXG4gIC8qKiBSZXZva2UgdGhpcyBzZXNzaW9uICovXG4gIGFzeW5jIHJldm9rZSgpIHtcbiAgICBhd2FpdCB0aGlzLiNjc2Muc2Vzc2lvblJldm9rZSh0aGlzLiNzZXNzaW9uSWQpO1xuICB9XG5cbiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbiAgLy8gLS0gSU5URVJOQUwgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cblxuICAvKipcbiAgICogSW50ZXJuYWwgY29uc3RydWN0b3IuXG4gICAqIEBwYXJhbSB7Q3ViZVNpZ25lckNsaWVudH0gY3MgQ3ViZVNpZ25lciBpbnN0YW5jZSB0byB1c2Ugd2hlbiBjYWxsaW5nIGByZXZva2VgXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBzZXNzaW9uSWQgVGhlIElEIG9mIHRoZSBzZXNzaW9uOyBjYW4gYmUgdXNlZCBmb3IgcmV2b2NhdGlvbiBidXQgbm90IGZvciBhdXRoXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBwdXJwb3NlIFNlc3Npb24gcHVycG9zZVxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIGNvbnN0cnVjdG9yKGNzOiBDdWJlU2lnbmVyQ2xpZW50LCBzZXNzaW9uSWQ6IHN0cmluZywgcHVycG9zZTogc3RyaW5nKSB7XG4gICAgdGhpcy4jY3NjID0gY3M7XG4gICAgdGhpcy4jc2Vzc2lvbklkID0gc2Vzc2lvbklkO1xuICAgIHRoaXMucHVycG9zZSA9IHB1cnBvc2U7XG4gIH1cbn1cblxuLyoqXG4gKiBTaWduZXIgc2Vzc2lvbi5cbiAqIEV4dGVuZHMge0BsaW5rIEN1YmVTaWduZXJDbGllbnR9IGFuZCBwcm92aWRlcyBhIGZldyBjb252ZW5pZW5jZSBtZXRob2RzIG9uIHRvcC5cbiAqL1xuZXhwb3J0IGNsYXNzIFNpZ25lclNlc3Npb24gZXh0ZW5kcyBDdWJlU2lnbmVyQ2xpZW50IHtcbiAgLyoqXG4gICAqIExvYWRzIGFuIGV4aXN0aW5nIHNpZ25lciBzZXNzaW9uIGZyb20gc3RvcmFnZS5cbiAgICogQHBhcmFtIHtTaWduZXJTZXNzaW9uU3RvcmFnZX0gc3RvcmFnZSBUaGUgc2Vzc2lvbiBzdG9yYWdlIHRvIHVzZVxuICAgKiBAcmV0dXJuIHtQcm9taXNlPFNpbmdlclNlc3Npb24+fSBOZXcgc2lnbmVyIHNlc3Npb25cbiAgICovXG4gIHN0YXRpYyBhc3luYyBsb2FkU2lnbmVyU2Vzc2lvbihzdG9yYWdlOiBTaWduZXJTZXNzaW9uU3RvcmFnZSk6IFByb21pc2U8U2lnbmVyU2Vzc2lvbj4ge1xuICAgIGNvbnN0IG1hbmFnZXIgPSBhd2FpdCBTaWduZXJTZXNzaW9uTWFuYWdlci5sb2FkRnJvbVN0b3JhZ2Uoc3RvcmFnZSk7XG4gICAgcmV0dXJuIG5ldyBTaWduZXJTZXNzaW9uKG1hbmFnZXIpO1xuICB9XG5cbiAgLyoqXG4gICAqIENvbnN0cnVjdG9yLlxuICAgKiBAcGFyYW0ge1NpZ25lclNlc3Npb25NYW5hZ2VyfSBzZXNzaW9uTWdyIFRoZSBzZXNzaW9uIG1hbmFnZXIgdG8gdXNlXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgY29uc3RydWN0b3Ioc2Vzc2lvbk1ncjogU2lnbmVyU2Vzc2lvbk1hbmFnZXIpIHtcbiAgICBzdXBlcihzZXNzaW9uTWdyKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBsaXN0IG9mIGtleXMgdGhhdCB0aGlzIHRva2VuIGdyYW50cyBhY2Nlc3MgdG8uXG4gICAqIEByZXR1cm4ge0tleUluZm9bXX0gVGhlIGxpc3Qgb2Yga2V5cy5cbiAgICovXG4gIGFzeW5jIGtleXMoKTogUHJvbWlzZTxLZXlJbmZvW10+IHtcbiAgICBjb25zdCBrZXlzID0gYXdhaXQgdGhpcy5zZXNzaW9uS2V5c0xpc3QoKTtcbiAgICByZXR1cm4ga2V5cy5tYXAoKGspID0+IHRvS2V5SW5mbyhrKSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { UserExportCompleteResponse, UserExportKeyMaterial } from "./schema_types";
|
|
2
|
+
import type { CipherSuite } from "@hpke/core";
|
|
3
|
+
/** Get the HPKE ciphersuite for user-export decryption.
|
|
4
|
+
*
|
|
5
|
+
* @return {any} The HPKE ciphersuite for user export.
|
|
6
|
+
*/
|
|
7
|
+
export declare function userExportCipherSuite(): Promise<CipherSuite>;
|
|
8
|
+
/**
|
|
9
|
+
* Generate a key pair for user export.
|
|
10
|
+
*
|
|
11
|
+
* @return {Promise<CryptoKeyPair>} The newly generated key pair.
|
|
12
|
+
*/
|
|
13
|
+
export declare function userExportKeygen(): Promise<CryptoKeyPair>;
|
|
14
|
+
/**
|
|
15
|
+
* Decrypt a user export.
|
|
16
|
+
*
|
|
17
|
+
* @param {CryptoKey} recipientKey The NIST P-256 secret key corresponding to the `publicKey` argument to the `userExportComplete` invocation that returned `response`.
|
|
18
|
+
* @param {UserExportCompleteResponse} response The response from a successful `userExportComplete` request.
|
|
19
|
+
* @return {Promise<UserExportKeyMaterial>} The decrypted key material.
|
|
20
|
+
*/
|
|
21
|
+
export declare function userExportDecrypt(recipientKey: CryptoKey, response: UserExportCompleteResponse): Promise<UserExportKeyMaterial>;
|
|
22
|
+
/**
|
|
23
|
+
* Figure out how to load SubtleCrypto in the current environment.
|
|
24
|
+
*
|
|
25
|
+
* This functionality is reproduced from the hpke-js package,
|
|
26
|
+
* https://github.com/dajiaji/hpke-js/
|
|
27
|
+
* which is Copyright (C) 2022 Ajitomi Daisuke and licensed
|
|
28
|
+
* under the MIT License, which follows:
|
|
29
|
+
*
|
|
30
|
+
* MIT License
|
|
31
|
+
*
|
|
32
|
+
* Copyright (c) 2022 Ajitomi Daisuke
|
|
33
|
+
*
|
|
34
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
35
|
+
* of this software and associated documentation files (the "Software"), to deal
|
|
36
|
+
* in the Software without restriction, including without limitation the rights
|
|
37
|
+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
38
|
+
* copies of the Software, and to permit persons to whom the Software is
|
|
39
|
+
* furnished to do so, subject to the following conditions:
|
|
40
|
+
*
|
|
41
|
+
* The above copyright notice and this permission notice shall be included in all
|
|
42
|
+
* copies or substantial portions of the Software.
|
|
43
|
+
*
|
|
44
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
45
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
46
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
47
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
48
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
49
|
+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
50
|
+
* SOFTWARE.
|
|
51
|
+
*/
|
|
52
|
+
export declare function loadSubtleCrypto(): Promise<SubtleCrypto>;
|