@cubist-labs/cubesigner-sdk 0.3.13 → 0.3.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/cjs/package.json +2 -2
- package/dist/cjs/spec/env/beta.json +2 -1
- package/dist/cjs/spec/env/gamma.json +2 -1
- package/dist/cjs/spec/env/prod.json +2 -1
- package/dist/cjs/src/api.d.ts +53 -6
- package/dist/cjs/src/api.js +75 -22
- package/dist/cjs/src/client.d.ts +15 -2
- package/dist/cjs/src/client.js +5 -3
- package/dist/cjs/src/env.d.ts +1 -0
- package/dist/cjs/src/env.js +1 -1
- package/dist/cjs/src/error.d.ts +2 -0
- package/dist/cjs/src/error.js +7 -2
- package/dist/cjs/src/evm/index.d.ts +74 -0
- package/dist/cjs/src/evm/index.js +165 -0
- package/dist/cjs/src/index.d.ts +4 -0
- package/dist/cjs/src/index.js +5 -1
- package/dist/cjs/src/org.d.ts +20 -1
- package/dist/cjs/src/org.js +11 -1
- package/dist/cjs/src/org_event_processor.d.ts +57 -0
- package/dist/cjs/src/org_event_processor.js +137 -0
- package/dist/cjs/src/schema.d.ts +201 -23
- package/dist/cjs/src/schema.js +1 -1
- package/dist/cjs/src/schema_types.d.ts +6 -1
- package/dist/cjs/src/schema_types.js +1 -1
- package/dist/esm/package.json +2 -2
- package/dist/esm/spec/env/beta.json +2 -1
- package/dist/esm/spec/env/gamma.json +2 -1
- package/dist/esm/spec/env/prod.json +2 -1
- package/dist/esm/src/api.d.ts +53 -6
- package/dist/esm/src/api.js +76 -23
- package/dist/esm/src/client.d.ts +15 -2
- package/dist/esm/src/client.js +5 -3
- package/dist/esm/src/env.d.ts +1 -0
- package/dist/esm/src/env.js +1 -1
- package/dist/esm/src/error.d.ts +2 -0
- package/dist/esm/src/error.js +7 -2
- package/dist/esm/src/evm/index.d.ts +74 -0
- package/dist/esm/src/evm/index.js +161 -0
- package/dist/esm/src/index.d.ts +4 -0
- package/dist/esm/src/index.js +5 -1
- package/dist/esm/src/org.d.ts +20 -1
- package/dist/esm/src/org.js +12 -2
- package/dist/esm/src/org_event_processor.d.ts +57 -0
- package/dist/esm/src/org_event_processor.js +133 -0
- package/dist/esm/src/schema.d.ts +201 -23
- package/dist/esm/src/schema.js +1 -1
- package/dist/esm/src/schema_types.d.ts +6 -1
- package/dist/esm/src/schema_types.js +1 -1
- package/package.json +2 -2
- package/src/api.ts +106 -22
- package/src/client.ts +11 -3
- package/src/env.ts +1 -0
- package/src/error.ts +8 -1
- package/src/evm/index.ts +192 -0
- package/src/index.ts +4 -0
- package/src/org.ts +17 -1
- package/src/org_event_processor.ts +173 -0
- package/src/schema.ts +226 -22
- package/src/schema_types.ts +6 -1
- package/tsconfig.json +3 -3
package/dist/cjs/src/api.js
CHANGED
|
@@ -13,7 +13,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
13
13
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
14
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
15
|
};
|
|
16
|
-
var _OpClient_op, _OpClient_client, _OpClient_eventEmitter, _CubeSignerApi_orgId, _CubeSignerApi_sessionMgr, _CubeSignerApi_eventEmitter, _OidcClient_env, _OidcClient_orgId, _OidcClient_client;
|
|
16
|
+
var _OpClient_op, _OpClient_client, _OpClient_eventEmitter, _OpClient_retry, _CubeSignerApi_orgId, _CubeSignerApi_sessionMgr, _CubeSignerApi_eventEmitter, _CubeSignerApi_retrySettings, _OidcClient_env, _OidcClient_orgId, _OidcClient_client, _OidcClient_retrySettings;
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
exports.OidcClient = exports.CubeSignerApi = exports.createHttpClient = exports.OpClient = void 0;
|
|
19
19
|
const openapi_fetch_1 = __importDefault(require("openapi-fetch"));
|
|
@@ -36,14 +36,21 @@ class OpClient {
|
|
|
36
36
|
* @param {Op} op The operation this client should be restricted to
|
|
37
37
|
* @param {FetchClient<Op> | Client} client open-fetch client (either restricted to {@link Op} or not)
|
|
38
38
|
* @param {EventEmitter} eventEmitter The client-local event dispatcher.
|
|
39
|
+
* @param {number[]} retrySettings Retry settings. By default, retries 3 times, sleeping 100ms
|
|
40
|
+
* after the first failed attempt, 200ms after the second, and finally 400ms after the third,
|
|
39
41
|
*/
|
|
40
|
-
constructor(op, client, eventEmitter) {
|
|
42
|
+
constructor(op, client, eventEmitter, retrySettings) {
|
|
41
43
|
_OpClient_op.set(this, void 0);
|
|
42
44
|
_OpClient_client.set(this, void 0);
|
|
43
45
|
_OpClient_eventEmitter.set(this, void 0);
|
|
46
|
+
_OpClient_retry.set(this, void 0);
|
|
44
47
|
__classPrivateFieldSet(this, _OpClient_op, op, "f");
|
|
45
48
|
__classPrivateFieldSet(this, _OpClient_client, client, "f"); // either works
|
|
46
49
|
__classPrivateFieldSet(this, _OpClient_eventEmitter, eventEmitter, "f");
|
|
50
|
+
__classPrivateFieldSet(this, _OpClient_retry, retrySettings ?? {
|
|
51
|
+
codes: [...Array(100).keys()].map((i) => 500 + i),
|
|
52
|
+
delaysMs: [100, 200, 400],
|
|
53
|
+
}, "f");
|
|
47
54
|
}
|
|
48
55
|
/** The operation this client is restricted to */
|
|
49
56
|
get op() {
|
|
@@ -61,6 +68,7 @@ class OpClient {
|
|
|
61
68
|
const errResp = resp.error;
|
|
62
69
|
const error = new error_1.ErrResponse({
|
|
63
70
|
operation: this.op,
|
|
71
|
+
requestId: errResp?.request_id,
|
|
64
72
|
message: errResp?.message,
|
|
65
73
|
statusText: resp.response?.statusText,
|
|
66
74
|
status: resp.response?.status,
|
|
@@ -75,37 +83,72 @@ class OpClient {
|
|
|
75
83
|
}
|
|
76
84
|
return resp.data;
|
|
77
85
|
}
|
|
86
|
+
/**
|
|
87
|
+
* @param {number[]} delaysMs Delays in milliseconds between retries.
|
|
88
|
+
* @return {OpClient<Op>} Returns the same client as this except with different retry delays.
|
|
89
|
+
*/
|
|
90
|
+
withRetries(delaysMs) {
|
|
91
|
+
return this.withRetrySettings({
|
|
92
|
+
codes: __classPrivateFieldGet(this, _OpClient_retry, "f").codes,
|
|
93
|
+
delaysMs,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* @param {RetrySettings} retrySettings New retry settings
|
|
98
|
+
* @return {OpClient<Op>} Returns the same client as this except with different retry settings.
|
|
99
|
+
*/
|
|
100
|
+
withRetrySettings(retrySettings) {
|
|
101
|
+
return new OpClient(this.op, __classPrivateFieldGet(this, _OpClient_client, "f"), __classPrivateFieldGet(this, _OpClient_eventEmitter, "f"), retrySettings);
|
|
102
|
+
}
|
|
103
|
+
// not private only so that the test can call it
|
|
104
|
+
/**
|
|
105
|
+
* Internal.
|
|
106
|
+
*
|
|
107
|
+
* Executes a given request, potentially retrying on 5xx errors. The
|
|
108
|
+
* retry configuration can be set via the constructor.
|
|
109
|
+
* On all other errors, throws {@link ErrResponse} (as well as after exhausting all retries).
|
|
110
|
+
* On success, returns the response body.
|
|
111
|
+
*
|
|
112
|
+
* @param {ReqFn<T>} req The request to execute and then retry on 5xx errors
|
|
113
|
+
* @return {Promise<FetchResponseSuccessData<T>>}
|
|
114
|
+
* @internal
|
|
115
|
+
*/
|
|
116
|
+
async execute(req) {
|
|
117
|
+
let resp = await req();
|
|
118
|
+
let i = 0;
|
|
119
|
+
while (__classPrivateFieldGet(this, _OpClient_retry, "f").codes.includes(resp.response?.status) && i < __classPrivateFieldGet(this, _OpClient_retry, "f").delaysMs.length) {
|
|
120
|
+
await (0, util_1.delay)(__classPrivateFieldGet(this, _OpClient_retry, "f").delaysMs[i]);
|
|
121
|
+
resp = await req();
|
|
122
|
+
i++;
|
|
123
|
+
}
|
|
124
|
+
return await this.assertOk(resp);
|
|
125
|
+
}
|
|
78
126
|
/* eslint-disable valid-jsdoc */
|
|
79
127
|
/**
|
|
80
128
|
* Invoke HTTP GET
|
|
81
129
|
*/
|
|
82
130
|
async get(url, init) {
|
|
83
|
-
|
|
84
|
-
return await this.assertOk(resp);
|
|
131
|
+
return await this.execute(() => __classPrivateFieldGet(this, _OpClient_client, "f").get(url, init));
|
|
85
132
|
}
|
|
86
133
|
/** Invoke HTTP POST */
|
|
87
134
|
async post(url, init) {
|
|
88
|
-
|
|
89
|
-
return await this.assertOk(resp);
|
|
135
|
+
return await this.execute(() => __classPrivateFieldGet(this, _OpClient_client, "f").post(url, init));
|
|
90
136
|
}
|
|
91
137
|
/** Invoke HTTP PATCH */
|
|
92
138
|
async patch(url, init) {
|
|
93
|
-
|
|
94
|
-
return await this.assertOk(resp);
|
|
139
|
+
return await this.execute(() => __classPrivateFieldGet(this, _OpClient_client, "f").patch(url, init));
|
|
95
140
|
}
|
|
96
141
|
/** Invoke HTTP DELETE */
|
|
97
142
|
async del(url, init) {
|
|
98
|
-
|
|
99
|
-
return await this.assertOk(resp);
|
|
143
|
+
return await this.execute(() => __classPrivateFieldGet(this, _OpClient_client, "f").del(url, init));
|
|
100
144
|
}
|
|
101
145
|
/** Invoke HTTP PUT */
|
|
102
146
|
async put(url, init) {
|
|
103
|
-
|
|
104
|
-
return await this.assertOk(resp);
|
|
147
|
+
return await this.execute(() => __classPrivateFieldGet(this, _OpClient_client, "f").put(url, init));
|
|
105
148
|
}
|
|
106
149
|
}
|
|
107
150
|
exports.OpClient = OpClient;
|
|
108
|
-
_OpClient_op = new WeakMap(), _OpClient_client = new WeakMap(), _OpClient_eventEmitter = new WeakMap();
|
|
151
|
+
_OpClient_op = new WeakMap(), _OpClient_client = new WeakMap(), _OpClient_eventEmitter = new WeakMap(), _OpClient_retry = new WeakMap();
|
|
109
152
|
/**
|
|
110
153
|
* Creates a new HTTP client, setting the "User-Agent" header to this package's {name}@{version}.
|
|
111
154
|
*
|
|
@@ -142,14 +185,18 @@ class CubeSignerApi {
|
|
|
142
185
|
* Constructor.
|
|
143
186
|
* @param {SignerSessionManager} sessionMgr The session manager to use
|
|
144
187
|
* @param {string?} orgId Optional organization ID; if omitted, uses the org ID from the session manager.
|
|
188
|
+
* @param {RetrySettings} retrySettings Retry settings. By default, retries 3 times, sleeping 100ms
|
|
189
|
+
* after the first failed attempt, 200ms after the second, and finally 400ms after the third,
|
|
145
190
|
*/
|
|
146
|
-
constructor(sessionMgr, orgId) {
|
|
191
|
+
constructor(sessionMgr, orgId, retrySettings) {
|
|
147
192
|
_CubeSignerApi_orgId.set(this, void 0);
|
|
148
193
|
_CubeSignerApi_sessionMgr.set(this, void 0);
|
|
149
194
|
_CubeSignerApi_eventEmitter.set(this, void 0);
|
|
195
|
+
_CubeSignerApi_retrySettings.set(this, void 0);
|
|
150
196
|
__classPrivateFieldSet(this, _CubeSignerApi_sessionMgr, sessionMgr, "f");
|
|
151
197
|
__classPrivateFieldSet(this, _CubeSignerApi_eventEmitter, new events_1.EventEmitter([sessionMgr.events]), "f");
|
|
152
198
|
__classPrivateFieldSet(this, _CubeSignerApi_orgId, orgId ?? sessionMgr.orgId, "f");
|
|
199
|
+
__classPrivateFieldSet(this, _CubeSignerApi_retrySettings, retrySettings, "f");
|
|
153
200
|
}
|
|
154
201
|
/**
|
|
155
202
|
* Returns a new instance of this class using the same session manager but targeting a different organization.
|
|
@@ -173,7 +220,7 @@ class CubeSignerApi {
|
|
|
173
220
|
*/
|
|
174
221
|
async client(op) {
|
|
175
222
|
const fetchClient = await __classPrivateFieldGet(this, _CubeSignerApi_sessionMgr, "f").client(op);
|
|
176
|
-
return new OpClient(op, fetchClient, __classPrivateFieldGet(this, _CubeSignerApi_eventEmitter, "f"));
|
|
223
|
+
return new OpClient(op, fetchClient, __classPrivateFieldGet(this, _CubeSignerApi_eventEmitter, "f"), __classPrivateFieldGet(this, _CubeSignerApi_retrySettings, "f"));
|
|
177
224
|
}
|
|
178
225
|
// #region USERS: userGet, userTotp(ResetInit|ResetComplete|Verify|Delete), userFido(RegisterInit|RegisterComplete|Delete)
|
|
179
226
|
/**
|
|
@@ -473,9 +520,10 @@ class CubeSignerApi {
|
|
|
473
520
|
* @param {KeyType} keyType The type of key to create.
|
|
474
521
|
* @param {number} count The number of keys to create.
|
|
475
522
|
* @param {string?} ownerId The owner of the keys. Defaults to the session's user.
|
|
523
|
+
* @param {UpdateKeyProperties?} props Additional key properties
|
|
476
524
|
* @return {KeyInfoApi[]} The new keys.
|
|
477
525
|
*/
|
|
478
|
-
async keysCreate(keyType, count, ownerId) {
|
|
526
|
+
async keysCreate(keyType, count, ownerId, props) {
|
|
479
527
|
const chain_id = 0; // not used anymore
|
|
480
528
|
const client = await this.client("createKey");
|
|
481
529
|
const data = await client.post("/v0/org/{org_id}/keys", {
|
|
@@ -484,7 +532,8 @@ class CubeSignerApi {
|
|
|
484
532
|
count,
|
|
485
533
|
chain_id,
|
|
486
534
|
key_type: keyType,
|
|
487
|
-
|
|
535
|
+
...props,
|
|
536
|
+
owner: props?.owner ?? ownerId,
|
|
488
537
|
},
|
|
489
538
|
});
|
|
490
539
|
return data.keys;
|
|
@@ -1264,7 +1313,7 @@ class CubeSignerApi {
|
|
|
1264
1313
|
}
|
|
1265
1314
|
}
|
|
1266
1315
|
exports.CubeSignerApi = CubeSignerApi;
|
|
1267
|
-
_CubeSignerApi_orgId = new WeakMap(), _CubeSignerApi_sessionMgr = new WeakMap(), _CubeSignerApi_eventEmitter = new WeakMap();
|
|
1316
|
+
_CubeSignerApi_orgId = new WeakMap(), _CubeSignerApi_sessionMgr = new WeakMap(), _CubeSignerApi_eventEmitter = new WeakMap(), _CubeSignerApi_retrySettings = new WeakMap();
|
|
1268
1317
|
/**
|
|
1269
1318
|
* Client to use to send requests to CubeSigner services
|
|
1270
1319
|
* when authenticating using an OIDC token.
|
|
@@ -1274,14 +1323,18 @@ class OidcClient {
|
|
|
1274
1323
|
* @param {EnvInterface} env CubeSigner deployment
|
|
1275
1324
|
* @param {string} orgId Target organization ID
|
|
1276
1325
|
* @param {string} oidcToken User's OIDC token
|
|
1326
|
+
* @param {RetrySettings} retrySettings Retry settings. By default, retries 3 times, sleeping 100ms
|
|
1327
|
+
* after the first failed attempt, 200ms after the second, and finally 400ms after the third.
|
|
1277
1328
|
*/
|
|
1278
|
-
constructor(env, orgId, oidcToken) {
|
|
1329
|
+
constructor(env, orgId, oidcToken, retrySettings) {
|
|
1279
1330
|
_OidcClient_env.set(this, void 0);
|
|
1280
1331
|
_OidcClient_orgId.set(this, void 0);
|
|
1281
1332
|
_OidcClient_client.set(this, void 0);
|
|
1333
|
+
_OidcClient_retrySettings.set(this, void 0);
|
|
1282
1334
|
__classPrivateFieldSet(this, _OidcClient_orgId, orgId, "f");
|
|
1283
1335
|
__classPrivateFieldSet(this, _OidcClient_env, env, "f");
|
|
1284
1336
|
__classPrivateFieldSet(this, _OidcClient_client, createHttpClient(env.SignerApiRoot, oidcToken), "f");
|
|
1337
|
+
__classPrivateFieldSet(this, _OidcClient_retrySettings, retrySettings, "f");
|
|
1285
1338
|
}
|
|
1286
1339
|
/**
|
|
1287
1340
|
* HTTP client restricted to a single operation.
|
|
@@ -1290,7 +1343,7 @@ class OidcClient {
|
|
|
1290
1343
|
* @return {OpClient<Op>} The client restricted to {@link op}
|
|
1291
1344
|
*/
|
|
1292
1345
|
client(op) {
|
|
1293
|
-
return new OpClient(op, __classPrivateFieldGet(this, _OidcClient_client, "f"), new events_1.EventEmitter([]));
|
|
1346
|
+
return new OpClient(op, __classPrivateFieldGet(this, _OidcClient_client, "f"), new events_1.EventEmitter([]), __classPrivateFieldGet(this, _OidcClient_retrySettings, "f"));
|
|
1294
1347
|
}
|
|
1295
1348
|
/**
|
|
1296
1349
|
* Exchange an OIDC token for a CubeSigner session token.
|
|
@@ -1335,11 +1388,11 @@ class OidcClient {
|
|
|
1335
1388
|
}
|
|
1336
1389
|
}
|
|
1337
1390
|
exports.OidcClient = OidcClient;
|
|
1338
|
-
_OidcClient_env = new WeakMap(), _OidcClient_orgId = new WeakMap(), _OidcClient_client = new WeakMap();
|
|
1391
|
+
_OidcClient_env = new WeakMap(), _OidcClient_orgId = new WeakMap(), _OidcClient_client = new WeakMap(), _OidcClient_retrySettings = new WeakMap();
|
|
1339
1392
|
const defaultSignerSessionLifetime = {
|
|
1340
1393
|
session: 604800, // 1 week
|
|
1341
1394
|
auth: 300, // 5 min
|
|
1342
1395
|
refresh: 86400, // 1 day
|
|
1343
1396
|
grace: 30, // seconds
|
|
1344
1397
|
};
|
|
1345
|
-
//# 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  ListKeyRolesResponse,\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  Eip191SignRequest,\n  Eip712SignRequest,\n  Eip191Or712SignResponse,\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  MfaVote,\n  MemberRole,\n  UserExportCompleteResponse,\n  UserExportInitResponse,\n  UserExportListResponse,\n  Empty,\n  ErrorResponse,\n} from \"./schema_types\";\nimport { encodeToBase64 } from \"./util\";\nimport { AddFidoChallenge, MfaFidoChallenge, MfaReceipt, TotpChallenge } from \"./mfa\";\nimport { CubeSignerResponse, mapResponse } from \"./response\";\nimport { ErrResponse } from \"./error\";\nimport { Key, KeyType } from \"./key\";\nimport { Page, PageOpts, PageQueryArgs, Paginator } from \"./paginator\";\nimport { KeyPolicy } from \"./role\";\nimport { EnvInterface } from \"./env\";\nimport { loadSubtleCrypto } from \"./user_export\";\nimport { EventEmitter } from \"./events\";\nimport { NAME, VERSION } from \"./index\";\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 * 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 errResp = resp.error as unknown as ErrorResponse | undefined;\n      const error = new ErrResponse({\n        operation: this.op,\n        message: errResp?.message,\n        statusText: resp.response?.statusText,\n        status: resp.response?.status,\n        url: resp.response?.url,\n        errorCode: errResp?.error_code,\n      });\n      await 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    cache: \"no-store\",\n    headers: {\n      Authorization: authToken,\n      [\"User-Agent\"]: `${NAME}@${VERSION}`,\n      [\"X-Cubist-Ts-Sdk\"]: `${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(op);\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   * List all roles a key is in.\n   *\n   * @param {string} keyId The id of the key to get.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListKeyRolesResponse, KeyInRoleInfo>} Paginator for iterating over the roles a key is in.\n   */\n  keyRolesList(keyId: string, page?: PageOpts): Paginator<ListKeyRolesResponse, KeyInRoleInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client(\"listKeyRoles\");\n      return await client.get(\"/v0/org/{org_id}/keys/{key_id}/roles\", {\n        params: {\n          path: { org_id: this.orgId, key_id: keyId },\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  /**\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, roleUserRemove, 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   * Remove an existing user from an existing role.\n   *\n   * @param {string} roleId The ID of the role.\n   * @param {string} userId The ID of the user to remove from the role.\n   */\n  async roleUserRemove(roleId: string, userId: string) {\n    const client = await this.client(\"removeUserFromRole\");\n    await client.del(\"/v0/org/{org_id}/roles/{role_id}/users/{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      session_exp: data.expiration!,\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      session_exp: data.expiration!,\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 or reject a pending MFA request using the current session.\n   *\n   * @param {string} mfaId The id of the MFA request\n   * @param {MfaVote} mfaVote Approve or reject the MFA request\n   * @return {Promise<MfaRequestInfo>} The result of the MFA request\n   */\n  async mfaVoteCs(mfaId: string, mfaVote: MfaVote): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaVoteCs\");\n    return await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}\", {\n      params: { path: { org_id: this.orgId, mfa_id: mfaId }, query: { mfa_vote: mfaVote } },\n    });\n  }\n\n  /**\n   * Approve or reject a pending MFA request using TOTP.\n   *\n   * @param {string} mfaId The ID of the MFA request\n   * @param {string} code The TOTP code\n   * @param {MfaVote} mfaVote Approve or reject the MFA request\n   * @return {Promise<MfaRequestInfo>} The current status of the MFA request\n   */\n  async mfaVoteTotp(mfaId: string, code: string, mfaVote: MfaVote): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaVoteTotp\");\n    return await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}/totp\", {\n      params: { path: { org_id: this.#orgId, mfa_id: mfaId }, query: { mfa_vote: mfaVote } },\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 mfaFidoInit(mfaId: string): Promise<MfaFidoChallenge> {\n    const client = await this.client(\"mfaFidoInit\");\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 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 {MfaVote} mfaVote Approve or reject the MFA request\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 mfaVoteFidoComplete(\n    mfaId: string,\n    mfaVote: MfaVote,\n    challengeId: string,\n    credential: PublicKeyCredential,\n  ): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaVoteFidoComplete\");\n    return await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", {\n      params: { path: { org_id: this.orgId, mfa_id: mfaId }, query: { mfa_vote: mfaVote } },\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 EIP-191 typed data.\n   *\n   * This requires the key to have a '\"AllowEip191Signing\"' {@link KeyPolicy}.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {BlobSignRequest} req What to sign\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip191(\n    key: Key | string,\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"eip191Sign\");\n      return await client.post(\"/v0/org/{org_id}/evm/eip191/sign/{pubkey}\", {\n        params: {\n          path: { org_id: this.orgId, pubkey },\n        },\n        body: req,\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign EIP-712 typed data.\n   *\n   * This requires the key to have a '\"AllowEip712Signing\"' {@link KeyPolicy}.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {BlobSignRequest} req What to sign\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip712(\n    key: Key | string,\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"eip712Sign\");\n      return await client.post(\"/v0/org/{org_id}/evm/eip712/sign/{pubkey}\", {\n        params: {\n          path: { org_id: this.orgId, pubkey },\n        },\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  // #region MISC: heartbeat()\n  /**\n   * Send a heartbeat / upcheck request.\n   *\n   * @return { Promise<void> } The response.\n   */\n  async heartbeat(): Promise<void> {\n    const client = await this.client(\"cube3signerHeartbeat\");\n    await client.post(\"/v1/org/{org_id}/cube3signer/heartbeat\", {\n      params: {\n        path: { org_id: this.orgId },\n      },\n    });\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"]}
|
|
1398
|
+
//# 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  ListKeyRolesResponse,\n  ListRoleKeysResponse,\n  ListRoleUsersResponse,\n  ListRolesResponse,\n  OidcIdentity,\n  SessionsResponse,\n  PublicKeyCredential,\n  RoleInfo,\n  UpdateKeyRequest,\n  UpdateOrgRequest,\n  UpdateOrgResponse,\n  UpdateRoleRequest,\n  UserInOrgInfo,\n  UserInRoleInfo,\n  UserInfo,\n  SessionInfo,\n  OrgInfo,\n  RatchetConfig,\n  Eip191SignRequest,\n  Eip712SignRequest,\n  Eip191Or712SignResponse,\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  MfaVote,\n  MemberRole,\n  UserExportCompleteResponse,\n  UserExportInitResponse,\n  UserExportListResponse,\n  Empty,\n  ErrorResponse,\n} from \"./schema_types\";\nimport { delay, encodeToBase64 } from \"./util\";\nimport { AddFidoChallenge, MfaFidoChallenge, MfaReceipt, TotpChallenge } from \"./mfa\";\nimport { CubeSignerResponse, mapResponse } from \"./response\";\nimport { ErrResponse } from \"./error\";\nimport { Key, KeyType } from \"./key\";\nimport { Page, PageOpts, PageQueryArgs, Paginator } from \"./paginator\";\nimport { KeyPolicy } from \"./role\";\nimport { EnvInterface } from \"./env\";\nimport { loadSubtleCrypto } from \"./user_export\";\nimport { EventEmitter } from \"./events\";\nimport { NAME, UpdateKeyProperties, VERSION } from \"./index\";\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 * Internal type for a function that returns a promise of a fetch response.\n */\ntype ReqFn<T> = () => Promise<FetchResponse<T>>;\n\n/**\n * Retry settings.\n *\n * By default, {@link OpClient} retries on 5xx codes with delays of\n * 100ms, 200ms, and 400ms between retries.\n */\nexport interface RetrySettings {\n  /** HTTP status codes on which to retry */\n  codes: number[];\n  /** Delays in milliseconds between retries */\n  delaysMs: number[];\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  readonly #retry: RetrySettings;\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   * @param {number[]} retrySettings Retry settings. By default, retries 3 times, sleeping 100ms\n   *  after the first failed attempt, 200ms after the second, and finally 400ms after the third,\n   */\n  constructor(\n    op: Op,\n    client: FetchClient<Op> | Client,\n    eventEmitter: EventEmitter,\n    retrySettings?: RetrySettings,\n  ) {\n    this.#op = op;\n    this.#client = client as FetchClient<Op>; // either works\n    this.#eventEmitter = eventEmitter;\n    this.#retry = retrySettings ?? {\n      codes: [...Array(100).keys()].map((i) => 500 + i),\n      delaysMs: [100, 200, 400],\n    };\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 errResp = resp.error as unknown as ErrorResponse | undefined;\n      const error = new ErrResponse({\n        operation: this.op,\n        requestId: errResp?.request_id,\n        message: errResp?.message,\n        statusText: resp.response?.statusText,\n        status: resp.response?.status,\n        url: resp.response?.url,\n        errorCode: errResp?.error_code,\n      });\n      await 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  /**\n   * @param {number[]} delaysMs Delays in milliseconds between retries.\n   * @return {OpClient<Op>} Returns the same client as this except with different retry delays.\n   */\n  withRetries(delaysMs: number[]): OpClient<Op> {\n    return this.withRetrySettings({\n      codes: this.#retry.codes,\n      delaysMs,\n    });\n  }\n\n  /**\n   * @param {RetrySettings} retrySettings New retry settings\n   * @return {OpClient<Op>} Returns the same client as this except with different retry settings.\n   */\n  withRetrySettings(retrySettings: RetrySettings): OpClient<Op> {\n    return new OpClient(this.op, this.#client, this.#eventEmitter, retrySettings);\n  }\n\n  // not private only so that the test can call it\n  /**\n   * Internal.\n   *\n   * Executes a given request, potentially retrying on 5xx errors. The\n   * retry configuration can be set via the constructor.\n   * On all other errors, throws {@link ErrResponse} (as well as after exhausting all retries).\n   * On success, returns the response body.\n   *\n   * @param {ReqFn<T>} req The request to execute and then retry on 5xx errors\n   * @return {Promise<FetchResponseSuccessData<T>>}\n   * @internal\n   */\n  async execute<T>(req: ReqFn<T>): Promise<FetchResponseSuccessData<T>> {\n    let resp = await req();\n    let i = 0;\n    while (this.#retry.codes.includes(resp.response?.status) && i < this.#retry.delaysMs.length) {\n      await delay(this.#retry.delaysMs[i]);\n      resp = await req();\n      i++;\n    }\n    return await this.assertOk(resp);\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    return await this.execute(() => this.#client.get(url, init));\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    return await this.execute(() => this.#client.post(url, init));\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    return await this.execute(() => this.#client.patch(url, init));\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    return await this.execute(() => this.#client.del(url, init));\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    return await this.execute(() => this.#client.put(url, init));\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    cache: \"no-store\",\n    headers: {\n      Authorization: authToken,\n      [\"User-Agent\"]: `${NAME}@${VERSION}`,\n      [\"X-Cubist-Ts-Sdk\"]: `${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  readonly #retrySettings?: RetrySettings;\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   * @param {RetrySettings} retrySettings Retry settings. By default, retries 3 times, sleeping 100ms\n   *   after the first failed attempt, 200ms after the second, and finally 400ms after the third,\n   */\n  constructor(sessionMgr: SignerSessionManager, orgId?: string, retrySettings?: RetrySettings) {\n    this.#sessionMgr = sessionMgr;\n    this.#eventEmitter = new EventEmitter([sessionMgr.events]);\n    this.#orgId = orgId ?? sessionMgr.orgId;\n    this.#retrySettings = retrySettings;\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(op);\n    return new OpClient(op, fetchClient, this.#eventEmitter, this.#retrySettings);\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<UserInOrgInfo[]> {\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   * List all roles a key is in.\n   *\n   * @param {string} keyId The id of the key to get.\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListKeyRolesResponse, KeyInRoleInfo>} Paginator for iterating over the roles a key is in.\n   */\n  keyRolesList(keyId: string, page?: PageOpts): Paginator<ListKeyRolesResponse, KeyInRoleInfo> {\n    const listFn = async (query: PageQueryArgs) => {\n      const client = await this.client(\"listKeyRoles\");\n      return await client.get(\"/v0/org/{org_id}/keys/{key_id}/roles\", {\n        params: {\n          path: { org_id: this.orgId, key_id: keyId },\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  /**\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   * @param {UpdateKeyProperties?} props Additional key properties\n   * @return {KeyInfoApi[]} The new keys.\n   */\n  async keysCreate(\n    keyType: KeyType,\n    count: number,\n    ownerId?: string,\n    props?: UpdateKeyProperties,\n  ): 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        ...props,\n        owner: props?.owner ?? ownerId,\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, roleUserRemove, 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   * Remove an existing user from an existing role.\n   *\n   * @param {string} roleId The ID of the role.\n   * @param {string} userId The ID of the user to remove from the role.\n   */\n  async roleUserRemove(roleId: string, userId: string) {\n    const client = await this.client(\"removeUserFromRole\");\n    await client.del(\"/v0/org/{org_id}/roles/{role_id}/users/{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      session_exp: data.expiration!,\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      session_exp: data.expiration!,\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 or reject a pending MFA request using the current session.\n   *\n   * @param {string} mfaId The id of the MFA request\n   * @param {MfaVote} mfaVote Approve or reject the MFA request\n   * @return {Promise<MfaRequestInfo>} The result of the MFA request\n   */\n  async mfaVoteCs(mfaId: string, mfaVote: MfaVote): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaVoteCs\");\n    return await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}\", {\n      params: { path: { org_id: this.orgId, mfa_id: mfaId }, query: { mfa_vote: mfaVote } },\n    });\n  }\n\n  /**\n   * Approve or reject a pending MFA request using TOTP.\n   *\n   * @param {string} mfaId The ID of the MFA request\n   * @param {string} code The TOTP code\n   * @param {MfaVote} mfaVote Approve or reject the MFA request\n   * @return {Promise<MfaRequestInfo>} The current status of the MFA request\n   */\n  async mfaVoteTotp(mfaId: string, code: string, mfaVote: MfaVote): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaVoteTotp\");\n    return await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}/totp\", {\n      params: { path: { org_id: this.#orgId, mfa_id: mfaId }, query: { mfa_vote: mfaVote } },\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 mfaFidoInit(mfaId: string): Promise<MfaFidoChallenge> {\n    const client = await this.client(\"mfaFidoInit\");\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 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 {MfaVote} mfaVote Approve or reject the MFA request\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 mfaVoteFidoComplete(\n    mfaId: string,\n    mfaVote: MfaVote,\n    challengeId: string,\n    credential: PublicKeyCredential,\n  ): Promise<MfaRequestInfo> {\n    const client = await this.client(\"mfaVoteFidoComplete\");\n    return await client.patch(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", {\n      params: { path: { org_id: this.orgId, mfa_id: mfaId }, query: { mfa_vote: mfaVote } },\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 EIP-191 typed data.\n   *\n   * This requires the key to have a '\"AllowEip191Signing\"' {@link KeyPolicy}.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {BlobSignRequest} req What to sign\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip191(\n    key: Key | string,\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"eip191Sign\");\n      return await client.post(\"/v0/org/{org_id}/evm/eip191/sign/{pubkey}\", {\n        params: {\n          path: { org_id: this.orgId, pubkey },\n        },\n        body: req,\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign EIP-712 typed data.\n   *\n   * This requires the key to have a '\"AllowEip712Signing\"' {@link KeyPolicy}.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {BlobSignRequest} req What to sign\n   * @param {MfaReceipt} mfaReceipt Optional MFA receipt\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip712(\n    key: Key | string,\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipt,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) => {\n      const client = await this.client(\"eip712Sign\");\n      return await client.post(\"/v0/org/{org_id}/evm/eip712/sign/{pubkey}\", {\n        params: {\n          path: { org_id: this.orgId, pubkey },\n        },\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  // #region MISC: heartbeat()\n  /**\n   * Send a heartbeat / upcheck request.\n   *\n   * @return { Promise<void> } The response.\n   */\n  async heartbeat(): Promise<void> {\n    const client = await this.client(\"cube3signerHeartbeat\");\n    await client.post(\"/v1/org/{org_id}/cube3signer/heartbeat\", {\n      params: {\n        path: { org_id: this.orgId },\n      },\n    });\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  readonly #retrySettings?: RetrySettings;\n\n  /**\n   * @param {EnvInterface} env CubeSigner deployment\n   * @param {string} orgId Target organization ID\n   * @param {string} oidcToken User's OIDC token\n   * @param {RetrySettings} retrySettings Retry settings. By default, retries 3 times, sleeping 100ms\n   *  after the first failed attempt, 200ms after the second, and finally 400ms after the third.\n   */\n  constructor(env: EnvInterface, orgId: string, oidcToken: string, retrySettings?: RetrySettings) {\n    this.#orgId = orgId;\n    this.#env = env;\n    this.#client = createHttpClient(env.SignerApiRoot, oidcToken);\n    this.#retrySettings = retrySettings;\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([]), this.#retrySettings);\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"]}
|