@cubist-labs/cubesigner-sdk 0.4.88-0 → 0.4.89-0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cubist-labs/cubesigner-sdk",
3
- "version": "0.4.88-0",
3
+ "version": "0.4.89-0",
4
4
  "description": "CubeSigner TypeScript SDK",
5
5
  "license": "MIT OR Apache-2.0",
6
6
  "author": "Cubist, Inc.",
@@ -1 +1 @@
1
- {"version":3,"file":"api_client.d.ts","sourceRoot":"","sources":["../../../src/client/api_client.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"api_client.d.ts","sourceRoot":"","sources":["../../../src/client/api_client.ts"],"names":[],"mappings":"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"}
@@ -1403,16 +1403,19 @@ class ApiClient extends base_client_1.BaseClient {
1403
1403
  tokens: lifetimes,
1404
1404
  },
1405
1405
  })).then(fetch_1.assertOk);
1406
- return (0, response_1.mapResponse)(data, (sessionInfo) => ({
1407
- env: {
1408
- ["Dev-CubeSignerStack"]: env,
1409
- },
1410
- org_id: orgId,
1411
- token: sessionInfo.token,
1412
- session_exp: sessionInfo.expiration,
1413
- purpose: "sign in via oidc",
1414
- session_info: sessionInfo.session_info,
1415
- }));
1406
+ return (0, response_1.mapResponse)(data, (sessionInfo) => {
1407
+ return {
1408
+ env: {
1409
+ ["Dev-CubeSignerStack"]: env,
1410
+ },
1411
+ org_id: orgId,
1412
+ token: sessionInfo.token,
1413
+ refresh_token: sessionInfo.refresh_token,
1414
+ session_exp: sessionInfo.expiration,
1415
+ purpose: "sign in via oidc",
1416
+ session_info: sessionInfo.session_info,
1417
+ };
1418
+ });
1416
1419
  };
1417
1420
  return await response_1.CubeSignerResponse.create(env, loginFn, mfaReceipt);
1418
1421
  }
@@ -1537,4 +1540,4 @@ const defaultSignerSessionLifetime = {
1537
1540
  refresh: 86400, // 1 day
1538
1541
  grace: 30, // seconds
1539
1542
  };
1540
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api_client.js","sourceRoot":"","sources":["../../../src/client/api_client.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  CreateOidcUserOptions,\n  IdentityProof,\n  KeyInRoleInfo,\n  KeyInfo,\n  OidcIdentity,\n  PublicKeyCredential,\n  RoleInfo,\n  UpdateKeyRequest,\n  UpdateOrgRequest,\n  UpdateOrgResponse,\n  UpdateRoleRequest,\n  UserInOrgInfo,\n  UserInRoleInfo,\n  GetUsersInOrgResponse,\n  UserInfo,\n  SessionInfo,\n  OrgInfo,\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  BtcMessageSignResponse,\n  BtcMessageSignRequest,\n  PsbtSignRequest,\n  PsbtSignResponse,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  AvaSignResponse,\n  AvaSignRequest,\n  AvaSerializedTxSignRequest,\n  AvaTx,\n  MfaRequestInfo,\n  MfaVote,\n  MemberRole,\n  UserExportCompleteResponse,\n  UserExportInitResponse,\n  UserExportListResponse,\n  Empty,\n  UserOrgsResponse,\n  CreateKeyImportKeyResponse,\n  ImportKeyRequest,\n} from \"../schema_types\";\nimport { encodeToBase64 } from \"../util\";\nimport { AddFidoChallenge, MfaFidoChallenge, TotpChallenge } from \"../mfa\";\nimport { CubeSignerResponse, mapResponse } from \"../response\";\nimport type { Key, KeyType } from \"../key\";\nimport type { PageOpts } from \"../paginator\";\nimport { Page, Paginator } from \"../paginator\";\nimport type { KeyPolicy } from \"../role\";\nimport { loadSubtleCrypto } from \"../user_export\";\nimport type {\n  AddIdentityRequest,\n  AvaChain,\n  EnvInterface,\n  EotsCreateNonceRequest,\n  EotsCreateNonceResponse,\n  EotsSignRequest,\n  EotsSignResponse,\n  JrpcResponse,\n  JsonArray,\n  ListIdentityResponse,\n  ListKeyRolesResponse,\n  ListKeysResponse,\n  ListRoleKeysResponse,\n  ListRoleUsersResponse,\n  ListRolesResponse,\n  MmiJrpcMethod,\n  PendingMessageInfo,\n  PendingMessageSignResponse,\n  RatchetConfig,\n  Scope,\n  SessionData,\n  SessionLifetime,\n  SessionsResponse,\n  TaprootSignRequest,\n  TaprootSignResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  UpdateUserMembershipRequest,\n  HistoricalTx,\n  ListHistoricalTxResponse,\n  PublicOrgInfo,\n  ImportDeriveKeyProperties,\n  PasswordResetRequest,\n  EmailOtpResponse,\n  AuthenticationRequest,\n  AuthenticationResponse,\n  CreateKeyProperties,\n  InvitationAcceptRequest,\n  MfaReceipts,\n} from \"../index\";\nimport { assertOk, op } from \"../fetch\";\nimport { BaseClient, signerSessionFromSessionInfo } from \"./base_client\";\nimport { retryOn5XX } from \"../retry\";\n\n/**\n * String returned by API when a user does not have an email address (for backwards compatibility)\n */\nconst EMAIL_NOT_FOUND = \"email not found\";\n\n/**\n * Session selector.\n */\nexport type SessionSelector =\n  /**\n   * Selects all sessions tied to a role with this ID\n   * @deprecated Use `{ role: string }` instead\n   */\n  | string\n  | {\n      /** Selects all sessions tied to a role with this ID */\n      role: string;\n    }\n  | {\n      /** Selects all sessions tied to a user with this ID. */\n      user: string;\n    };\n\n/**\n * An extension of BaseClient that adds specialized methods for api endpoints\n */\nexport class ApiClient extends BaseClient {\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    const o = op(\"/v0/org/{org_id}/user/me\", \"get\");\n\n    return this.exec(o, {}).then(ApiClient.#processUserInfo);\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 ApiClient.userTotpResetComplete}).\n   *\n   * @param {string} issuer Optional issuer; defaults to \"Cubist\"\n   * @param {MfaReceipts} mfaReceipt MFA receipt(s) to include in HTTP headers\n   */\n  async userTotpResetInit(\n    issuer?: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<TotpChallenge>> {\n    const o = op(\"/v0/org/{org_id}/user/me/totp\", \"post\");\n    const resetTotpFn = async (headers?: HeadersInit) => {\n      const data = await this.exec(o, {\n        headers,\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(this.env, 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 o = op(\"/v0/org/{org_id}/user/me/totp\", \"patch\");\n    await this.exec(o, {\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 o = op(\"/v0/org/{org_id}/user/me/totp/verify\", \"post\");\n\n    await this.exec(o, {\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s) to include in HTTP headers\n   */\n  async userTotpDelete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    const o = op(\"/v0/org/{org_id}/user/me/totp\", \"delete\");\n    const deleteTotpFn = async (headers?: HeadersInit) => {\n      return await this.exec(o, {\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s) 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?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AddFidoChallenge>> {\n    const o = op(\"/v0/org/{org_id}/user/me/fido\", \"post\");\n    const addFidoFn = async (headers?: HeadersInit) => {\n      const data = await this.exec(o, {\n        headers,\n        body: { name },\n      });\n      return mapResponse(data, (c) => new AddFidoChallenge(this, c));\n    };\n    return await CubeSignerResponse.create(this.env, 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 o = op(\"/v0/org/{org_id}/user/me/fido\", \"patch\");\n\n    return this.exec(o, {\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s) to include in HTTP headers\n   */\n  async userFidoDelete(\n    fidoId: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Empty>> {\n    const deleteFidoFn = (headers?: HeadersInit) => {\n      const o = op(\"/v0/org/{org_id}/user/me/fido/{fido_id}\", \"delete\");\n\n      return this.exec(o, {\n        headers,\n        params: { path: { fido_id: fidoId } },\n      });\n    };\n    return await CubeSignerResponse.create(this.env, deleteFidoFn, mfaReceipt);\n  }\n\n  // #endregion\n\n  // #region ORGS: orgGet, orgUpdate, orgUpdateUserMembership\n\n  /**\n   * Obtain information about an org\n   *\n   * @param {string | undefined} orgId The org to get info for\n   * @return {OrgInfo} Information about the organization.\n   */\n  async orgGet(orgId?: string): Promise<OrgInfo> {\n    const o = op(\"/v0/org/{org_id}\", \"get\");\n    return this.exec(o, {\n      params: {\n        path: { org_id: orgId ?? this.sessionMeta.org_id },\n      },\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 o = op(\"/v0/org/{org_id}\", \"patch\");\n\n    return this.exec(o, { body: request });\n  }\n\n  /**\n   * Update user's membership in this org.\n   * @param {string} userId The ID of the user whose membership to update.\n   * @param {UpdateUserMembershipRequest} req The update request\n   * @return {Promise<UserInOrgInfo>} Updated user membership\n   */\n  async orgUpdateUserMembership(\n    userId: string,\n    req: UpdateUserMembershipRequest,\n  ): Promise<UserInOrgInfo> {\n    const o = op(\"/v0/org/{org_id}/users/{user_id}/membership\", \"patch\");\n    return this.exec(o, {\n      params: { path: { user_id: userId } },\n      body: req,\n    }).then(ApiClient.#processUserInOrgInfo);\n  }\n\n  // #endregion\n\n  // #region ORG USERS: orgUserInvite, orgUserDelete, orgUsersList, orgUserGet, 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   * @param {boolean} skipEmail Optionally skip sending the invite email.\n   */\n  async orgUserInvite(\n    email: string,\n    name: string,\n    role?: MemberRole,\n    skipEmail?: boolean,\n  ): Promise<void> {\n    const o = op(\"/v0/org/{org_id}/invite\", \"post\");\n\n    await this.exec(o, {\n      body: {\n        email,\n        name,\n        role,\n        skip_email: !!skipEmail,\n      },\n    });\n  }\n\n  /**\n   * Remove the user from the org.\n   * @param {string} userId The ID of the user to remove.\n   */\n  async orgUserDelete(userId: string): Promise<Empty> {\n    const o = op(\"/v0/org/{org_id}/users/{user_id}\", \"delete\");\n\n    return this.exec(o, {\n      params: {\n        path: {\n          user_id: userId,\n        },\n      },\n    });\n  }\n\n  /**\n   * List users in the org.\n   *\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<GetUsersInOrgResponse, UserInOrgInfo>} Paginator for iterating over the users in the org.\n   */\n  orgUsersList(page?: PageOpts): Paginator<GetUsersInOrgResponse, UserInOrgInfo> {\n    const o = op(\"/v0/org/{org_id}/users\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) => this.exec(o, { params: { path: {}, ...query } }),\n      (r) => r.users.map(ApiClient.#processUserInOrgInfo),\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  /**\n   * Get user by id.\n   * @param {string} userId The id of the user to get.\n   * @return {UserInOrgInfo} Org user.\n   */\n  async orgUserGet(userId: string): Promise<UserInOrgInfo> {\n    const o = op(\"/v0/org/{org_id}/users/{user_id}\", \"get\");\n\n    const resp = await this.exec(o, {\n      params: {\n        path: {\n          user_id: userId,\n        },\n      },\n    });\n    return ApiClient.#processUserInOrgInfo(resp);\n  }\n\n  /**\n   * Create a new OIDC user. This can be a first-party \"Member\" or third-party \"Alien\".\n   * @param {OidcIdentity | IdentityProof} identityOrProof The identity or\n   *   identity proof 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    identityOrProof: OidcIdentity | IdentityProof,\n    email?: string | null,\n    opts: CreateOidcUserOptions = {},\n  ): Promise<string> {\n    const o = op(\"/v0/org/{org_id}/users\", \"post\");\n\n    const identityOrProofFields =\n      \"id\" in identityOrProof ? { proof: identityOrProof } : { identity: identityOrProof };\n\n    const { user_id } = await this.exec(o, {\n      body: {\n        role: opts.memberRole ?? \"Alien\",\n        email,\n        name: opts.name,\n        mfa_policy: opts.mfaPolicy,\n        ...identityOrProofFields,\n      },\n    });\n\n    return 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 o = op(\"/v0/org/{org_id}/users/oidc\", \"delete\");\n\n    return this.exec(o, {\n      body: identity,\n    });\n  }\n\n  // #endregion\n\n  // #region KEYS: keyGet, keyUpdate, keyDelete, keysCreate, keysDerive, keysList, keyHistory\n\n  /**\n   * Get a key by its id.\n   *\n   * @param {string} keyId The id of the key to get.\n   * @return {KeyInfo} The key information.\n   */\n  async keyGet(keyId: string): Promise<KeyInfo> {\n    const o = op(\"/v0/org/{org_id}/keys/{key_id}\", \"get\");\n\n    return this.exec(o, {\n      params: { path: { key_id: keyId } },\n    });\n  }\n\n  /**\n   * Get a key by its type and material id.\n   *\n   * @param {KeyType} keyType The key type.\n   * @param {string} materialId The material id of the key to get.\n   * @return {KeyInfo} The key information.\n   */\n  async keyGetByMaterialId(keyType: KeyType, materialId: string): Promise<KeyInfo> {\n    const o = op(\"/v0/org/{org_id}/keys/{key_type}/{material_id}\", \"get\");\n\n    return this.exec(o, {\n      params: { path: { key_type: keyType, material_id: materialId } },\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 o = op(\"/v0/org/{org_id}/keys/{key_id}/roles\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) =>\n        this.exec(o, {\n          params: {\n            path: { key_id: keyId },\n            ...query,\n          },\n        }),\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 {KeyInfo} The JSON response from the API server.\n   */\n  async keyUpdate(keyId: string, request: UpdateKeyRequest): Promise<KeyInfo> {\n    const o = op(\"/v0/org/{org_id}/keys/{key_id}\", \"patch\");\n\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/keys/{key_id}\", \"delete\");\n    await this.exec(o, {\n      params: { path: { 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 {KeyProperties?} props Additional key properties\n   * @return {KeyInfo[]} The new keys.\n   */\n  async keysCreate(\n    keyType: KeyType,\n    count: number,\n    ownerId?: string,\n    props?: CreateKeyProperties,\n  ): Promise<KeyInfo[]> {\n    const chain_id = 0; // not used anymore\n\n    const o = op(\"/v0/org/{org_id}/keys\", \"post\");\n\n    const policy = (props?.policy ?? null) as Record<string, never>[] | null;\n    const { keys } = await this.exec(o, {\n      body: {\n        count,\n        chain_id,\n        key_type: keyType,\n        ...props,\n        owner: props?.owner ?? ownerId,\n        policy,\n      },\n    });\n    return 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 material_id of mnemonic key used to derive the new key.\n   * @param { ImportDeriveKeyProperties? } props Additional options for derivation.\n   *\n   * @return {KeyInfo[]} The newly derived keys.\n   */\n  async keysDerive(\n    keyType: KeyType,\n    derivationPaths: string[],\n    mnemonicId: string,\n    props?: ImportDeriveKeyProperties,\n  ): Promise<KeyInfo[]> {\n    const o = op(\"/v0/org/{org_id}/derive_key\", \"put\");\n\n    const policy = (props?.policy ?? null) as Record<string, never>[] | null;\n    const { keys } = await this.exec(o, {\n      body: {\n        derivation_path: derivationPaths,\n        mnemonic_id: mnemonicId,\n        key_type: keyType,\n        ...props,\n        policy,\n      },\n    });\n\n    return 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   * @param {string?} owner Optional key owner to filter list for.\n   * @param {string?} search Optionally search by key's material ID and metadata\n   * @return {Paginator<ListKeysResponse, KeyInfo>} Paginator for iterating over keys.\n   */\n  keysList(\n    type?: KeyType,\n    page?: PageOpts,\n    owner?: string,\n    search?: string,\n  ): Paginator<ListKeysResponse, KeyInfo> {\n    const o = op(\"/v0/org/{org_id}/keys\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) =>\n        this.exec(o, { params: { query: { key_type: type, key_owner: owner, search, ...query } } }),\n      (r) => r.keys,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  /**\n   * List recent historical key transactions.\n   *\n   * @param {string} keyId The key id.\n   * @param {PageOpts?} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListHistoricalTxResponse, HistoricalTx>} Paginator for iterating over historical transactions.\n   */\n  keyHistory(keyId: string, page?: PageOpts): Paginator<ListHistoricalTxResponse, HistoricalTx> {\n    const o = op(\"/v0/org/{org_id}/keys/{key_id}/tx\", \"get\");\n    return new Paginator(\n      page ?? Page.default(),\n      () => this.exec(o, { params: { path: { key_id: keyId } } }),\n      (r) => r.txs,\n      (r) => r.last_evaluated_key,\n    );\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 o = op(\"/v0/org/{org_id}/roles\", \"post\");\n\n    const data = await this.exec(o, {\n      body: name ? { name } : undefined,\n    });\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 o = op(\"/v0/org/{org_id}/roles/{role_id}\", \"get\");\n\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}\", \"patch\");\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}\", \"delete\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles\", \"get\");\n    return new Paginator(\n      page ?? Page.default(),\n      (query) => this.exec(o, { params: { query } }),\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 o = op(\"/v0/org/{org_id}/roles/{role_id}/add_keys\", \"put\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}/keys/{key_id}\", \"delete\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}/keys\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) =>\n        this.exec(o, {\n          params: {\n            path: { role_id: roleId },\n            query,\n          },\n        }),\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 o = op(\"/v0/org/{org_id}/roles/{role_id}/add_user/{user_id}\", \"put\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}/users/{user_id}\", \"delete\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}/users\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) => this.exec(o, { params: { query, path: { role_id: roleId } } }),\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). The lifetime of\n   * the new session is silently truncated to that of the current session.\n   *\n   * @param {string} purpose The purpose of the session\n   * @param {Scope[]} scopes Session scopes.\n   * @param {SessionLifetime} lifetimes Lifetime settings\n   * @return {Promise<SessionData>} New signer session info.\n   */\n  async sessionCreate(\n    purpose: string,\n    scopes: Scope[],\n    lifetimes?: SessionLifetime,\n  ): Promise<SessionData> {\n    lifetimes ??= defaultSignerSessionLifetime;\n    const o = op(\"/v0/org/{org_id}/session\", \"post\");\n\n    const data = await this.exec(o, {\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 signerSessionFromSessionInfo(this.sessionMeta, data, {\n      purpose,\n    });\n  }\n\n  /**\n   * Create new user session (management and/or signing) whose lifetime potentially\n   * extends the lifetime of the current session.  MFA is always required.\n   *\n   * @param {string} purpose The purpose of the session\n   * @param {Scope[]} scopes Session scopes.\n   * @param {SessionLifetime} lifetime Lifetime settings\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<CubeSignerResponse<SessionData>>} New signer session info.\n   */\n  async sessionCreateExtended(\n    purpose: string,\n    scopes: Scope[],\n    lifetime: SessionLifetime,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SessionData>> {\n    const o = op(\"/v0/org/{org_id}/session\", \"post\");\n\n    const requestFn = async (headers?: HeadersInit) => {\n      const resp = await this.exec(o, {\n        headers,\n        body: {\n          purpose,\n          scopes,\n          extend_lifetimes: true,\n          auth_lifetime: lifetime.auth,\n          refresh_lifetime: lifetime.refresh,\n          session_lifetime: lifetime.session,\n          grace_lifetime: lifetime.grace,\n        },\n      });\n      return mapResponse(resp, (sessionInfo) =>\n        signerSessionFromSessionInfo(this.sessionMeta, sessionInfo, {\n          purpose,\n        }),\n      );\n    };\n    return await CubeSignerResponse.create(this.env, requestFn, mfaReceipt);\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 {Scope[]} scopes Session scopes. Not all scopes are valid for a role.\n   * @param {SessionLifetime} lifetimes Lifetime settings\n   * @return {Promise<SessionData>} New signer session info.\n   */\n  async sessionCreateForRole(\n    roleId: string,\n    purpose: string,\n    scopes?: Scope[],\n    lifetimes?: SessionLifetime,\n  ): Promise<SessionData> {\n    lifetimes ??= defaultSignerSessionLifetime;\n    const o = op(\"/v0/org/{org_id}/roles/{role_id}/tokens\", \"post\");\n    const data = await this.exec(o, {\n      params: { path: { 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\n    return signerSessionFromSessionInfo(this.sessionMeta, data, {\n      role_id: roleId,\n      purpose,\n    });\n  }\n\n  /**\n   * Revoke a session.\n   *\n   * @param {string} [sessionId] The ID of the session to revoke. This session by default\n   */\n  async sessionRevoke(sessionId?: string) {\n    const o = op(\"/v0/org/{org_id}/session/{session_id}\", \"delete\");\n    await this.exec(o, {\n      params: { path: { session_id: sessionId ?? \"self\" } },\n    });\n  }\n\n  /**\n   * Revoke all sessions.\n   *\n   * @param {SessionSelector?} [selector] Which sessions to revoke.\n   *  If not defined, all the current user's sessions will be revoked.\n   */\n  async sessionRevokeAll(selector?: SessionSelector) {\n    const o = op(\"/v0/org/{org_id}/session\", \"delete\");\n    const query = typeof selector === \"string\" ? { role: selector } : selector;\n    await this.exec(o, {\n      params: { query },\n    });\n  }\n\n  /**\n   * Returns a paginator for iterating over all signer sessions optionally filtered by a role.\n   *\n   * @param {SessionSelector?} selector If set, limit to sessions for a specified user or a role.\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(\n    selector?: SessionSelector,\n    page?: PageOpts,\n  ): Paginator<SessionsResponse, SessionInfo> {\n    const o = op(\"/v0/org/{org_id}/session\", \"get\");\n    const selectorQuery = typeof selector === \"string\" ? { role: selector } : selector;\n    return new Paginator(\n      page ?? Page.default(),\n      (query) => this.exec(o, { params: { query: { ...selectorQuery, ...query } } }),\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 {KeyInfo[]} The list of keys.\n   */\n  async sessionKeysList(): Promise<KeyInfo[]> {\n    const o = op(\"/v0/org/{org_id}/token/keys\", \"get\");\n    const { keys } = await this.exec(o, {});\n    return keys;\n  }\n\n  // #endregion\n\n  // #region IDENTITY: identityProve, identityVerify, identityAdd, identityRemove, identityList\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 o = op(\"/v0/org/{org_id}/identity/prove\", \"post\");\n\n    return this.exec(o, {});\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 o = op(\"/v0/org/{org_id}/identity/verify\", \"post\");\n    await this.exec(o, {\n      body: proof,\n    });\n  }\n\n  /**\n   * Associates an OIDC identity with the current user's account.\n   *\n   * @param {AddIdentityRequest} body The request body, containing an OIDC token to prove the identity ownership.\n   */\n  async identityAdd(body: AddIdentityRequest) {\n    const o = op(\"/v0/org/{org_id}/identity\", \"post\");\n    await this.exec(o, { body });\n  }\n\n  /**\n   * Removes an OIDC identity from the current user's account.\n   *\n   * @param {OidcIdentity} body The identity to remove.\n   */\n  async identityRemove(body: OidcIdentity) {\n    const o = op(\"/v0/org/{org_id}/identity\", \"delete\");\n    await this.exec(o, { body });\n  }\n\n  /**\n   * Lists associated OIDC identities with the current user.\n   *\n   * @return {ListIdentityResponse} Associated identities\n   */\n  async identityList(): Promise<ListIdentityResponse> {\n    const o = op(\"/v0/org/{org_id}/identity\", \"get\");\n    return await this.exec(o, {});\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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}\", \"get\");\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/mfa\", \"get\");\n\n    const { mfa_requests } = await this.exec(o, {});\n    return 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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}\", \"patch\");\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}/totp\", \"patch\");\n\n    return this.exec(o, {\n      params: { path: { 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 mfaVoteFidoComplete}.\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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", \"post\");\n\n    const challenge = await this.exec(o, {\n      params: { path: { mfa_id: mfaId } },\n    });\n\n    return new MfaFidoChallenge(this, mfaId, challenge);\n  }\n\n  /**\n   * Complete a previously initiated (via {@link mfaFidoInit}) 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 mfaFidoInit}\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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", \"patch\");\n    return await this.exec(o, {\n      params: { path: { 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, signSerializedAva, signBlob, signBtc, signTaproot, signSolana, signEots, eotsCreateNonce, signMmi\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEvm(\n    key: Key | string,\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    const o = op(\"/v1/org/{org_id}/eth1/sign/{pubkey}\", \"post\");\n\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip191(\n    key: Key | string,\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    const o = op(\"/v0/org/{org_id}/evm/eip191/sign/{pubkey}\", \"post\");\n\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip712(\n    key: Key | string,\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    const o = op(\"/v0/org/{org_id}/evm/eip712/sign/{pubkey}\", \"post\");\n\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<Eth2SignResponse | AcceptedResponse>} Signature\n   */\n  async signEth2(\n    key: Key | string,\n    req: Eth2SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2SignResponse>> {\n    const o = op(\"/v1/org/{org_id}/eth2/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<Eth2StakeResponse | AcceptedResponse>} The response.\n   */\n  async signStake(\n    req: Eth2StakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2StakeResponse>> {\n    const o = op(\"/v1/org/{org_id}/eth2/stake\", \"post\");\n    const sign = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} The response.\n   */\n  async signUnstake(\n    key: Key | string,\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    const o = op(\"/v1/org/{org_id}/eth2/unstake/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signAva(\n    key: Key | string,\n    tx: AvaTx,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/ava/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: <AvaSignRequest>{\n          tx: tx as unknown,\n        },\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a serialized Avalanche C-, P-, or X-chain message. See [the Avalanche\n   * documentation](https://docs.avax.network/reference/standards/serialization-primitives)\n   * for the specification of the serialization format.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its\n   * material ID).\n   * @param {AvaChain} avaChain Avalanche chain\n   * @param {string} tx Hex encoded transaction\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSerializedAva(\n    key: Key | string,\n    avaChain: AvaChain,\n    tx: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/ava/sign/{ava_chain}/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { ava_chain: avaChain, pubkey } },\n        body: <AvaSerializedTxSignRequest>{\n          tx,\n        },\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BlobSignResponse | AcceptedResponse>} The response.\n   */\n  async signBlob(\n    key: Key | string,\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    const o = op(\"/v1/org/{org_id}/blob/sign/{key_id}\", \"post\");\n\n    const key_id = typeof key === \"string\" ? (key as string) : key.id;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { key_id } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin transaction input.\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.\n   */\n  async signBtc(\n    key: Key | string,\n    req: BtcSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BtcSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/btc/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin BIP-137 message.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {BtcMessageSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BtcMessageSignResponse | AcceptedResponse>} The response.\n   */\n  async signBtcMessage(\n    key: Key | string,\n    req: BtcMessageSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BtcMessageSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/btc/message/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Taproot transaction input.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {TaprootSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<TaprootSignResponse | AcceptedResponse>} The response.\n   */\n  async signTaproot(\n    key: Key | string,\n    req: TaprootSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<TaprootSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/btc/taproot/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a PSBT.\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.\n   */\n  async signPsbt(\n    key: Key | string,\n    req: PsbtSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<PsbtSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/btc/psbt/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Generate an Extractable One-Time Signature\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {EotsSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EotsSignResponse | AcceptedResponse>} The response.\n   */\n  async signEots(\n    key: Key | string,\n    req: EotsSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EotsSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/babylon/eots/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Generates a set of Babylon EOTS nonces for a specified chain-id, starting at a specified block height.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {EotsCreateNonceRequest} req What and how many nonces to create\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EotsCreateNonceResponse | AcceptedResponse>} The response.\n   */\n  async eotsCreateNonce(\n    key: Key | string,\n    req: EotsCreateNonceRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EotsCreateNonceResponse>> {\n    const o = op(\"/v0/org/{org_id}/babylon/eots/nonces/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon staking transaction.\n   *\n   * @param {Key | string} key The taproot key to sign with (either {@link Key} or its material ID).\n   * @param {BabylonStakingRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<TaprootSignResponse | AcceptedResponse>} The response.\n   */\n  async signBabylonStakingTxn(\n    key: Key | string,\n    req: BabylonStakingRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonStakingResponse>> {\n    const o = op(\"/v0/org/{org_id}/babylon/staking/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSolana(\n    key: Key | string,\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SolanaSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/solana/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a MMI pending message.\n   *\n   * @param {PendingMessageInfo} message the message info.\n   * @param {MfaReceipts | undefined} mfaReceipt optional MFA receipt(s).\n   * @return {PendingMessageSignResponse} the updated message.\n   */\n  async signMmi(\n    message: PendingMessageInfo,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<PendingMessageSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages/{msg_id}/sign\", \"post\");\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { msg_id: message.id } },\n        headers: headers,\n        body: message,\n      });\n    return await CubeSignerResponse.create(this.env, 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 o = op(\"/v0/org/{org_id}/user/me/export\", \"get\");\n    return new Paginator(\n      page ?? Page.default(),\n      (query) =>\n        this.exec(o, {\n          params: {\n            query: {\n              user_id: userId,\n              key_id: keyId,\n              ...query,\n            },\n          },\n        }),\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 o = op(\"/v0/org/{org_id}/user/me/export\", \"delete\");\n    await this.exec(o, {\n      params: {\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<UserExportInitResponse | AcceptedResponse>} The response.\n   */\n  async userExportInit(\n    keyId: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<UserExportInitResponse>> {\n    const o = op(\"/v0/org/{org_id}/user/me/export\", \"post\");\n    const initFn = async (headers?: HeadersInit) => {\n      return this.exec(o, {\n        body: { key_id: keyId },\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<UserExportCompleteResponse | AcceptedResponse>} The response.\n   */\n  async userExportComplete(\n    keyId: string,\n    publicKey: CryptoKey,\n    mfaReceipt?: MfaReceipts,\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    const o = op(\"/v0/org/{org_id}/user/me/export\", \"patch\");\n    // make the request\n    const completeFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        body: {\n          key_id: keyId,\n          public_key: publicKeyB64,\n        },\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, completeFn, mfaReceipt);\n  }\n  // #endregion\n\n  // #region KEY IMPORT: createKeyImportKey, importKeys\n  /**\n   * Request a fresh key-import key.\n   *\n   * @return { Promise<GetKeyImportKeyResponse> } A fresh key-import key\n   */\n  async createKeyImportKey(): Promise<CreateKeyImportKeyResponse> {\n    const o = op(\"/v0/org/{org_id}/import_key\", \"get\");\n    return await this.exec(o, {});\n  }\n\n  /**\n   * Import one or more keys. To use this functionality, you must first create an\n   * encrypted key-import request using the `@cubist-labs/cubesigner-sdk-key-import`\n   * library. See that library's documentation for more info.\n   *\n   * @param { ImportKeyRequest } body An encrypted key-import request.\n   * @return { KeyInfo[] } The newly imported keys.\n   */\n  async importKeys(body: ImportKeyRequest): Promise<KeyInfo[]> {\n    const o = op(\"/v0/org/{org_id}/import_key\", \"put\");\n    const { keys } = await this.exec(o, { body });\n    return keys;\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 o = op(\"/v1/org/{org_id}/cube3signer/heartbeat\", \"post\");\n    await this.exec(o, {});\n  }\n  // #endregion\n\n  // #region MMI: mmi(), mmiList()\n  /**\n   * Call the MMI JSON RPC endpoint.\n   *\n   * @param {MmiJrpcMethod} method The name of the method to call.\n   * @param {JsonArray} params The list of method parameters.\n   * @return {object | null | undefined} the return value of the method.\n   * @internal\n   */\n  async mmi(method: MmiJrpcMethod, params: JsonArray): Promise<JrpcResponse> {\n    const o = op(\"/v0/mmi/v3/json-rpc\", \"post\");\n    const body = {\n      id: 1,\n      jsonrpc: \"2.0\",\n      method: method,\n      params: params,\n    };\n    const func = async (headers?: HeadersInit) => this.exec(o, { headers, body });\n    const resp = (await CubeSignerResponse.create(this.env, func)).data();\n    return resp;\n  }\n\n  /**\n   * List pending MMI messages.\n   *\n   * @return { PendingMessageInfo[] } The list of pending MMI messages.\n   */\n  async mmiList(): Promise<PendingMessageInfo[]> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages\", \"get\");\n    const { pending_messages } = await this.exec(o, {});\n    return pending_messages as PendingMessageInfo[];\n  }\n\n  /**\n   * Get a pending MMI message by its ID.\n   *\n   * @param {string} msgId The ID of the pending message.\n   * @return {PendingMessageInfo} The pending MMI message.\n   */\n  async mmiGet(msgId: string): Promise<PendingMessageInfo> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages/{msg_id}\", \"get\");\n    return await this.exec(o, { params: { path: { msg_id: msgId } } });\n  }\n\n  /**\n   * Delete the MMI message with the given ID.\n   *\n   * @param {string} msgId the ID of the MMI message.\n   */\n  async mmiDelete(msgId: string): Promise<void> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages/{msg_id}\", \"delete\");\n    await this.exec(o, { params: { path: { msg_id: msgId } } });\n  }\n\n  /**\n   * Reject the MMI message with the given ID.\n   *\n   * @param {string} msgId the ID of the MMI message.\n   */\n  async mmiReject(msgId: string): Promise<PendingMessageInfo> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages/{msg_id}/reject\", \"post\");\n    return await this.exec(o, { params: { path: { msg_id: msgId } } });\n  }\n\n  // #endregion\n\n  /**\n   * Returns public org information.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The org to log into\n   * @return {Promise<PublicOrgInfo>} Public org information\n   */\n  static async publicOrgInfo(env: EnvInterface, orgId: string): Promise<PublicOrgInfo> {\n    const o = op(\"/v0/org/{org_id}/info\", \"get\");\n    return await retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Exchange an OIDC token for a CubeSigner session token.\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The org to log into.\n   * @param {string} token The OIDC token to exchange\n   * @param {List<Scope>} scopes The scopes for the new session\n   * @param {RatchetConfig} lifetimes Lifetimes of the new session.\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @param {string} purpose Optional session description.\n   * @return {Promise<CubeSignerResponse<SessionData>>} The session data.\n   */\n  static async oidcSessionCreate(\n    env: EnvInterface,\n    orgId: string,\n    token: string,\n    scopes: Array<Scope>,\n    lifetimes?: RatchetConfig,\n    mfaReceipt?: MfaReceipts,\n    purpose?: string,\n  ): Promise<CubeSignerResponse<SessionData>> {\n    const o = op(\"/v0/org/{org_id}/oidc\", \"post\");\n\n    const loginFn = async (headers?: HeadersInit) => {\n      const data = await retryOn5XX(() =>\n        o({\n          baseUrl: env.SignerApiRoot,\n          params: { path: { org_id: orgId } },\n          headers: {\n            ...headers,\n            Authorization: token,\n          },\n          body: {\n            scopes,\n            purpose,\n            tokens: lifetimes,\n          },\n        }),\n      ).then(assertOk);\n\n      return mapResponse(\n        data,\n        (sessionInfo) =>\n          <SessionData>{\n            env: {\n              [\"Dev-CubeSignerStack\"]: env,\n            },\n            org_id: orgId,\n            token: sessionInfo.token,\n            session_exp: sessionInfo.expiration,\n            purpose: \"sign in via oidc\",\n            session_info: sessionInfo.session_info,\n          },\n      );\n    };\n\n    return await CubeSignerResponse.create(env, loginFn, mfaReceipt);\n  }\n\n  /**\n   * Accept an invitation to join a CubeSigner org.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The id of the organization\n   * @param {InvitationAcceptRequest} body The request body\n   */\n  static async idpAcceptInvite(\n    env: EnvInterface,\n    orgId: string,\n    body: InvitationAcceptRequest,\n  ): Promise<void> {\n    const o = op(\"/v0/org/{org_id}/invitation/accept\", \"post\");\n    await retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        body,\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Unauthenticated endpoint for authenticating with email/password.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The id of the organization\n   * @param {AuthenticationRequest} body The request body\n   * @return {AuthenticationResponse} Returns an OIDC token which can be used\n   *   to log in via OIDC (see {@link oidcSessionCreate}).\n   */\n  static async idpAuthenticate(\n    env: EnvInterface,\n    orgId: string,\n    body: AuthenticationRequest,\n  ): Promise<AuthenticationResponse> {\n    const o = op(\"/v0/org/{org_id}/idp/authenticate\", \"post\");\n    return retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        body,\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Unauthenticated endpoint for requesting password reset.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The id of the organization\n   * @param {PasswordResetRequest} body The request body\n   * @return {EmailOtpResponse} Returns the partial token (`${header}.${claims}.`) while the signature is sent via email.\n   */\n  static async idpPasswordResetRequest(\n    env: EnvInterface,\n    orgId: string,\n    body: PasswordResetRequest,\n  ): Promise<EmailOtpResponse> {\n    const o = op(\"/v0/org/{org_id}/idp/password_reset\", \"post\");\n    return retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        body,\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Unauthenticated endpoint for confirming a previously initiated password reset request.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The id of the organization\n   * @param {string} partialToken The partial token returned by {@link passwordResetRequest}\n   * @param {string} signature The one-time code (signature in this case) sent via email\n   * @param {string} newPassword The new password\n   */\n  static async idpPasswordResetConfirm(\n    env: EnvInterface,\n    orgId: string,\n    partialToken: string,\n    signature: string,\n    newPassword: string,\n  ): Promise<void> {\n    const o = op(\"/v0/org/{org_id}/idp/password_reset\", \"patch\");\n    await retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        body: {\n          token: `${partialToken}${signature}`,\n          new_password: newPassword,\n        },\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Exchange an OIDC token for a proof of authentication.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The org id in which to generate proof\n   * @param {string} token The oidc token\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  static async identityProveOidc(\n    env: EnvInterface,\n    orgId: string,\n    token: string,\n  ): Promise<IdentityProof> {\n    const o = op(\"/v0/org/{org_id}/identity/prove/oidc\", \"post\");\n    return retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        headers: {\n          Authorization: token,\n        },\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Obtain all organizations a user is a member of\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} token The oidc token identifying the user\n   * @return {Promise<UserOrgsResponse>} The organization the user belongs to\n   */\n  static async userOrgs(env: EnvInterface, token: string): Promise<UserOrgsResponse> {\n    const o = op(\"/v0/user/orgs\", \"get\");\n    return retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        headers: {\n          Authorization: token,\n        },\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Post-process a {@link UserInfo} response. Post-processing ensures that the email field for\n   * users without an email is set to `null`.\n   *\n   * @param {UserInfo} info The info to post-process\n   * @return {Promise<UserInfo>} The processed user info\n   */\n  static #processUserInfo(info: UserInfo): UserInfo {\n    if (info.email === EMAIL_NOT_FOUND) {\n      info.email = null;\n    }\n    return info;\n  }\n\n  /**\n   * Post-process a {@link UserInOrgInfo} response. Post-processing ensures that the email field for\n   * users without an email is set to `null`.\n   *\n   * @param {UserInOrgInfo} info The info to post-process\n   * @return {Promise<UserInOrgInfo>} The processed user info\n   */\n  static #processUserInOrgInfo(info: UserInOrgInfo): UserInOrgInfo {\n    if (info.email === EMAIL_NOT_FOUND) {\n      info.email = null;\n    }\n    return info;\n  }\n}\n\nconst defaultSignerSessionLifetime: SessionLifetime = {\n  session: 604800, // 1 week\n  auth: 300, // 5 min\n  refresh: 86400, // 1 day\n  grace: 30, // seconds\n};\n"]}
1543
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api_client.js","sourceRoot":"","sources":["../../../src/client/api_client.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  CreateOidcUserOptions,\n  IdentityProof,\n  KeyInRoleInfo,\n  KeyInfo,\n  OidcIdentity,\n  PublicKeyCredential,\n  RoleInfo,\n  UpdateKeyRequest,\n  UpdateOrgRequest,\n  UpdateOrgResponse,\n  UpdateRoleRequest,\n  UserInOrgInfo,\n  UserInRoleInfo,\n  GetUsersInOrgResponse,\n  UserInfo,\n  SessionInfo,\n  OrgInfo,\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  BtcMessageSignResponse,\n  BtcMessageSignRequest,\n  PsbtSignRequest,\n  PsbtSignResponse,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  AvaSignResponse,\n  AvaSignRequest,\n  AvaSerializedTxSignRequest,\n  AvaTx,\n  MfaRequestInfo,\n  MfaVote,\n  MemberRole,\n  UserExportCompleteResponse,\n  UserExportInitResponse,\n  UserExportListResponse,\n  Empty,\n  UserOrgsResponse,\n  CreateKeyImportKeyResponse,\n  ImportKeyRequest,\n} from \"../schema_types\";\nimport { encodeToBase64 } from \"../util\";\nimport { AddFidoChallenge, MfaFidoChallenge, TotpChallenge } from \"../mfa\";\nimport { CubeSignerResponse, mapResponse } from \"../response\";\nimport type { Key, KeyType } from \"../key\";\nimport type { PageOpts } from \"../paginator\";\nimport { Page, Paginator } from \"../paginator\";\nimport type { KeyPolicy } from \"../role\";\nimport { loadSubtleCrypto } from \"../user_export\";\nimport type {\n  AddIdentityRequest,\n  AvaChain,\n  EnvInterface,\n  EotsCreateNonceRequest,\n  EotsCreateNonceResponse,\n  EotsSignRequest,\n  EotsSignResponse,\n  JrpcResponse,\n  JsonArray,\n  ListIdentityResponse,\n  ListKeyRolesResponse,\n  ListKeysResponse,\n  ListRoleKeysResponse,\n  ListRoleUsersResponse,\n  ListRolesResponse,\n  MmiJrpcMethod,\n  PendingMessageInfo,\n  PendingMessageSignResponse,\n  RatchetConfig,\n  Scope,\n  SessionData,\n  SessionLifetime,\n  SessionsResponse,\n  TaprootSignRequest,\n  TaprootSignResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  UpdateUserMembershipRequest,\n  HistoricalTx,\n  ListHistoricalTxResponse,\n  PublicOrgInfo,\n  ImportDeriveKeyProperties,\n  PasswordResetRequest,\n  EmailOtpResponse,\n  AuthenticationRequest,\n  AuthenticationResponse,\n  CreateKeyProperties,\n  InvitationAcceptRequest,\n  MfaReceipts,\n} from \"../index\";\nimport { assertOk, op } from \"../fetch\";\nimport { BaseClient, signerSessionFromSessionInfo } from \"./base_client\";\nimport { retryOn5XX } from \"../retry\";\n\n/**\n * String returned by API when a user does not have an email address (for backwards compatibility)\n */\nconst EMAIL_NOT_FOUND = \"email not found\";\n\n/**\n * Session selector.\n */\nexport type SessionSelector =\n  /**\n   * Selects all sessions tied to a role with this ID\n   * @deprecated Use `{ role: string }` instead\n   */\n  | string\n  | {\n      /** Selects all sessions tied to a role with this ID */\n      role: string;\n    }\n  | {\n      /** Selects all sessions tied to a user with this ID. */\n      user: string;\n    };\n\n/**\n * An extension of BaseClient that adds specialized methods for api endpoints\n */\nexport class ApiClient extends BaseClient {\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    const o = op(\"/v0/org/{org_id}/user/me\", \"get\");\n\n    return this.exec(o, {}).then(ApiClient.#processUserInfo);\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 ApiClient.userTotpResetComplete}).\n   *\n   * @param {string} issuer Optional issuer; defaults to \"Cubist\"\n   * @param {MfaReceipts} mfaReceipt MFA receipt(s) to include in HTTP headers\n   */\n  async userTotpResetInit(\n    issuer?: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<TotpChallenge>> {\n    const o = op(\"/v0/org/{org_id}/user/me/totp\", \"post\");\n    const resetTotpFn = async (headers?: HeadersInit) => {\n      const data = await this.exec(o, {\n        headers,\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(this.env, 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 o = op(\"/v0/org/{org_id}/user/me/totp\", \"patch\");\n    await this.exec(o, {\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 o = op(\"/v0/org/{org_id}/user/me/totp/verify\", \"post\");\n\n    await this.exec(o, {\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s) to include in HTTP headers\n   */\n  async userTotpDelete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    const o = op(\"/v0/org/{org_id}/user/me/totp\", \"delete\");\n    const deleteTotpFn = async (headers?: HeadersInit) => {\n      return await this.exec(o, {\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s) 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?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AddFidoChallenge>> {\n    const o = op(\"/v0/org/{org_id}/user/me/fido\", \"post\");\n    const addFidoFn = async (headers?: HeadersInit) => {\n      const data = await this.exec(o, {\n        headers,\n        body: { name },\n      });\n      return mapResponse(data, (c) => new AddFidoChallenge(this, c));\n    };\n    return await CubeSignerResponse.create(this.env, 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 o = op(\"/v0/org/{org_id}/user/me/fido\", \"patch\");\n\n    return this.exec(o, {\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s) to include in HTTP headers\n   */\n  async userFidoDelete(\n    fidoId: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Empty>> {\n    const deleteFidoFn = (headers?: HeadersInit) => {\n      const o = op(\"/v0/org/{org_id}/user/me/fido/{fido_id}\", \"delete\");\n\n      return this.exec(o, {\n        headers,\n        params: { path: { fido_id: fidoId } },\n      });\n    };\n    return await CubeSignerResponse.create(this.env, deleteFidoFn, mfaReceipt);\n  }\n\n  // #endregion\n\n  // #region ORGS: orgGet, orgUpdate, orgUpdateUserMembership\n\n  /**\n   * Obtain information about an org\n   *\n   * @param {string | undefined} orgId The org to get info for\n   * @return {OrgInfo} Information about the organization.\n   */\n  async orgGet(orgId?: string): Promise<OrgInfo> {\n    const o = op(\"/v0/org/{org_id}\", \"get\");\n    return this.exec(o, {\n      params: {\n        path: { org_id: orgId ?? this.sessionMeta.org_id },\n      },\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 o = op(\"/v0/org/{org_id}\", \"patch\");\n\n    return this.exec(o, { body: request });\n  }\n\n  /**\n   * Update user's membership in this org.\n   * @param {string} userId The ID of the user whose membership to update.\n   * @param {UpdateUserMembershipRequest} req The update request\n   * @return {Promise<UserInOrgInfo>} Updated user membership\n   */\n  async orgUpdateUserMembership(\n    userId: string,\n    req: UpdateUserMembershipRequest,\n  ): Promise<UserInOrgInfo> {\n    const o = op(\"/v0/org/{org_id}/users/{user_id}/membership\", \"patch\");\n    return this.exec(o, {\n      params: { path: { user_id: userId } },\n      body: req,\n    }).then(ApiClient.#processUserInOrgInfo);\n  }\n\n  // #endregion\n\n  // #region ORG USERS: orgUserInvite, orgUserDelete, orgUsersList, orgUserGet, 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   * @param {boolean} skipEmail Optionally skip sending the invite email.\n   */\n  async orgUserInvite(\n    email: string,\n    name: string,\n    role?: MemberRole,\n    skipEmail?: boolean,\n  ): Promise<void> {\n    const o = op(\"/v0/org/{org_id}/invite\", \"post\");\n\n    await this.exec(o, {\n      body: {\n        email,\n        name,\n        role,\n        skip_email: !!skipEmail,\n      },\n    });\n  }\n\n  /**\n   * Remove the user from the org.\n   * @param {string} userId The ID of the user to remove.\n   */\n  async orgUserDelete(userId: string): Promise<Empty> {\n    const o = op(\"/v0/org/{org_id}/users/{user_id}\", \"delete\");\n\n    return this.exec(o, {\n      params: {\n        path: {\n          user_id: userId,\n        },\n      },\n    });\n  }\n\n  /**\n   * List users in the org.\n   *\n   * @param {PageOpts} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<GetUsersInOrgResponse, UserInOrgInfo>} Paginator for iterating over the users in the org.\n   */\n  orgUsersList(page?: PageOpts): Paginator<GetUsersInOrgResponse, UserInOrgInfo> {\n    const o = op(\"/v0/org/{org_id}/users\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) => this.exec(o, { params: { path: {}, ...query } }),\n      (r) => r.users.map(ApiClient.#processUserInOrgInfo),\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  /**\n   * Get user by id.\n   * @param {string} userId The id of the user to get.\n   * @return {UserInOrgInfo} Org user.\n   */\n  async orgUserGet(userId: string): Promise<UserInOrgInfo> {\n    const o = op(\"/v0/org/{org_id}/users/{user_id}\", \"get\");\n\n    const resp = await this.exec(o, {\n      params: {\n        path: {\n          user_id: userId,\n        },\n      },\n    });\n    return ApiClient.#processUserInOrgInfo(resp);\n  }\n\n  /**\n   * Create a new OIDC user. This can be a first-party \"Member\" or third-party \"Alien\".\n   * @param {OidcIdentity | IdentityProof} identityOrProof The identity or\n   *   identity proof 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    identityOrProof: OidcIdentity | IdentityProof,\n    email?: string | null,\n    opts: CreateOidcUserOptions = {},\n  ): Promise<string> {\n    const o = op(\"/v0/org/{org_id}/users\", \"post\");\n\n    const identityOrProofFields =\n      \"id\" in identityOrProof ? { proof: identityOrProof } : { identity: identityOrProof };\n\n    const { user_id } = await this.exec(o, {\n      body: {\n        role: opts.memberRole ?? \"Alien\",\n        email,\n        name: opts.name,\n        mfa_policy: opts.mfaPolicy,\n        ...identityOrProofFields,\n      },\n    });\n\n    return 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 o = op(\"/v0/org/{org_id}/users/oidc\", \"delete\");\n\n    return this.exec(o, {\n      body: identity,\n    });\n  }\n\n  // #endregion\n\n  // #region KEYS: keyGet, keyUpdate, keyDelete, keysCreate, keysDerive, keysList, keyHistory\n\n  /**\n   * Get a key by its id.\n   *\n   * @param {string} keyId The id of the key to get.\n   * @return {KeyInfo} The key information.\n   */\n  async keyGet(keyId: string): Promise<KeyInfo> {\n    const o = op(\"/v0/org/{org_id}/keys/{key_id}\", \"get\");\n\n    return this.exec(o, {\n      params: { path: { key_id: keyId } },\n    });\n  }\n\n  /**\n   * Get a key by its type and material id.\n   *\n   * @param {KeyType} keyType The key type.\n   * @param {string} materialId The material id of the key to get.\n   * @return {KeyInfo} The key information.\n   */\n  async keyGetByMaterialId(keyType: KeyType, materialId: string): Promise<KeyInfo> {\n    const o = op(\"/v0/org/{org_id}/keys/{key_type}/{material_id}\", \"get\");\n\n    return this.exec(o, {\n      params: { path: { key_type: keyType, material_id: materialId } },\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 o = op(\"/v0/org/{org_id}/keys/{key_id}/roles\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) =>\n        this.exec(o, {\n          params: {\n            path: { key_id: keyId },\n            ...query,\n          },\n        }),\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 {KeyInfo} The JSON response from the API server.\n   */\n  async keyUpdate(keyId: string, request: UpdateKeyRequest): Promise<KeyInfo> {\n    const o = op(\"/v0/org/{org_id}/keys/{key_id}\", \"patch\");\n\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/keys/{key_id}\", \"delete\");\n    await this.exec(o, {\n      params: { path: { 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 {KeyProperties?} props Additional key properties\n   * @return {KeyInfo[]} The new keys.\n   */\n  async keysCreate(\n    keyType: KeyType,\n    count: number,\n    ownerId?: string,\n    props?: CreateKeyProperties,\n  ): Promise<KeyInfo[]> {\n    const chain_id = 0; // not used anymore\n\n    const o = op(\"/v0/org/{org_id}/keys\", \"post\");\n\n    const policy = (props?.policy ?? null) as Record<string, never>[] | null;\n    const { keys } = await this.exec(o, {\n      body: {\n        count,\n        chain_id,\n        key_type: keyType,\n        ...props,\n        owner: props?.owner ?? ownerId,\n        policy,\n      },\n    });\n    return 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 material_id of mnemonic key used to derive the new key.\n   * @param { ImportDeriveKeyProperties? } props Additional options for derivation.\n   *\n   * @return {KeyInfo[]} The newly derived keys.\n   */\n  async keysDerive(\n    keyType: KeyType,\n    derivationPaths: string[],\n    mnemonicId: string,\n    props?: ImportDeriveKeyProperties,\n  ): Promise<KeyInfo[]> {\n    const o = op(\"/v0/org/{org_id}/derive_key\", \"put\");\n\n    const policy = (props?.policy ?? null) as Record<string, never>[] | null;\n    const { keys } = await this.exec(o, {\n      body: {\n        derivation_path: derivationPaths,\n        mnemonic_id: mnemonicId,\n        key_type: keyType,\n        ...props,\n        policy,\n      },\n    });\n\n    return 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   * @param {string?} owner Optional key owner to filter list for.\n   * @param {string?} search Optionally search by key's material ID and metadata\n   * @return {Paginator<ListKeysResponse, KeyInfo>} Paginator for iterating over keys.\n   */\n  keysList(\n    type?: KeyType,\n    page?: PageOpts,\n    owner?: string,\n    search?: string,\n  ): Paginator<ListKeysResponse, KeyInfo> {\n    const o = op(\"/v0/org/{org_id}/keys\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) =>\n        this.exec(o, { params: { query: { key_type: type, key_owner: owner, search, ...query } } }),\n      (r) => r.keys,\n      (r) => r.last_evaluated_key,\n    );\n  }\n\n  /**\n   * List recent historical key transactions.\n   *\n   * @param {string} keyId The key id.\n   * @param {PageOpts?} page Pagination options. Defaults to fetching the entire result set.\n   * @return {Paginator<ListHistoricalTxResponse, HistoricalTx>} Paginator for iterating over historical transactions.\n   */\n  keyHistory(keyId: string, page?: PageOpts): Paginator<ListHistoricalTxResponse, HistoricalTx> {\n    const o = op(\"/v0/org/{org_id}/keys/{key_id}/tx\", \"get\");\n    return new Paginator(\n      page ?? Page.default(),\n      () => this.exec(o, { params: { path: { key_id: keyId } } }),\n      (r) => r.txs,\n      (r) => r.last_evaluated_key,\n    );\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 o = op(\"/v0/org/{org_id}/roles\", \"post\");\n\n    const data = await this.exec(o, {\n      body: name ? { name } : undefined,\n    });\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 o = op(\"/v0/org/{org_id}/roles/{role_id}\", \"get\");\n\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}\", \"patch\");\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}\", \"delete\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles\", \"get\");\n    return new Paginator(\n      page ?? Page.default(),\n      (query) => this.exec(o, { params: { query } }),\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 o = op(\"/v0/org/{org_id}/roles/{role_id}/add_keys\", \"put\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}/keys/{key_id}\", \"delete\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}/keys\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) =>\n        this.exec(o, {\n          params: {\n            path: { role_id: roleId },\n            query,\n          },\n        }),\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 o = op(\"/v0/org/{org_id}/roles/{role_id}/add_user/{user_id}\", \"put\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}/users/{user_id}\", \"delete\");\n\n    await this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/roles/{role_id}/users\", \"get\");\n\n    return new Paginator(\n      page ?? Page.default(),\n      (query) => this.exec(o, { params: { query, path: { role_id: roleId } } }),\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). The lifetime of\n   * the new session is silently truncated to that of the current session.\n   *\n   * @param {string} purpose The purpose of the session\n   * @param {Scope[]} scopes Session scopes.\n   * @param {SessionLifetime} lifetimes Lifetime settings\n   * @return {Promise<SessionData>} New signer session info.\n   */\n  async sessionCreate(\n    purpose: string,\n    scopes: Scope[],\n    lifetimes?: SessionLifetime,\n  ): Promise<SessionData> {\n    lifetimes ??= defaultSignerSessionLifetime;\n    const o = op(\"/v0/org/{org_id}/session\", \"post\");\n\n    const data = await this.exec(o, {\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 signerSessionFromSessionInfo(this.sessionMeta, data, {\n      purpose,\n    });\n  }\n\n  /**\n   * Create new user session (management and/or signing) whose lifetime potentially\n   * extends the lifetime of the current session.  MFA is always required.\n   *\n   * @param {string} purpose The purpose of the session\n   * @param {Scope[]} scopes Session scopes.\n   * @param {SessionLifetime} lifetime Lifetime settings\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<CubeSignerResponse<SessionData>>} New signer session info.\n   */\n  async sessionCreateExtended(\n    purpose: string,\n    scopes: Scope[],\n    lifetime: SessionLifetime,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SessionData>> {\n    const o = op(\"/v0/org/{org_id}/session\", \"post\");\n\n    const requestFn = async (headers?: HeadersInit) => {\n      const resp = await this.exec(o, {\n        headers,\n        body: {\n          purpose,\n          scopes,\n          extend_lifetimes: true,\n          auth_lifetime: lifetime.auth,\n          refresh_lifetime: lifetime.refresh,\n          session_lifetime: lifetime.session,\n          grace_lifetime: lifetime.grace,\n        },\n      });\n      return mapResponse(resp, (sessionInfo) =>\n        signerSessionFromSessionInfo(this.sessionMeta, sessionInfo, {\n          purpose,\n        }),\n      );\n    };\n    return await CubeSignerResponse.create(this.env, requestFn, mfaReceipt);\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 {Scope[]} scopes Session scopes. Not all scopes are valid for a role.\n   * @param {SessionLifetime} lifetimes Lifetime settings\n   * @return {Promise<SessionData>} New signer session info.\n   */\n  async sessionCreateForRole(\n    roleId: string,\n    purpose: string,\n    scopes?: Scope[],\n    lifetimes?: SessionLifetime,\n  ): Promise<SessionData> {\n    lifetimes ??= defaultSignerSessionLifetime;\n    const o = op(\"/v0/org/{org_id}/roles/{role_id}/tokens\", \"post\");\n    const data = await this.exec(o, {\n      params: { path: { 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\n    return signerSessionFromSessionInfo(this.sessionMeta, data, {\n      role_id: roleId,\n      purpose,\n    });\n  }\n\n  /**\n   * Revoke a session.\n   *\n   * @param {string} [sessionId] The ID of the session to revoke. This session by default\n   */\n  async sessionRevoke(sessionId?: string) {\n    const o = op(\"/v0/org/{org_id}/session/{session_id}\", \"delete\");\n    await this.exec(o, {\n      params: { path: { session_id: sessionId ?? \"self\" } },\n    });\n  }\n\n  /**\n   * Revoke all sessions.\n   *\n   * @param {SessionSelector?} [selector] Which sessions to revoke.\n   *  If not defined, all the current user's sessions will be revoked.\n   */\n  async sessionRevokeAll(selector?: SessionSelector) {\n    const o = op(\"/v0/org/{org_id}/session\", \"delete\");\n    const query = typeof selector === \"string\" ? { role: selector } : selector;\n    await this.exec(o, {\n      params: { query },\n    });\n  }\n\n  /**\n   * Returns a paginator for iterating over all signer sessions optionally filtered by a role.\n   *\n   * @param {SessionSelector?} selector If set, limit to sessions for a specified user or a role.\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(\n    selector?: SessionSelector,\n    page?: PageOpts,\n  ): Paginator<SessionsResponse, SessionInfo> {\n    const o = op(\"/v0/org/{org_id}/session\", \"get\");\n    const selectorQuery = typeof selector === \"string\" ? { role: selector } : selector;\n    return new Paginator(\n      page ?? Page.default(),\n      (query) => this.exec(o, { params: { query: { ...selectorQuery, ...query } } }),\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 {KeyInfo[]} The list of keys.\n   */\n  async sessionKeysList(): Promise<KeyInfo[]> {\n    const o = op(\"/v0/org/{org_id}/token/keys\", \"get\");\n    const { keys } = await this.exec(o, {});\n    return keys;\n  }\n\n  // #endregion\n\n  // #region IDENTITY: identityProve, identityVerify, identityAdd, identityRemove, identityList\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 o = op(\"/v0/org/{org_id}/identity/prove\", \"post\");\n\n    return this.exec(o, {});\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 o = op(\"/v0/org/{org_id}/identity/verify\", \"post\");\n    await this.exec(o, {\n      body: proof,\n    });\n  }\n\n  /**\n   * Associates an OIDC identity with the current user's account.\n   *\n   * @param {AddIdentityRequest} body The request body, containing an OIDC token to prove the identity ownership.\n   */\n  async identityAdd(body: AddIdentityRequest) {\n    const o = op(\"/v0/org/{org_id}/identity\", \"post\");\n    await this.exec(o, { body });\n  }\n\n  /**\n   * Removes an OIDC identity from the current user's account.\n   *\n   * @param {OidcIdentity} body The identity to remove.\n   */\n  async identityRemove(body: OidcIdentity) {\n    const o = op(\"/v0/org/{org_id}/identity\", \"delete\");\n    await this.exec(o, { body });\n  }\n\n  /**\n   * Lists associated OIDC identities with the current user.\n   *\n   * @return {ListIdentityResponse} Associated identities\n   */\n  async identityList(): Promise<ListIdentityResponse> {\n    const o = op(\"/v0/org/{org_id}/identity\", \"get\");\n    return await this.exec(o, {});\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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}\", \"get\");\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/mfa\", \"get\");\n\n    const { mfa_requests } = await this.exec(o, {});\n    return 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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}\", \"patch\");\n    return this.exec(o, {\n      params: { path: { 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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}/totp\", \"patch\");\n\n    return this.exec(o, {\n      params: { path: { 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 mfaVoteFidoComplete}.\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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", \"post\");\n\n    const challenge = await this.exec(o, {\n      params: { path: { mfa_id: mfaId } },\n    });\n\n    return new MfaFidoChallenge(this, mfaId, challenge);\n  }\n\n  /**\n   * Complete a previously initiated (via {@link mfaFidoInit}) 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 mfaFidoInit}\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 o = op(\"/v0/org/{org_id}/mfa/{mfa_id}/fido\", \"patch\");\n    return await this.exec(o, {\n      params: { path: { 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, signSerializedAva, signBlob, signBtc, signTaproot, signSolana, signEots, eotsCreateNonce, signMmi\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEvm(\n    key: Key | string,\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    const o = op(\"/v1/org/{org_id}/eth1/sign/{pubkey}\", \"post\");\n\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip191(\n    key: Key | string,\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    const o = op(\"/v0/org/{org_id}/evm/eip191/sign/{pubkey}\", \"post\");\n\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip712(\n    key: Key | string,\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    const o = op(\"/v0/org/{org_id}/evm/eip712/sign/{pubkey}\", \"post\");\n\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<Eth2SignResponse | AcceptedResponse>} Signature\n   */\n  async signEth2(\n    key: Key | string,\n    req: Eth2SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2SignResponse>> {\n    const o = op(\"/v1/org/{org_id}/eth2/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<Eth2StakeResponse | AcceptedResponse>} The response.\n   */\n  async signStake(\n    req: Eth2StakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2StakeResponse>> {\n    const o = op(\"/v1/org/{org_id}/eth2/stake\", \"post\");\n    const sign = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} The response.\n   */\n  async signUnstake(\n    key: Key | string,\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    const o = op(\"/v1/org/{org_id}/eth2/unstake/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signAva(\n    key: Key | string,\n    tx: AvaTx,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/ava/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: <AvaSignRequest>{\n          tx: tx as unknown,\n        },\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a serialized Avalanche C-, P-, or X-chain message. See [the Avalanche\n   * documentation](https://docs.avax.network/reference/standards/serialization-primitives)\n   * for the specification of the serialization format.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its\n   * material ID).\n   * @param {AvaChain} avaChain Avalanche chain\n   * @param {string} tx Hex encoded transaction\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSerializedAva(\n    key: Key | string,\n    avaChain: AvaChain,\n    tx: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/ava/sign/{ava_chain}/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { ava_chain: avaChain, pubkey } },\n        body: <AvaSerializedTxSignRequest>{\n          tx,\n        },\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BlobSignResponse | AcceptedResponse>} The response.\n   */\n  async signBlob(\n    key: Key | string,\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    const o = op(\"/v1/org/{org_id}/blob/sign/{key_id}\", \"post\");\n\n    const key_id = typeof key === \"string\" ? (key as string) : key.id;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { key_id } },\n        body: req,\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin transaction input.\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.\n   */\n  async signBtc(\n    key: Key | string,\n    req: BtcSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BtcSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/btc/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin BIP-137 message.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {BtcMessageSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BtcMessageSignResponse | AcceptedResponse>} The response.\n   */\n  async signBtcMessage(\n    key: Key | string,\n    req: BtcMessageSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BtcMessageSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/btc/message/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Taproot transaction input.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {TaprootSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<TaprootSignResponse | AcceptedResponse>} The response.\n   */\n  async signTaproot(\n    key: Key | string,\n    req: TaprootSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<TaprootSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/btc/taproot/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a PSBT.\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.\n   */\n  async signPsbt(\n    key: Key | string,\n    req: PsbtSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<PsbtSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/btc/psbt/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Generate an Extractable One-Time Signature\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {EotsSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EotsSignResponse | AcceptedResponse>} The response.\n   */\n  async signEots(\n    key: Key | string,\n    req: EotsSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EotsSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/babylon/eots/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Generates a set of Babylon EOTS nonces for a specified chain-id, starting at a specified block height.\n   *\n   * @param {Key | string} key The key to sign with (either {@link Key} or its material ID).\n   * @param {EotsCreateNonceRequest} req What and how many nonces to create\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EotsCreateNonceResponse | AcceptedResponse>} The response.\n   */\n  async eotsCreateNonce(\n    key: Key | string,\n    req: EotsCreateNonceRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EotsCreateNonceResponse>> {\n    const o = op(\"/v0/org/{org_id}/babylon/eots/nonces/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon staking transaction.\n   *\n   * @param {Key | string} key The taproot key to sign with (either {@link Key} or its material ID).\n   * @param {BabylonStakingRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<TaprootSignResponse | AcceptedResponse>} The response.\n   */\n  async signBabylonStakingTxn(\n    key: Key | string,\n    req: BabylonStakingRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonStakingResponse>> {\n    const o = op(\"/v0/org/{org_id}/babylon/staking/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSolana(\n    key: Key | string,\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SolanaSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/solana/sign/{pubkey}\", \"post\");\n    const pubkey = typeof key === \"string\" ? (key as string) : key.materialId;\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { pubkey } },\n        body: req,\n        headers: headers,\n      });\n    return await CubeSignerResponse.create(this.env, signFn, mfaReceipt);\n  }\n\n  /**\n   * Sign a MMI pending message.\n   *\n   * @param {PendingMessageInfo} message the message info.\n   * @param {MfaReceipts | undefined} mfaReceipt optional MFA receipt(s).\n   * @return {PendingMessageSignResponse} the updated message.\n   */\n  async signMmi(\n    message: PendingMessageInfo,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<PendingMessageSignResponse>> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages/{msg_id}/sign\", \"post\");\n    const signFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        params: { path: { msg_id: message.id } },\n        headers: headers,\n        body: message,\n      });\n    return await CubeSignerResponse.create(this.env, 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 o = op(\"/v0/org/{org_id}/user/me/export\", \"get\");\n    return new Paginator(\n      page ?? Page.default(),\n      (query) =>\n        this.exec(o, {\n          params: {\n            query: {\n              user_id: userId,\n              key_id: keyId,\n              ...query,\n            },\n          },\n        }),\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 o = op(\"/v0/org/{org_id}/user/me/export\", \"delete\");\n    await this.exec(o, {\n      params: {\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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<UserExportInitResponse | AcceptedResponse>} The response.\n   */\n  async userExportInit(\n    keyId: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<UserExportInitResponse>> {\n    const o = op(\"/v0/org/{org_id}/user/me/export\", \"post\");\n    const initFn = async (headers?: HeadersInit) => {\n      return this.exec(o, {\n        body: { key_id: keyId },\n        headers,\n      });\n    };\n    return await CubeSignerResponse.create(this.env, 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 {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<UserExportCompleteResponse | AcceptedResponse>} The response.\n   */\n  async userExportComplete(\n    keyId: string,\n    publicKey: CryptoKey,\n    mfaReceipt?: MfaReceipts,\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    const o = op(\"/v0/org/{org_id}/user/me/export\", \"patch\");\n    // make the request\n    const completeFn = async (headers?: HeadersInit) =>\n      this.exec(o, {\n        body: {\n          key_id: keyId,\n          public_key: publicKeyB64,\n        },\n        headers,\n      });\n    return await CubeSignerResponse.create(this.env, completeFn, mfaReceipt);\n  }\n  // #endregion\n\n  // #region KEY IMPORT: createKeyImportKey, importKeys\n  /**\n   * Request a fresh key-import key.\n   *\n   * @return { Promise<GetKeyImportKeyResponse> } A fresh key-import key\n   */\n  async createKeyImportKey(): Promise<CreateKeyImportKeyResponse> {\n    const o = op(\"/v0/org/{org_id}/import_key\", \"get\");\n    return await this.exec(o, {});\n  }\n\n  /**\n   * Import one or more keys. To use this functionality, you must first create an\n   * encrypted key-import request using the `@cubist-labs/cubesigner-sdk-key-import`\n   * library. See that library's documentation for more info.\n   *\n   * @param { ImportKeyRequest } body An encrypted key-import request.\n   * @return { KeyInfo[] } The newly imported keys.\n   */\n  async importKeys(body: ImportKeyRequest): Promise<KeyInfo[]> {\n    const o = op(\"/v0/org/{org_id}/import_key\", \"put\");\n    const { keys } = await this.exec(o, { body });\n    return keys;\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 o = op(\"/v1/org/{org_id}/cube3signer/heartbeat\", \"post\");\n    await this.exec(o, {});\n  }\n  // #endregion\n\n  // #region MMI: mmi(), mmiList()\n  /**\n   * Call the MMI JSON RPC endpoint.\n   *\n   * @param {MmiJrpcMethod} method The name of the method to call.\n   * @param {JsonArray} params The list of method parameters.\n   * @return {object | null | undefined} the return value of the method.\n   * @internal\n   */\n  async mmi(method: MmiJrpcMethod, params: JsonArray): Promise<JrpcResponse> {\n    const o = op(\"/v0/mmi/v3/json-rpc\", \"post\");\n    const body = {\n      id: 1,\n      jsonrpc: \"2.0\",\n      method: method,\n      params: params,\n    };\n    const func = async (headers?: HeadersInit) => this.exec(o, { headers, body });\n    const resp = (await CubeSignerResponse.create(this.env, func)).data();\n    return resp;\n  }\n\n  /**\n   * List pending MMI messages.\n   *\n   * @return { PendingMessageInfo[] } The list of pending MMI messages.\n   */\n  async mmiList(): Promise<PendingMessageInfo[]> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages\", \"get\");\n    const { pending_messages } = await this.exec(o, {});\n    return pending_messages as PendingMessageInfo[];\n  }\n\n  /**\n   * Get a pending MMI message by its ID.\n   *\n   * @param {string} msgId The ID of the pending message.\n   * @return {PendingMessageInfo} The pending MMI message.\n   */\n  async mmiGet(msgId: string): Promise<PendingMessageInfo> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages/{msg_id}\", \"get\");\n    return await this.exec(o, { params: { path: { msg_id: msgId } } });\n  }\n\n  /**\n   * Delete the MMI message with the given ID.\n   *\n   * @param {string} msgId the ID of the MMI message.\n   */\n  async mmiDelete(msgId: string): Promise<void> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages/{msg_id}\", \"delete\");\n    await this.exec(o, { params: { path: { msg_id: msgId } } });\n  }\n\n  /**\n   * Reject the MMI message with the given ID.\n   *\n   * @param {string} msgId the ID of the MMI message.\n   */\n  async mmiReject(msgId: string): Promise<PendingMessageInfo> {\n    const o = op(\"/v0/org/{org_id}/mmi/v3/messages/{msg_id}/reject\", \"post\");\n    return await this.exec(o, { params: { path: { msg_id: msgId } } });\n  }\n\n  // #endregion\n\n  /**\n   * Returns public org information.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The org to log into\n   * @return {Promise<PublicOrgInfo>} Public org information\n   */\n  static async publicOrgInfo(env: EnvInterface, orgId: string): Promise<PublicOrgInfo> {\n    const o = op(\"/v0/org/{org_id}/info\", \"get\");\n    return await retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Exchange an OIDC token for a CubeSigner session token.\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The org to log into.\n   * @param {string} token The OIDC token to exchange\n   * @param {List<Scope>} scopes The scopes for the new session\n   * @param {RatchetConfig} lifetimes Lifetimes of the new session.\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @param {string} purpose Optional session description.\n   * @return {Promise<CubeSignerResponse<SessionData>>} The session data.\n   */\n  static async oidcSessionCreate(\n    env: EnvInterface,\n    orgId: string,\n    token: string,\n    scopes: Array<Scope>,\n    lifetimes?: RatchetConfig,\n    mfaReceipt?: MfaReceipts,\n    purpose?: string,\n  ): Promise<CubeSignerResponse<SessionData>> {\n    const o = op(\"/v0/org/{org_id}/oidc\", \"post\");\n\n    const loginFn = async (headers?: HeadersInit) => {\n      const data = await retryOn5XX(() =>\n        o({\n          baseUrl: env.SignerApiRoot,\n          params: { path: { org_id: orgId } },\n          headers: {\n            ...headers,\n            Authorization: token,\n          },\n          body: {\n            scopes,\n            purpose,\n            tokens: lifetimes,\n          },\n        }),\n      ).then(assertOk);\n\n      return mapResponse(data, (sessionInfo): SessionData => {\n        return {\n          env: {\n            [\"Dev-CubeSignerStack\"]: env,\n          },\n          org_id: orgId,\n          token: sessionInfo.token,\n          refresh_token: sessionInfo.refresh_token,\n          session_exp: sessionInfo.expiration,\n          purpose: \"sign in via oidc\",\n          session_info: sessionInfo.session_info,\n        };\n      });\n    };\n\n    return await CubeSignerResponse.create(env, loginFn, mfaReceipt);\n  }\n\n  /**\n   * Accept an invitation to join a CubeSigner org.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The id of the organization\n   * @param {InvitationAcceptRequest} body The request body\n   */\n  static async idpAcceptInvite(\n    env: EnvInterface,\n    orgId: string,\n    body: InvitationAcceptRequest,\n  ): Promise<void> {\n    const o = op(\"/v0/org/{org_id}/invitation/accept\", \"post\");\n    await retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        body,\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Unauthenticated endpoint for authenticating with email/password.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The id of the organization\n   * @param {AuthenticationRequest} body The request body\n   * @return {AuthenticationResponse} Returns an OIDC token which can be used\n   *   to log in via OIDC (see {@link oidcSessionCreate}).\n   */\n  static async idpAuthenticate(\n    env: EnvInterface,\n    orgId: string,\n    body: AuthenticationRequest,\n  ): Promise<AuthenticationResponse> {\n    const o = op(\"/v0/org/{org_id}/idp/authenticate\", \"post\");\n    return retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        body,\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Unauthenticated endpoint for requesting password reset.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The id of the organization\n   * @param {PasswordResetRequest} body The request body\n   * @return {EmailOtpResponse} Returns the partial token (`${header}.${claims}.`) while the signature is sent via email.\n   */\n  static async idpPasswordResetRequest(\n    env: EnvInterface,\n    orgId: string,\n    body: PasswordResetRequest,\n  ): Promise<EmailOtpResponse> {\n    const o = op(\"/v0/org/{org_id}/idp/password_reset\", \"post\");\n    return retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        body,\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Unauthenticated endpoint for confirming a previously initiated password reset request.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The id of the organization\n   * @param {string} partialToken The partial token returned by {@link passwordResetRequest}\n   * @param {string} signature The one-time code (signature in this case) sent via email\n   * @param {string} newPassword The new password\n   */\n  static async idpPasswordResetConfirm(\n    env: EnvInterface,\n    orgId: string,\n    partialToken: string,\n    signature: string,\n    newPassword: string,\n  ): Promise<void> {\n    const o = op(\"/v0/org/{org_id}/idp/password_reset\", \"patch\");\n    await retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        body: {\n          token: `${partialToken}${signature}`,\n          new_password: newPassword,\n        },\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Exchange an OIDC token for a proof of authentication.\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} orgId The org id in which to generate proof\n   * @param {string} token The oidc token\n   * @return {Promise<IdentityProof>} Proof of authentication\n   */\n  static async identityProveOidc(\n    env: EnvInterface,\n    orgId: string,\n    token: string,\n  ): Promise<IdentityProof> {\n    const o = op(\"/v0/org/{org_id}/identity/prove/oidc\", \"post\");\n    return retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        params: { path: { org_id: orgId } },\n        headers: {\n          Authorization: token,\n        },\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Obtain all organizations a user is a member of\n   *\n   * @param {EnvInterface} env The environment to log into\n   * @param {string} token The oidc token identifying the user\n   * @return {Promise<UserOrgsResponse>} The organization the user belongs to\n   */\n  static async userOrgs(env: EnvInterface, token: string): Promise<UserOrgsResponse> {\n    const o = op(\"/v0/user/orgs\", \"get\");\n    return retryOn5XX(() =>\n      o({\n        baseUrl: env.SignerApiRoot,\n        headers: {\n          Authorization: token,\n        },\n      }),\n    ).then(assertOk);\n  }\n\n  /**\n   * Post-process a {@link UserInfo} response. Post-processing ensures that the email field for\n   * users without an email is set to `null`.\n   *\n   * @param {UserInfo} info The info to post-process\n   * @return {Promise<UserInfo>} The processed user info\n   */\n  static #processUserInfo(info: UserInfo): UserInfo {\n    if (info.email === EMAIL_NOT_FOUND) {\n      info.email = null;\n    }\n    return info;\n  }\n\n  /**\n   * Post-process a {@link UserInOrgInfo} response. Post-processing ensures that the email field for\n   * users without an email is set to `null`.\n   *\n   * @param {UserInOrgInfo} info The info to post-process\n   * @return {Promise<UserInOrgInfo>} The processed user info\n   */\n  static #processUserInOrgInfo(info: UserInOrgInfo): UserInOrgInfo {\n    if (info.email === EMAIL_NOT_FOUND) {\n      info.email = null;\n    }\n    return info;\n  }\n}\n\nconst defaultSignerSessionLifetime: SessionLifetime = {\n  session: 604800, // 1 week\n  auth: 300, // 5 min\n  refresh: 86400, // 1 day\n  grace: 30, // seconds\n};\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cubist-labs/cubesigner-sdk",
3
- "version": "0.4.88-0",
3
+ "version": "0.4.89-0",
4
4
  "description": "CubeSigner TypeScript SDK",
5
5
  "license": "MIT OR Apache-2.0",
6
6
  "author": "Cubist, Inc.",
@@ -1890,20 +1890,19 @@ export class ApiClient extends BaseClient {
1890
1890
  }),
1891
1891
  ).then(assertOk);
1892
1892
 
1893
- return mapResponse(
1894
- data,
1895
- (sessionInfo) =>
1896
- <SessionData>{
1897
- env: {
1898
- ["Dev-CubeSignerStack"]: env,
1899
- },
1900
- org_id: orgId,
1901
- token: sessionInfo.token,
1902
- session_exp: sessionInfo.expiration,
1903
- purpose: "sign in via oidc",
1904
- session_info: sessionInfo.session_info,
1893
+ return mapResponse(data, (sessionInfo): SessionData => {
1894
+ return {
1895
+ env: {
1896
+ ["Dev-CubeSignerStack"]: env,
1905
1897
  },
1906
- );
1898
+ org_id: orgId,
1899
+ token: sessionInfo.token,
1900
+ refresh_token: sessionInfo.refresh_token,
1901
+ session_exp: sessionInfo.expiration,
1902
+ purpose: "sign in via oidc",
1903
+ session_info: sessionInfo.session_info,
1904
+ };
1905
+ });
1907
1906
  };
1908
1907
 
1909
1908
  return await CubeSignerResponse.create(env, loginFn, mfaReceipt);