@cubist-labs/cubesigner-sdk 0.2.17 → 0.2.21
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 +6 -6
- package/dist/src/api.d.ts +145 -15
- package/dist/src/api.js +340 -252
- package/dist/src/client.d.ts +28 -8
- package/dist/src/client.js +33 -13
- package/dist/src/events.d.ts +84 -0
- package/dist/src/events.js +195 -0
- package/dist/src/index.d.ts +2 -0
- package/dist/src/index.js +10 -6
- package/dist/src/mfa.js +3 -3
- package/dist/src/schema.d.ts +81 -0
- package/dist/src/schema.js +1 -1
- package/dist/src/schema_types.d.ts +1 -0
- package/dist/src/schema_types.js +1 -1
- package/dist/src/session/cognito_manager.js +2 -2
- package/dist/src/session/session_manager.d.ts +6 -4
- package/dist/src/session/session_manager.js +11 -5
- package/dist/src/session/signer_session_manager.d.ts +8 -2
- package/dist/src/session/signer_session_manager.js +43 -16
- package/dist/src/util.d.ts +0 -30
- package/dist/src/util.js +2 -38
- package/package.json +6 -6
- package/src/api.ts +424 -250
- package/src/client.ts +34 -12
- package/src/events.ts +197 -0
- package/src/index.ts +6 -4
- package/src/mfa.ts +2 -2
- package/src/schema.ts +81 -0
- package/src/schema_types.ts +2 -0
- package/src/session/cognito_manager.ts +2 -2
- package/src/session/session_manager.ts +11 -5
- package/src/session/signer_session_manager.ts +51 -18
- package/src/util.ts +0 -45
package/dist/src/api.js
CHANGED
|
@@ -1,21 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
3
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
4
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
5
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
6
|
-
};
|
|
7
2
|
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
8
3
|
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
9
4
|
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
10
5
|
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
6
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
12
7
|
};
|
|
8
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
9
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
10
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
11
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
12
|
+
};
|
|
13
13
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
14
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
15
|
};
|
|
16
|
-
var _CubeSignerApi_orgId, _CubeSignerApi_sessionMgr, _OidcClient_env, _OidcClient_orgId, _OidcClient_client;
|
|
16
|
+
var _OpClient_op, _OpClient_client, _OpClient_eventEmitter, _CubeSignerApi_orgId, _CubeSignerApi_sessionMgr, _CubeSignerApi_eventEmitter, _OidcClient_env, _OidcClient_orgId, _OidcClient_client;
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
exports.OidcClient = exports.CubeSignerApi = exports.createHttpClient = void 0;
|
|
18
|
+
exports.OidcClient = exports.CubeSignerApi = exports.createHttpClient = exports.OpClient = exports.ErrResponse = void 0;
|
|
19
19
|
const openapi_fetch_1 = __importDefault(require("openapi-fetch"));
|
|
20
20
|
const util_1 = require("./util");
|
|
21
21
|
const mfa_1 = require("./mfa");
|
|
@@ -23,6 +23,99 @@ const response_1 = require("./response");
|
|
|
23
23
|
const paginator_1 = require("./paginator");
|
|
24
24
|
const _1 = require(".");
|
|
25
25
|
const user_export_1 = require("./user_export");
|
|
26
|
+
const events_1 = require("./events");
|
|
27
|
+
/**
|
|
28
|
+
* Error response type, thrown on non-successful responses.
|
|
29
|
+
*/
|
|
30
|
+
class ErrResponse extends Error {
|
|
31
|
+
/**
|
|
32
|
+
* @param {Partial<ErrResponse>} init Initializer
|
|
33
|
+
*/
|
|
34
|
+
constructor(init) {
|
|
35
|
+
super(init.message);
|
|
36
|
+
Object.assign(this, init);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
exports.ErrResponse = ErrResponse;
|
|
40
|
+
/**
|
|
41
|
+
* Wrapper around an open-fetch client restricted to a single operation.
|
|
42
|
+
* The restriction applies only when type checking, the actual
|
|
43
|
+
* client does not restrict anything at runtime.
|
|
44
|
+
* client does not restrict anything at runtime
|
|
45
|
+
*/
|
|
46
|
+
class OpClient {
|
|
47
|
+
/**
|
|
48
|
+
* @param {Op} op The operation this client should be restricted to
|
|
49
|
+
* @param {FetchClient<Op> | Client} client open-fetch client (either restricted to {@link Op} or not)
|
|
50
|
+
* @param {EventEmitter} eventEmitter The client-local event dispatcher.
|
|
51
|
+
*/
|
|
52
|
+
constructor(op, client, eventEmitter) {
|
|
53
|
+
_OpClient_op.set(this, void 0);
|
|
54
|
+
_OpClient_client.set(this, void 0);
|
|
55
|
+
_OpClient_eventEmitter.set(this, void 0);
|
|
56
|
+
__classPrivateFieldSet(this, _OpClient_op, op, "f");
|
|
57
|
+
__classPrivateFieldSet(this, _OpClient_client, client, "f"); // either works
|
|
58
|
+
__classPrivateFieldSet(this, _OpClient_eventEmitter, eventEmitter, "f");
|
|
59
|
+
}
|
|
60
|
+
/** The operation this client is restricted to */
|
|
61
|
+
get op() {
|
|
62
|
+
return __classPrivateFieldGet(this, _OpClient_op, "f");
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Inspects the response and returns the response body if the request was successful.
|
|
66
|
+
* Otherwise, dispatches the error to event listeners, then throws {@link ErrResponse}.
|
|
67
|
+
*
|
|
68
|
+
* @param {FetchResponse<T>} resp The response to check
|
|
69
|
+
* @return {FetchResponseSuccessData<T>} The response data corresponding to response type {@link T}.
|
|
70
|
+
*/
|
|
71
|
+
async assertOk(resp) {
|
|
72
|
+
if (resp.error) {
|
|
73
|
+
const error = new ErrResponse({
|
|
74
|
+
operation: this.op,
|
|
75
|
+
message: resp.error.message, // eslint-disable-line @typescript-eslint/no-explicit-any
|
|
76
|
+
statusText: resp.response?.statusText,
|
|
77
|
+
status: resp.response?.status,
|
|
78
|
+
url: resp.response?.url,
|
|
79
|
+
});
|
|
80
|
+
__classPrivateFieldGet(this, _OpClient_eventEmitter, "f").classifyAndEmitError(error);
|
|
81
|
+
throw error;
|
|
82
|
+
}
|
|
83
|
+
if (resp.data === undefined) {
|
|
84
|
+
throw new Error("Response data is undefined");
|
|
85
|
+
}
|
|
86
|
+
return resp.data;
|
|
87
|
+
}
|
|
88
|
+
/* eslint-disable valid-jsdoc */
|
|
89
|
+
/**
|
|
90
|
+
* Invoke HTTP GET
|
|
91
|
+
*/
|
|
92
|
+
async get(url, init) {
|
|
93
|
+
const resp = await __classPrivateFieldGet(this, _OpClient_client, "f").get(url, init);
|
|
94
|
+
return await this.assertOk(resp);
|
|
95
|
+
}
|
|
96
|
+
/** Invoke HTTP POST */
|
|
97
|
+
async post(url, init) {
|
|
98
|
+
const resp = await __classPrivateFieldGet(this, _OpClient_client, "f").post(url, init);
|
|
99
|
+
return await this.assertOk(resp);
|
|
100
|
+
}
|
|
101
|
+
/** Invoke HTTP PATCH */
|
|
102
|
+
async patch(url, init) {
|
|
103
|
+
const resp = await __classPrivateFieldGet(this, _OpClient_client, "f").patch(url, init);
|
|
104
|
+
return await this.assertOk(resp);
|
|
105
|
+
}
|
|
106
|
+
/** Invoke HTTP DELETE */
|
|
107
|
+
async del(url, init) {
|
|
108
|
+
const resp = await __classPrivateFieldGet(this, _OpClient_client, "f").del(url, init);
|
|
109
|
+
return await this.assertOk(resp);
|
|
110
|
+
}
|
|
111
|
+
/** Invoke HTTP PUT */
|
|
112
|
+
async put(url, init) {
|
|
113
|
+
const resp = await __classPrivateFieldGet(this, _OpClient_client, "f").put(url, init);
|
|
114
|
+
return await this.assertOk(resp);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
exports.OpClient = OpClient;
|
|
118
|
+
_OpClient_op = new WeakMap(), _OpClient_client = new WeakMap(), _OpClient_eventEmitter = new WeakMap();
|
|
26
119
|
/**
|
|
27
120
|
* Creates a new HTTP client, setting the "User-Agent" header to this package's {name}@{version}.
|
|
28
121
|
*
|
|
@@ -61,7 +154,9 @@ class CubeSignerApi {
|
|
|
61
154
|
constructor(sessionMgr, orgId) {
|
|
62
155
|
_CubeSignerApi_orgId.set(this, void 0);
|
|
63
156
|
_CubeSignerApi_sessionMgr.set(this, void 0);
|
|
157
|
+
_CubeSignerApi_eventEmitter.set(this, void 0);
|
|
64
158
|
__classPrivateFieldSet(this, _CubeSignerApi_sessionMgr, sessionMgr, "f");
|
|
159
|
+
__classPrivateFieldSet(this, _CubeSignerApi_eventEmitter, new events_1.EventEmitter([sessionMgr.events]), "f");
|
|
65
160
|
__classPrivateFieldSet(this, _CubeSignerApi_orgId, orgId ?? sessionMgr.orgId, "f");
|
|
66
161
|
}
|
|
67
162
|
/**
|
|
@@ -77,34 +172,47 @@ class CubeSignerApi {
|
|
|
77
172
|
get orgId() {
|
|
78
173
|
return __classPrivateFieldGet(this, _CubeSignerApi_orgId, "f");
|
|
79
174
|
}
|
|
80
|
-
|
|
175
|
+
/**
|
|
176
|
+
* HTTP client restricted to a single operation. The restriction applies only
|
|
177
|
+
* when type checking, the actual client does not restrict anything at runtime.
|
|
178
|
+
*
|
|
179
|
+
* @param {Op} op The operation to restrict the client to
|
|
180
|
+
* @return {Promise<OpClient<Op>>} The client restricted to {@link op}
|
|
181
|
+
*/
|
|
182
|
+
async client(op) {
|
|
183
|
+
const fetchClient = await __classPrivateFieldGet(this, _CubeSignerApi_sessionMgr, "f").client();
|
|
184
|
+
return new OpClient(op, fetchClient, __classPrivateFieldGet(this, _CubeSignerApi_eventEmitter, "f"));
|
|
185
|
+
}
|
|
186
|
+
// #region USERS: userGet, userTotp(ResetInit|ResetComplete|Verify|Delete), userFido(RegisterInit|RegisterComplete|Delete)
|
|
81
187
|
/**
|
|
82
188
|
* Obtain information about the current user.
|
|
83
189
|
*
|
|
84
190
|
* @return {Promise<UserInfo>} Retrieves information about the current user.
|
|
85
191
|
*/
|
|
86
192
|
async userGet() {
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
193
|
+
if (`${this.orgId}` === "undefined") {
|
|
194
|
+
const client = await this.client("aboutMeLegacy");
|
|
195
|
+
return await client.get("/v0/about_me", {});
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
const client = await this.client("aboutMe");
|
|
199
|
+
return await client.get("/v0/org/{org_id}/user/me", {
|
|
90
200
|
params: { path: { org_id: this.orgId } },
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
: await client.get("/v0/about_me", { parseAs: "json" });
|
|
94
|
-
return (0, util_1.assertOk)(resp);
|
|
201
|
+
});
|
|
202
|
+
}
|
|
95
203
|
}
|
|
96
204
|
/**
|
|
97
205
|
* Creates a request to change user's TOTP. Returns a {@link TotpChallenge}
|
|
98
206
|
* that must be answered either by calling {@link TotpChallenge.answer} (or
|
|
99
|
-
* {@link CubeSignerApi.
|
|
207
|
+
* {@link CubeSignerApi.userTotpResetComplete}).
|
|
100
208
|
*
|
|
101
209
|
* @param {string} issuer Optional issuer; defaults to "Cubist"
|
|
102
210
|
* @param {MfaReceipt} mfaReceipt MFA receipt to include in HTTP headers
|
|
103
211
|
*/
|
|
104
|
-
async
|
|
212
|
+
async userTotpResetInit(issuer, mfaReceipt) {
|
|
105
213
|
const resetTotpFn = async (headers) => {
|
|
106
|
-
const client = await this.client();
|
|
107
|
-
const
|
|
214
|
+
const client = await this.client("userResetTotpInit");
|
|
215
|
+
const data = await client.post("/v0/org/{org_id}/user/me/totp", {
|
|
108
216
|
headers,
|
|
109
217
|
params: { path: { org_id: this.orgId } },
|
|
110
218
|
body: issuer
|
|
@@ -112,15 +220,13 @@ class CubeSignerApi {
|
|
|
112
220
|
issuer,
|
|
113
221
|
}
|
|
114
222
|
: null,
|
|
115
|
-
parseAs: "json",
|
|
116
223
|
});
|
|
117
|
-
const data = (0, util_1.assertOk)(resp);
|
|
118
224
|
return (0, response_1.mapResponse)(data, (totpInfo) => new mfa_1.TotpChallenge(this, totpInfo));
|
|
119
225
|
};
|
|
120
226
|
return await response_1.CubeSignerResponse.create(resetTotpFn, mfaReceipt);
|
|
121
227
|
}
|
|
122
228
|
/**
|
|
123
|
-
* Answer the TOTP challenge issued by {@link
|
|
229
|
+
* Answer the TOTP challenge issued by {@link userTotpResetInit}. If successful, user's
|
|
124
230
|
* TOTP configuration will be updated to that of the TOTP challenge.
|
|
125
231
|
*
|
|
126
232
|
* Instead of calling this method directly, prefer {@link TotpChallenge.answer}.
|
|
@@ -128,14 +234,12 @@ class CubeSignerApi {
|
|
|
128
234
|
* @param {string} totpId - The ID of the TOTP challenge
|
|
129
235
|
* @param {string} code - The TOTP code that should verify against the TOTP configuration from the challenge.
|
|
130
236
|
*/
|
|
131
|
-
async
|
|
132
|
-
const client = await this.client();
|
|
133
|
-
|
|
134
|
-
parseAs: "json",
|
|
237
|
+
async userTotpResetComplete(totpId, code) {
|
|
238
|
+
const client = await this.client("userResetTotpComplete");
|
|
239
|
+
await client.patch("/v0/org/{org_id}/user/me/totp", {
|
|
135
240
|
params: { path: { org_id: this.orgId } },
|
|
136
241
|
body: { totp_id: totpId, code },
|
|
137
242
|
});
|
|
138
|
-
(0, util_1.assertOk)(resp);
|
|
139
243
|
}
|
|
140
244
|
/**
|
|
141
245
|
* Verifies a given TOTP code against the current user's TOTP configuration.
|
|
@@ -143,40 +247,54 @@ class CubeSignerApi {
|
|
|
143
247
|
*
|
|
144
248
|
* @param {string} code Current TOTP code
|
|
145
249
|
*/
|
|
146
|
-
async
|
|
147
|
-
const client = await this.client();
|
|
148
|
-
|
|
250
|
+
async userTotpVerify(code) {
|
|
251
|
+
const client = await this.client("userVerifyTotp");
|
|
252
|
+
await client.post("/v0/org/{org_id}/user/me/totp/verify", {
|
|
149
253
|
params: { path: { org_id: this.orgId } },
|
|
150
254
|
body: { code },
|
|
151
|
-
parseAs: "json",
|
|
152
255
|
});
|
|
153
|
-
|
|
256
|
+
}
|
|
257
|
+
/**
|
|
258
|
+
* Delete TOTP from the user's account.
|
|
259
|
+
* Allowed only if at least one FIDO key is registered with the user's account.
|
|
260
|
+
* MFA via FIDO is always required.
|
|
261
|
+
*
|
|
262
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt to include in HTTP headers
|
|
263
|
+
*/
|
|
264
|
+
async userTotpDelete(mfaReceipt) {
|
|
265
|
+
const deleteTotpFn = async (headers) => {
|
|
266
|
+
const client = await this.client("userDeleteTotp");
|
|
267
|
+
return await client.del("/v0/org/{org_id}/user/me/totp", {
|
|
268
|
+
headers,
|
|
269
|
+
params: { path: { org_id: this.orgId } },
|
|
270
|
+
body: null,
|
|
271
|
+
});
|
|
272
|
+
};
|
|
273
|
+
return await response_1.CubeSignerResponse.create(deleteTotpFn, mfaReceipt);
|
|
154
274
|
}
|
|
155
275
|
/**
|
|
156
276
|
* Initiate adding a new FIDO device. MFA may be required. This returns a {@link AddFidoChallenge}
|
|
157
|
-
* that must be answered with {@link AddFidoChallenge.answer} or {@link
|
|
277
|
+
* that must be answered with {@link AddFidoChallenge.answer} or {@link userFidoRegisterComplete}
|
|
158
278
|
* (after MFA approvals).
|
|
159
279
|
*
|
|
160
280
|
* @param {string} name The name of the new device.
|
|
161
281
|
* @param {MfaReceipt} mfaReceipt Optional MFA receipt to include in HTTP headers
|
|
162
282
|
* @return {Promise<CubeSignerResponse<AddFidoChallenge>>} A challenge that must be answered in order to complete FIDO registration.
|
|
163
283
|
*/
|
|
164
|
-
async
|
|
284
|
+
async userFidoRegisterInit(name, mfaReceipt) {
|
|
165
285
|
const addFidoFn = async (headers) => {
|
|
166
|
-
const client = await this.client();
|
|
167
|
-
const
|
|
286
|
+
const client = await this.client("userRegisterFidoInit");
|
|
287
|
+
const data = await client.post("/v0/org/{org_id}/user/me/fido", {
|
|
168
288
|
headers,
|
|
169
289
|
params: { path: { org_id: this.orgId } },
|
|
170
290
|
body: { name },
|
|
171
|
-
parseAs: "json",
|
|
172
291
|
});
|
|
173
|
-
const data = (0, util_1.assertOk)(resp);
|
|
174
292
|
return (0, response_1.mapResponse)(data, (c) => new mfa_1.AddFidoChallenge(this, c));
|
|
175
293
|
};
|
|
176
294
|
return await response_1.CubeSignerResponse.create(addFidoFn, mfaReceipt);
|
|
177
295
|
}
|
|
178
296
|
/**
|
|
179
|
-
* Complete a previously initiated (via {@link
|
|
297
|
+
* Complete a previously initiated (via {@link userFidoRegisterInit}) request to add a new FIDO device.
|
|
180
298
|
*
|
|
181
299
|
* Instead of calling this method directly, prefer {@link AddFidoChallenge.answer} or
|
|
182
300
|
* {@link AddFidoChallenge.createCredentialAndAnswer}.
|
|
@@ -184,17 +302,34 @@ class CubeSignerApi {
|
|
|
184
302
|
* @param {string} challengeId The ID of the challenge returned by the remote end.
|
|
185
303
|
* @param {PublicKeyCredential} credential The answer to the challenge.
|
|
186
304
|
*/
|
|
187
|
-
async
|
|
188
|
-
const client = await this.client();
|
|
189
|
-
|
|
305
|
+
async userFidoRegisterComplete(challengeId, credential) {
|
|
306
|
+
const client = await this.client("userRegisterFidoComplete");
|
|
307
|
+
await client.patch("/v0/org/{org_id}/user/me/fido", {
|
|
190
308
|
params: { path: { org_id: this.orgId } },
|
|
191
309
|
body: {
|
|
192
310
|
challenge_id: challengeId,
|
|
193
311
|
credential,
|
|
194
312
|
},
|
|
195
|
-
parseAs: "json",
|
|
196
313
|
});
|
|
197
|
-
|
|
314
|
+
}
|
|
315
|
+
/**
|
|
316
|
+
* Delete a FIDO key from the user's account.
|
|
317
|
+
* Allowed only if TOTP is also defined.
|
|
318
|
+
* MFA via TOTP is always required.
|
|
319
|
+
*
|
|
320
|
+
* @param {string} fidoId The ID of the desired FIDO key
|
|
321
|
+
* @param {MfaReceipt} mfaReceipt Optional MFA receipt to include in HTTP headers
|
|
322
|
+
*/
|
|
323
|
+
async userFidoDelete(fidoId, mfaReceipt) {
|
|
324
|
+
const deleteFidoFn = async (headers) => {
|
|
325
|
+
const client = await this.client("userDeleteFido");
|
|
326
|
+
return await client.del("/v0/org/{org_id}/user/me/fido/{fido_id}", {
|
|
327
|
+
headers,
|
|
328
|
+
params: { path: { org_id: this.orgId, fido_id: fidoId } },
|
|
329
|
+
body: null,
|
|
330
|
+
});
|
|
331
|
+
};
|
|
332
|
+
return await response_1.CubeSignerResponse.create(deleteFidoFn, mfaReceipt);
|
|
198
333
|
}
|
|
199
334
|
// #endregion
|
|
200
335
|
// #region ORGS: orgGet, orgUpdate
|
|
@@ -203,12 +338,10 @@ class CubeSignerApi {
|
|
|
203
338
|
* @return {OrgInfo} Information about the organization.
|
|
204
339
|
*/
|
|
205
340
|
async orgGet() {
|
|
206
|
-
const client = await this.client();
|
|
207
|
-
|
|
341
|
+
const client = await this.client("getOrg");
|
|
342
|
+
return await client.get("/v0/org/{org_id}", {
|
|
208
343
|
params: { path: { org_id: this.orgId } },
|
|
209
|
-
parseAs: "json",
|
|
210
344
|
});
|
|
211
|
-
return (0, util_1.assertOk)(resp);
|
|
212
345
|
}
|
|
213
346
|
/**
|
|
214
347
|
* Update the org.
|
|
@@ -216,13 +349,11 @@ class CubeSignerApi {
|
|
|
216
349
|
* @return {UpdateOrgResponse} Updated org information.
|
|
217
350
|
*/
|
|
218
351
|
async orgUpdate(request) {
|
|
219
|
-
const client = await this.client();
|
|
220
|
-
|
|
352
|
+
const client = await this.client("updateOrg");
|
|
353
|
+
return await client.patch("/v0/org/{org_id}", {
|
|
221
354
|
params: { path: { org_id: this.orgId } },
|
|
222
355
|
body: request,
|
|
223
|
-
parseAs: "json",
|
|
224
356
|
});
|
|
225
|
-
return (0, util_1.assertOk)(resp);
|
|
226
357
|
}
|
|
227
358
|
// #endregion
|
|
228
359
|
// #region ORG USERS: orgUserInvite, orgUsersList, orgUserCreateOidc, orgUserDeleteOidc
|
|
@@ -234,8 +365,8 @@ class CubeSignerApi {
|
|
|
234
365
|
* @param {MemberRole} role Optional role. Defaults to "alien".
|
|
235
366
|
*/
|
|
236
367
|
async orgUserInvite(email, name, role) {
|
|
237
|
-
const client = await this.client();
|
|
238
|
-
|
|
368
|
+
const client = await this.client("invite");
|
|
369
|
+
await client.post("/v0/org/{org_id}/invite", {
|
|
239
370
|
params: { path: { org_id: this.orgId } },
|
|
240
371
|
body: {
|
|
241
372
|
email,
|
|
@@ -243,22 +374,18 @@ class CubeSignerApi {
|
|
|
243
374
|
role,
|
|
244
375
|
skip_email: false,
|
|
245
376
|
},
|
|
246
|
-
parseAs: "json",
|
|
247
377
|
});
|
|
248
|
-
(0, util_1.assertOk)(resp);
|
|
249
378
|
}
|
|
250
379
|
/**
|
|
251
380
|
* List users.
|
|
252
381
|
* @return {User[]} Org users.
|
|
253
382
|
*/
|
|
254
383
|
async orgUsersList() {
|
|
255
|
-
const client = await this.client();
|
|
384
|
+
const client = await this.client("listUsersInOrg");
|
|
256
385
|
const resp = await client.get("/v0/org/{org_id}/users", {
|
|
257
386
|
params: { path: { org_id: this.orgId } },
|
|
258
|
-
parseAs: "json",
|
|
259
387
|
});
|
|
260
|
-
|
|
261
|
-
return data.users;
|
|
388
|
+
return resp.users;
|
|
262
389
|
}
|
|
263
390
|
/**
|
|
264
391
|
* Create a new OIDC user. This can be a first-party "Member" or third-party "Alien".
|
|
@@ -268,8 +395,8 @@ class CubeSignerApi {
|
|
|
268
395
|
* @return {string} User id of the new user
|
|
269
396
|
*/
|
|
270
397
|
async orgUserCreateOidc(identity, email, opts = {}) {
|
|
271
|
-
const client = await this.client();
|
|
272
|
-
const
|
|
398
|
+
const client = await this.client("createOidcUser");
|
|
399
|
+
const data = await client.post("/v0/org/{org_id}/users", {
|
|
273
400
|
params: { path: { org_id: this.orgId } },
|
|
274
401
|
body: {
|
|
275
402
|
identity,
|
|
@@ -277,22 +404,19 @@ class CubeSignerApi {
|
|
|
277
404
|
email: email,
|
|
278
405
|
mfa_policy: opts.mfaPolicy ?? null,
|
|
279
406
|
},
|
|
280
|
-
parseAs: "json",
|
|
281
407
|
});
|
|
282
|
-
return
|
|
408
|
+
return data.user_id;
|
|
283
409
|
}
|
|
284
410
|
/**
|
|
285
411
|
* Delete an existing OIDC user.
|
|
286
412
|
* @param {OidcIdentity} identity The identity of the OIDC user
|
|
287
413
|
*/
|
|
288
414
|
async orgUserDeleteOidc(identity) {
|
|
289
|
-
const client = await this.client();
|
|
290
|
-
|
|
415
|
+
const client = await this.client("deleteOidcUser");
|
|
416
|
+
return await client.del("/v0/org/{org_id}/users/oidc", {
|
|
291
417
|
params: { path: { org_id: this.orgId } },
|
|
292
418
|
body: identity,
|
|
293
|
-
parseAs: "json",
|
|
294
419
|
});
|
|
295
|
-
return (0, util_1.assertOk)(resp);
|
|
296
420
|
}
|
|
297
421
|
// #endregion
|
|
298
422
|
// #region KEYS: keyGet, keyUpdate, keyDelete, keysCreate, keysDerive, keysList
|
|
@@ -303,12 +427,10 @@ class CubeSignerApi {
|
|
|
303
427
|
* @return {KeyInfoApi} The key information.
|
|
304
428
|
*/
|
|
305
429
|
async keyGet(keyId) {
|
|
306
|
-
const client = await this.client();
|
|
307
|
-
|
|
430
|
+
const client = await this.client("getKeyInOrg");
|
|
431
|
+
return await client.get("/v0/org/{org_id}/keys/{key_id}", {
|
|
308
432
|
params: { path: { org_id: this.orgId, key_id: keyId } },
|
|
309
|
-
parseAs: "json",
|
|
310
433
|
});
|
|
311
|
-
return (0, util_1.assertOk)(resp);
|
|
312
434
|
}
|
|
313
435
|
/**
|
|
314
436
|
* Update key.
|
|
@@ -317,13 +439,11 @@ class CubeSignerApi {
|
|
|
317
439
|
* @return {KeyInfoApi} The JSON response from the API server.
|
|
318
440
|
*/
|
|
319
441
|
async keyUpdate(keyId, request) {
|
|
320
|
-
const client = await this.client();
|
|
321
|
-
|
|
442
|
+
const client = await this.client("updateKey");
|
|
443
|
+
return await client.patch("/v0/org/{org_id}/keys/{key_id}", {
|
|
322
444
|
params: { path: { org_id: this.orgId, key_id: keyId } },
|
|
323
445
|
body: request,
|
|
324
|
-
parseAs: "json",
|
|
325
446
|
});
|
|
326
|
-
return (0, util_1.assertOk)(resp);
|
|
327
447
|
}
|
|
328
448
|
/**
|
|
329
449
|
* Deletes a key.
|
|
@@ -331,12 +451,10 @@ class CubeSignerApi {
|
|
|
331
451
|
* @param {string} keyId - Key id
|
|
332
452
|
*/
|
|
333
453
|
async keyDelete(keyId) {
|
|
334
|
-
const client = await this.client();
|
|
335
|
-
|
|
454
|
+
const client = await this.client("deleteKey");
|
|
455
|
+
await client.del("/v0/org/{org_id}/keys/{key_id}", {
|
|
336
456
|
params: { path: { org_id: this.orgId, key_id: keyId } },
|
|
337
|
-
parseAs: "json",
|
|
338
457
|
});
|
|
339
|
-
(0, util_1.assertOk)(resp);
|
|
340
458
|
}
|
|
341
459
|
/**
|
|
342
460
|
* Create new signing keys.
|
|
@@ -348,8 +466,8 @@ class CubeSignerApi {
|
|
|
348
466
|
*/
|
|
349
467
|
async keysCreate(keyType, count, ownerId) {
|
|
350
468
|
const chain_id = 0; // not used anymore
|
|
351
|
-
const client = await this.client();
|
|
352
|
-
const
|
|
469
|
+
const client = await this.client("createKey");
|
|
470
|
+
const data = await client.post("/v0/org/{org_id}/keys", {
|
|
353
471
|
params: { path: { org_id: this.orgId } },
|
|
354
472
|
body: {
|
|
355
473
|
count,
|
|
@@ -357,9 +475,7 @@ class CubeSignerApi {
|
|
|
357
475
|
key_type: keyType,
|
|
358
476
|
owner: ownerId || null,
|
|
359
477
|
},
|
|
360
|
-
parseAs: "json",
|
|
361
478
|
});
|
|
362
|
-
const data = (0, util_1.assertOk)(resp);
|
|
363
479
|
return data.keys;
|
|
364
480
|
}
|
|
365
481
|
/**
|
|
@@ -374,17 +490,16 @@ class CubeSignerApi {
|
|
|
374
490
|
* @return {KeyInfoApi[]} The newly derived keys.
|
|
375
491
|
*/
|
|
376
492
|
async keysDerive(keyType, derivationPaths, mnemonicId) {
|
|
377
|
-
const client = await this.client();
|
|
378
|
-
const
|
|
493
|
+
const client = await this.client("deriveKey");
|
|
494
|
+
const data = await client.put("/v0/org/{org_id}/derive_key", {
|
|
379
495
|
params: { path: { org_id: this.orgId } },
|
|
380
496
|
body: {
|
|
381
497
|
derivation_path: derivationPaths,
|
|
382
498
|
mnemonic_id: mnemonicId,
|
|
383
499
|
key_type: keyType,
|
|
384
500
|
},
|
|
385
|
-
parseAs: "json",
|
|
386
501
|
});
|
|
387
|
-
return
|
|
502
|
+
return data.keys;
|
|
388
503
|
}
|
|
389
504
|
/**
|
|
390
505
|
* List all keys in the org.
|
|
@@ -394,8 +509,8 @@ class CubeSignerApi {
|
|
|
394
509
|
*/
|
|
395
510
|
keysList(type, page) {
|
|
396
511
|
const listFn = async (query) => {
|
|
397
|
-
const client = await this.client();
|
|
398
|
-
|
|
512
|
+
const client = await this.client("listKeysInOrg");
|
|
513
|
+
return await client.get("/v0/org/{org_id}/keys", {
|
|
399
514
|
params: {
|
|
400
515
|
path: { org_id: this.orgId },
|
|
401
516
|
query: {
|
|
@@ -403,9 +518,7 @@ class CubeSignerApi {
|
|
|
403
518
|
...query,
|
|
404
519
|
},
|
|
405
520
|
},
|
|
406
|
-
parseAs: "json",
|
|
407
521
|
});
|
|
408
|
-
return (0, util_1.assertOk)(resp);
|
|
409
522
|
};
|
|
410
523
|
return new paginator_1.Paginator(page ?? paginator_1.Page.default(), listFn, (r) => r.keys, (r) => r.last_evaluated_key);
|
|
411
524
|
}
|
|
@@ -418,13 +531,12 @@ class CubeSignerApi {
|
|
|
418
531
|
* @return {string} The ID of the new role.
|
|
419
532
|
*/
|
|
420
533
|
async roleCreate(name) {
|
|
421
|
-
const client = await this.client();
|
|
422
|
-
const
|
|
534
|
+
const client = await this.client("createRole");
|
|
535
|
+
const data = await client.post("/v0/org/{org_id}/roles", {
|
|
423
536
|
params: { path: { org_id: this.orgId } },
|
|
424
537
|
body: name ? { name } : undefined,
|
|
425
|
-
parseAs: "json",
|
|
426
538
|
});
|
|
427
|
-
return
|
|
539
|
+
return data.role_id;
|
|
428
540
|
}
|
|
429
541
|
/**
|
|
430
542
|
* Get a role by its id (or name).
|
|
@@ -432,12 +544,10 @@ class CubeSignerApi {
|
|
|
432
544
|
* @return {RoleInfo} The role.
|
|
433
545
|
*/
|
|
434
546
|
async roleGet(roleId) {
|
|
435
|
-
const client = await this.client();
|
|
436
|
-
|
|
547
|
+
const client = await this.client("getRole");
|
|
548
|
+
return await client.get("/v0/org/{org_id}/roles/{role_id}", {
|
|
437
549
|
params: { path: { org_id: this.orgId, role_id: roleId } },
|
|
438
|
-
parseAs: "json",
|
|
439
550
|
});
|
|
440
|
-
return (0, util_1.assertOk)(resp);
|
|
441
551
|
}
|
|
442
552
|
/**
|
|
443
553
|
* Update a role.
|
|
@@ -447,13 +557,11 @@ class CubeSignerApi {
|
|
|
447
557
|
* @return {Promise<RoleInfo>} The updated role information.
|
|
448
558
|
*/
|
|
449
559
|
async roleUpdate(roleId, request) {
|
|
450
|
-
const client = await this.client();
|
|
451
|
-
|
|
560
|
+
const client = await this.client("updateRole");
|
|
561
|
+
return await client.patch("/v0/org/{org_id}/roles/{role_id}", {
|
|
452
562
|
params: { path: { org_id: this.orgId, role_id: roleId } },
|
|
453
563
|
body: request,
|
|
454
|
-
parseAs: "json",
|
|
455
564
|
});
|
|
456
|
-
return (0, util_1.assertOk)(resp);
|
|
457
565
|
}
|
|
458
566
|
/**
|
|
459
567
|
* Delete a role by its ID.
|
|
@@ -461,12 +569,10 @@ class CubeSignerApi {
|
|
|
461
569
|
* @param {string} roleId The ID of the role to delete.
|
|
462
570
|
*/
|
|
463
571
|
async roleDelete(roleId) {
|
|
464
|
-
const client = await this.client();
|
|
465
|
-
|
|
572
|
+
const client = await this.client("deleteRole");
|
|
573
|
+
await client.del("/v0/org/{org_id}/roles/{role_id}", {
|
|
466
574
|
params: { path: { org_id: this.orgId, role_id: roleId } },
|
|
467
|
-
parseAs: "json",
|
|
468
575
|
});
|
|
469
|
-
(0, util_1.assertOk)(resp);
|
|
470
576
|
}
|
|
471
577
|
/**
|
|
472
578
|
* List all roles in the org.
|
|
@@ -476,15 +582,13 @@ class CubeSignerApi {
|
|
|
476
582
|
*/
|
|
477
583
|
rolesList(page) {
|
|
478
584
|
const listFn = async (query) => {
|
|
479
|
-
const client = await this.client();
|
|
480
|
-
|
|
585
|
+
const client = await this.client("listRoles");
|
|
586
|
+
return await client.get("/v0/org/{org_id}/roles", {
|
|
481
587
|
params: {
|
|
482
588
|
path: { org_id: this.orgId },
|
|
483
589
|
query,
|
|
484
590
|
},
|
|
485
|
-
parseAs: "json",
|
|
486
591
|
});
|
|
487
|
-
return (0, util_1.assertOk)(resp);
|
|
488
592
|
};
|
|
489
593
|
return new paginator_1.Paginator(page ?? paginator_1.Page.default(), listFn, (r) => r.roles, (r) => r.last_evaluated_key);
|
|
490
594
|
}
|
|
@@ -498,16 +602,14 @@ class CubeSignerApi {
|
|
|
498
602
|
* @param {KeyPolicy?} policy The optional policy to apply to each key.
|
|
499
603
|
*/
|
|
500
604
|
async roleKeysAdd(roleId, keyIds, policy) {
|
|
501
|
-
const client = await this.client();
|
|
502
|
-
|
|
605
|
+
const client = await this.client("addKeysToRole");
|
|
606
|
+
await client.put("/v0/org/{org_id}/roles/{role_id}/add_keys", {
|
|
503
607
|
params: { path: { org_id: __classPrivateFieldGet(this, _CubeSignerApi_orgId, "f"), role_id: roleId } },
|
|
504
608
|
body: {
|
|
505
609
|
key_ids: keyIds,
|
|
506
610
|
policy: (policy ?? null),
|
|
507
611
|
},
|
|
508
|
-
parseAs: "json",
|
|
509
612
|
});
|
|
510
|
-
(0, util_1.assertOk)(resp, "Failed to add keys to role");
|
|
511
613
|
}
|
|
512
614
|
/**
|
|
513
615
|
* Remove an existing key from an existing role.
|
|
@@ -516,12 +618,10 @@ class CubeSignerApi {
|
|
|
516
618
|
* @param {string} keyId The ID of the key to remove from the role
|
|
517
619
|
*/
|
|
518
620
|
async roleKeysRemove(roleId, keyId) {
|
|
519
|
-
const client = await this.client();
|
|
520
|
-
|
|
621
|
+
const client = await this.client("removeKeyFromRole");
|
|
622
|
+
await client.del("/v0/org/{org_id}/roles/{role_id}/keys/{key_id}", {
|
|
521
623
|
params: { path: { org_id: __classPrivateFieldGet(this, _CubeSignerApi_orgId, "f"), role_id: roleId, key_id: keyId } },
|
|
522
|
-
parseAs: "json",
|
|
523
624
|
});
|
|
524
|
-
(0, util_1.assertOk)(resp, "Failed to remove key from a role");
|
|
525
625
|
}
|
|
526
626
|
/**
|
|
527
627
|
* List all keys in a role.
|
|
@@ -532,15 +632,13 @@ class CubeSignerApi {
|
|
|
532
632
|
*/
|
|
533
633
|
roleKeysList(roleId, page) {
|
|
534
634
|
const listFn = async (query) => {
|
|
535
|
-
const client = await this.client();
|
|
536
|
-
|
|
635
|
+
const client = await this.client("listRoleKeys");
|
|
636
|
+
return await client.get("/v0/org/{org_id}/roles/{role_id}/keys", {
|
|
537
637
|
params: {
|
|
538
638
|
path: { org_id: this.orgId, role_id: roleId },
|
|
539
639
|
query,
|
|
540
640
|
},
|
|
541
|
-
parseAs: "json",
|
|
542
641
|
});
|
|
543
|
-
return (0, util_1.assertOk)(resp);
|
|
544
642
|
};
|
|
545
643
|
return new paginator_1.Paginator(page ?? paginator_1.Page.default(), listFn, (r) => r.keys, (r) => r.last_evaluated_key);
|
|
546
644
|
}
|
|
@@ -553,12 +651,10 @@ class CubeSignerApi {
|
|
|
553
651
|
* @param {string} userId The ID of the user to add to the role.
|
|
554
652
|
*/
|
|
555
653
|
async roleUserAdd(roleId, userId) {
|
|
556
|
-
const client = await this.client();
|
|
557
|
-
|
|
654
|
+
const client = await this.client("addUserToRole");
|
|
655
|
+
await client.put("/v0/org/{org_id}/roles/{role_id}/add_user/{user_id}", {
|
|
558
656
|
params: { path: { org_id: __classPrivateFieldGet(this, _CubeSignerApi_orgId, "f"), role_id: roleId, user_id: userId } },
|
|
559
|
-
parseAs: "json",
|
|
560
657
|
});
|
|
561
|
-
(0, util_1.assertOk)(resp, "Failed to add user to role");
|
|
562
658
|
}
|
|
563
659
|
/**
|
|
564
660
|
* List all users in a role.
|
|
@@ -569,20 +665,52 @@ class CubeSignerApi {
|
|
|
569
665
|
*/
|
|
570
666
|
roleUsersList(roleId, page) {
|
|
571
667
|
const listFn = async (query) => {
|
|
572
|
-
const client = await this.client();
|
|
573
|
-
|
|
668
|
+
const client = await this.client("listRoleUsers");
|
|
669
|
+
return await client.get("/v0/org/{org_id}/roles/{role_id}/users", {
|
|
574
670
|
params: {
|
|
575
671
|
path: { org_id: this.orgId, role_id: roleId },
|
|
576
672
|
query,
|
|
577
673
|
},
|
|
578
|
-
parseAs: "json",
|
|
579
674
|
});
|
|
580
|
-
return (0, util_1.assertOk)(resp);
|
|
581
675
|
};
|
|
582
676
|
return new paginator_1.Paginator(page ?? paginator_1.Page.default(), listFn, (r) => r.users, (r) => r.last_evaluated_key);
|
|
583
677
|
}
|
|
584
678
|
// #endregion
|
|
585
|
-
// #region SESSIONS:
|
|
679
|
+
// #region SESSIONS: session(Create|CreateForRole|Refresh|Revoke|List|KeysList)
|
|
680
|
+
/**
|
|
681
|
+
* Create new user session (management and/or signing)
|
|
682
|
+
*
|
|
683
|
+
* @param {string} purpose The purpose of the session
|
|
684
|
+
* @param {string[]} scopes Session scopes.
|
|
685
|
+
* @param {SignerSessionLifetime} lifetimes Lifetime settings
|
|
686
|
+
* @return {Promise<SignerSessionData>} New signer session info.
|
|
687
|
+
*/
|
|
688
|
+
async sessionCreate(purpose, scopes, lifetimes) {
|
|
689
|
+
lifetimes ??= defaultSignerSessionLifetime;
|
|
690
|
+
const client = await this.client("createSession");
|
|
691
|
+
const data = await client.post("/v0/org/{org_id}/session", {
|
|
692
|
+
params: { path: { org_id: this.orgId } },
|
|
693
|
+
body: {
|
|
694
|
+
purpose,
|
|
695
|
+
scopes,
|
|
696
|
+
auth_lifetime: lifetimes.auth,
|
|
697
|
+
refresh_lifetime: lifetimes.refresh,
|
|
698
|
+
session_lifetime: lifetimes.session,
|
|
699
|
+
grace_lifetime: lifetimes.grace,
|
|
700
|
+
},
|
|
701
|
+
});
|
|
702
|
+
return {
|
|
703
|
+
org_id: this.orgId,
|
|
704
|
+
role_id: undefined,
|
|
705
|
+
purpose,
|
|
706
|
+
token: data.token,
|
|
707
|
+
session_info: data.session_info,
|
|
708
|
+
// Keep compatibility with tokens produced by CLI
|
|
709
|
+
env: {
|
|
710
|
+
["Dev-CubeSignerStack"]: __classPrivateFieldGet(this, _CubeSignerApi_sessionMgr, "f").env,
|
|
711
|
+
},
|
|
712
|
+
};
|
|
713
|
+
}
|
|
586
714
|
/**
|
|
587
715
|
* Create a new signer session for a given role.
|
|
588
716
|
*
|
|
@@ -598,8 +726,8 @@ class CubeSignerApi {
|
|
|
598
726
|
if (invalidScopes.length > 0) {
|
|
599
727
|
throw new Error(`Role scopes must start with 'sign:'; invalid scopes: ${invalidScopes}`);
|
|
600
728
|
}
|
|
601
|
-
const client = await this.client();
|
|
602
|
-
const
|
|
729
|
+
const client = await this.client("createRoleToken");
|
|
730
|
+
const data = await client.post("/v0/org/{org_id}/roles/{role_id}/tokens", {
|
|
603
731
|
params: { path: { org_id: this.orgId, role_id: roleId } },
|
|
604
732
|
body: {
|
|
605
733
|
purpose,
|
|
@@ -609,9 +737,7 @@ class CubeSignerApi {
|
|
|
609
737
|
session_lifetime: lifetimes.session,
|
|
610
738
|
grace_lifetime: lifetimes.grace,
|
|
611
739
|
},
|
|
612
|
-
parseAs: "json",
|
|
613
740
|
});
|
|
614
|
-
const data = (0, util_1.assertOk)(resp);
|
|
615
741
|
return {
|
|
616
742
|
org_id: this.orgId,
|
|
617
743
|
role_id: roleId,
|
|
@@ -630,12 +756,10 @@ class CubeSignerApi {
|
|
|
630
756
|
* @param {string} sessionId The ID of the session to revoke.
|
|
631
757
|
*/
|
|
632
758
|
async sessionRevoke(sessionId) {
|
|
633
|
-
const client = await this.client();
|
|
634
|
-
|
|
759
|
+
const client = await this.client("revokeSession");
|
|
760
|
+
await client.del("/v0/org/{org_id}/session/{session_id}", {
|
|
635
761
|
params: { path: { org_id: this.orgId, session_id: sessionId } },
|
|
636
|
-
parseAs: "json",
|
|
637
762
|
});
|
|
638
|
-
(0, util_1.assertOk)(resp);
|
|
639
763
|
}
|
|
640
764
|
/**
|
|
641
765
|
* Returns a paginator for iterating over all signer sessions optionally filtered by a role.
|
|
@@ -646,15 +770,13 @@ class CubeSignerApi {
|
|
|
646
770
|
*/
|
|
647
771
|
sessionsList(roleId, page) {
|
|
648
772
|
const listFn = async (query) => {
|
|
649
|
-
const client = await this.client();
|
|
650
|
-
|
|
773
|
+
const client = await this.client("listSessions");
|
|
774
|
+
return await client.get("/v0/org/{org_id}/session", {
|
|
651
775
|
params: {
|
|
652
776
|
path: { org_id: __classPrivateFieldGet(this, _CubeSignerApi_orgId, "f") },
|
|
653
777
|
query: { role: roleId, ...query },
|
|
654
778
|
},
|
|
655
|
-
parseAs: "json",
|
|
656
779
|
});
|
|
657
|
-
return (0, util_1.assertOk)(resp);
|
|
658
780
|
};
|
|
659
781
|
return new paginator_1.Paginator(page ?? paginator_1.Page.default(), listFn, (r) => r.sessions, (r) => r.last_evaluated_key);
|
|
660
782
|
}
|
|
@@ -663,12 +785,11 @@ class CubeSignerApi {
|
|
|
663
785
|
* @return {Key[]} The list of keys.
|
|
664
786
|
*/
|
|
665
787
|
async sessionKeysList() {
|
|
666
|
-
const client = await this.client();
|
|
788
|
+
const client = await this.client("listTokenKeys");
|
|
667
789
|
const resp = await client.get("/v0/org/{org_id}/token/keys", {
|
|
668
790
|
params: { path: { org_id: this.orgId } },
|
|
669
|
-
parseAs: "json",
|
|
670
791
|
});
|
|
671
|
-
return
|
|
792
|
+
return resp.keys;
|
|
672
793
|
}
|
|
673
794
|
// #endregion
|
|
674
795
|
// #region IDENTITY: identityProve, identityVerify
|
|
@@ -678,12 +799,10 @@ class CubeSignerApi {
|
|
|
678
799
|
* @return {Promise<IdentityProof>} Proof of authentication
|
|
679
800
|
*/
|
|
680
801
|
async identityProve() {
|
|
681
|
-
const client = await this.client();
|
|
682
|
-
|
|
802
|
+
const client = await this.client("createProofCubeSigner");
|
|
803
|
+
return await client.post("/v0/org/{org_id}/identity/prove", {
|
|
683
804
|
params: { path: { org_id: this.orgId } },
|
|
684
|
-
parseAs: "json",
|
|
685
805
|
});
|
|
686
|
-
return (0, util_1.assertOk)(resp);
|
|
687
806
|
}
|
|
688
807
|
/**
|
|
689
808
|
* Checks if a given identity proof is valid.
|
|
@@ -691,13 +810,11 @@ class CubeSignerApi {
|
|
|
691
810
|
* @param {IdentityProof} proof The proof of authentication.
|
|
692
811
|
*/
|
|
693
812
|
async identityVerify(proof) {
|
|
694
|
-
const client = await this.client();
|
|
695
|
-
|
|
813
|
+
const client = await this.client("verifyProof");
|
|
814
|
+
await client.post("/v0/org/{org_id}/identity/verify", {
|
|
696
815
|
params: { path: { org_id: this.orgId } },
|
|
697
816
|
body: proof,
|
|
698
|
-
parseAs: "json",
|
|
699
817
|
});
|
|
700
|
-
(0, util_1.assertOk)(resp);
|
|
701
818
|
}
|
|
702
819
|
// #endregion
|
|
703
820
|
// #region MFA: mfaGet, mfaList, mfaApprove, mfaList, mfaApprove, mfaApproveTotp, mfaApproveFido(Init|Complete)
|
|
@@ -708,11 +825,10 @@ class CubeSignerApi {
|
|
|
708
825
|
* @return {Promise<MfaRequestInfo>} MFA request information
|
|
709
826
|
*/
|
|
710
827
|
async mfaGet(mfaId) {
|
|
711
|
-
const client = await this.client();
|
|
712
|
-
|
|
828
|
+
const client = await this.client("mfaGet");
|
|
829
|
+
return await client.get("/v0/org/{org_id}/mfa/{mfa_id}", {
|
|
713
830
|
params: { path: { org_id: this.orgId, mfa_id: mfaId } },
|
|
714
831
|
});
|
|
715
|
-
return (0, util_1.assertOk)(resp);
|
|
716
832
|
}
|
|
717
833
|
/**
|
|
718
834
|
* List pending MFA requests accessible to the current user.
|
|
@@ -720,11 +836,11 @@ class CubeSignerApi {
|
|
|
720
836
|
* @return {Promise<MfaRequestInfo[]>} The MFA requests.
|
|
721
837
|
*/
|
|
722
838
|
async mfaList() {
|
|
723
|
-
const client = await this.client();
|
|
839
|
+
const client = await this.client("mfaList");
|
|
724
840
|
const resp = await client.get("/v0/org/{org_id}/mfa", {
|
|
725
841
|
params: { path: { org_id: this.orgId } },
|
|
726
842
|
});
|
|
727
|
-
return
|
|
843
|
+
return resp.mfa_requests;
|
|
728
844
|
}
|
|
729
845
|
/**
|
|
730
846
|
* Approve a pending MFA request using the current session.
|
|
@@ -733,11 +849,10 @@ class CubeSignerApi {
|
|
|
733
849
|
* @return {Promise<MfaRequestInfo>} The result of the MFA request
|
|
734
850
|
*/
|
|
735
851
|
async mfaApprove(mfaId) {
|
|
736
|
-
const client = await this.client();
|
|
737
|
-
|
|
852
|
+
const client = await this.client("mfaApproveCs");
|
|
853
|
+
return await client.patch("/v0/org/{org_id}/mfa/{mfa_id}", {
|
|
738
854
|
params: { path: { org_id: this.orgId, mfa_id: mfaId } },
|
|
739
855
|
});
|
|
740
|
-
return (0, util_1.assertOk)(resp);
|
|
741
856
|
}
|
|
742
857
|
/**
|
|
743
858
|
* Approve a pending MFA request using TOTP.
|
|
@@ -747,13 +862,11 @@ class CubeSignerApi {
|
|
|
747
862
|
* @return {Promise<MfaRequestInfo>} The current status of the MFA request
|
|
748
863
|
*/
|
|
749
864
|
async mfaApproveTotp(mfaId, code) {
|
|
750
|
-
const client = await this.client();
|
|
751
|
-
|
|
865
|
+
const client = await this.client("mfaApproveTotp");
|
|
866
|
+
return await client.patch("/v0/org/{org_id}/mfa/{mfa_id}/totp", {
|
|
752
867
|
params: { path: { org_id: __classPrivateFieldGet(this, _CubeSignerApi_orgId, "f"), mfa_id: mfaId } },
|
|
753
868
|
body: { code },
|
|
754
|
-
parseAs: "json",
|
|
755
869
|
});
|
|
756
|
-
return (0, util_1.assertOk)(resp);
|
|
757
870
|
}
|
|
758
871
|
/**
|
|
759
872
|
* Initiate approval of an existing MFA request using FIDO. A challenge is
|
|
@@ -763,12 +876,10 @@ class CubeSignerApi {
|
|
|
763
876
|
* @return {Promise<MfaFidoChallenge>} A challenge that needs to be answered to complete the approval.
|
|
764
877
|
*/
|
|
765
878
|
async mfaApproveFidoInit(mfaId) {
|
|
766
|
-
const client = await this.client();
|
|
767
|
-
const
|
|
879
|
+
const client = await this.client("mfaApproveFido");
|
|
880
|
+
const challenge = await client.post("/v0/org/{org_id}/mfa/{mfa_id}/fido", {
|
|
768
881
|
params: { path: { org_id: this.orgId, mfa_id: mfaId } },
|
|
769
|
-
parseAs: "json",
|
|
770
882
|
});
|
|
771
|
-
const challenge = (0, util_1.assertOk)(resp);
|
|
772
883
|
return new mfa_1.MfaFidoChallenge(this, mfaId, challenge);
|
|
773
884
|
}
|
|
774
885
|
/**
|
|
@@ -783,16 +894,14 @@ class CubeSignerApi {
|
|
|
783
894
|
* @return {Promise<MfaRequestInfo>} The current status of the MFA request.
|
|
784
895
|
*/
|
|
785
896
|
async mfaApproveFidoComplete(mfaId, challengeId, credential) {
|
|
786
|
-
const client = await this.client();
|
|
787
|
-
|
|
897
|
+
const client = await this.client("mfaApproveFidoComplete");
|
|
898
|
+
return await client.patch("/v0/org/{org_id}/mfa/{mfa_id}/fido", {
|
|
788
899
|
params: { path: { org_id: this.orgId, mfa_id: mfaId } },
|
|
789
900
|
body: {
|
|
790
901
|
challenge_id: challengeId,
|
|
791
902
|
credential,
|
|
792
903
|
},
|
|
793
|
-
parseAs: "json",
|
|
794
904
|
});
|
|
795
|
-
return (0, util_1.assertOk)(resp);
|
|
796
905
|
}
|
|
797
906
|
// #endregion
|
|
798
907
|
// #region SIGN: signEvm, signEth2, signStake, signUnstake, signAva, signBlob, signBtc, signSolana
|
|
@@ -805,17 +914,15 @@ class CubeSignerApi {
|
|
|
805
914
|
*/
|
|
806
915
|
async signEvm(key, req, mfaReceipt) {
|
|
807
916
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
808
|
-
const
|
|
809
|
-
const client = await this.client();
|
|
810
|
-
|
|
917
|
+
const signFn = async (headers) => {
|
|
918
|
+
const client = await this.client("eth1Sign");
|
|
919
|
+
return await client.post("/v1/org/{org_id}/eth1/sign/{pubkey}", {
|
|
811
920
|
params: { path: { org_id: this.orgId, pubkey } },
|
|
812
921
|
body: req,
|
|
813
922
|
headers,
|
|
814
|
-
parseAs: "json",
|
|
815
923
|
});
|
|
816
|
-
return (0, util_1.assertOk)(resp);
|
|
817
924
|
};
|
|
818
|
-
return await response_1.CubeSignerResponse.create(
|
|
925
|
+
return await response_1.CubeSignerResponse.create(signFn, mfaReceipt);
|
|
819
926
|
}
|
|
820
927
|
/**
|
|
821
928
|
* Sign an Eth2/Beacon-chain validation message.
|
|
@@ -828,14 +935,12 @@ class CubeSignerApi {
|
|
|
828
935
|
async signEth2(key, req, mfaReceipt) {
|
|
829
936
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
830
937
|
const sign = async (headers) => {
|
|
831
|
-
const client = await this.client();
|
|
832
|
-
|
|
938
|
+
const client = await this.client("eth2Sign");
|
|
939
|
+
return await client.post("/v1/org/{org_id}/eth2/sign/{pubkey}", {
|
|
833
940
|
params: { path: { org_id: this.orgId, pubkey } },
|
|
834
941
|
body: req,
|
|
835
942
|
headers,
|
|
836
|
-
parseAs: "json",
|
|
837
943
|
});
|
|
838
|
-
return (0, util_1.assertOk)(resp);
|
|
839
944
|
};
|
|
840
945
|
return await response_1.CubeSignerResponse.create(sign, mfaReceipt);
|
|
841
946
|
}
|
|
@@ -848,14 +953,12 @@ class CubeSignerApi {
|
|
|
848
953
|
*/
|
|
849
954
|
async signStake(req, mfaReceipt) {
|
|
850
955
|
const sign = async (headers) => {
|
|
851
|
-
const client = await this.client();
|
|
852
|
-
|
|
956
|
+
const client = await this.client("stake");
|
|
957
|
+
return await client.post("/v1/org/{org_id}/eth2/stake", {
|
|
853
958
|
params: { path: { org_id: this.orgId } },
|
|
854
959
|
body: req,
|
|
855
960
|
headers,
|
|
856
|
-
parseAs: "json",
|
|
857
961
|
});
|
|
858
|
-
return (0, util_1.assertOk)(resp);
|
|
859
962
|
};
|
|
860
963
|
return await response_1.CubeSignerResponse.create(sign, mfaReceipt);
|
|
861
964
|
}
|
|
@@ -869,17 +972,15 @@ class CubeSignerApi {
|
|
|
869
972
|
*/
|
|
870
973
|
async signUnstake(key, req, mfaReceipt) {
|
|
871
974
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
872
|
-
const
|
|
873
|
-
const client = await this.client();
|
|
874
|
-
|
|
975
|
+
const signFn = async (headers) => {
|
|
976
|
+
const client = await this.client("unstake");
|
|
977
|
+
return await client.post("/v1/org/{org_id}/eth2/unstake/{pubkey}", {
|
|
875
978
|
params: { path: { org_id: this.orgId, pubkey } },
|
|
876
979
|
body: req,
|
|
877
980
|
headers,
|
|
878
|
-
parseAs: "json",
|
|
879
981
|
});
|
|
880
|
-
return (0, util_1.assertOk)(resp);
|
|
881
982
|
};
|
|
882
|
-
return await response_1.CubeSignerResponse.create(
|
|
983
|
+
return await response_1.CubeSignerResponse.create(signFn, mfaReceipt);
|
|
883
984
|
}
|
|
884
985
|
/**
|
|
885
986
|
* Sign an Avalanche P- or X-chain message.
|
|
@@ -890,20 +991,18 @@ class CubeSignerApi {
|
|
|
890
991
|
*/
|
|
891
992
|
async signAva(key, tx, mfaReceipt) {
|
|
892
993
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
893
|
-
const
|
|
994
|
+
const signFn = async (headers) => {
|
|
894
995
|
const req = {
|
|
895
996
|
tx: tx,
|
|
896
997
|
};
|
|
897
|
-
const client = await this.client();
|
|
898
|
-
|
|
998
|
+
const client = await this.client("avaSign");
|
|
999
|
+
return await client.post("/v0/org/{org_id}/ava/sign/{pubkey}", {
|
|
899
1000
|
params: { path: { org_id: this.orgId, pubkey } },
|
|
900
1001
|
body: req,
|
|
901
1002
|
headers,
|
|
902
|
-
parseAs: "json",
|
|
903
1003
|
});
|
|
904
|
-
return (0, util_1.assertOk)(resp);
|
|
905
1004
|
};
|
|
906
|
-
return await response_1.CubeSignerResponse.create(
|
|
1005
|
+
return await response_1.CubeSignerResponse.create(signFn, mfaReceipt);
|
|
907
1006
|
}
|
|
908
1007
|
/**
|
|
909
1008
|
* Sign a raw blob.
|
|
@@ -930,19 +1029,17 @@ class CubeSignerApi {
|
|
|
930
1029
|
*/
|
|
931
1030
|
async signBlob(key, req, mfaReceipt) {
|
|
932
1031
|
const key_id = typeof key === "string" ? key : key.id;
|
|
933
|
-
const
|
|
934
|
-
const client = await this.client();
|
|
935
|
-
|
|
1032
|
+
const signFn = async (headers) => {
|
|
1033
|
+
const client = await this.client("blobSign");
|
|
1034
|
+
return await client.post("/v1/org/{org_id}/blob/sign/{key_id}", {
|
|
936
1035
|
params: {
|
|
937
1036
|
path: { org_id: this.orgId, key_id },
|
|
938
1037
|
},
|
|
939
1038
|
body: req,
|
|
940
1039
|
headers,
|
|
941
|
-
parseAs: "json",
|
|
942
1040
|
});
|
|
943
|
-
return (0, util_1.assertOk)(resp);
|
|
944
1041
|
};
|
|
945
|
-
return await response_1.CubeSignerResponse.create(
|
|
1042
|
+
return await response_1.CubeSignerResponse.create(signFn, mfaReceipt);
|
|
946
1043
|
}
|
|
947
1044
|
/**
|
|
948
1045
|
* Sign a Bitcoin message.
|
|
@@ -954,19 +1051,17 @@ class CubeSignerApi {
|
|
|
954
1051
|
*/
|
|
955
1052
|
async signBtc(key, req, mfaReceipt) {
|
|
956
1053
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
957
|
-
const
|
|
958
|
-
const client = await this.client();
|
|
959
|
-
|
|
1054
|
+
const signFn = async (headers) => {
|
|
1055
|
+
const client = await this.client("btcSign");
|
|
1056
|
+
return await client.post("/v0/org/{org_id}/btc/sign/{pubkey}", {
|
|
960
1057
|
params: {
|
|
961
1058
|
path: { org_id: this.orgId, pubkey },
|
|
962
1059
|
},
|
|
963
1060
|
body: req,
|
|
964
1061
|
headers: headers,
|
|
965
|
-
parseAs: "json",
|
|
966
1062
|
});
|
|
967
|
-
return (0, util_1.assertOk)(resp);
|
|
968
1063
|
};
|
|
969
|
-
return await response_1.CubeSignerResponse.create(
|
|
1064
|
+
return await response_1.CubeSignerResponse.create(signFn, mfaReceipt);
|
|
970
1065
|
}
|
|
971
1066
|
/**
|
|
972
1067
|
* Sign a Solana message.
|
|
@@ -978,23 +1073,17 @@ class CubeSignerApi {
|
|
|
978
1073
|
*/
|
|
979
1074
|
async signSolana(key, req, mfaReceipt) {
|
|
980
1075
|
const pubkey = typeof key === "string" ? key : key.materialId;
|
|
981
|
-
const
|
|
982
|
-
const client = await this.client();
|
|
983
|
-
|
|
1076
|
+
const signFn = async (headers) => {
|
|
1077
|
+
const client = await this.client("solanaSign");
|
|
1078
|
+
return await client.post("/v0/org/{org_id}/solana/sign/{pubkey}", {
|
|
984
1079
|
params: { path: { org_id: this.orgId, pubkey } },
|
|
985
1080
|
body: req,
|
|
986
1081
|
headers,
|
|
987
|
-
parseAs: "json",
|
|
988
1082
|
});
|
|
989
|
-
return (0, util_1.assertOk)(resp);
|
|
990
1083
|
};
|
|
991
|
-
return await response_1.CubeSignerResponse.create(
|
|
1084
|
+
return await response_1.CubeSignerResponse.create(signFn, mfaReceipt);
|
|
992
1085
|
}
|
|
993
1086
|
// #endregion
|
|
994
|
-
/** HTTPS client */
|
|
995
|
-
async client() {
|
|
996
|
-
return await __classPrivateFieldGet(this, _CubeSignerApi_sessionMgr, "f").client();
|
|
997
|
-
}
|
|
998
1087
|
// #region USER EXPORT: userExport(Init,Complete,List,Delete)
|
|
999
1088
|
/**
|
|
1000
1089
|
* List outstanding user-export requests.
|
|
@@ -1006,8 +1095,8 @@ class CubeSignerApi {
|
|
|
1006
1095
|
*/
|
|
1007
1096
|
userExportList(keyId, userId, page) {
|
|
1008
1097
|
const listFn = async (query) => {
|
|
1009
|
-
const client = await this.client();
|
|
1010
|
-
|
|
1098
|
+
const client = await this.client("userExportList");
|
|
1099
|
+
return await client.get("/v0/org/{org_id}/user/me/export", {
|
|
1011
1100
|
params: {
|
|
1012
1101
|
path: { org_id: this.orgId },
|
|
1013
1102
|
query: {
|
|
@@ -1016,9 +1105,7 @@ class CubeSignerApi {
|
|
|
1016
1105
|
...query,
|
|
1017
1106
|
},
|
|
1018
1107
|
},
|
|
1019
|
-
parseAs: "json",
|
|
1020
1108
|
});
|
|
1021
|
-
return (0, util_1.assertOk)(resp);
|
|
1022
1109
|
};
|
|
1023
1110
|
return new paginator_1.Paginator(page ?? paginator_1.Page.default(), listFn, (r) => r.export_requests, (r) => r.last_evaluated_key);
|
|
1024
1111
|
}
|
|
@@ -1029,8 +1116,8 @@ class CubeSignerApi {
|
|
|
1029
1116
|
* @param {string?} userId Optional user ID. If omitted, uses the current user's ID. Only org owners can delete user-export requests for users other than themselves.
|
|
1030
1117
|
*/
|
|
1031
1118
|
async userExportDelete(keyId, userId) {
|
|
1032
|
-
const client = await this.client();
|
|
1033
|
-
|
|
1119
|
+
const client = await this.client("userExportDelete");
|
|
1120
|
+
await client.del("/v0/org/{org_id}/user/me/export", {
|
|
1034
1121
|
params: {
|
|
1035
1122
|
path: { org_id: this.orgId },
|
|
1036
1123
|
query: {
|
|
@@ -1038,9 +1125,7 @@ class CubeSignerApi {
|
|
|
1038
1125
|
user_id: userId,
|
|
1039
1126
|
},
|
|
1040
1127
|
},
|
|
1041
|
-
parseAs: "json",
|
|
1042
1128
|
});
|
|
1043
|
-
(0, util_1.assertOk)(resp);
|
|
1044
1129
|
}
|
|
1045
1130
|
/**
|
|
1046
1131
|
* Initiate a user-export request.
|
|
@@ -1050,17 +1135,15 @@ class CubeSignerApi {
|
|
|
1050
1135
|
* @return {Promise<UserExportInitResponse | AcceptedResponse>} The response.
|
|
1051
1136
|
*/
|
|
1052
1137
|
async userExportInit(keyId, mfaReceipt) {
|
|
1053
|
-
const
|
|
1054
|
-
const client = await this.client();
|
|
1055
|
-
|
|
1138
|
+
const initFn = async (headers) => {
|
|
1139
|
+
const client = await this.client("userExportInit");
|
|
1140
|
+
return await client.post("/v0/org/{org_id}/user/me/export", {
|
|
1056
1141
|
params: { path: { org_id: this.orgId } },
|
|
1057
1142
|
body: { key_id: keyId },
|
|
1058
1143
|
headers,
|
|
1059
|
-
parseAs: "json",
|
|
1060
1144
|
});
|
|
1061
|
-
return (0, util_1.assertOk)(resp);
|
|
1062
1145
|
};
|
|
1063
|
-
return await response_1.CubeSignerResponse.create(
|
|
1146
|
+
return await response_1.CubeSignerResponse.create(initFn, mfaReceipt);
|
|
1064
1147
|
}
|
|
1065
1148
|
/**
|
|
1066
1149
|
* Complete a user-export request.
|
|
@@ -1075,24 +1158,22 @@ class CubeSignerApi {
|
|
|
1075
1158
|
const subtle = await (0, user_export_1.loadSubtleCrypto)();
|
|
1076
1159
|
const publicKeyB64 = (0, util_1.encodeToBase64)(Buffer.from(await subtle.exportKey("raw", publicKey)));
|
|
1077
1160
|
// make the request
|
|
1078
|
-
const
|
|
1079
|
-
const client = await this.client();
|
|
1080
|
-
|
|
1161
|
+
const completeFn = async (headers) => {
|
|
1162
|
+
const client = await this.client("userExportComplete");
|
|
1163
|
+
return await client.patch("/v0/org/{org_id}/user/me/export", {
|
|
1081
1164
|
params: { path: { org_id: this.orgId } },
|
|
1082
1165
|
body: {
|
|
1083
1166
|
key_id: keyId,
|
|
1084
1167
|
public_key: publicKeyB64,
|
|
1085
1168
|
},
|
|
1086
1169
|
headers,
|
|
1087
|
-
parseAs: "json",
|
|
1088
1170
|
});
|
|
1089
|
-
return (0, util_1.assertOk)(resp);
|
|
1090
1171
|
};
|
|
1091
|
-
return await response_1.CubeSignerResponse.create(
|
|
1172
|
+
return await response_1.CubeSignerResponse.create(completeFn, mfaReceipt);
|
|
1092
1173
|
}
|
|
1093
1174
|
}
|
|
1094
1175
|
exports.CubeSignerApi = CubeSignerApi;
|
|
1095
|
-
_CubeSignerApi_orgId = new WeakMap(), _CubeSignerApi_sessionMgr = new WeakMap();
|
|
1176
|
+
_CubeSignerApi_orgId = new WeakMap(), _CubeSignerApi_sessionMgr = new WeakMap(), _CubeSignerApi_eventEmitter = new WeakMap();
|
|
1096
1177
|
/**
|
|
1097
1178
|
* Client to use to send requests to CubeSigner services
|
|
1098
1179
|
* when authenticating using an OIDC token.
|
|
@@ -1111,6 +1192,15 @@ class OidcClient {
|
|
|
1111
1192
|
__classPrivateFieldSet(this, _OidcClient_env, env, "f");
|
|
1112
1193
|
__classPrivateFieldSet(this, _OidcClient_client, createHttpClient(env.SignerApiRoot, oidcToken), "f");
|
|
1113
1194
|
}
|
|
1195
|
+
/**
|
|
1196
|
+
* HTTP client restricted to a single operation.
|
|
1197
|
+
*
|
|
1198
|
+
* @param {Op} op The operation to restrict the client to
|
|
1199
|
+
* @return {OpClient<Op>} The client restricted to {@link op}
|
|
1200
|
+
*/
|
|
1201
|
+
client(op) {
|
|
1202
|
+
return new OpClient(op, __classPrivateFieldGet(this, _OidcClient_client, "f"), new events_1.EventEmitter([]));
|
|
1203
|
+
}
|
|
1114
1204
|
/**
|
|
1115
1205
|
* Exchange an OIDC token for a CubeSigner session token.
|
|
1116
1206
|
* @param {List<string>} scopes The scopes for the new session
|
|
@@ -1120,16 +1210,15 @@ class OidcClient {
|
|
|
1120
1210
|
*/
|
|
1121
1211
|
async sessionCreate(scopes, lifetimes, mfaReceipt) {
|
|
1122
1212
|
const loginFn = async (headers) => {
|
|
1123
|
-
const
|
|
1213
|
+
const client = this.client("oidcAuth");
|
|
1214
|
+
const data = await client.post("/v0/org/{org_id}/oidc", {
|
|
1124
1215
|
params: { path: { org_id: __classPrivateFieldGet(this, _OidcClient_orgId, "f") } },
|
|
1125
1216
|
headers,
|
|
1126
1217
|
body: {
|
|
1127
1218
|
scopes,
|
|
1128
1219
|
tokens: lifetimes,
|
|
1129
1220
|
},
|
|
1130
|
-
parseAs: "json",
|
|
1131
1221
|
});
|
|
1132
|
-
const data = (0, util_1.assertOk)(resp);
|
|
1133
1222
|
return (0, response_1.mapResponse)(data, (sessionInfo) => ({
|
|
1134
1223
|
env: {
|
|
1135
1224
|
["Dev-CubeSignerStack"]: __classPrivateFieldGet(this, _OidcClient_env, "f"),
|
|
@@ -1148,11 +1237,10 @@ class OidcClient {
|
|
|
1148
1237
|
* @return {Promise<IdentityProof>} Proof of authentication
|
|
1149
1238
|
*/
|
|
1150
1239
|
async identityProve() {
|
|
1151
|
-
const
|
|
1240
|
+
const client = this.client("createProofOidc");
|
|
1241
|
+
return await client.post("/v0/org/{org_id}/identity/prove/oidc", {
|
|
1152
1242
|
params: { path: { org_id: __classPrivateFieldGet(this, _OidcClient_orgId, "f") } },
|
|
1153
|
-
parseAs: "json",
|
|
1154
1243
|
});
|
|
1155
|
-
return (0, util_1.assertOk)(resp);
|
|
1156
1244
|
}
|
|
1157
1245
|
}
|
|
1158
1246
|
exports.OidcClient = OidcClient;
|
|
@@ -1163,4 +1251,4 @@ const defaultSignerSessionLifetime = {
|
|
|
1163
1251
|
refresh: 86400, // 1 day
|
|
1164
1252
|
grace: 30, // seconds
|
|
1165
1253
|
};
|
|
1166
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../src/api.ts"],"names":[],"mappings":"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","sourcesContent":["import createClient from \"openapi-fetch\";\nimport { paths } from \"./schema\";\nimport {\n  SignerSessionData,\n  SignerSessionLifetime,\n  SignerSessionManager,\n} from \"./session/signer_session_manager\";\nimport {\n  CreateOidcUserOptions,\n  IdentityProof,\n  KeyInRoleInfo,\n  KeyInfoApi,\n  ListKeysResponse,\n  ListRoleKeysResponse,\n  ListRoleUsersResponse,\n  ListRolesResponse,\n  OidcIdentity,\n  SessionsResponse,\n  PublicKeyCredential,\n  RoleInfo,\n  UpdateKeyRequest,\n  UpdateOrgRequest,\n  UpdateOrgResponse,\n  UpdateRoleRequest,\n  UserIdInfo,\n  UserInRoleInfo,\n  UserInfo,\n  SessionInfo,\n  OrgInfo,\n  RatchetConfig,\n  EvmSignRequest,\n  EvmSignResponse,\n  Eth2SignRequest,\n  Eth2SignResponse,\n  Eth2StakeRequest,\n  Eth2StakeResponse,\n  Eth2UnstakeRequest,\n  Eth2UnstakeResponse,\n  BlobSignRequest,\n  BlobSignResponse,\n  BtcSignResponse,\n  BtcSignRequest,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  AvaSignResponse,\n  AvaSignRequest,\n  AvaTx,\n  MfaRequestInfo,\n  MemberRole,\n  UserExportCompleteResponse,\n  UserExportInitResponse,\n  UserExportListResponse,\n} from \"./schema_types\";\nimport { assertOk, encodeToBase64 } from \"./util\";\nimport { AddFidoChallenge, MfaFidoChallenge, MfaReceipt, TotpChallenge } from \"./mfa\";\nimport { CubeSignerResponse, mapResponse } from \"./response\";\nimport { Key, KeyType } from \"./key\";\nimport { Page, PageOpts, PageQueryArgs, Paginator } from \"./paginator\";\nimport { KeyPolicy } from \"./role\";\nimport { EnvInterface } from \"./env\";\nimport { NAME, VERSION } from \".\";\nimport { loadSubtleCrypto } from \"./user_export\";\n\n/** @internal */\nexport type Client = ReturnType<typeof createClient<paths>>;\n\nexport { paths };\n\n/**\n * Creates a new HTTP client, setting the \"User-Agent\" header to this package's {name}@{version}.\n *\n * @param {string} baseUrl The base URL of the client (e.g., \"https://gamma.signer.cubist.dev\")\n * @param {string} authToken The value to send as \"Authorization\" header.\n * @return {Client} The new HTTP client.\n */\nexport function createHttpClient(baseUrl: string, authToken: string): Client {\n  return createClient<paths>({\n    baseUrl,\n    headers: {\n      Authorization: authToken,\n      [\"User-Agent\"]: `${NAME}@${VERSION}`,\n    },\n  });\n}\n\n/**\n * Client to use to send requests to CubeSigner services\n * when authenticating using a CubeSigner session token.\n */\nexport class CubeSignerApi {\n  readonly #orgId: string;\n  readonly #sessionMgr: SignerSessionManager;\n\n  /** Underlying session manager */\n  get sessionMgr(): SignerSessionManager {\n    return this.#sessionMgr;\n  }\n\n  /** Target environment */\n  get env(): EnvInterface {\n    return this.sessionMgr.env;\n  }\n\n  /**\n   * Constructor.\n   * @param {SignerSessionManager} sessionMgr The session manager to use\n   * @param {string?} orgId Optional organization ID; if omitted, uses the org ID from the session manager.\n   */\n  constructor(sessionMgr: SignerSessionManager, orgId?: string) {\n    this.#sessionMgr = sessionMgr;\n    this.#orgId = orgId ?? sessionMgr.orgId;\n  }\n\n  /**\n   * Returns a new instance of this class using the same session manager but targeting a different organization.\n   *\n   * @param {string} orgId The organization ID.\n   * @return {CubeSignerApi} A new instance of this class using the same session manager but targeting different organization.\n   */\n  withOrg(orgId?: string): CubeSignerApi {\n    return orgId ? new CubeSignerApi(this.#sessionMgr, orgId) : this;\n  }\n\n  /** Org id or name */\n  get orgId() {\n    return this.#orgId;\n  }\n\n  // #region USERS: userGet, userResetTotp(Init|Complete), userVerifyTotp, userRegisterFido(Init|Complete)\n\n  /**\n   * Obtain information about the current user.\n   *\n   * @return {Promise<UserInfo>} Retrieves information about the current user.\n   */\n  async userGet(): Promise<UserInfo> {\n    const client = await this.client();\n    const resp =\n      `${this.orgId}` !== \"undefined\"\n        ? await client.get(\"/v0/org/{org_id}/user/me\", {\n            params: { path: { org_id: this.orgId } },\n            parseAs: \"json\",\n          })\n        : await client.get(\"/v0/about_me\", { parseAs: \"json\" });\n    return assertOk(resp);\n  }\n\n  /**\n   * Creates a request to change user's TOTP. Returns a {@link TotpChallenge}\n   * that must be answered either by calling {@link TotpChallenge.answer} (or\n   * {@link CubeSignerApi.userResetTotpComplete}).\n   *\n   * @param {string} issuer Optional issuer; defaults to \"Cubist\"\n   * @param {MfaReceipt} mfaReceipt MFA receipt to include in HTTP headers\n   */\n  async userResetTotpInit(\n    issuer?: string,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<TotpChallenge>> {\n    const resetTotpFn = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.post(\"/v0/org/{org_id}/user/me/totp\", {\n        headers,\n        params: { path: { org_id: this.orgId } },\n        body: issuer\n          ? {\n              issuer,\n            }\n          : null,\n        parseAs: \"json\",\n      });\n      const data = assertOk(resp);\n      return mapResponse(data, (totpInfo) => new TotpChallenge(this, totpInfo));\n    };\n    return await CubeSignerResponse.create(resetTotpFn, mfaReceipt);\n  }\n\n  /**\n   * Answer the TOTP challenge issued by {@link userResetTotpInit}. If successful, user's\n   * TOTP configuration will be updated to that of the TOTP challenge.\n   *\n   * Instead of calling this method directly, prefer {@link TotpChallenge.answer}.\n   *\n   * @param {string} totpId - The ID of the TOTP challenge\n   * @param {string} code - The TOTP code that should verify against the TOTP configuration from the challenge.\n   */\n  async userResetTotpComplete(totpId: string, code: string): Promise<void> {\n    const client = await this.client();\n    const resp = await client.patch(\"/v0/org/{org_id}/user/me/totp\", {\n      parseAs: \"json\",\n      params: { path: { org_id: this.orgId } },\n      body: { totp_id: totpId, code },\n    });\n    assertOk(resp);\n  }\n\n  /**\n   * Verifies a given TOTP code against the current user's TOTP configuration.\n   * Throws an error if the verification fails.\n   *\n   * @param {string} code Current TOTP code\n   */\n  async userVerifyTotp(code: string) {\n    const client = await this.client();\n    const resp = await client.post(\"/v0/org/{org_id}/user/me/totp/verify\", {\n      params: { path: { org_id: this.orgId } },\n      body: { code },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  /**\n   * Initiate adding a new FIDO device. MFA may be required.  This returns a {@link AddFidoChallenge}\n   * that must be answered with {@link AddFidoChallenge.answer} or {@link userRegisterFidoComplete}\n   * (after MFA approvals).\n   *\n   * @param {string} name The name of the new device.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt to include in HTTP headers\n   * @return {Promise<CubeSignerResponse<AddFidoChallenge>>} A challenge that must be answered in order to complete FIDO registration.\n   */\n  async userRegisterFidoInit(\n    name: string,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<AddFidoChallenge>> {\n    const addFidoFn = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.post(\"/v0/org/{org_id}/user/me/fido\", {\n        headers,\n        params: { path: { org_id: this.orgId } },\n        body: { name },\n        parseAs: \"json\",\n      });\n      const data = assertOk(resp);\n      return mapResponse(data, (c) => new AddFidoChallenge(this, c));\n    };\n    return await CubeSignerResponse.create(addFidoFn, mfaReceipt);\n  }\n\n  /**\n   * Complete a previously initiated (via {@link userRegisterFidoInit}) request to add a new FIDO device.\n   *\n   * Instead of calling this method directly, prefer {@link AddFidoChallenge.answer} or\n   * {@link AddFidoChallenge.createCredentialAndAnswer}.\n   *\n   * @param {string} challengeId The ID of the challenge returned by the remote end.\n   * @param {PublicKeyCredential} credential The answer to the challenge.\n   */\n  async userRegisterFidoComplete(challengeId: string, credential: PublicKeyCredential) {\n    const client = await this.client();\n    const resp = await client.patch(\"/v0/org/{org_id}/user/me/fido\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        challenge_id: challengeId,\n        credential,\n      },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  // #endregion\n\n  // #region ORGS: orgGet, orgUpdate\n\n  /**\n   * Obtain information about the current organization.\n   * @return {OrgInfo} Information about the organization.\n   */\n  async orgGet(): Promise<OrgInfo> {\n    const client = await this.client();\n    const resp = await client.get(\"/v0/org/{org_id}\", {\n      params: { path: { org_id: this.orgId } },\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /**\n   * Update the org.\n   * @param {UpdateOrgRequest} request The JSON request to send to the API server.\n   * @return {UpdateOrgResponse} Updated org information.\n   */\n  async orgUpdate(request: UpdateOrgRequest): Promise<UpdateOrgResponse> {\n    const client = await this.client();\n    const resp = await client.patch(\"/v0/org/{org_id}\", {\n      params: { path: { org_id: this.orgId } },\n      body: request,\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  // #endregion\n\n  // #region ORG USERS: orgUserInvite, orgUsersList, orgUserCreateOidc, orgUserDeleteOidc\n\n  /**\n   * Create a new (first-party) user in the organization and send an email invitation to that user.\n   *\n   * @param {string} email Email of the user\n   * @param {string} name The full name of the user\n   * @param {MemberRole} role Optional role. Defaults to \"alien\".\n   */\n  async orgUserInvite(email: string, name: string, role?: MemberRole): Promise<void> {\n    const client = await this.client();\n    const resp = await client.post(\"/v0/org/{org_id}/invite\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        email,\n        name,\n        role,\n        skip_email: false,\n      },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  /**\n   * List users.\n   * @return {User[]} Org users.\n   */\n  async orgUsersList(): Promise<UserIdInfo[]> {\n    const client = await this.client();\n    const resp = await client.get(\"/v0/org/{org_id}/users\", {\n      params: { path: { org_id: this.orgId } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.users;\n  }\n\n  /**\n   * Create a new OIDC user. This can be a first-party \"Member\" or third-party \"Alien\".\n   * @param {OidcIdentity} identity The identity of the OIDC user\n   * @param {string} email Email of the OIDC user\n   * @param {CreateOidcUserOptions} opts Additional options for new OIDC users\n   * @return {string} User id of the new user\n   */\n  async orgUserCreateOidc(\n    identity: OidcIdentity,\n    email: string,\n    opts: CreateOidcUserOptions = {},\n  ): Promise<string> {\n    const client = await this.client();\n    const resp = await client.post(\"/v0/org/{org_id}/users\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        identity,\n        role: opts.memberRole ?? \"Alien\",\n        email: email,\n        mfa_policy: opts.mfaPolicy ?? null,\n      },\n      parseAs: \"json\",\n    });\n    return assertOk(resp).user_id;\n  }\n\n  /**\n   * Delete an existing OIDC user.\n   * @param {OidcIdentity} identity The identity of the OIDC user\n   */\n  async orgUserDeleteOidc(identity: OidcIdentity) {\n    const client = await this.client();\n    const resp = await client.del(\"/v0/org/{org_id}/users/oidc\", {\n      params: { path: { org_id: this.orgId } },\n      body: identity,\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  // #endregion\n\n  // #region KEYS: keyGet, keyUpdate, keyDelete, keysCreate, keysDerive, keysList\n\n  /**\n   * Get a key by its id.\n   *\n   * @param {string} keyId The id of the key to get.\n   * @return {KeyInfoApi} The key information.\n   */\n  async keyGet(keyId: string): Promise<KeyInfoApi> {\n    const client = await this.client();\n    const resp = await client.get(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: keyId } },\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /**\n   * Update key.\n   * @param {string} keyId The ID of the key to update.\n   * @param {UpdateKeyRequest} request The JSON request to send to the API server.\n   * @return {KeyInfoApi} The JSON response from the API server.\n   */\n  async keyUpdate(keyId: string, request: UpdateKeyRequest): Promise<KeyInfoApi> {\n    const client = await this.client();\n    const resp = await client.patch(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: keyId } },\n      body: request,\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /**\n   * Deletes a key.\n   *\n   * @param {string} keyId - Key id\n   */\n  async keyDelete(keyId: string) {\n    const client = await this.client();\n    const resp = await client.del(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: keyId } },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  /**\n   * Create new signing keys.\n   *\n   * @param {KeyType} keyType The type of key to create.\n   * @param {number} count The number of keys to create.\n   * @param {string?} ownerId The owner of the keys. Defaults to the session's user.\n   * @return {KeyInfoApi[]} The new keys.\n   */\n  async keysCreate(keyType: KeyType, count: number, ownerId?: string): Promise<KeyInfoApi[]> {\n    const chain_id = 0; // not used anymore\n    const client = await this.client();\n    const resp = await client.post(\"/v0/org/{org_id}/keys\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        count,\n        chain_id,\n        key_type: keyType,\n        owner: ownerId || null,\n      },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.keys;\n  }\n\n  /**\n   * Derive a set of keys of a specified type using a supplied derivation path and an existing long-lived mnemonic.\n   *\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param {KeyType} keyType The type of key to create.\n   * @param {string[]} derivationPaths Derivation paths from which to derive new keys.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {KeyInfoApi[]} The newly derived keys.\n   */\n  async keysDerive(\n    keyType: KeyType,\n    derivationPaths: string[],\n    mnemonicId: string,\n  ): Promise<KeyInfoApi[]> {\n    const client = await this.client();\n    const resp = await client.put(\"/v0/org/{org_id}/derive_key\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        derivation_path: derivationPaths,\n        mnemonic_id: mnemonicId,\n        key_type: keyType,\n      },\n      parseAs: \"json\",\n    });\n    return assertOk(resp).keys;\n  }\n\n  /**\n   * List all keys in the org.\n   * @param {KeyType?} type Optional key type to filter list for.\n   * @param {PageOpts?} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListKeysResponse, KeyInfoApi>} Paginator for iterating over keys.\n   */\n  keysList(type?: KeyType, page?: PageOpts): Paginator<ListKeysResponse, KeyInfoApi> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client();\n      const resp = await client.get(\"/v0/org/{org_id}/keys\", {\n        params: {\n          path: { org_id: this.orgId },\n          query: {\n            key_type: type,\n            ...query,\n          },\n        },\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.keys,\n      (r) => r.last_evaluated_key,\n    );\n  }\n  // #endregion\n\n  // #region ROLES: roleCreate, roleRead, roleUpdate, roleDelete, rolesList\n\n  /**\n   * Create a new role.\n   *\n   * @param {string?} name The optional name of the role.\n   * @return {string} The ID of the new role.\n   */\n  async roleCreate(name?: string): Promise<string> {\n    const client = await this.client();\n    const resp = await client.post(\"/v0/org/{org_id}/roles\", {\n      params: { path: { org_id: this.orgId } },\n      body: name ? { name } : undefined,\n      parseAs: \"json\",\n    });\n    return assertOk(resp).role_id;\n  }\n\n  /**\n   * Get a role by its id (or name).\n   * @param {string} roleId The id of the role to get.\n   * @return {RoleInfo} The role.\n   */\n  async roleGet(roleId: string): Promise<RoleInfo> {\n    const client = await this.client();\n    const resp = await client.get(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: this.orgId, role_id: roleId } },\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /**\n   * Update a role.\n   *\n   * @param {string} roleId The ID of the role to update.\n   * @param {UpdateRoleRequest} request The update request.\n   * @return {Promise<RoleInfo>} The updated role information.\n   */\n  async roleUpdate(roleId: string, request: UpdateRoleRequest): Promise<RoleInfo> {\n    const client = await this.client();\n    const resp = await client.patch(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: this.orgId, role_id: roleId } },\n      body: request,\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n\n  /**\n   * Delete a role by its ID.\n   *\n   * @param {string} roleId The ID of the role to delete.\n   */\n  async roleDelete(roleId: string): Promise<void> {\n    const client = await this.client();\n    const resp = await client.del(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: this.orgId, role_id: roleId } },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  /**\n   * List all roles in the org.\n   *\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {RoleInfo} Paginator for iterating over roles.\n   */\n  rolesList(page?: PageOpts): Paginator<ListRolesResponse, RoleInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client();\n      const resp = await client.get(\"/v0/org/{org_id}/roles\", {\n        params: {\n          path: { org_id: this.orgId },\n          query,\n        },\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.roles,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  // #endregion\n\n  // #region ROLE KEYS: roleKeysAdd, roleKeysDelete, roleKeysList\n\n  /**\n   * Add existing keys to an existing role.\n   *\n   * @param {string} roleId The ID of the role\n   * @param {string[]} keyIds The IDs of the keys to add to the role.\n   * @param {KeyPolicy?} policy The optional policy to apply to each key.\n   */\n  async roleKeysAdd(roleId: string, keyIds: string[], policy?: KeyPolicy) {\n    const client = await this.client();\n    const resp = await client.put(\"/v0/org/{org_id}/roles/{role_id}/add_keys\", {\n      params: { path: { org_id: this.#orgId, role_id: roleId } },\n      body: {\n        key_ids: keyIds,\n        policy: (policy ?? null) as Record<string, never>[] | null,\n      },\n      parseAs: \"json\",\n    });\n    assertOk(resp, \"Failed to add keys to role\");\n  }\n\n  /**\n   * Remove an existing key from an existing role.\n   *\n   * @param {string} roleId The ID of the role\n   * @param {string} keyId The ID of the key to remove from the role\n   */\n  async roleKeysRemove(roleId: string, keyId: string) {\n    const client = await this.client();\n    const resp = await client.del(\"/v0/org/{org_id}/roles/{role_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.#orgId, role_id: roleId, key_id: keyId } },\n      parseAs: \"json\",\n    });\n    assertOk(resp, \"Failed to remove key from a role\");\n  }\n\n  /**\n   * List all keys in a role.\n   *\n   * @param {string} roleId The ID of the role whose keys to retrieve.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListRoleKeysResponse, KeyInRoleInfo>} Paginator for iterating over the keys in the role.\n   */\n  roleKeysList(roleId: string, page?: PageOpts): Paginator<ListRoleKeysResponse, KeyInRoleInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client();\n      const resp = await client.get(\"/v0/org/{org_id}/roles/{role_id}/keys\", {\n        params: {\n          path: { org_id: this.orgId, role_id: roleId },\n          query,\n        },\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.keys,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  // #endregion\n\n  // #region ROLE USERS: roleUserAdd, roleUsersList\n\n  /**\n   * Add an existing user to an existing role.\n   *\n   * @param {string} roleId The ID of the role.\n   * @param {string} userId The ID of the user to add to the role.\n   */\n  async roleUserAdd(roleId: string, userId: string) {\n    const client = await this.client();\n    const resp = await client.put(\"/v0/org/{org_id}/roles/{role_id}/add_user/{user_id}\", {\n      params: { path: { org_id: this.#orgId, role_id: roleId, user_id: userId } },\n      parseAs: \"json\",\n    });\n    assertOk(resp, \"Failed to add user to role\");\n  }\n\n  /**\n   * List all users in a role.\n   *\n   * @param {string} roleId The ID of the role whose users to retrieve.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListRoleUsersResponse, UserInRoleInfo>} Paginator for iterating over the users in the role.\n   */\n  roleUsersList(roleId: string, page?: PageOpts): Paginator<ListRoleUsersResponse, UserInRoleInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client();\n      const resp = await client.get(\"/v0/org/{org_id}/roles/{role_id}/users\", {\n        params: {\n          path: { org_id: this.orgId, role_id: roleId },\n          query,\n        },\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.users,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  // #endregion\n\n  // #region SESSIONS: sessionCreateForRole, sessionRefresh, sessionRevoke, sessionsList, sessionKeysList\n\n  /**\n   * Create a new signer session for a given role.\n   *\n   * @param {string} roleId Role ID\n   * @param {string} purpose The purpose of the session\n   * @param {string[]} scopes Session scopes. Only `sign:*` scopes are allowed.\n   * @param {SignerSessionLifetime} lifetimes Lifetime settings\n   * @return {Promise<SignerSessionData>} New signer session info.\n   */\n  async sessionCreateForRole(\n    roleId: string,\n    purpose: string,\n    scopes?: string[],\n    lifetimes?: SignerSessionLifetime,\n  ): Promise<SignerSessionData> {\n    lifetimes ??= defaultSignerSessionLifetime;\n    const invalidScopes = (scopes || []).filter((s) => !s.startsWith(\"sign:\"));\n    if (invalidScopes.length > 0) {\n      throw new Error(`Role scopes must start with 'sign:'; invalid scopes: ${invalidScopes}`);\n    }\n\n    const client = await this.client();\n    const resp = await client.post(\"/v0/org/{org_id}/roles/{role_id}/tokens\", {\n      params: { path: { org_id: this.orgId, role_id: roleId } },\n      body: {\n        purpose,\n        scopes,\n        auth_lifetime: lifetimes.auth,\n        refresh_lifetime: lifetimes.refresh,\n        session_lifetime: lifetimes.session,\n        grace_lifetime: lifetimes.grace,\n      },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return {\n      org_id: this.orgId,\n      role_id: roleId,\n      purpose,\n      token: data.token,\n      session_info: data.session_info,\n      // Keep compatibility with tokens produced by CLI\n      env: {\n        [\"Dev-CubeSignerStack\"]: this.#sessionMgr.env,\n      },\n    };\n  }\n\n  /**\n   * Revoke a session.\n   *\n   * @param {string} sessionId The ID of the session to revoke.\n   */\n  async sessionRevoke(sessionId: string) {\n    const client = await this.client();\n    const resp = await client.del(\"/v0/org/{org_id}/session/{session_id}\", {\n      params: { path: { org_id: this.orgId, session_id: sessionId } },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  /**\n   * Returns a paginator for iterating over all signer sessions optionally filtered by a role.\n   *\n   * @param {string?} roleId If set, limit to sessions for this role only.\n   * @param {PageOpts?} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Promise<SignerSessionInfo[]>} Signer sessions for this role.\n   */\n  sessionsList(roleId?: string, page?: PageOpts): Paginator<SessionsResponse, SessionInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client();\n      const resp = await client.get(\"/v0/org/{org_id}/session\", {\n        params: {\n          path: { org_id: this.#orgId },\n          query: { role: roleId, ...query },\n        },\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.sessions,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  /**\n   * Returns the list of keys that this session has access to.\n   * @return {Key[]} The list of keys.\n   */\n  async sessionKeysList(): Promise<KeyInfoApi[]> {\n    const client = await this.client();\n    const resp = await client.get(\"/v0/org/{org_id}/token/keys\", {\n      params: { path: { org_id: this.orgId } },\n      parseAs: \"json\",\n    });\n    return assertOk(resp).keys;\n  }\n\n  // #endregion\n\n  // #region IDENTITY: identityProve, identityVerify\n\n  /**\n   * Obtain proof of authentication using the current CubeSigner session.\n   *\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async identityProve(): Promise<IdentityProof> {\n    const client = await this.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   * Checks if a given identity proof is valid.\n   *\n   * @param {IdentityProof} proof The proof of authentication.\n   */\n  async identityVerify(proof: IdentityProof) {\n    const client = await this.client();\n    const resp = await client.post(\"/v0/org/{org_id}/identity/verify\", {\n      params: { path: { org_id: this.orgId } },\n      body: proof,\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  // #endregion\n\n  // #region MFA: mfaGet, mfaList, mfaApprove, mfaList, mfaApprove, mfaApproveTotp, mfaApproveFido(Init|Complete)\n\n  /**\n   * Retrieves existing MFA request.\n   *\n   * @param {string} mfaId MFA request ID\n   * @return {Promise<MfaRequestInfo>} MFA request information\n   */\n  async mfaGet(mfaId: string): Promise<MfaRequestInfo> {\n    const client = await this.client();\n    const resp = await client.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   * List pending MFA requests accessible to the current user.\n   *\n   * @return {Promise<MfaRequestInfo[]>} The MFA requests.\n   */\n  async mfaList(): Promise<MfaRequestInfo[]> {\n    const client = await this.client();\n    const resp = await client.get(\"/v0/org/{org_id}/mfa\", {\n      params: { path: { org_id: this.orgId } },\n    });\n    return assertOk(resp).mfa_requests;\n  }\n\n  /**\n   * Approve a pending MFA request using the current session.\n   *\n   * @param {string} mfaId The id of the MFA request\n   * @return {Promise<MfaRequestInfo>} The result of the MFA request\n   */\n  async mfaApprove(mfaId: string): Promise<MfaRequestInfo> {\n    const client = await this.client();\n    const resp = await client.patch(\"/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   * 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 mfaApproveTotp(mfaId: string, code: string): Promise<MfaRequestInfo> {\n    const client = await this.client();\n    const resp = await client.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. A challenge is\n   * returned which must be answered via {@link MfaFidoChallenge.answer} or {@link mfaApproveFidoComplete}.\n   *\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 mfaApproveFidoInit(mfaId: string): Promise<MfaFidoChallenge> {\n    const client = await this.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 (via {@link mfaApproveFidoInit}) MFA request approval using FIDO.\n   *\n   * Instead of calling this method directly, prefer {@link MfaFidoChallenge.answer} or\n   * {@link MfaFidoChallenge.createCredentialAndAnswer}.\n   *\n   * @param {string} mfaId The MFA request ID\n   * @param {string} challengeId The ID of the challenge issued by {@link mfaApproveFidoInit}\n   * @param {PublicKeyCredential} credential The answer to the challenge\n   * @return {Promise<MfaRequestInfo>} The current status of the MFA request.\n   */\n  async mfaApproveFidoComplete(\n    mfaId: string,\n    challengeId: string,\n    credential: PublicKeyCredential,\n  ): Promise<MfaRequestInfo> {\n    const client = await this.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  // #endregion\n\n  // #region SIGN: signEvm, signEth2, signStake, signUnstake, signAva, signBlob, signBtc, signSolana\n\n  /**\n   * Sign an EVM transaction.\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 (or MFA approval request).\n   */\n  async signEvm(\n    key: Key | string,\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.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 CubeSignerResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain validation message.\n   *\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<CubeSignerResponse<Eth2SignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.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 CubeSignerResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain deposit (or staking) message.\n   *\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 signStake(\n    req: Eth2StakeRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Eth2StakeResponse>> {\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.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 CubeSignerResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain unstake/exit request.\n   *\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 signUnstake(\n    key: Key | string,\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.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 CubeSignerResponse.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<CubeSignerResponse<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 client = await this.client();\n      const resp = await client.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 CubeSignerResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign a raw blob.\n   *\n   * This requires the key to have a '\"AllowRawBlobSigning\"' {@link KeyPolicy}. This is because\n   * signing arbitrary messages is, in general, dangerous (and you should instead\n   * prefer typed end-points as used by, for example, {@link signEvm}). For Secp256k1 keys,\n   * for example, you **must** call this function with a message that is 32 bytes long and\n   * the output of a secure hash function.\n   *\n   * This function returns signatures serialized as;\n   *\n   * - ECDSA signatures are serialized as big-endian r and s plus recovery-id\n   *    byte v, which can in general take any of the values 0, 1, 2, or 3.\n   *\n   * - EdDSA signatures are serialized in the standard format.\n   *\n   * - BLS signatures are not supported on the blob-sign endpoint.\n   *\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<CubeSignerResponse<BlobSignResponse>> {\n    const key_id = typeof key === \"string\" ? (key as string) : key.id;\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.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 CubeSignerResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin message.\n   *\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<CubeSignerResponse<BtcSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.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 CubeSignerResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign a Solana message.\n   *\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<CubeSignerResponse<SolanaSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.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 CubeSignerResponse.create(sign, mfaReceipt);\n  }\n  // #endregion\n\n  /** HTTPS client */\n  private async client(): Promise<Client> {\n    return await this.#sessionMgr.client();\n  }\n\n  // #region USER EXPORT: userExport(Init,Complete,List,Delete)\n  /**\n   * List outstanding user-export requests.\n   *\n   * @param {string?} keyId Optional key ID. If supplied, list the outstanding request (if any) only for the specified key; otherwise, list all outstanding requests for the specified user.\n   * @param {string?} userId Optional user ID. If omtted, uses the current user's ID. Only org owners can list user-export requests for users other than themselves.\n   * @param {PageOpts?} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<UserExportListResponse, UserExportInitResponse>} Paginator for iterating over the result set.\n   */\n  userExportList(\n    keyId?: string,\n    userId?: string,\n    page?: PageOpts,\n  ): Paginator<UserExportListResponse, UserExportInitResponse> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client();\n      const resp = await client.get(\"/v0/org/{org_id}/user/me/export\", {\n        params: {\n          path: { org_id: this.orgId },\n          query: {\n            user_id: userId,\n            key_id: keyId,\n            ...query,\n          },\n        },\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.export_requests,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  /**\n   * Delete an outstanding user-export request.\n   *\n   * @param {string} keyId The key-id corresponding to the user-export request to delete.\n   * @param {string?} userId Optional user ID. If omitted, uses the current user's ID. Only org owners can delete user-export requests for users other than themselves.\n   */\n  async userExportDelete(keyId: string, userId?: string): Promise<void> {\n    const client = await this.client();\n    const resp = await client.del(\"/v0/org/{org_id}/user/me/export\", {\n      params: {\n        path: { org_id: this.orgId },\n        query: {\n          key_id: keyId,\n          user_id: userId,\n        },\n      },\n      parseAs: \"json\",\n    });\n    assertOk(resp);\n  }\n\n  /**\n   * Initiate a user-export request.\n   *\n   * @param {string} keyId The key-id for which to initiate an export.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt.\n   * @return {Promise<UserExportInitResponse | AcceptedResponse>} The response.\n   */\n  async userExportInit(\n    keyId: string,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<UserExportInitResponse>> {\n    const init = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.post(\"/v0/org/{org_id}/user/me/export\", {\n        params: { path: { org_id: this.orgId } },\n        body: { key_id: keyId },\n        headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return await CubeSignerResponse.create(init, mfaReceipt);\n  }\n\n  /**\n   * Complete a user-export request.\n   *\n   * @param {string} keyId The key-id for which to initiate an export.\n   * @param {CryptoKey} publicKey The NIST P-256 public key to which the export will be encrypted. This should be the `publicKey` property of a value returned by `userExportKeygen`.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt.\n   * @return {Promise<UserExportCompleteResponse | AcceptedResponse>} The response.\n   */\n  async userExportComplete(\n    keyId: string,\n    publicKey: CryptoKey,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<UserExportCompleteResponse>> {\n    // base64-encode the public key\n    const subtle = await loadSubtleCrypto();\n    const publicKeyB64 = encodeToBase64(Buffer.from(await subtle.exportKey(\"raw\", publicKey)));\n\n    // make the request\n    const complete = async (headers?: HeadersInit) => {\n      const client = await this.client();\n      const resp = await client.patch(\"/v0/org/{org_id}/user/me/export\", {\n        params: { path: { org_id: this.orgId } },\n        body: {\n          key_id: keyId,\n          public_key: publicKeyB64,\n        },\n        headers,\n        parseAs: \"json\",\n      });\n      return assertOk(resp);\n    };\n    return await CubeSignerResponse.create(complete, mfaReceipt);\n  }\n  // #endregion\n}\n\n/**\n * Client to use to send requests to CubeSigner services\n * when authenticating using an OIDC token.\n */\nexport class OidcClient {\n  readonly #env: EnvInterface;\n  readonly #orgId: string;\n  readonly #client: Client;\n\n  /**\n   * @param {EnvInterface} env CubeSigner deployment\n   * @param {string} orgId Target organization ID\n   * @param {string} oidcToken User's OIDC token\n   */\n  constructor(env: EnvInterface, orgId: string, oidcToken: string) {\n    this.#orgId = orgId;\n    this.#env = env;\n    this.#client = createHttpClient(env.SignerApiRoot, oidcToken);\n  }\n\n  /**\n   * Exchange an OIDC token for a CubeSigner session token.\n   * @param {List<string>} scopes The scopes for the new session\n   * @param {RatchetConfig} lifetimes Lifetimes of the new session.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt (id + confirmation code)\n   * @return {Promise<CubeSignerResponse<SignerSessionData>>} The session data.\n   */\n  async sessionCreate(\n    scopes: Array<string>,\n    lifetimes?: RatchetConfig,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<SignerSessionData>> {\n    const loginFn = async (headers?: HeadersInit) => {\n      const resp = await this.#client.post(\"/v0/org/{org_id}/oidc\", {\n        params: { path: { org_id: this.#orgId } },\n        headers,\n        body: {\n          scopes,\n          tokens: lifetimes,\n        },\n        parseAs: \"json\",\n      });\n      const data = assertOk(resp);\n      return mapResponse(\n        data,\n        (sessionInfo) =>\n          <SignerSessionData>{\n            env: {\n              [\"Dev-CubeSignerStack\"]: this.#env,\n            },\n            org_id: this.#orgId,\n            token: sessionInfo.token,\n            purpose: \"sign via oidc\",\n            session_info: sessionInfo.session_info,\n          },\n      );\n    };\n\n    return await CubeSignerResponse.create(loginFn, mfaReceipt);\n  }\n\n  /**\n   * Exchange an OIDC token for a proof of authentication.\n   *\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async identityProve(): Promise<IdentityProof> {\n    const resp = await this.#client.post(\"/v0/org/{org_id}/identity/prove/oidc\", {\n      params: { path: { org_id: this.#orgId } },\n      parseAs: \"json\",\n    });\n    return assertOk(resp);\n  }\n}\n\nconst defaultSignerSessionLifetime: SignerSessionLifetime = {\n  session: 604800, // 1 week\n  auth: 300, // 5 min\n  refresh: 86400, // 1 day\n  grace: 30, // seconds\n};\n"]}
|
|
1254
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../src/api.ts"],"names":[],"mappings":"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","sourcesContent":["import createClient, {\n  FetchOptions,\n  FetchResponse,\n  FilterKeys,\n  HttpMethod,\n  PathsWith,\n} from \"openapi-fetch\";\nimport { paths, operations } from \"./schema\";\nimport {\n  SignerSessionData,\n  SignerSessionLifetime,\n  SignerSessionManager,\n} from \"./session/signer_session_manager\";\nimport {\n  CreateOidcUserOptions,\n  IdentityProof,\n  KeyInRoleInfo,\n  KeyInfoApi,\n  ListKeysResponse,\n  ListRoleKeysResponse,\n  ListRoleUsersResponse,\n  ListRolesResponse,\n  OidcIdentity,\n  SessionsResponse,\n  PublicKeyCredential,\n  RoleInfo,\n  UpdateKeyRequest,\n  UpdateOrgRequest,\n  UpdateOrgResponse,\n  UpdateRoleRequest,\n  UserIdInfo,\n  UserInRoleInfo,\n  UserInfo,\n  SessionInfo,\n  OrgInfo,\n  RatchetConfig,\n  EvmSignRequest,\n  EvmSignResponse,\n  Eth2SignRequest,\n  Eth2SignResponse,\n  Eth2StakeRequest,\n  Eth2StakeResponse,\n  Eth2UnstakeRequest,\n  Eth2UnstakeResponse,\n  BlobSignRequest,\n  BlobSignResponse,\n  BtcSignResponse,\n  BtcSignRequest,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  AvaSignResponse,\n  AvaSignRequest,\n  AvaTx,\n  MfaRequestInfo,\n  MemberRole,\n  UserExportCompleteResponse,\n  UserExportInitResponse,\n  UserExportListResponse,\n  Empty,\n} from \"./schema_types\";\nimport { encodeToBase64 } from \"./util\";\nimport { AddFidoChallenge, MfaFidoChallenge, MfaReceipt, TotpChallenge } from \"./mfa\";\nimport { CubeSignerResponse, mapResponse } from \"./response\";\nimport { Key, KeyType } from \"./key\";\nimport { Page, PageOpts, PageQueryArgs, Paginator } from \"./paginator\";\nimport { KeyPolicy } from \"./role\";\nimport { EnvInterface } from \"./env\";\nimport { NAME, VERSION } from \".\";\nimport { loadSubtleCrypto } from \"./user_export\";\nimport { EventEmitter } from \"./events\";\n\n/** @internal */\nexport type Client = ReturnType<typeof createClient<paths>>;\n\nexport { paths, operations };\n\n/**\n * Omit routes in {@link T} whose methods are all 'never'\n */\ntype OmitNeverPaths<T extends paths> = {\n  /* eslint-disable-next-line no-unused-vars */ // 'm', but it's needed\n  [p in keyof T as T[p] extends { [m in keyof T[p]]: never } ? never : p]: T[p];\n};\n\n/**\n * Filter out methods that don't match operation {@link Op}\n */\ntype FilterPaths<Op extends keyof operations> = {\n  [p in keyof paths]: {\n    [m in HttpMethod as m extends keyof paths[p] ? m : never]: m extends keyof paths[p]\n      ? operations[Op] extends paths[p][m]\n        ? paths[p][m] extends operations[Op]\n          ? operations[Op]\n          : never\n        : never\n      : never;\n  };\n};\n\ntype Paths<Op extends keyof operations> = OmitNeverPaths<FilterPaths<Op>>;\n\n/**\n * Open-fetch client restricted to the route that corresponds to operation {@link Op}\n */\nexport type FetchClient<Op extends keyof operations> = ReturnType<typeof createClient<Paths<Op>>>;\n\n/**\n * Type alias for the type of the response body (the \"data\" field of\n * {@link FetchResponse<T>}) when that response is successful.\n */\nexport type FetchResponseSuccessData<T> = Required<FetchResponse<T>>[\"data\"];\n\n/**\n * Error response type, thrown on non-successful responses.\n */\nexport class ErrResponse extends Error {\n  /** Operation that produced this error */\n  readonly operation?: keyof operations;\n  /** HTTP status code text (derived from `this.status`) */\n  readonly statusText?: string;\n  /** HTTP status code */\n  readonly status?: number;\n  /** HTTP response url */\n  readonly url?: string;\n\n  /**\n   * @param {Partial<ErrResponse>} init Initializer\n   */\n  constructor(init: Partial<ErrResponse>) {\n    super(init.message);\n    Object.assign(this, init);\n  }\n}\n\n/**\n * Wrapper around an open-fetch client restricted to a single operation.\n * The restriction applies only when type checking, the actual\n * client does not restrict anything at runtime.\n * client does not restrict anything at runtime\n */\nexport class OpClient<Op extends keyof operations> {\n  readonly #op: Op;\n  readonly #client: FetchClient<Op>;\n  readonly #eventEmitter: EventEmitter;\n\n  /**\n   * @param {Op} op The operation this client should be restricted to\n   * @param {FetchClient<Op> | Client} client open-fetch client (either restricted to {@link Op} or not)\n   * @param {EventEmitter} eventEmitter The client-local event dispatcher.\n   */\n  constructor(op: Op, client: FetchClient<Op> | Client, eventEmitter: EventEmitter) {\n    this.#op = op;\n    this.#client = client as FetchClient<Op>; // either works\n    this.#eventEmitter = eventEmitter;\n  }\n\n  /** The operation this client is restricted to */\n  get op() {\n    return this.#op;\n  }\n\n  /**\n   * Inspects the response and returns the response body if the request was successful.\n   * Otherwise, dispatches the error to event listeners, then throws {@link ErrResponse}.\n   *\n   * @param {FetchResponse<T>} resp The response to check\n   * @return {FetchResponseSuccessData<T>} The response data corresponding to response type {@link T}.\n   */\n  private async assertOk<T>(resp: FetchResponse<T>): Promise<FetchResponseSuccessData<T>> {\n    if (resp.error) {\n      const error = new ErrResponse({\n        operation: this.op,\n        message: (resp.error as any).message, // eslint-disable-line @typescript-eslint/no-explicit-any\n        statusText: resp.response?.statusText,\n        status: resp.response?.status,\n        url: resp.response?.url,\n      });\n      this.#eventEmitter.classifyAndEmitError(error);\n      throw error;\n    }\n    if (resp.data === undefined) {\n      throw new Error(\"Response data is undefined\");\n    }\n    return resp.data;\n  }\n\n  /* eslint-disable valid-jsdoc */\n\n  /**\n   * Invoke HTTP GET\n   */\n  async get(\n    url: PathsWith<Paths<Op>, \"get\">,\n    init: FetchOptions<FilterKeys<Paths<Op>[PathsWith<Paths<Op>, \"get\">], \"get\">>,\n  ) {\n    const resp = await this.#client.get(url, init);\n    return await this.assertOk(resp);\n  }\n\n  /** Invoke HTTP POST */\n  async post(\n    url: PathsWith<Paths<Op>, \"post\">,\n    init: FetchOptions<FilterKeys<Paths<Op>[PathsWith<Paths<Op>, \"post\">], \"post\">>,\n  ) {\n    const resp = await this.#client.post(url, init);\n    return await this.assertOk(resp);\n  }\n\n  /** Invoke HTTP PATCH */\n  async patch(\n    url: PathsWith<Paths<Op>, \"patch\">,\n    init: FetchOptions<FilterKeys<Paths<Op>[PathsWith<Paths<Op>, \"patch\">], \"patch\">>,\n  ) {\n    const resp = await this.#client.patch(url, init);\n    return await this.assertOk(resp);\n  }\n\n  /** Invoke HTTP DELETE */\n  async del(\n    url: PathsWith<Paths<Op>, \"delete\">,\n    init: FetchOptions<FilterKeys<Paths<Op>[PathsWith<Paths<Op>, \"delete\">], \"delete\">>,\n  ) {\n    const resp = await this.#client.del(url, init);\n    return await this.assertOk(resp);\n  }\n\n  /** Invoke HTTP PUT */\n  async put(\n    url: PathsWith<Paths<Op>, \"put\">,\n    init: FetchOptions<FilterKeys<Paths<Op>[PathsWith<Paths<Op>, \"put\">], \"put\">>,\n  ) {\n    const resp = await this.#client.put(url, init);\n    return await this.assertOk(resp);\n  }\n\n  /* eslint-enable valid-jsdoc */\n}\n\n/**\n * Creates a new HTTP client, setting the \"User-Agent\" header to this package's {name}@{version}.\n *\n * @param {string} baseUrl The base URL of the client (e.g., \"https://gamma.signer.cubist.dev\")\n * @param {string} authToken The value to send as \"Authorization\" header.\n * @return {Client} The new HTTP client.\n */\nexport function createHttpClient(baseUrl: string, authToken: string): Client {\n  return createClient<paths>({\n    baseUrl,\n    headers: {\n      Authorization: authToken,\n      [\"User-Agent\"]: `${NAME}@${VERSION}`,\n    },\n  });\n}\n\n/**\n * Client to use to send requests to CubeSigner services\n * when authenticating using a CubeSigner session token.\n */\nexport class CubeSignerApi {\n  readonly #orgId: string;\n  readonly #sessionMgr: SignerSessionManager;\n  readonly #eventEmitter: EventEmitter;\n\n  /** Underlying session manager */\n  get sessionMgr(): SignerSessionManager {\n    return this.#sessionMgr;\n  }\n\n  /** Target environment */\n  get env(): EnvInterface {\n    return this.sessionMgr.env;\n  }\n\n  /**\n   * Constructor.\n   * @param {SignerSessionManager} sessionMgr The session manager to use\n   * @param {string?} orgId Optional organization ID; if omitted, uses the org ID from the session manager.\n   */\n  constructor(sessionMgr: SignerSessionManager, orgId?: string) {\n    this.#sessionMgr = sessionMgr;\n    this.#eventEmitter = new EventEmitter([sessionMgr.events]);\n    this.#orgId = orgId ?? sessionMgr.orgId;\n  }\n\n  /**\n   * Returns a new instance of this class using the same session manager but targeting a different organization.\n   *\n   * @param {string} orgId The organization ID.\n   * @return {CubeSignerApi} A new instance of this class using the same session manager but targeting different organization.\n   */\n  withOrg(orgId?: string): CubeSignerApi {\n    return orgId ? new CubeSignerApi(this.#sessionMgr, orgId) : this;\n  }\n\n  /** Org id or name */\n  get orgId() {\n    return this.#orgId;\n  }\n\n  /**\n   * HTTP client restricted to a single operation. The restriction applies only\n   * when type checking, the actual client does not restrict anything at runtime.\n   *\n   * @param {Op} op The operation to restrict the client to\n   * @return {Promise<OpClient<Op>>} The client restricted to {@link op}\n   */\n  private async client<Op extends keyof operations>(op: Op): Promise<OpClient<Op>> {\n    const fetchClient = await this.#sessionMgr.client();\n    return new OpClient(op, fetchClient, this.#eventEmitter);\n  }\n\n  // #region USERS: userGet, userTotp(ResetInit|ResetComplete|Verify|Delete), userFido(RegisterInit|RegisterComplete|Delete)\n\n  /**\n   * Obtain information about the current user.\n   *\n   * @return {Promise<UserInfo>} Retrieves information about the current user.\n   */\n  async userGet(): Promise<UserInfo> {\n    if (`${this.orgId}` === \"undefined\") {\n      const client = await this.client(\"aboutMeLegacy\");\n      return await client.get(\"/v0/about_me\", {});\n    } else {\n      const client = await this.client(\"aboutMe\");\n      return await client.get(\"/v0/org/{org_id}/user/me\", {\n        params: { path: { org_id: this.orgId } },\n      });\n    }\n  }\n\n  /**\n   * Creates a request to change user's TOTP. Returns a {@link TotpChallenge}\n   * that must be answered either by calling {@link TotpChallenge.answer} (or\n   * {@link CubeSignerApi.userTotpResetComplete}).\n   *\n   * @param {string} issuer Optional issuer; defaults to \"Cubist\"\n   * @param {MfaReceipt} mfaReceipt MFA receipt to include in HTTP headers\n   */\n  async userTotpResetInit(\n    issuer?: string,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<TotpChallenge>> {\n    const resetTotpFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"userResetTotpInit\");\n      const data = await client.post(\"/v0/org/{org_id}/user/me/totp\", {\n        headers,\n        params: { path: { org_id: this.orgId } },\n        body: issuer\n          ? {\n              issuer,\n            }\n          : null,\n      });\n      return mapResponse(data, (totpInfo) => new TotpChallenge(this, totpInfo));\n    };\n    return await CubeSignerResponse.create(resetTotpFn, mfaReceipt);\n  }\n\n  /**\n   * Answer the TOTP challenge issued by {@link userTotpResetInit}. If successful, user's\n   * TOTP configuration will be updated to that of the TOTP challenge.\n   *\n   * Instead of calling this method directly, prefer {@link TotpChallenge.answer}.\n   *\n   * @param {string} totpId - The ID of the TOTP challenge\n   * @param {string} code - The TOTP code that should verify against the TOTP configuration from the challenge.\n   */\n  async userTotpResetComplete(totpId: string, code: string): Promise<void> {\n    const client = await this.client(\"userResetTotpComplete\");\n    await client.patch(\"/v0/org/{org_id}/user/me/totp\", {\n      params: { path: { org_id: this.orgId } },\n      body: { totp_id: totpId, code },\n    });\n  }\n\n  /**\n   * Verifies a given TOTP code against the current user's TOTP configuration.\n   * Throws an error if the verification fails.\n   *\n   * @param {string} code Current TOTP code\n   */\n  async userTotpVerify(code: string) {\n    const client = await this.client(\"userVerifyTotp\");\n    await client.post(\"/v0/org/{org_id}/user/me/totp/verify\", {\n      params: { path: { org_id: this.orgId } },\n      body: { code },\n    });\n  }\n\n  /**\n   * Delete TOTP from the user's account.\n   * Allowed only if at least one FIDO key is registered with the user's account.\n   * MFA via FIDO is always required.\n   *\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt to include in HTTP headers\n   */\n  async userTotpDelete(mfaReceipt?: MfaReceipt): Promise<CubeSignerResponse<Empty>> {\n    const deleteTotpFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"userDeleteTotp\");\n      return await client.del(\"/v0/org/{org_id}/user/me/totp\", {\n        headers,\n        params: { path: { org_id: this.orgId } },\n        body: null,\n      });\n    };\n    return await CubeSignerResponse.create(deleteTotpFn, mfaReceipt);\n  }\n\n  /**\n   * Initiate adding a new FIDO device. MFA may be required.  This returns a {@link AddFidoChallenge}\n   * that must be answered with {@link AddFidoChallenge.answer} or {@link userFidoRegisterComplete}\n   * (after MFA approvals).\n   *\n   * @param {string} name The name of the new device.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt to include in HTTP headers\n   * @return {Promise<CubeSignerResponse<AddFidoChallenge>>} A challenge that must be answered in order to complete FIDO registration.\n   */\n  async userFidoRegisterInit(\n    name: string,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<AddFidoChallenge>> {\n    const addFidoFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"userRegisterFidoInit\");\n      const data = await client.post(\"/v0/org/{org_id}/user/me/fido\", {\n        headers,\n        params: { path: { org_id: this.orgId } },\n        body: { name },\n      });\n      return mapResponse(data, (c) => new AddFidoChallenge(this, c));\n    };\n    return await CubeSignerResponse.create(addFidoFn, mfaReceipt);\n  }\n\n  /**\n   * Complete a previously initiated (via {@link userFidoRegisterInit}) request to add a new FIDO device.\n   *\n   * Instead of calling this method directly, prefer {@link AddFidoChallenge.answer} or\n   * {@link AddFidoChallenge.createCredentialAndAnswer}.\n   *\n   * @param {string} challengeId The ID of the challenge returned by the remote end.\n   * @param {PublicKeyCredential} credential The answer to the challenge.\n   */\n  async userFidoRegisterComplete(challengeId: string, credential: PublicKeyCredential) {\n    const client = await this.client(\"userRegisterFidoComplete\");\n    await client.patch(\"/v0/org/{org_id}/user/me/fido\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        challenge_id: challengeId,\n        credential,\n      },\n    });\n  }\n\n  /**\n   * Delete a FIDO key from the user's account.\n   * Allowed only if TOTP is also defined.\n   * MFA via TOTP is always required.\n   *\n   * @param {string} fidoId The ID of the desired FIDO key\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt to include in HTTP headers\n   */\n  async userFidoDelete(\n    fidoId: string,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Empty>> {\n    const deleteFidoFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"userDeleteFido\");\n      return await client.del(\"/v0/org/{org_id}/user/me/fido/{fido_id}\", {\n        headers,\n        params: { path: { org_id: this.orgId, fido_id: fidoId } },\n        body: null,\n      });\n    };\n    return await CubeSignerResponse.create(deleteFidoFn, mfaReceipt);\n  }\n\n  // #endregion\n\n  // #region ORGS: orgGet, orgUpdate\n\n  /**\n   * Obtain information about the current organization.\n   * @return {OrgInfo} Information about the organization.\n   */\n  async orgGet(): Promise<OrgInfo> {\n    const client = await this.client(\"getOrg\");\n    return await client.get(\"/v0/org/{org_id}\", {\n      params: { path: { org_id: this.orgId } },\n    });\n  }\n\n  /**\n   * Update the org.\n   * @param {UpdateOrgRequest} request The JSON request to send to the API server.\n   * @return {UpdateOrgResponse} Updated org information.\n   */\n  async orgUpdate(request: UpdateOrgRequest): Promise<UpdateOrgResponse> {\n    const client = await this.client(\"updateOrg\");\n    return await client.patch(\"/v0/org/{org_id}\", {\n      params: { path: { org_id: this.orgId } },\n      body: request,\n    });\n  }\n\n  // #endregion\n\n  // #region ORG USERS: orgUserInvite, orgUsersList, orgUserCreateOidc, orgUserDeleteOidc\n\n  /**\n   * Create a new (first-party) user in the organization and send an email invitation to that user.\n   *\n   * @param {string} email Email of the user\n   * @param {string} name The full name of the user\n   * @param {MemberRole} role Optional role. Defaults to \"alien\".\n   */\n  async orgUserInvite(email: string, name: string, role?: MemberRole): Promise<void> {\n    const client = await this.client(\"invite\");\n    await client.post(\"/v0/org/{org_id}/invite\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        email,\n        name,\n        role,\n        skip_email: false,\n      },\n    });\n  }\n\n  /**\n   * List users.\n   * @return {User[]} Org users.\n   */\n  async orgUsersList(): Promise<UserIdInfo[]> {\n    const client = await this.client(\"listUsersInOrg\");\n    const resp = await client.get(\"/v0/org/{org_id}/users\", {\n      params: { path: { org_id: this.orgId } },\n    });\n    return resp.users;\n  }\n\n  /**\n   * Create a new OIDC user. This can be a first-party \"Member\" or third-party \"Alien\".\n   * @param {OidcIdentity} identity The identity of the OIDC user\n   * @param {string} email Email of the OIDC user\n   * @param {CreateOidcUserOptions} opts Additional options for new OIDC users\n   * @return {string} User id of the new user\n   */\n  async orgUserCreateOidc(\n    identity: OidcIdentity,\n    email: string,\n    opts: CreateOidcUserOptions = {},\n  ): Promise<string> {\n    const client = await this.client(\"createOidcUser\");\n    const data = await client.post(\"/v0/org/{org_id}/users\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        identity,\n        role: opts.memberRole ?? \"Alien\",\n        email: email,\n        mfa_policy: opts.mfaPolicy ?? null,\n      },\n    });\n    return data.user_id;\n  }\n\n  /**\n   * Delete an existing OIDC user.\n   * @param {OidcIdentity} identity The identity of the OIDC user\n   */\n  async orgUserDeleteOidc(identity: OidcIdentity) {\n    const client = await this.client(\"deleteOidcUser\");\n    return await client.del(\"/v0/org/{org_id}/users/oidc\", {\n      params: { path: { org_id: this.orgId } },\n      body: identity,\n    });\n  }\n\n  // #endregion\n\n  // #region KEYS: keyGet, keyUpdate, keyDelete, keysCreate, keysDerive, keysList\n\n  /**\n   * Get a key by its id.\n   *\n   * @param {string} keyId The id of the key to get.\n   * @return {KeyInfoApi} The key information.\n   */\n  async keyGet(keyId: string): Promise<KeyInfoApi> {\n    const client = await this.client(\"getKeyInOrg\");\n    return await client.get(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: keyId } },\n    });\n  }\n\n  /**\n   * Update key.\n   * @param {string} keyId The ID of the key to update.\n   * @param {UpdateKeyRequest} request The JSON request to send to the API server.\n   * @return {KeyInfoApi} The JSON response from the API server.\n   */\n  async keyUpdate(keyId: string, request: UpdateKeyRequest): Promise<KeyInfoApi> {\n    const client = await this.client(\"updateKey\");\n    return await client.patch(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: keyId } },\n      body: request,\n    });\n  }\n\n  /**\n   * Deletes a key.\n   *\n   * @param {string} keyId - Key id\n   */\n  async keyDelete(keyId: string) {\n    const client = await this.client(\"deleteKey\");\n    await client.del(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: keyId } },\n    });\n  }\n\n  /**\n   * Create new signing keys.\n   *\n   * @param {KeyType} keyType The type of key to create.\n   * @param {number} count The number of keys to create.\n   * @param {string?} ownerId The owner of the keys. Defaults to the session's user.\n   * @return {KeyInfoApi[]} The new keys.\n   */\n  async keysCreate(keyType: KeyType, count: number, ownerId?: string): Promise<KeyInfoApi[]> {\n    const chain_id = 0; // not used anymore\n    const client = await this.client(\"createKey\");\n    const data = await client.post(\"/v0/org/{org_id}/keys\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        count,\n        chain_id,\n        key_type: keyType,\n        owner: ownerId || null,\n      },\n    });\n    return data.keys;\n  }\n\n  /**\n   * Derive a set of keys of a specified type using a supplied derivation path and an existing long-lived mnemonic.\n   *\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param {KeyType} keyType The type of key to create.\n   * @param {string[]} derivationPaths Derivation paths from which to derive new keys.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {KeyInfoApi[]} The newly derived keys.\n   */\n  async keysDerive(\n    keyType: KeyType,\n    derivationPaths: string[],\n    mnemonicId: string,\n  ): Promise<KeyInfoApi[]> {\n    const client = await this.client(\"deriveKey\");\n    const data = await client.put(\"/v0/org/{org_id}/derive_key\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        derivation_path: derivationPaths,\n        mnemonic_id: mnemonicId,\n        key_type: keyType,\n      },\n    });\n    return data.keys;\n  }\n\n  /**\n   * List all keys in the org.\n   * @param {KeyType?} type Optional key type to filter list for.\n   * @param {PageOpts?} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListKeysResponse, KeyInfoApi>} Paginator for iterating over keys.\n   */\n  keysList(type?: KeyType, page?: PageOpts): Paginator<ListKeysResponse, KeyInfoApi> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client(\"listKeysInOrg\");\n      return await client.get(\"/v0/org/{org_id}/keys\", {\n        params: {\n          path: { org_id: this.orgId },\n          query: {\n            key_type: type,\n            ...query,\n          },\n        },\n      });\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.keys,\n      (r) => r.last_evaluated_key,\n    );\n  }\n  // #endregion\n\n  // #region ROLES: roleCreate, roleRead, roleUpdate, roleDelete, rolesList\n\n  /**\n   * Create a new role.\n   *\n   * @param {string?} name The optional name of the role.\n   * @return {string} The ID of the new role.\n   */\n  async roleCreate(name?: string): Promise<string> {\n    const client = await this.client(\"createRole\");\n    const data = await client.post(\"/v0/org/{org_id}/roles\", {\n      params: { path: { org_id: this.orgId } },\n      body: name ? { name } : undefined,\n    });\n    return data.role_id;\n  }\n\n  /**\n   * Get a role by its id (or name).\n   * @param {string} roleId The id of the role to get.\n   * @return {RoleInfo} The role.\n   */\n  async roleGet(roleId: string): Promise<RoleInfo> {\n    const client = await this.client(\"getRole\");\n    return await client.get(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: this.orgId, role_id: roleId } },\n    });\n  }\n\n  /**\n   * Update a role.\n   *\n   * @param {string} roleId The ID of the role to update.\n   * @param {UpdateRoleRequest} request The update request.\n   * @return {Promise<RoleInfo>} The updated role information.\n   */\n  async roleUpdate(roleId: string, request: UpdateRoleRequest): Promise<RoleInfo> {\n    const client = await this.client(\"updateRole\");\n    return await client.patch(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: this.orgId, role_id: roleId } },\n      body: request,\n    });\n  }\n\n  /**\n   * Delete a role by its ID.\n   *\n   * @param {string} roleId The ID of the role to delete.\n   */\n  async roleDelete(roleId: string): Promise<void> {\n    const client = await this.client(\"deleteRole\");\n    await client.del(\"/v0/org/{org_id}/roles/{role_id}\", {\n      params: { path: { org_id: this.orgId, role_id: roleId } },\n    });\n  }\n\n  /**\n   * List all roles in the org.\n   *\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {RoleInfo} Paginator for iterating over roles.\n   */\n  rolesList(page?: PageOpts): Paginator<ListRolesResponse, RoleInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client(\"listRoles\");\n      return await client.get(\"/v0/org/{org_id}/roles\", {\n        params: {\n          path: { org_id: this.orgId },\n          query,\n        },\n      });\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.roles,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  // #endregion\n\n  // #region ROLE KEYS: roleKeysAdd, roleKeysDelete, roleKeysList\n\n  /**\n   * Add existing keys to an existing role.\n   *\n   * @param {string} roleId The ID of the role\n   * @param {string[]} keyIds The IDs of the keys to add to the role.\n   * @param {KeyPolicy?} policy The optional policy to apply to each key.\n   */\n  async roleKeysAdd(roleId: string, keyIds: string[], policy?: KeyPolicy) {\n    const client = await this.client(\"addKeysToRole\");\n    await client.put(\"/v0/org/{org_id}/roles/{role_id}/add_keys\", {\n      params: { path: { org_id: this.#orgId, role_id: roleId } },\n      body: {\n        key_ids: keyIds,\n        policy: (policy ?? null) as Record<string, never>[] | null,\n      },\n    });\n  }\n\n  /**\n   * Remove an existing key from an existing role.\n   *\n   * @param {string} roleId The ID of the role\n   * @param {string} keyId The ID of the key to remove from the role\n   */\n  async roleKeysRemove(roleId: string, keyId: string) {\n    const client = await this.client(\"removeKeyFromRole\");\n    await client.del(\"/v0/org/{org_id}/roles/{role_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.#orgId, role_id: roleId, key_id: keyId } },\n    });\n  }\n\n  /**\n   * List all keys in a role.\n   *\n   * @param {string} roleId The ID of the role whose keys to retrieve.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListRoleKeysResponse, KeyInRoleInfo>} Paginator for iterating over the keys in the role.\n   */\n  roleKeysList(roleId: string, page?: PageOpts): Paginator<ListRoleKeysResponse, KeyInRoleInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client(\"listRoleKeys\");\n      return await client.get(\"/v0/org/{org_id}/roles/{role_id}/keys\", {\n        params: {\n          path: { org_id: this.orgId, role_id: roleId },\n          query,\n        },\n      });\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.keys,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  // #endregion\n\n  // #region ROLE USERS: roleUserAdd, roleUsersList\n\n  /**\n   * Add an existing user to an existing role.\n   *\n   * @param {string} roleId The ID of the role.\n   * @param {string} userId The ID of the user to add to the role.\n   */\n  async roleUserAdd(roleId: string, userId: string) {\n    const client = await this.client(\"addUserToRole\");\n    await client.put(\"/v0/org/{org_id}/roles/{role_id}/add_user/{user_id}\", {\n      params: { path: { org_id: this.#orgId, role_id: roleId, user_id: userId } },\n    });\n  }\n\n  /**\n   * List all users in a role.\n   *\n   * @param {string} roleId The ID of the role whose users to retrieve.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListRoleUsersResponse, UserInRoleInfo>} Paginator for iterating over the users in the role.\n   */\n  roleUsersList(roleId: string, page?: PageOpts): Paginator<ListRoleUsersResponse, UserInRoleInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client(\"listRoleUsers\");\n      return await client.get(\"/v0/org/{org_id}/roles/{role_id}/users\", {\n        params: {\n          path: { org_id: this.orgId, role_id: roleId },\n          query,\n        },\n      });\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.users,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  // #endregion\n\n  // #region SESSIONS: session(Create|CreateForRole|Refresh|Revoke|List|KeysList)\n\n  /**\n   * Create new user session (management and/or signing)\n   *\n   * @param {string} purpose The purpose of the session\n   * @param {string[]} scopes Session scopes.\n   * @param {SignerSessionLifetime} lifetimes Lifetime settings\n   * @return {Promise<SignerSessionData>} New signer session info.\n   */\n  async sessionCreate(\n    purpose: string,\n    scopes: string[],\n    lifetimes?: SignerSessionLifetime,\n  ): Promise<SignerSessionData> {\n    lifetimes ??= defaultSignerSessionLifetime;\n    const client = await this.client(\"createSession\");\n    const data = await client.post(\"/v0/org/{org_id}/session\", {\n      params: { path: { org_id: this.orgId } },\n      body: {\n        purpose,\n        scopes,\n        auth_lifetime: lifetimes.auth,\n        refresh_lifetime: lifetimes.refresh,\n        session_lifetime: lifetimes.session,\n        grace_lifetime: lifetimes.grace,\n      },\n    });\n    return {\n      org_id: this.orgId,\n      role_id: undefined,\n      purpose,\n      token: data.token,\n      session_info: data.session_info,\n      // Keep compatibility with tokens produced by CLI\n      env: {\n        [\"Dev-CubeSignerStack\"]: this.#sessionMgr.env,\n      },\n    };\n  }\n\n  /**\n   * Create a new signer session for a given role.\n   *\n   * @param {string} roleId Role ID\n   * @param {string} purpose The purpose of the session\n   * @param {string[]} scopes Session scopes. Only `sign:*` scopes are allowed.\n   * @param {SignerSessionLifetime} lifetimes Lifetime settings\n   * @return {Promise<SignerSessionData>} New signer session info.\n   */\n  async sessionCreateForRole(\n    roleId: string,\n    purpose: string,\n    scopes?: string[],\n    lifetimes?: SignerSessionLifetime,\n  ): Promise<SignerSessionData> {\n    lifetimes ??= defaultSignerSessionLifetime;\n    const invalidScopes = (scopes || []).filter((s) => !s.startsWith(\"sign:\"));\n    if (invalidScopes.length > 0) {\n      throw new Error(`Role scopes must start with 'sign:'; invalid scopes: ${invalidScopes}`);\n    }\n\n    const client = await this.client(\"createRoleToken\");\n    const data = await client.post(\"/v0/org/{org_id}/roles/{role_id}/tokens\", {\n      params: { path: { org_id: this.orgId, role_id: roleId } },\n      body: {\n        purpose,\n        scopes,\n        auth_lifetime: lifetimes.auth,\n        refresh_lifetime: lifetimes.refresh,\n        session_lifetime: lifetimes.session,\n        grace_lifetime: lifetimes.grace,\n      },\n    });\n    return {\n      org_id: this.orgId,\n      role_id: roleId,\n      purpose,\n      token: data.token,\n      session_info: data.session_info,\n      // Keep compatibility with tokens produced by CLI\n      env: {\n        [\"Dev-CubeSignerStack\"]: this.#sessionMgr.env,\n      },\n    };\n  }\n\n  /**\n   * Revoke a session.\n   *\n   * @param {string} sessionId The ID of the session to revoke.\n   */\n  async sessionRevoke(sessionId: string) {\n    const client = await this.client(\"revokeSession\");\n    await client.del(\"/v0/org/{org_id}/session/{session_id}\", {\n      params: { path: { org_id: this.orgId, session_id: sessionId } },\n    });\n  }\n\n  /**\n   * Returns a paginator for iterating over all signer sessions optionally filtered by a role.\n   *\n   * @param {string?} roleId If set, limit to sessions for this role only.\n   * @param {PageOpts?} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Promise<SignerSessionInfo[]>} Signer sessions for this role.\n   */\n  sessionsList(roleId?: string, page?: PageOpts): Paginator<SessionsResponse, SessionInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client(\"listSessions\");\n      return await client.get(\"/v0/org/{org_id}/session\", {\n        params: {\n          path: { org_id: this.#orgId },\n          query: { role: roleId, ...query },\n        },\n      });\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.sessions,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  /**\n   * Returns the list of keys that this session has access to.\n   * @return {Key[]} The list of keys.\n   */\n  async sessionKeysList(): Promise<KeyInfoApi[]> {\n    const client = await this.client(\"listTokenKeys\");\n    const resp = await client.get(\"/v0/org/{org_id}/token/keys\", {\n      params: { path: { org_id: this.orgId } },\n    });\n    return resp.keys;\n  }\n\n  // #endregion\n\n  // #region IDENTITY: identityProve, identityVerify\n\n  /**\n   * Obtain proof of authentication using the current CubeSigner session.\n   *\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async identityProve(): Promise<IdentityProof> {\n    const client = await this.client(\"createProofCubeSigner\");\n    return await client.post(\"/v0/org/{org_id}/identity/prove\", {\n      params: { path: { org_id: this.orgId } },\n    });\n  }\n\n  /**\n   * Checks if a given identity proof is valid.\n   *\n   * @param {IdentityProof} proof The proof of authentication.\n   */\n  async identityVerify(proof: IdentityProof) {\n    const client = await this.client(\"verifyProof\");\n    await client.post(\"/v0/org/{org_id}/identity/verify\", {\n      params: { path: { org_id: this.orgId } },\n      body: proof,\n    });\n  }\n\n  // #endregion\n\n  // #region MFA: mfaGet, mfaList, mfaApprove, mfaList, mfaApprove, mfaApproveTotp, mfaApproveFido(Init|Complete)\n\n  /**\n   * Retrieves existing MFA request.\n   *\n   * @param {string} mfaId MFA request ID\n   * @return {Promise<MfaRequestInfo>} MFA request information\n   */\n  async mfaGet(mfaId: string): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaGet\");\n    return await client.get(\"/v0/org/{org_id}/mfa/{mfa_id}\", {\n      params: { path: { org_id: this.orgId, mfa_id: mfaId } },\n    });\n  }\n\n  /**\n   * List pending MFA requests accessible to the current user.\n   *\n   * @return {Promise<MfaRequestInfo[]>} The MFA requests.\n   */\n  async mfaList(): Promise<MfaRequestInfo[]> {\n    const client = await this.client(\"mfaList\");\n    const resp = await client.get(\"/v0/org/{org_id}/mfa\", {\n      params: { path: { org_id: this.orgId } },\n    });\n    return resp.mfa_requests;\n  }\n\n  /**\n   * Approve a pending MFA request using the current session.\n   *\n   * @param {string} mfaId The id of the MFA request\n   * @return {Promise<MfaRequestInfo>} The result of the MFA request\n   */\n  async mfaApprove(mfaId: string): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaApproveCs\");\n    return await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}\", {\n      params: { path: { org_id: this.orgId, mfa_id: mfaId } },\n    });\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 mfaApproveTotp(mfaId: string, code: string): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaApproveTotp\");\n    return await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}/totp\", {\n      params: { path: { org_id: this.#orgId, mfa_id: mfaId } },\n      body: { code },\n    });\n  }\n\n  /**\n   * Initiate approval of an existing MFA request using FIDO. A challenge is\n   * returned which must be answered via {@link MfaFidoChallenge.answer} or {@link mfaApproveFidoComplete}.\n   *\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 mfaApproveFidoInit(mfaId: string): Promise<MfaFidoChallenge> {\n    const client = await this.client(\"mfaApproveFido\");\n    const challenge = await client.post(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", {\n      params: { path: { org_id: this.orgId, mfa_id: mfaId } },\n    });\n    return new MfaFidoChallenge(this, mfaId, challenge);\n  }\n\n  /**\n   * Complete a previously initiated (via {@link mfaApproveFidoInit}) MFA request approval using FIDO.\n   *\n   * Instead of calling this method directly, prefer {@link MfaFidoChallenge.answer} or\n   * {@link MfaFidoChallenge.createCredentialAndAnswer}.\n   *\n   * @param {string} mfaId The MFA request ID\n   * @param {string} challengeId The ID of the challenge issued by {@link mfaApproveFidoInit}\n   * @param {PublicKeyCredential} credential The answer to the challenge\n   * @return {Promise<MfaRequestInfo>} The current status of the MFA request.\n   */\n  async mfaApproveFidoComplete(\n    mfaId: string,\n    challengeId: string,\n    credential: PublicKeyCredential,\n  ): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaApproveFidoComplete\");\n    return 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    });\n  }\n\n  // #endregion\n\n  // #region SIGN: signEvm, signEth2, signStake, signUnstake, signAva, signBlob, signBtc, signSolana\n\n  /**\n   * Sign an EVM transaction.\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 (or MFA approval request).\n   */\n  async signEvm(\n    key: Key | string,\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"eth1Sign\");\n      return await client.post(\"/v1/org/{org_id}/eth1/sign/{pubkey}\", {\n        params: { path: { org_id: this.orgId, pubkey } },\n        body: req,\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain validation message.\n   *\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<CubeSignerResponse<Eth2SignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client(\"eth2Sign\");\n      return await client.post(\"/v1/org/{org_id}/eth2/sign/{pubkey}\", {\n        params: { path: { org_id: this.orgId, pubkey } },\n        body: req,\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain deposit (or staking) message.\n   *\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 signStake(\n    req: Eth2StakeRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Eth2StakeResponse>> {\n    const sign = async (headers?: HeadersInit) => {\n      const client = await this.client(\"stake\");\n      return await client.post(\"/v1/org/{org_id}/eth2/stake\", {\n        params: { path: { org_id: this.orgId } },\n        body: req,\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(sign, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain unstake/exit request.\n   *\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 signUnstake(\n    key: Key | string,\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"unstake\");\n      return await client.post(\"/v1/org/{org_id}/eth2/unstake/{pubkey}\", {\n        params: { path: { org_id: this.orgId, pubkey } },\n        body: req,\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(signFn, 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<CubeSignerResponse<AvaSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const req = <AvaSignRequest>{\n        tx: tx as unknown,\n      };\n      const client = await this.client(\"avaSign\");\n      return await client.post(\"/v0/org/{org_id}/ava/sign/{pubkey}\", {\n        params: { path: { org_id: this.orgId, pubkey } },\n        body: req,\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a raw blob.\n   *\n   * This requires the key to have a '\"AllowRawBlobSigning\"' {@link KeyPolicy}. This is because\n   * signing arbitrary messages is, in general, dangerous (and you should instead\n   * prefer typed end-points as used by, for example, {@link signEvm}). For Secp256k1 keys,\n   * for example, you **must** call this function with a message that is 32 bytes long and\n   * the output of a secure hash function.\n   *\n   * This function returns signatures serialized as;\n   *\n   * - ECDSA signatures are serialized as big-endian r and s plus recovery-id\n   *    byte v, which can in general take any of the values 0, 1, 2, or 3.\n   *\n   * - EdDSA signatures are serialized in the standard format.\n   *\n   * - BLS signatures are not supported on the blob-sign endpoint.\n   *\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<CubeSignerResponse<BlobSignResponse>> {\n    const key_id = typeof key === \"string\" ? (key as string) : key.id;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"blobSign\");\n      return await client.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      });\n    };\n    return await CubeSignerResponse.create(signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin message.\n   *\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<CubeSignerResponse<BtcSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"btcSign\");\n      return await client.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      });\n    };\n    return await CubeSignerResponse.create(signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Solana message.\n   *\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<CubeSignerResponse<SolanaSignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"solanaSign\");\n      return await client.post(\"/v0/org/{org_id}/solana/sign/{pubkey}\", {\n        params: { path: { org_id: this.orgId, pubkey } },\n        body: req,\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(signFn, mfaReceipt);\n  }\n  // #endregion\n\n  // #region USER EXPORT: userExport(Init,Complete,List,Delete)\n  /**\n   * List outstanding user-export requests.\n   *\n   * @param {string?} keyId Optional key ID. If supplied, list the outstanding request (if any) only for the specified key; otherwise, list all outstanding requests for the specified user.\n   * @param {string?} userId Optional user ID. If omtted, uses the current user's ID. Only org owners can list user-export requests for users other than themselves.\n   * @param {PageOpts?} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<UserExportListResponse, UserExportInitResponse>} Paginator for iterating over the result set.\n   */\n  userExportList(\n    keyId?: string,\n    userId?: string,\n    page?: PageOpts,\n  ): Paginator<UserExportListResponse, UserExportInitResponse> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client(\"userExportList\");\n      return await client.get(\"/v0/org/{org_id}/user/me/export\", {\n        params: {\n          path: { org_id: this.orgId },\n          query: {\n            user_id: userId,\n            key_id: keyId,\n            ...query,\n          },\n        },\n      });\n    };\n    return new Paginator(\n      page ?? Page.default(),\n      listFn,\n      (r) => r.export_requests,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  /**\n   * Delete an outstanding user-export request.\n   *\n   * @param {string} keyId The key-id corresponding to the user-export request to delete.\n   * @param {string?} userId Optional user ID. If omitted, uses the current user's ID. Only org owners can delete user-export requests for users other than themselves.\n   */\n  async userExportDelete(keyId: string, userId?: string): Promise<void> {\n    const client = await this.client(\"userExportDelete\");\n    await client.del(\"/v0/org/{org_id}/user/me/export\", {\n      params: {\n        path: { org_id: this.orgId },\n        query: {\n          key_id: keyId,\n          user_id: userId,\n        },\n      },\n    });\n  }\n\n  /**\n   * Initiate a user-export request.\n   *\n   * @param {string} keyId The key-id for which to initiate an export.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt.\n   * @return {Promise<UserExportInitResponse | AcceptedResponse>} The response.\n   */\n  async userExportInit(\n    keyId: string,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<UserExportInitResponse>> {\n    const initFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"userExportInit\");\n      return await client.post(\"/v0/org/{org_id}/user/me/export\", {\n        params: { path: { org_id: this.orgId } },\n        body: { key_id: keyId },\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(initFn, mfaReceipt);\n  }\n\n  /**\n   * Complete a user-export request.\n   *\n   * @param {string} keyId The key-id for which to initiate an export.\n   * @param {CryptoKey} publicKey The NIST P-256 public key to which the export will be encrypted. This should be the `publicKey` property of a value returned by `userExportKeygen`.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt.\n   * @return {Promise<UserExportCompleteResponse | AcceptedResponse>} The response.\n   */\n  async userExportComplete(\n    keyId: string,\n    publicKey: CryptoKey,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<UserExportCompleteResponse>> {\n    // base64-encode the public key\n    const subtle = await loadSubtleCrypto();\n    const publicKeyB64 = encodeToBase64(Buffer.from(await subtle.exportKey(\"raw\", publicKey)));\n\n    // make the request\n    const completeFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"userExportComplete\");\n      return await client.patch(\"/v0/org/{org_id}/user/me/export\", {\n        params: { path: { org_id: this.orgId } },\n        body: {\n          key_id: keyId,\n          public_key: publicKeyB64,\n        },\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(completeFn, mfaReceipt);\n  }\n  // #endregion\n}\n\n/**\n * Client to use to send requests to CubeSigner services\n * when authenticating using an OIDC token.\n */\nexport class OidcClient {\n  readonly #env: EnvInterface;\n  readonly #orgId: string;\n  readonly #client: Client;\n\n  /**\n   * @param {EnvInterface} env CubeSigner deployment\n   * @param {string} orgId Target organization ID\n   * @param {string} oidcToken User's OIDC token\n   */\n  constructor(env: EnvInterface, orgId: string, oidcToken: string) {\n    this.#orgId = orgId;\n    this.#env = env;\n    this.#client = createHttpClient(env.SignerApiRoot, oidcToken);\n  }\n\n  /**\n   * HTTP client restricted to a single operation.\n   *\n   * @param {Op} op The operation to restrict the client to\n   * @return {OpClient<Op>} The client restricted to {@link op}\n   */\n  private client<Op extends keyof operations>(op: Op): OpClient<Op> {\n    return new OpClient(op, this.#client, new EventEmitter([]));\n  }\n\n  /**\n   * Exchange an OIDC token for a CubeSigner session token.\n   * @param {List<string>} scopes The scopes for the new session\n   * @param {RatchetConfig} lifetimes Lifetimes of the new session.\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt (id + confirmation code)\n   * @return {Promise<CubeSignerResponse<SignerSessionData>>} The session data.\n   */\n  async sessionCreate(\n    scopes: Array<string>,\n    lifetimes?: RatchetConfig,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<SignerSessionData>> {\n    const loginFn = async (headers?: HeadersInit) => {\n      const client = this.client(\"oidcAuth\");\n      const data = await client.post(\"/v0/org/{org_id}/oidc\", {\n        params: { path: { org_id: this.#orgId } },\n        headers,\n        body: {\n          scopes,\n          tokens: lifetimes,\n        },\n      });\n      return mapResponse(\n        data,\n        (sessionInfo) =>\n          <SignerSessionData>{\n            env: {\n              [\"Dev-CubeSignerStack\"]: this.#env,\n            },\n            org_id: this.#orgId,\n            token: sessionInfo.token,\n            purpose: \"sign via oidc\",\n            session_info: sessionInfo.session_info,\n          },\n      );\n    };\n\n    return await CubeSignerResponse.create(loginFn, mfaReceipt);\n  }\n\n  /**\n   * Exchange an OIDC token for a proof of authentication.\n   *\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  async identityProve(): Promise<IdentityProof> {\n    const client = this.client(\"createProofOidc\");\n    return await client.post(\"/v0/org/{org_id}/identity/prove/oidc\", {\n      params: { path: { org_id: this.#orgId } },\n    });\n  }\n}\n\nconst defaultSignerSessionLifetime: SignerSessionLifetime = {\n  session: 604800, // 1 week\n  auth: 300, // 5 min\n  refresh: 86400, // 1 day\n  grace: 30, // seconds\n};\n"]}
|