@cubist-labs/cubesigner-sdk 0.4.152-0 → 0.4.153-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 +1 -1
- package/dist/src/key.d.ts +5 -1
- package/dist/src/key.d.ts.map +1 -1
- package/dist/src/key.js +14 -1
- package/dist/src/passkey.d.ts.map +1 -1
- package/dist/src/passkey.js +4 -5
- package/dist/src/schema.d.ts +14 -8
- package/dist/src/schema.d.ts.map +1 -1
- package/dist/src/schema.js +1 -1
- package/package.json +1 -1
- package/src/key.ts +13 -0
- package/src/passkey.ts +3 -4
- package/src/schema.ts +18 -7
package/dist/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"url": "git+https://github.com/cubist-labs/CubeSigner-TypeScript-SDK.git",
|
|
6
6
|
"directory": "packages/sdk"
|
|
7
7
|
},
|
|
8
|
-
"version": "0.4.
|
|
8
|
+
"version": "0.4.153-0",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
package/dist/src/key.d.ts
CHANGED
|
@@ -8,6 +8,9 @@ export declare enum Secp256k1 {
|
|
|
8
8
|
Evm = "SecpEthAddr",
|
|
9
9
|
Btc = "SecpBtc",
|
|
10
10
|
BtcTest = "SecpBtcTest",
|
|
11
|
+
Ltc = "SecpLtc",
|
|
12
|
+
LtcTest = "SecpLtcTest",
|
|
13
|
+
Xrp = "SecpXrpAddr",
|
|
11
14
|
Cosmos = "SecpCosmosAddr",
|
|
12
15
|
Taproot = "TaprootBtc",
|
|
13
16
|
TaprootTest = "TaprootBtcTest",
|
|
@@ -40,7 +43,8 @@ export declare enum Ed25519 {
|
|
|
40
43
|
Stellar = "Ed25519StellarAddr",
|
|
41
44
|
Substrate = "Ed25519SubstrateAddr",
|
|
42
45
|
Tendermint = "Ed25519TendermintAddr",
|
|
43
|
-
Ton = "Ed25519TonAddr"
|
|
46
|
+
Ton = "Ed25519TonAddr",
|
|
47
|
+
Xrp = "Ed25519XrpAddr"
|
|
44
48
|
}
|
|
45
49
|
/** P256 key type */
|
|
46
50
|
export declare enum P256 {
|
package/dist/src/key.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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"}
|
package/dist/src/key.js
CHANGED
|
@@ -22,6 +22,9 @@ var Secp256k1;
|
|
|
22
22
|
Secp256k1["Evm"] = "SecpEthAddr";
|
|
23
23
|
Secp256k1["Btc"] = "SecpBtc";
|
|
24
24
|
Secp256k1["BtcTest"] = "SecpBtcTest";
|
|
25
|
+
Secp256k1["Ltc"] = "SecpLtc";
|
|
26
|
+
Secp256k1["LtcTest"] = "SecpLtcTest";
|
|
27
|
+
Secp256k1["Xrp"] = "SecpXrpAddr";
|
|
25
28
|
Secp256k1["Cosmos"] = "SecpCosmosAddr";
|
|
26
29
|
Secp256k1["Taproot"] = "TaprootBtc";
|
|
27
30
|
Secp256k1["TaprootTest"] = "TaprootBtcTest";
|
|
@@ -57,6 +60,7 @@ var Ed25519;
|
|
|
57
60
|
Ed25519["Substrate"] = "Ed25519SubstrateAddr";
|
|
58
61
|
Ed25519["Tendermint"] = "Ed25519TendermintAddr";
|
|
59
62
|
Ed25519["Ton"] = "Ed25519TonAddr";
|
|
63
|
+
Ed25519["Xrp"] = "Ed25519XrpAddr";
|
|
60
64
|
})(Ed25519 || (exports.Ed25519 = Ed25519 = {}));
|
|
61
65
|
/** P256 key type */
|
|
62
66
|
var P256;
|
|
@@ -577,6 +581,15 @@ function fromSchemaKeyType(ty) {
|
|
|
577
581
|
return P256.Ontology;
|
|
578
582
|
case "P256Neo3Addr":
|
|
579
583
|
return P256.Neo3;
|
|
584
|
+
case "SecpLtc":
|
|
585
|
+
return Secp256k1.Ltc;
|
|
586
|
+
case "SecpLtcTest":
|
|
587
|
+
return Secp256k1.LtcTest;
|
|
588
|
+
case "SecpXrpAddr":
|
|
589
|
+
return Secp256k1.Xrp;
|
|
590
|
+
case "Ed25519XrpAddr":
|
|
591
|
+
return Ed25519.Xrp;
|
|
592
|
+
// NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts
|
|
580
593
|
}
|
|
581
594
|
}
|
|
582
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import type { KeyPolicy } from \"./role\";\nimport type { PageOpts } from \"./paginator\";\nimport type {\n  KeyInfo,\n  UpdateKeyRequest,\n  SchemaKeyType,\n  KeyInRoleInfo,\n  EvmSignRequest,\n  EvmSignResponse,\n  Eip191SignRequest,\n  Eip712SignRequest,\n  Eth2SignRequest,\n  Eth2UnstakeRequest,\n  AvaTx,\n  BlobSignRequest,\n  BtcSignRequest,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  BtcMessageSignResponse,\n  BtcSignResponse,\n  BlobSignResponse,\n  AvaSignResponse,\n  Eth2UnstakeResponse,\n  Eth2SignResponse,\n  Eip191Or712SignResponse,\n  PsbtSignRequest,\n  PsbtSignResponse,\n} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  BabylonRegistrationRequest,\n  BabylonRegistrationResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  BtcMessageSignRequest,\n  CubeSignerResponse,\n  Empty,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n  SuiSignRequest,\n  SuiSignResponse,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { encodeToHex } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\",\n  Btc = \"SecpBtc\",\n  BtcTest = \"SecpBtcTest\",\n  Cosmos = \"SecpCosmosAddr\",\n  Taproot = \"TaprootBtc\",\n  TaprootTest = \"TaprootBtcTest\",\n  BabylonEots = \"BabylonEots\",\n  BabylonCov = \"BabylonCov\",\n  Ava = \"SecpAvaAddr\",\n  AvaTest = \"SecpAvaTestAddr\",\n  Tron = \"SecpTronAddr\",\n  BtcLegacy = \"SecpBtcLegacy\",\n  BtcLegacyTest = \"SecpBtcLegacyTest\",\n  Doge = \"SecpDogeAddr\",\n  DogeTest = \"SecpDogeTestAddr\",\n  Kaspa = \"SecpKaspaAddr\",\n  KaspaTest = \"SecpKaspaTestAddr\",\n  KaspaSchnorr = \"SchnorrKaspaAddr\",\n  KaspaTestSchnorr = \"SchnorrKaspaTestAddr\",\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\",\n  Eth2Inactive = \"BlsInactive\",\n  AvaIcm = \"BlsAvaIcm\",\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\",\n  Sui = \"Ed25519SuiAddr\",\n  Aptos = \"Ed25519AptosAddr\",\n  Cardano = \"Ed25519CardanoAddrVk\",\n  Stellar = \"Ed25519StellarAddr\",\n  Substrate = \"Ed25519SubstrateAddr\",\n  Tendermint = \"Ed25519TendermintAddr\",\n  Ton = \"Ed25519TonAddr\",\n}\n\n/** P256 key type */\nexport enum P256 {\n  Cosmos = \"P256CosmosAddr\",\n  Ontology = \"P256OntologyAddr\",\n  Neo3 = \"P256Neo3Addr\",\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256;\n\n/**\n * A representation of a signing key.\n */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #apiClient: ApiClient;\n\n  /** @returns The organization that this key is in */\n  get orgId() {\n    return this.#apiClient.sessionMeta.org_id;\n  }\n\n  /**\n   * The id of the key: \"Key#\" followed by a unique identifier specific to\n   * the type of key (such as a public key for BLS or an ethereum address for Secp)\n   *\n   * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly id: string;\n\n  /**\n   * A unique identifier specific to the type of key, such as a public key or an ethereum address\n   *\n   * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly materialId!: string;\n\n  /**\n   * @description Hex-encoded, serialized public key. The format used depends on the key type:\n   * - secp256k1 keys use 65-byte uncompressed SECG format\n   * - BLS keys use 48-byte compressed BLS12-381 (ZCash) format\n   * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431\n   */\n  readonly publicKey: string;\n\n  /**\n   * Get the cached properties of this key. The cached properties reflect the\n   * state of the last fetch or update (e.g., after awaiting `Key.enabled()`\n   * or `Key.disable()`).\n   */\n  cached: KeyInfo;\n\n  /** @returns The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** @returns Whether the key is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /**\n   * Enable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async enable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: true }, mfaReceipt);\n  }\n\n  /**\n   * Disable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async disable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: false }, mfaReceipt);\n  }\n\n  /**\n   * List roles this key is in.\n   *\n   * @param page Optional pagination options; by default, retrieves all roles this key is in.\n   * @returns Roles this key is in.\n   */\n  async roles(page?: PageOpts): Promise<KeyInRoleInfo[]> {\n    return await this.#apiClient.keyRolesList(this.id, page).fetch();\n  }\n\n  /**\n   * List historical transactions for this key.\n   *\n   * @param page Optional pagination options; by default, retrieves all historical transactions for this key.\n   * @returns Historical key transactions.\n   */\n  async history(page?: PageOpts): Promise<HistoricalTx[]> {\n    return await this.#apiClient.keyHistory(this.id, page).fetch();\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   *\n   * @param policy The new policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ policy }, mfaReceipt);\n  }\n\n  /**\n   * Set key metadata. The metadata must be at most 1024 characters\n   * and must match the following regex: ^[A-Za-z0-9_=+/ \\-\\.\\,]{0,1024}$.\n   *\n   * @param metadata The new metadata to set.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns The updated key info\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is an object (throws if it is not),\n   * then sets the value of the {@link name} property in that object to {@link value},\n   * and finally submits the request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async setMetadataProperty(\n    name: string,\n    value: JsonValue,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      value,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is in object (throws if it is not),\n   * then deletes the {@link name} property in that object, and finally submits the\n   * request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async deleteMetadataProperty(name: string, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      undefined,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param delaysMs Delays in milliseconds between retries\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   * @internal\n   */\n  async #setMetadataProperty(\n    name: string,\n    value: JsonValue | undefined,\n    delaysMs: number[],\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    const data = await this.fetch();\n    const current = data.metadata ?? {};\n    if (typeof current !== \"object\") {\n      throw new Error(\"Current metadata is not a JSON object\");\n    }\n    const updated = {\n      ...current,\n      [name]: value,\n    };\n    try {\n      return await this.update(\n        {\n          metadata: updated,\n          version: data.version,\n        },\n        mfaReceipt,\n      );\n    } catch (e) {\n      if ((e as ErrResponse).errorCode === \"InvalidUpdate\" && delaysMs.length > 0) {\n        await delay(delaysMs[0]);\n        return await this.#setMetadataProperty(name, value, delaysMs.slice(1));\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy}\n   * to fetch the current policy and then {@link setPolicy} to set the policy -- and\n   * should not be used in across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   */\n  async appendPolicy(policy: KeyPolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\n  }\n\n  /**\n   * Get the policy for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * Fetch the metadata for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * @returns The user id for the owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /**\n   * Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   *\n   * @param owner The user-id of the new owner of the key.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setOwner(owner: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ owner }, mfaReceipt);\n  }\n\n  /**\n   * Delete this key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns A response which can be used to approve MFA if needed\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.keyDelete(this.id, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Create a new key.\n   *\n   * @param client The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(client: ApiClient | CubeSignerClient, data: KeyInfo) {\n    this.#apiClient = client instanceof CubeSignerClient ? client.apiClient : client;\n    this.id = data.key_id;\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n    this.cached = data;\n  }\n\n  /**\n   * Sign an EVM transaction.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signEvm(\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    return await this.#apiClient.signEvm(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon staking transaction.\n   *\n   * @param req The staking transaction to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signBabylonStakingTxn(\n    req: BabylonStakingRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonStakingResponse>> {\n    return this.#apiClient.signBabylonStakingTxn(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon registration.\n   *\n   * @param req The registration request to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Babylon staking registration data (or MFA approval request).\n   */\n  async signBabylonRegistration(\n    req: BabylonRegistrationRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonRegistrationResponse>> {\n    return this.#apiClient.signBabylonRegistration(this, req, 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 req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip191(\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip191(this, req, 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 req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip712(\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip712(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain validation message.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature\n   */\n  async signEth2(\n    req: Eth2SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2SignResponse>> {\n    return await this.#apiClient.signEth2(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain unstake/exit request.\n   *\n   * @param req The request to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async unstake(\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    return await this.#apiClient.signUnstake(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Avalanche P- or X-chain message.\n   *\n   * @param tx Avalanche message (transaction) to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signAva(tx: AvaTx, mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signAva(this, tx, mfaReceipt);\n  }\n\n  /**\n   * Sign a serialized Avalanche C-/X-/P-chain message.\n   *\n   * @param avaChain Avalanche chain\n   * @param tx Hex encoded transaction\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSerializedAva(\n    avaChain: AvaChain,\n    tx: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signSerializedAva(this, avaChain, tx, 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 req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBlob(\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    return await this.#apiClient.signBlob(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin transaction.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBtc(\n    req: BtcSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BtcSignResponse>> {\n    return await this.#apiClient.signBtc(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a PSBT.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response\n   */\n  async signPsbt(\n    req: PsbtSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<PsbtSignResponse>> {\n    return await this.#apiClient.signPsbt(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin message.\n   *\n   * @param req The message to sign\n   * @param opts Options for this request\n   * @param opts.p2sh If this is a segwit key and p2sh is true, sign as p2sh-p2wpkh instead of p2wpkh. Defaults to false if not specified.\n   * @param opts.metadata Optional arbitrary JSON metadata\n   * @param opts.mfaReceipt Optional MFA receipt(s)\n   * @returns The response\n   */\n  async signBtcMessage(\n    req: Uint8Array | string,\n    opts: { p2sh?: boolean; mfaReceipt?: MfaReceipts; metadata?: unknown },\n  ): Promise<CubeSignerResponse<BtcMessageSignResponse>> {\n    const request: BtcMessageSignRequest = {\n      data: encodeToHex(req),\n      is_p2sh: opts.p2sh ?? false,\n      metadata: opts.metadata,\n    };\n    return await this.#apiClient.signBtcMessage(this, request, opts.mfaReceipt);\n  }\n\n  /**\n   * Sign a Solana message.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSolana(\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SolanaSignResponse>> {\n    return await this.#apiClient.signSolana(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a SUI transaction.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSui(\n    req: SuiSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SuiSignResponse>> {\n    return await this.#apiClient.signSui(this, req, mfaReceipt);\n  }\n\n  /**\n   * Update the key.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The JSON response from the API server.\n   * @throws if MFA is required and no MFA receipts are provided\n   * @internal\n   */\n  private async update(request: UpdateKeyRequest, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    const resp = await this.#apiClient.keyUpdate(this.id, request, mfaReceipt);\n    this.cached = resp.data();\n    return this.cached;\n  }\n\n  /**\n   * Fetch the key information.\n   *\n   * @returns The key information.\n   * @internal\n   */\n  private async fetch(): Promise<KeyInfo> {\n    this.cached = await this.#apiClient.keyGet(this.id);\n    return this.cached;\n  }\n}\n\n/**\n * Convert a schema key type to a key type.\n *\n * @param ty The schema key type.\n * @returns The key type.\n * @internal\n */\nexport function fromSchemaKeyType(ty: SchemaKeyType): KeyType {\n  switch (ty) {\n    case \"SecpEthAddr\":\n      return Secp256k1.Evm;\n    case \"SecpCosmosAddr\":\n      return Secp256k1.Cosmos;\n    case \"SecpBtc\":\n      return Secp256k1.Btc;\n    case \"SecpBtcTest\":\n      return Secp256k1.BtcTest;\n    case \"SecpBtcLegacy\":\n      return Secp256k1.BtcLegacy;\n    case \"SecpBtcLegacyTest\":\n      return Secp256k1.BtcLegacyTest;\n    case \"SecpAvaAddr\":\n      return Secp256k1.Ava;\n    case \"SecpAvaTestAddr\":\n      return Secp256k1.AvaTest;\n    case \"BabylonEots\":\n      return Secp256k1.BabylonEots;\n    case \"BabylonCov\":\n      return Secp256k1.BabylonEots;\n    case \"TaprootBtc\":\n      return Secp256k1.Taproot;\n    case \"TaprootBtcTest\":\n      return Secp256k1.TaprootTest;\n    case \"SecpTronAddr\":\n      return Secp256k1.Tron;\n    case \"SecpDogeAddr\":\n      return Secp256k1.Doge;\n    case \"SecpDogeTestAddr\":\n      return Secp256k1.DogeTest;\n    case \"SecpKaspaAddr\":\n      return Secp256k1.Kaspa;\n    case \"SecpKaspaTestAddr\":\n      return Secp256k1.KaspaTest;\n    case \"SchnorrKaspaAddr\":\n      return Secp256k1.KaspaSchnorr;\n    case \"SchnorrKaspaTestAddr\":\n      return Secp256k1.KaspaTestSchnorr;\n    case \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\n    case \"BlsAvaIcm\":\n      return Bls.AvaIcm;\n    case \"Ed25519SolanaAddr\":\n      return Ed25519.Solana;\n    case \"Ed25519SuiAddr\":\n      return Ed25519.Sui;\n    case \"Ed25519AptosAddr\":\n      return Ed25519.Aptos;\n    case \"Ed25519CardanoAddrVk\":\n      return Ed25519.Cardano;\n    case \"Ed25519StellarAddr\":\n      return Ed25519.Stellar;\n    case \"Ed25519SubstrateAddr\":\n      return Ed25519.Substrate;\n    case \"Ed25519TendermintAddr\":\n      return Ed25519.Tendermint;\n    case \"Ed25519TonAddr\":\n      return Ed25519.Ton;\n    case \"Stark\":\n      return Stark;\n    case \"Mnemonic\":\n      return Mnemonic;\n    case \"P256CosmosAddr\":\n      return P256.Cosmos;\n    case \"P256OntologyAddr\":\n      return P256.Ontology;\n    case \"P256Neo3Addr\":\n      return P256.Neo3;\n  }\n}\n"]}
|
|
595
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import type { KeyPolicy } from \"./role\";\nimport type { PageOpts } from \"./paginator\";\nimport type {\n  KeyInfo,\n  UpdateKeyRequest,\n  SchemaKeyType,\n  KeyInRoleInfo,\n  EvmSignRequest,\n  EvmSignResponse,\n  Eip191SignRequest,\n  Eip712SignRequest,\n  Eth2SignRequest,\n  Eth2UnstakeRequest,\n  AvaTx,\n  BlobSignRequest,\n  BtcSignRequest,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  BtcMessageSignResponse,\n  BtcSignResponse,\n  BlobSignResponse,\n  AvaSignResponse,\n  Eth2UnstakeResponse,\n  Eth2SignResponse,\n  Eip191Or712SignResponse,\n  PsbtSignRequest,\n  PsbtSignResponse,\n} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  BabylonRegistrationRequest,\n  BabylonRegistrationResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  BtcMessageSignRequest,\n  CubeSignerResponse,\n  Empty,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n  SuiSignRequest,\n  SuiSignResponse,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { encodeToHex } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\",\n  Btc = \"SecpBtc\",\n  BtcTest = \"SecpBtcTest\",\n  Ltc = \"SecpLtc\",\n  LtcTest = \"SecpLtcTest\",\n  Xrp = \"SecpXrpAddr\",\n  Cosmos = \"SecpCosmosAddr\",\n  Taproot = \"TaprootBtc\",\n  TaprootTest = \"TaprootBtcTest\",\n  BabylonEots = \"BabylonEots\",\n  BabylonCov = \"BabylonCov\",\n  Ava = \"SecpAvaAddr\",\n  AvaTest = \"SecpAvaTestAddr\",\n  Tron = \"SecpTronAddr\",\n  BtcLegacy = \"SecpBtcLegacy\",\n  BtcLegacyTest = \"SecpBtcLegacyTest\",\n  Doge = \"SecpDogeAddr\",\n  DogeTest = \"SecpDogeTestAddr\",\n  Kaspa = \"SecpKaspaAddr\",\n  KaspaTest = \"SecpKaspaTestAddr\",\n  KaspaSchnorr = \"SchnorrKaspaAddr\",\n  KaspaTestSchnorr = \"SchnorrKaspaTestAddr\",\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\",\n  Eth2Inactive = \"BlsInactive\",\n  AvaIcm = \"BlsAvaIcm\",\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\",\n  Sui = \"Ed25519SuiAddr\",\n  Aptos = \"Ed25519AptosAddr\",\n  Cardano = \"Ed25519CardanoAddrVk\",\n  Stellar = \"Ed25519StellarAddr\",\n  Substrate = \"Ed25519SubstrateAddr\",\n  Tendermint = \"Ed25519TendermintAddr\",\n  Ton = \"Ed25519TonAddr\",\n  Xrp = \"Ed25519XrpAddr\",\n}\n\n/** P256 key type */\nexport enum P256 {\n  Cosmos = \"P256CosmosAddr\",\n  Ontology = \"P256OntologyAddr\",\n  Neo3 = \"P256Neo3Addr\",\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256;\n\n/**\n * A representation of a signing key.\n */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #apiClient: ApiClient;\n\n  /** @returns The organization that this key is in */\n  get orgId() {\n    return this.#apiClient.sessionMeta.org_id;\n  }\n\n  /**\n   * The id of the key: \"Key#\" followed by a unique identifier specific to\n   * the type of key (such as a public key for BLS or an ethereum address for Secp)\n   *\n   * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly id: string;\n\n  /**\n   * A unique identifier specific to the type of key, such as a public key or an ethereum address\n   *\n   * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly materialId!: string;\n\n  /**\n   * @description Hex-encoded, serialized public key. The format used depends on the key type:\n   * - secp256k1 keys use 65-byte uncompressed SECG format\n   * - BLS keys use 48-byte compressed BLS12-381 (ZCash) format\n   * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431\n   */\n  readonly publicKey: string;\n\n  /**\n   * Get the cached properties of this key. The cached properties reflect the\n   * state of the last fetch or update (e.g., after awaiting `Key.enabled()`\n   * or `Key.disable()`).\n   */\n  cached: KeyInfo;\n\n  /** @returns The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** @returns Whether the key is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /**\n   * Enable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async enable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: true }, mfaReceipt);\n  }\n\n  /**\n   * Disable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async disable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: false }, mfaReceipt);\n  }\n\n  /**\n   * List roles this key is in.\n   *\n   * @param page Optional pagination options; by default, retrieves all roles this key is in.\n   * @returns Roles this key is in.\n   */\n  async roles(page?: PageOpts): Promise<KeyInRoleInfo[]> {\n    return await this.#apiClient.keyRolesList(this.id, page).fetch();\n  }\n\n  /**\n   * List historical transactions for this key.\n   *\n   * @param page Optional pagination options; by default, retrieves all historical transactions for this key.\n   * @returns Historical key transactions.\n   */\n  async history(page?: PageOpts): Promise<HistoricalTx[]> {\n    return await this.#apiClient.keyHistory(this.id, page).fetch();\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   *\n   * @param policy The new policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ policy }, mfaReceipt);\n  }\n\n  /**\n   * Set key metadata. The metadata must be at most 1024 characters\n   * and must match the following regex: ^[A-Za-z0-9_=+/ \\-\\.\\,]{0,1024}$.\n   *\n   * @param metadata The new metadata to set.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns The updated key info\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is an object (throws if it is not),\n   * then sets the value of the {@link name} property in that object to {@link value},\n   * and finally submits the request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async setMetadataProperty(\n    name: string,\n    value: JsonValue,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      value,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is in object (throws if it is not),\n   * then deletes the {@link name} property in that object, and finally submits the\n   * request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async deleteMetadataProperty(name: string, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      undefined,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param delaysMs Delays in milliseconds between retries\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   * @internal\n   */\n  async #setMetadataProperty(\n    name: string,\n    value: JsonValue | undefined,\n    delaysMs: number[],\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    const data = await this.fetch();\n    const current = data.metadata ?? {};\n    if (typeof current !== \"object\") {\n      throw new Error(\"Current metadata is not a JSON object\");\n    }\n    const updated = {\n      ...current,\n      [name]: value,\n    };\n    try {\n      return await this.update(\n        {\n          metadata: updated,\n          version: data.version,\n        },\n        mfaReceipt,\n      );\n    } catch (e) {\n      if ((e as ErrResponse).errorCode === \"InvalidUpdate\" && delaysMs.length > 0) {\n        await delay(delaysMs[0]);\n        return await this.#setMetadataProperty(name, value, delaysMs.slice(1));\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy}\n   * to fetch the current policy and then {@link setPolicy} to set the policy -- and\n   * should not be used in across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   */\n  async appendPolicy(policy: KeyPolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\n  }\n\n  /**\n   * Get the policy for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * Fetch the metadata for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * @returns The user id for the owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /**\n   * Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   *\n   * @param owner The user-id of the new owner of the key.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setOwner(owner: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ owner }, mfaReceipt);\n  }\n\n  /**\n   * Delete this key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns A response which can be used to approve MFA if needed\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.keyDelete(this.id, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Create a new key.\n   *\n   * @param client The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(client: ApiClient | CubeSignerClient, data: KeyInfo) {\n    this.#apiClient = client instanceof CubeSignerClient ? client.apiClient : client;\n    this.id = data.key_id;\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n    this.cached = data;\n  }\n\n  /**\n   * Sign an EVM transaction.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signEvm(\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    return await this.#apiClient.signEvm(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon staking transaction.\n   *\n   * @param req The staking transaction to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signBabylonStakingTxn(\n    req: BabylonStakingRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonStakingResponse>> {\n    return this.#apiClient.signBabylonStakingTxn(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon registration.\n   *\n   * @param req The registration request to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Babylon staking registration data (or MFA approval request).\n   */\n  async signBabylonRegistration(\n    req: BabylonRegistrationRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonRegistrationResponse>> {\n    return this.#apiClient.signBabylonRegistration(this, req, 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 req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip191(\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip191(this, req, 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 req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip712(\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip712(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain validation message.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature\n   */\n  async signEth2(\n    req: Eth2SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2SignResponse>> {\n    return await this.#apiClient.signEth2(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain unstake/exit request.\n   *\n   * @param req The request to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async unstake(\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    return await this.#apiClient.signUnstake(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Avalanche P- or X-chain message.\n   *\n   * @param tx Avalanche message (transaction) to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signAva(tx: AvaTx, mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signAva(this, tx, mfaReceipt);\n  }\n\n  /**\n   * Sign a serialized Avalanche C-/X-/P-chain message.\n   *\n   * @param avaChain Avalanche chain\n   * @param tx Hex encoded transaction\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSerializedAva(\n    avaChain: AvaChain,\n    tx: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signSerializedAva(this, avaChain, tx, 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 req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBlob(\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    return await this.#apiClient.signBlob(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin transaction.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBtc(\n    req: BtcSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BtcSignResponse>> {\n    return await this.#apiClient.signBtc(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a PSBT.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response\n   */\n  async signPsbt(\n    req: PsbtSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<PsbtSignResponse>> {\n    return await this.#apiClient.signPsbt(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin message.\n   *\n   * @param req The message to sign\n   * @param opts Options for this request\n   * @param opts.p2sh If this is a segwit key and p2sh is true, sign as p2sh-p2wpkh instead of p2wpkh. Defaults to false if not specified.\n   * @param opts.metadata Optional arbitrary JSON metadata\n   * @param opts.mfaReceipt Optional MFA receipt(s)\n   * @returns The response\n   */\n  async signBtcMessage(\n    req: Uint8Array | string,\n    opts: { p2sh?: boolean; mfaReceipt?: MfaReceipts; metadata?: unknown },\n  ): Promise<CubeSignerResponse<BtcMessageSignResponse>> {\n    const request: BtcMessageSignRequest = {\n      data: encodeToHex(req),\n      is_p2sh: opts.p2sh ?? false,\n      metadata: opts.metadata,\n    };\n    return await this.#apiClient.signBtcMessage(this, request, opts.mfaReceipt);\n  }\n\n  /**\n   * Sign a Solana message.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSolana(\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SolanaSignResponse>> {\n    return await this.#apiClient.signSolana(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a SUI transaction.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSui(\n    req: SuiSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SuiSignResponse>> {\n    return await this.#apiClient.signSui(this, req, mfaReceipt);\n  }\n\n  /**\n   * Update the key.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The JSON response from the API server.\n   * @throws if MFA is required and no MFA receipts are provided\n   * @internal\n   */\n  private async update(request: UpdateKeyRequest, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    const resp = await this.#apiClient.keyUpdate(this.id, request, mfaReceipt);\n    this.cached = resp.data();\n    return this.cached;\n  }\n\n  /**\n   * Fetch the key information.\n   *\n   * @returns The key information.\n   * @internal\n   */\n  private async fetch(): Promise<KeyInfo> {\n    this.cached = await this.#apiClient.keyGet(this.id);\n    return this.cached;\n  }\n}\n\n/**\n * Convert a schema key type to a key type.\n *\n * @param ty The schema key type.\n * @returns The key type.\n * @internal\n */\nexport function fromSchemaKeyType(ty: SchemaKeyType): KeyType {\n  switch (ty) {\n    case \"SecpEthAddr\":\n      return Secp256k1.Evm;\n    case \"SecpCosmosAddr\":\n      return Secp256k1.Cosmos;\n    case \"SecpBtc\":\n      return Secp256k1.Btc;\n    case \"SecpBtcTest\":\n      return Secp256k1.BtcTest;\n    case \"SecpBtcLegacy\":\n      return Secp256k1.BtcLegacy;\n    case \"SecpBtcLegacyTest\":\n      return Secp256k1.BtcLegacyTest;\n    case \"SecpAvaAddr\":\n      return Secp256k1.Ava;\n    case \"SecpAvaTestAddr\":\n      return Secp256k1.AvaTest;\n    case \"BabylonEots\":\n      return Secp256k1.BabylonEots;\n    case \"BabylonCov\":\n      return Secp256k1.BabylonEots;\n    case \"TaprootBtc\":\n      return Secp256k1.Taproot;\n    case \"TaprootBtcTest\":\n      return Secp256k1.TaprootTest;\n    case \"SecpTronAddr\":\n      return Secp256k1.Tron;\n    case \"SecpDogeAddr\":\n      return Secp256k1.Doge;\n    case \"SecpDogeTestAddr\":\n      return Secp256k1.DogeTest;\n    case \"SecpKaspaAddr\":\n      return Secp256k1.Kaspa;\n    case \"SecpKaspaTestAddr\":\n      return Secp256k1.KaspaTest;\n    case \"SchnorrKaspaAddr\":\n      return Secp256k1.KaspaSchnorr;\n    case \"SchnorrKaspaTestAddr\":\n      return Secp256k1.KaspaTestSchnorr;\n    case \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\n    case \"BlsAvaIcm\":\n      return Bls.AvaIcm;\n    case \"Ed25519SolanaAddr\":\n      return Ed25519.Solana;\n    case \"Ed25519SuiAddr\":\n      return Ed25519.Sui;\n    case \"Ed25519AptosAddr\":\n      return Ed25519.Aptos;\n    case \"Ed25519CardanoAddrVk\":\n      return Ed25519.Cardano;\n    case \"Ed25519StellarAddr\":\n      return Ed25519.Stellar;\n    case \"Ed25519SubstrateAddr\":\n      return Ed25519.Substrate;\n    case \"Ed25519TendermintAddr\":\n      return Ed25519.Tendermint;\n    case \"Ed25519TonAddr\":\n      return Ed25519.Ton;\n    case \"Stark\":\n      return Stark;\n    case \"Mnemonic\":\n      return Mnemonic;\n    case \"P256CosmosAddr\":\n      return P256.Cosmos;\n    case \"P256OntologyAddr\":\n      return P256.Ontology;\n    case \"P256Neo3Addr\":\n      return P256.Neo3;\n    case \"SecpLtc\":\n      return Secp256k1.Ltc;\n    case \"SecpLtcTest\":\n      return Secp256k1.LtcTest;\n    case \"SecpXrpAddr\":\n      return Secp256k1.Xrp;\n    case \"Ed25519XrpAddr\":\n      return Ed25519.Xrp;\n    // NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts\n  }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"passkey.d.ts","sourceRoot":"","sources":["../../src/passkey.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,YAAY,EACjB,KAAK,sBAAsB,EAC3B,KAAK,OAAO,EACZ,KAAK,WAAW,EACjB,MAAM,GAAG,CAAC;AAwBX;;;;;;GAMG;AACH,wBAAgB,mBAAmB,CACjC,OAAO,EAAE,OAAO,CAAC,mCAAmC,CAAC,GACpD,iCAAiC,CASnC;AAED;;;;;;GAMG;AACH,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,OAAO,CAAC,oCAAoC,CAAC,GACrD,kCAAkC,CAWpC;AA2BD;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,qBAAqB,CAAC,
|
|
1
|
+
{"version":3,"file":"passkey.d.ts","sourceRoot":"","sources":["../../src/passkey.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,YAAY,EACjB,KAAK,sBAAsB,EAC3B,KAAK,OAAO,EACZ,KAAK,WAAW,EACjB,MAAM,GAAG,CAAC;AAwBX;;;;;;GAMG;AACH,wBAAgB,mBAAmB,CACjC,OAAO,EAAE,OAAO,CAAC,mCAAmC,CAAC,GACpD,iCAAiC,CASnC;AAED;;;;;;GAMG;AACH,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,OAAO,CAAC,oCAAoC,CAAC,GACrD,kCAAkC,CAWpC;AA2BD;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAyB1F;AAED;;GAEG;AACH,qBAAa,qBAAqB;;IAe9B,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS;IAb7C,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,sBAAsB,EAAE,SAAS,CAAC,CAAC;IAC5D,QAAQ,CAAC,OAAO,EAAE,iCAAiC,CAAC;IAEpD;;;;;;OAMG;gBAED,GAAG,EAAE,YAAY,EACjB,SAAS,EAAE,sBAAsB,EACxB,OAAO,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS;IAO7C;;;;;OAKG;IACG,sBAAsB,IAAI,OAAO,CAAC,WAAW,CAAC;IAMpD;;;;;;;;;;;OAWG;IACG,MAAM,CAAC,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,WAAW,CAAC;CAM9D"}
|
package/dist/src/passkey.js
CHANGED
|
@@ -98,6 +98,7 @@ function credentialToJSON(cred) {
|
|
|
98
98
|
if (isAuthenticatorAttestationResponse(cred.response)) {
|
|
99
99
|
return {
|
|
100
100
|
id: cred.id,
|
|
101
|
+
clientExtensionResults: cred.getClientExtensionResults(),
|
|
101
102
|
response: {
|
|
102
103
|
clientDataJSON: (0, _1.encodeToBase64Url)(cred.response.clientDataJSON),
|
|
103
104
|
attestationObject: (0, _1.encodeToBase64Url)(cred.response.attestationObject),
|
|
@@ -107,6 +108,7 @@ function credentialToJSON(cred) {
|
|
|
107
108
|
if (isAuthenticatorAssertionResponse(cred.response)) {
|
|
108
109
|
return {
|
|
109
110
|
id: cred.id,
|
|
111
|
+
clientExtensionResults: cred.getClientExtensionResults(),
|
|
110
112
|
response: {
|
|
111
113
|
clientDataJSON: (0, _1.encodeToBase64Url)(cred.response.clientDataJSON),
|
|
112
114
|
authenticatorData: (0, _1.encodeToBase64Url)(cred.response.authenticatorData),
|
|
@@ -141,10 +143,7 @@ class PasskeyLoginChallenge {
|
|
|
141
143
|
* @returns New session.
|
|
142
144
|
*/
|
|
143
145
|
async getCredentialAndAnswer() {
|
|
144
|
-
const cred = await navigator.credentials.get({
|
|
145
|
-
publicKey: this.options,
|
|
146
|
-
mediation: (this.options.allowCredentials ?? []).length > 0 ? undefined : "conditional",
|
|
147
|
-
});
|
|
146
|
+
const cred = await navigator.credentials.get({ publicKey: this.options });
|
|
148
147
|
if (cred === null)
|
|
149
148
|
throw new Error("Credential not found");
|
|
150
149
|
return await this.answer(cred);
|
|
@@ -170,4 +169,4 @@ class PasskeyLoginChallenge {
|
|
|
170
169
|
}
|
|
171
170
|
exports.PasskeyLoginChallenge = PasskeyLoginChallenge;
|
|
172
171
|
_PasskeyLoginChallenge_env = new WeakMap();
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"passkey.js","sourceRoot":"","sources":["../../src/passkey.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApiClient,\n  decodeBase64Url,\n  encodeToBase64Url,\n  type EnvInterface,\n  type PasskeyAssertChallenge,\n  type schemas,\n  type SessionData,\n} from \".\";\n\n/**\n * @param val The value to check\n * @returns If the value is `null`, returns undefined, otherwise returns the value\n */\nfunction noNull<T>(val: T | null): T | undefined {\n  return val === null ? undefined : val;\n}\n\n/**\n * @param cred Credential descriptor, as returned by the CubeSigner back end\n * @returns The credential converted to {@link PublicKeyCredentialDescriptor}\n */\nfunction mapPublicKeyCredentialDescriptor(\n  cred: schemas[\"PublicKeyCredentialDescriptor\"],\n): PublicKeyCredentialDescriptor {\n  return {\n    id: decodeBase64Url(cred.id),\n    type: cred.type,\n    transports: noNull(cred.transports),\n  };\n}\n\n/**\n * Manual implementation of [PublicKeyCredential.parseRequestOptionsFromJSON](https://developer.mozilla.org/en-US/docs/Web/API/PublicKeyCredential/parseRequestOptionsFromJSON_static)\n * (implemented here because not all browsers support it)\n *\n * @param options The credential request options as returned by the CubeSigner back end\n * @returns Parsed credential request options\n */\nexport function parseRequestOptions(\n  options: schemas[\"PublicKeyCredentialRequestOptions\"],\n): PublicKeyCredentialRequestOptions {\n  return {\n    ...options,\n    challenge: decodeBase64Url(options.challenge),\n    extensions: noNull(options.extensions),\n    rpId: noNull(options.rpId),\n    timeout: noNull(options.timeout),\n    allowCredentials: options.allowCredentials?.map(mapPublicKeyCredentialDescriptor),\n  };\n}\n\n/**\n * Manual implementation of [PublicKeyCredential.parseCreationOptionsFromJSON](https://developer.mozilla.org/en-US/docs/Web/API/PublicKeyCredential/parseCreationOptionsFromJSON_static)\n * (implemented here because not all browsers support it)\n *\n * @param options The credential creation options as returned by the CubeSigner back end\n * @returns Parsed credential creation options\n */\nexport function parseCreationOptions(\n  options: schemas[\"PublicKeyCredentialCreationOptions\"],\n): PublicKeyCredentialCreationOptions {\n  return {\n    ...(options as unknown as PublicKeyCredentialCreationOptions),\n    challenge: decodeBase64Url(options.challenge),\n    excludeCredentials: options.excludeCredentials?.map(mapPublicKeyCredentialDescriptor),\n    user: {\n      id: decodeBase64Url(options.user.id),\n      displayName: options.user.displayName,\n      name: options.user.name,\n    },\n  };\n}\n\n/**\n * Type narrowing from {@link AuthenticatorResponse} to {@link AuthenticatorAttestationResponse}\n *\n * @param resp The value to check\n * @returns Whether the value is a {@link AuthenticatorAttestationResponse}\n */\nfunction isAuthenticatorAttestationResponse(\n  resp: AuthenticatorResponse,\n): resp is AuthenticatorAttestationResponse {\n  return !!(resp as AuthenticatorAttestationResponse).attestationObject;\n}\n\n/**\n * Type narrowing from {@link AuthenticatorResponse} to {@link AuthenticatorAssertionResponse}\n *\n * @param resp The value to check\n * @returns Whether the value is a {@link AuthenticatorAssertionResponse}\n */\nfunction isAuthenticatorAssertionResponse(\n  resp: AuthenticatorResponse,\n): resp is AuthenticatorAssertionResponse {\n  const asAssertion = resp as AuthenticatorAssertionResponse;\n  return !!asAssertion.authenticatorData && !!asAssertion.signature;\n}\n\n/**\n * @param cred The credential response to convert\n * @returns Corresponding serializable JSON object that the CubeSigner back end expects\n */\nexport function credentialToJSON(cred: PublicKeyCredential): schemas[\"PublicKeyCredential\"] {\n  if (isAuthenticatorAttestationResponse(cred.response)) {\n    return {\n      id: cred.id,\n      response: {\n        clientDataJSON: encodeToBase64Url(cred.response.clientDataJSON),\n        attestationObject: encodeToBase64Url(cred.response.attestationObject),\n      },\n    };\n  }\n\n  if (isAuthenticatorAssertionResponse(cred.response)) {\n    return {\n      id: cred.id,\n      response: {\n        clientDataJSON: encodeToBase64Url(cred.response.clientDataJSON),\n        authenticatorData: encodeToBase64Url(cred.response.authenticatorData),\n        signature: encodeToBase64Url(cred.response.signature),\n      },\n    };\n  }\n\n  throw new Error(\"Unrecognized public key credential response\");\n}\n\n/**\n * Helper class for answering a passkey login challenge.\n */\nexport class PasskeyLoginChallenge {\n  readonly #env: EnvInterface;\n  readonly challenge: Omit<PasskeyAssertChallenge, \"options\">;\n  readonly options: PublicKeyCredentialRequestOptions;\n\n  /**\n   * Internal, called by {@link ApiClient.passkeyLoginInit}.\n   *\n   * @param env Target CubeSigner environment\n   * @param challenge The challenge to answer\n   * @param purpose Optional descriptive purpose of the new session\n   */\n  constructor(\n    env: EnvInterface,\n    challenge: PasskeyAssertChallenge,\n    readonly purpose: string | null | undefined,\n  ) {\n    this.#env = env;\n    this.challenge = challenge;\n    this.options = parseRequestOptions(challenge.options);\n  }\n\n  /**\n   * Answers this challenge by using the `CredentialsContainer` API to get a credential\n   * based on the the public key credential request options from this challenge.\n   *\n   * @returns New session.\n   */\n  async getCredentialAndAnswer(): Promise<SessionData> {\n    const cred = await navigator.credentials.get({\n      publicKey: this.options,\n      mediation: (this.options.allowCredentials ?? []).length > 0 ? undefined : \"conditional\",\n    });\n    if (cred === null) throw new Error(\"Credential not found\");\n    return await this.answer(cred as PublicKeyCredential);\n  }\n\n  /**\n   * Answers this challenge using a given credential `cred`.\n   * To obtain this credential, for example, call\n   *\n   * ```\n   * const cred = await navigator.credentials.get({ publicKey: this.options });\n   * ```\n   *\n   * @param cred Credential created by calling the `CredentialContainer`'s `get` method\n   *             based on the public key credential request options from this challenge.\n   * @returns New session\n   */\n  async answer(cred: PublicKeyCredential): Promise<SessionData> {\n    return await ApiClient.passkeyLoginComplete(this.#env, {\n      challenge_id: this.challenge.challenge_id,\n      credential: credentialToJSON(cred),\n    });\n  }\n}\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"passkey.js","sourceRoot":"","sources":["../../src/passkey.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApiClient,\n  decodeBase64Url,\n  encodeToBase64Url,\n  type EnvInterface,\n  type PasskeyAssertChallenge,\n  type schemas,\n  type SessionData,\n} from \".\";\n\n/**\n * @param val The value to check\n * @returns If the value is `null`, returns undefined, otherwise returns the value\n */\nfunction noNull<T>(val: T | null): T | undefined {\n  return val === null ? undefined : val;\n}\n\n/**\n * @param cred Credential descriptor, as returned by the CubeSigner back end\n * @returns The credential converted to {@link PublicKeyCredentialDescriptor}\n */\nfunction mapPublicKeyCredentialDescriptor(\n  cred: schemas[\"PublicKeyCredentialDescriptor\"],\n): PublicKeyCredentialDescriptor {\n  return {\n    id: decodeBase64Url(cred.id),\n    type: cred.type,\n    transports: noNull(cred.transports),\n  };\n}\n\n/**\n * Manual implementation of [PublicKeyCredential.parseRequestOptionsFromJSON](https://developer.mozilla.org/en-US/docs/Web/API/PublicKeyCredential/parseRequestOptionsFromJSON_static)\n * (implemented here because not all browsers support it)\n *\n * @param options The credential request options as returned by the CubeSigner back end\n * @returns Parsed credential request options\n */\nexport function parseRequestOptions(\n  options: schemas[\"PublicKeyCredentialRequestOptions\"],\n): PublicKeyCredentialRequestOptions {\n  return {\n    ...options,\n    challenge: decodeBase64Url(options.challenge),\n    extensions: noNull(options.extensions),\n    rpId: noNull(options.rpId),\n    timeout: noNull(options.timeout),\n    allowCredentials: options.allowCredentials?.map(mapPublicKeyCredentialDescriptor),\n  };\n}\n\n/**\n * Manual implementation of [PublicKeyCredential.parseCreationOptionsFromJSON](https://developer.mozilla.org/en-US/docs/Web/API/PublicKeyCredential/parseCreationOptionsFromJSON_static)\n * (implemented here because not all browsers support it)\n *\n * @param options The credential creation options as returned by the CubeSigner back end\n * @returns Parsed credential creation options\n */\nexport function parseCreationOptions(\n  options: schemas[\"PublicKeyCredentialCreationOptions\"],\n): PublicKeyCredentialCreationOptions {\n  return {\n    ...(options as unknown as PublicKeyCredentialCreationOptions),\n    challenge: decodeBase64Url(options.challenge),\n    excludeCredentials: options.excludeCredentials?.map(mapPublicKeyCredentialDescriptor),\n    user: {\n      id: decodeBase64Url(options.user.id),\n      displayName: options.user.displayName,\n      name: options.user.name,\n    },\n  };\n}\n\n/**\n * Type narrowing from {@link AuthenticatorResponse} to {@link AuthenticatorAttestationResponse}\n *\n * @param resp The value to check\n * @returns Whether the value is a {@link AuthenticatorAttestationResponse}\n */\nfunction isAuthenticatorAttestationResponse(\n  resp: AuthenticatorResponse,\n): resp is AuthenticatorAttestationResponse {\n  return !!(resp as AuthenticatorAttestationResponse).attestationObject;\n}\n\n/**\n * Type narrowing from {@link AuthenticatorResponse} to {@link AuthenticatorAssertionResponse}\n *\n * @param resp The value to check\n * @returns Whether the value is a {@link AuthenticatorAssertionResponse}\n */\nfunction isAuthenticatorAssertionResponse(\n  resp: AuthenticatorResponse,\n): resp is AuthenticatorAssertionResponse {\n  const asAssertion = resp as AuthenticatorAssertionResponse;\n  return !!asAssertion.authenticatorData && !!asAssertion.signature;\n}\n\n/**\n * @param cred The credential response to convert\n * @returns Corresponding serializable JSON object that the CubeSigner back end expects\n */\nexport function credentialToJSON(cred: PublicKeyCredential): schemas[\"PublicKeyCredential\"] {\n  if (isAuthenticatorAttestationResponse(cred.response)) {\n    return {\n      id: cred.id,\n      clientExtensionResults: cred.getClientExtensionResults() as Record<string, unknown>,\n      response: {\n        clientDataJSON: encodeToBase64Url(cred.response.clientDataJSON),\n        attestationObject: encodeToBase64Url(cred.response.attestationObject),\n      },\n    };\n  }\n\n  if (isAuthenticatorAssertionResponse(cred.response)) {\n    return {\n      id: cred.id,\n      clientExtensionResults: cred.getClientExtensionResults() as Record<string, unknown>,\n      response: {\n        clientDataJSON: encodeToBase64Url(cred.response.clientDataJSON),\n        authenticatorData: encodeToBase64Url(cred.response.authenticatorData),\n        signature: encodeToBase64Url(cred.response.signature),\n      },\n    };\n  }\n\n  throw new Error(\"Unrecognized public key credential response\");\n}\n\n/**\n * Helper class for answering a passkey login challenge.\n */\nexport class PasskeyLoginChallenge {\n  readonly #env: EnvInterface;\n  readonly challenge: Omit<PasskeyAssertChallenge, \"options\">;\n  readonly options: PublicKeyCredentialRequestOptions;\n\n  /**\n   * Internal, called by {@link ApiClient.passkeyLoginInit}.\n   *\n   * @param env Target CubeSigner environment\n   * @param challenge The challenge to answer\n   * @param purpose Optional descriptive purpose of the new session\n   */\n  constructor(\n    env: EnvInterface,\n    challenge: PasskeyAssertChallenge,\n    readonly purpose: string | null | undefined,\n  ) {\n    this.#env = env;\n    this.challenge = challenge;\n    this.options = parseRequestOptions(challenge.options);\n  }\n\n  /**\n   * Answers this challenge by using the `CredentialsContainer` API to get a credential\n   * based on the the public key credential request options from this challenge.\n   *\n   * @returns New session.\n   */\n  async getCredentialAndAnswer(): Promise<SessionData> {\n    const cred = await navigator.credentials.get({ publicKey: this.options });\n    if (cred === null) throw new Error(\"Credential not found\");\n    return await this.answer(cred as PublicKeyCredential);\n  }\n\n  /**\n   * Answers this challenge using a given credential `cred`.\n   * To obtain this credential, for example, call\n   *\n   * ```\n   * const cred = await navigator.credentials.get({ publicKey: this.options });\n   * ```\n   *\n   * @param cred Credential created by calling the `CredentialContainer`'s `get` method\n   *             based on the public key credential request options from this challenge.\n   * @returns New session\n   */\n  async answer(cred: PublicKeyCredential): Promise<SessionData> {\n    return await ApiClient.passkeyLoginComplete(this.#env, {\n      challenge_id: this.challenge.challenge_id,\n      credential: credentialToJSON(cred),\n    });\n  }\n}\n"]}
|
package/dist/src/schema.d.ts
CHANGED
|
@@ -1211,10 +1211,12 @@ export interface paths {
|
|
|
1211
1211
|
};
|
|
1212
1212
|
"/v0/org/{org_id}/user/me/fido": {
|
|
1213
1213
|
/**
|
|
1214
|
-
* Initiate registration of a FIDO key
|
|
1215
|
-
* @description Initiate registration of a FIDO key
|
|
1214
|
+
* Initiate registration of a FIDO key.
|
|
1215
|
+
* @description Initiate registration of a FIDO key.
|
|
1216
1216
|
*
|
|
1217
|
-
*
|
|
1217
|
+
* If a discoverable key is requested, user verification (PIN) is required.
|
|
1218
|
+
*
|
|
1219
|
+
* Generates a challenge that must be answered to prove ownership of a key.
|
|
1218
1220
|
*/
|
|
1219
1221
|
post: operations["userRegisterFidoInit"];
|
|
1220
1222
|
/**
|
|
@@ -2608,6 +2610,8 @@ export interface components {
|
|
|
2608
2610
|
* @description Creation date
|
|
2609
2611
|
*/
|
|
2610
2612
|
created_at: number;
|
|
2613
|
+
/** @description Whether this key was requested to be discoverable. */
|
|
2614
|
+
discoverable: boolean;
|
|
2611
2615
|
/** @description A unique credential id */
|
|
2612
2616
|
id: string;
|
|
2613
2617
|
/**
|
|
@@ -3852,7 +3856,7 @@ export interface components {
|
|
|
3852
3856
|
keys: components["schemas"]["KeyInfo"][];
|
|
3853
3857
|
};
|
|
3854
3858
|
/** @enum {string} */
|
|
3855
|
-
KeyType: "SecpEthAddr" | "SecpBtc" | "SecpBtcTest" | "SecpBtcLegacy" | "SecpBtcLegacyTest" | "SecpAvaAddr" | "SecpAvaTestAddr" | "BlsPub" | "BlsInactive" | "BlsAvaIcm" | "Ed25519SolanaAddr" | "Ed25519SuiAddr" | "Ed25519AptosAddr" | "Ed25519CardanoAddrVk" | "Ed25519StellarAddr" | "Ed25519SubstrateAddr" | "Mnemonic" | "Stark" | "BabylonEots" | "BabylonCov" | "TaprootBtc" | "TaprootBtcTest" | "SecpCosmosAddr" | "P256CosmosAddr" | "P256OntologyAddr" | "P256Neo3Addr" | "Ed25519TendermintAddr" | "SecpTronAddr" | "Ed25519TonAddr" | "SecpDogeAddr" | "SecpDogeTestAddr" | "SecpKaspaAddr" | "SecpKaspaTestAddr" | "SchnorrKaspaAddr" | "SchnorrKaspaTestAddr";
|
|
3859
|
+
KeyType: "SecpEthAddr" | "SecpBtc" | "SecpBtcTest" | "SecpBtcLegacy" | "SecpBtcLegacyTest" | "SecpAvaAddr" | "SecpAvaTestAddr" | "BlsPub" | "BlsInactive" | "BlsAvaIcm" | "Ed25519SolanaAddr" | "Ed25519SuiAddr" | "Ed25519AptosAddr" | "Ed25519CardanoAddrVk" | "Ed25519StellarAddr" | "Ed25519SubstrateAddr" | "Mnemonic" | "Stark" | "BabylonEots" | "BabylonCov" | "TaprootBtc" | "TaprootBtcTest" | "SecpCosmosAddr" | "P256CosmosAddr" | "P256OntologyAddr" | "P256Neo3Addr" | "Ed25519TendermintAddr" | "SecpTronAddr" | "Ed25519TonAddr" | "SecpDogeAddr" | "SecpDogeTestAddr" | "SecpKaspaAddr" | "SecpKaspaTestAddr" | "SchnorrKaspaAddr" | "SchnorrKaspaTestAddr" | "SecpLtc" | "SecpLtcTest" | "SecpXrpAddr" | "Ed25519XrpAddr";
|
|
3856
3860
|
KeyTypeAndDerivationPath: {
|
|
3857
3861
|
/**
|
|
3858
3862
|
* @description List of derivation paths for which to derive.
|
|
@@ -5428,7 +5432,7 @@ export interface components {
|
|
|
5428
5432
|
users?: string[] | null;
|
|
5429
5433
|
};
|
|
5430
5434
|
/** @description All scopes for accessing CubeSigner APIs */
|
|
5431
|
-
Scope: ("sign:*" | "sign:ava" | "sign:blob" | "sign:btc:*" | "sign:btc:segwit" | "sign:btc:taproot" | "sign:btc:psbt:*" | "sign:btc:psbt:doge" | "sign:btc:psbt:legacy" | "sign:btc:psbt:segwit" | "sign:btc:psbt:taproot" | "sign:btc:message:*" | "sign:btc:message:segwit" | "sign:btc:message:legacy" | "sign:babylon:*" | "sign:babylon:eots:*" | "sign:babylon:eots:nonces" | "sign:babylon:eots:sign" | "sign:babylon:staking:*" | "sign:babylon:staking:deposit" | "sign:babylon:staking:unbond" | "sign:babylon:staking:withdraw" | "sign:babylon:staking:slash" | "sign:babylon:registration" | "sign:babylon:covenant" | "sign:evm:*" | "sign:evm:tx" | "sign:evm:eip191" | "sign:evm:eip712" | "sign:eth2:*" | "sign:eth2:validate" | "sign:eth2:stake" | "sign:eth2:unstake" | "sign:solana" | "sign:sui" | "sign:tendermint" | "sign:mmi" | "manage:*" | "manage:readonly" | "manage:email" | "manage:mfa:*" | "manage:mfa:readonly" | "manage:mfa:list" | "manage:mfa:vote:*" | "manage:mfa:vote:cs" | "manage:mfa:vote:email" | "manage:mfa:vote:fido" | "manage:mfa:vote:totp" | "manage:mfa:register:*" | "manage:mfa:register:fido" | "manage:mfa:register:totp" | "manage:mfa:unregister:*" | "manage:mfa:unregister:fido" | "manage:mfa:unregister:totp" | "manage:mfa:verify:*" | "manage:mfa:verify:totp" | "manage:key:*" | "manage:key:readonly" | "manage:key:get" | "manage:key:listRoles" | "manage:key:list" | "manage:key:history:tx:list" | "manage:key:create" | "manage:key:import" | "manage:key:update:*" | "manage:key:update:owner" | "manage:key:update:policy" | "manage:key:update:enabled" | "manage:key:update:metadata" | "manage:key:update:editPolicy" | "manage:key:delete" | "manage:policy:*" | "manage:policy:create" | "manage:policy:get" | "manage:policy:list" | "manage:policy:delete" | "manage:policy:update:*" | "manage:policy:update:owner" | "manage:policy:update:name" | "manage:policy:update:editPolicy" | "manage:policy:update:metadata" | "manage:policy:update:rule" | "manage:policy:invoke" | "manage:policy:wasm:*" | "manage:policy:wasm:upload" | "manage:policy:secrets:*" | "manage:policy:secrets:get" | "manage:policy:secrets:update:*" | "manage:policy:secrets:update:values" | "manage:policy:secrets:update:editPolicy" | "manage:contact:*" | "manage:contact:create" | "manage:contact:get" | "manage:contact:list" | "manage:contact:delete" | "manage:contact:update:*" | "manage:contact:update:name" | "manage:contact:update:addresses" | "manage:contact:update:owner" | "manage:contact:update:metadata" | "manage:contact:update:editPolicy" | "manage:policy:createImportKey" | "manage:role:*" | "manage:role:readonly" | "manage:role:create" | "manage:role:delete" | "manage:role:get:*" | "manage:role:get:keys" | "manage:role:get:keys:list" | "manage:role:get:keys:get" | "manage:role:get:users" | "manage:role:list" | "manage:role:update:*" | "manage:role:update:enabled" | "manage:role:update:policy" | "manage:role:update:editPolicy" | "manage:role:update:key:*" | "manage:role:update:key:add" | "manage:role:update:key:remove" | "manage:role:update:user:*" | "manage:role:update:user:add" | "manage:role:update:user:remove" | "manage:role:history:tx:list" | "manage:identity:*" | "manage:identity:verify" | "manage:identity:add" | "manage:identity:remove" | "manage:identity:list" | "manage:org:*" | "manage:org:create" | "manage:org:metrics:query" | "manage:org:readonly" | "manage:org:addUser" | "manage:org:inviteUser" | "manage:org:inviteAlien" | "manage:org:updateMembership" | "manage:org:listUsers" | "manage:org:user:get" | "manage:org:deleteUser" | "manage:org:get" | "manage:session:*" | "manage:session:readonly" | "manage:session:get" | "manage:session:list" | "manage:session:create" | "manage:session:extend" | "manage:session:revoke" | "manage:export:*" | "manage:export:org:*" | "manage:export:org:get" | "manage:export:user:*" | "manage:export:user:delete" | "manage:export:user:list" | "manage:auth_migration:identity:add" | "manage:auth_migration:identity:remove" | "manage:mmi:*" | "manage:mmi:readonly" | "manage:mmi:get" | "manage:mmi:list" | "manage:mmi:reject" | "manage:mmi:delete" | "export:*" | "export:user:*" | "export:user:init" | "export:user:complete" | "mmi:*" | "orgAccess:*" | "orgAccess:child:*") | string;
|
|
5435
|
+
Scope: ("sign:*" | "sign:ava" | "sign:blob" | "sign:btc:*" | "sign:btc:segwit" | "sign:btc:taproot" | "sign:btc:psbt:*" | "sign:btc:psbt:doge" | "sign:btc:psbt:legacy" | "sign:btc:psbt:segwit" | "sign:btc:psbt:taproot" | "sign:btc:psbt:ltcSegwit" | "sign:btc:message:*" | "sign:btc:message:segwit" | "sign:btc:message:legacy" | "sign:babylon:*" | "sign:babylon:eots:*" | "sign:babylon:eots:nonces" | "sign:babylon:eots:sign" | "sign:babylon:staking:*" | "sign:babylon:staking:deposit" | "sign:babylon:staking:unbond" | "sign:babylon:staking:withdraw" | "sign:babylon:staking:slash" | "sign:babylon:registration" | "sign:babylon:covenant" | "sign:evm:*" | "sign:evm:tx" | "sign:evm:eip191" | "sign:evm:eip712" | "sign:eth2:*" | "sign:eth2:validate" | "sign:eth2:stake" | "sign:eth2:unstake" | "sign:solana" | "sign:sui" | "sign:tendermint" | "sign:mmi" | "manage:*" | "manage:readonly" | "manage:email" | "manage:mfa:*" | "manage:mfa:readonly" | "manage:mfa:list" | "manage:mfa:vote:*" | "manage:mfa:vote:cs" | "manage:mfa:vote:email" | "manage:mfa:vote:fido" | "manage:mfa:vote:totp" | "manage:mfa:register:*" | "manage:mfa:register:fido" | "manage:mfa:register:totp" | "manage:mfa:unregister:*" | "manage:mfa:unregister:fido" | "manage:mfa:unregister:totp" | "manage:mfa:verify:*" | "manage:mfa:verify:totp" | "manage:key:*" | "manage:key:readonly" | "manage:key:get" | "manage:key:listRoles" | "manage:key:list" | "manage:key:history:tx:list" | "manage:key:create" | "manage:key:import" | "manage:key:update:*" | "manage:key:update:owner" | "manage:key:update:policy" | "manage:key:update:enabled" | "manage:key:update:metadata" | "manage:key:update:editPolicy" | "manage:key:delete" | "manage:policy:*" | "manage:policy:create" | "manage:policy:get" | "manage:policy:list" | "manage:policy:delete" | "manage:policy:update:*" | "manage:policy:update:owner" | "manage:policy:update:name" | "manage:policy:update:editPolicy" | "manage:policy:update:metadata" | "manage:policy:update:rule" | "manage:policy:invoke" | "manage:policy:wasm:*" | "manage:policy:wasm:upload" | "manage:policy:secrets:*" | "manage:policy:secrets:get" | "manage:policy:secrets:update:*" | "manage:policy:secrets:update:values" | "manage:policy:secrets:update:editPolicy" | "manage:contact:*" | "manage:contact:create" | "manage:contact:get" | "manage:contact:list" | "manage:contact:delete" | "manage:contact:update:*" | "manage:contact:update:name" | "manage:contact:update:addresses" | "manage:contact:update:owner" | "manage:contact:update:metadata" | "manage:contact:update:editPolicy" | "manage:policy:createImportKey" | "manage:role:*" | "manage:role:readonly" | "manage:role:create" | "manage:role:delete" | "manage:role:get:*" | "manage:role:get:keys" | "manage:role:get:keys:list" | "manage:role:get:keys:get" | "manage:role:get:users" | "manage:role:list" | "manage:role:update:*" | "manage:role:update:enabled" | "manage:role:update:policy" | "manage:role:update:editPolicy" | "manage:role:update:key:*" | "manage:role:update:key:add" | "manage:role:update:key:remove" | "manage:role:update:user:*" | "manage:role:update:user:add" | "manage:role:update:user:remove" | "manage:role:history:tx:list" | "manage:identity:*" | "manage:identity:verify" | "manage:identity:add" | "manage:identity:remove" | "manage:identity:list" | "manage:org:*" | "manage:org:create" | "manage:org:metrics:query" | "manage:org:readonly" | "manage:org:addUser" | "manage:org:inviteUser" | "manage:org:inviteAlien" | "manage:org:updateMembership" | "manage:org:listUsers" | "manage:org:user:get" | "manage:org:deleteUser" | "manage:org:get" | "manage:session:*" | "manage:session:readonly" | "manage:session:get" | "manage:session:list" | "manage:session:create" | "manage:session:extend" | "manage:session:revoke" | "manage:export:*" | "manage:export:org:*" | "manage:export:org:get" | "manage:export:user:*" | "manage:export:user:delete" | "manage:export:user:list" | "manage:auth_migration:identity:add" | "manage:auth_migration:identity:remove" | "manage:mmi:*" | "manage:mmi:readonly" | "manage:mmi:get" | "manage:mmi:list" | "manage:mmi:reject" | "manage:mmi:delete" | "export:*" | "export:user:*" | "export:user:init" | "export:user:complete" | "mmi:*" | "orgAccess:*" | "orgAccess:child:*") | string;
|
|
5432
5436
|
/** @description A set of scopes. */
|
|
5433
5437
|
ScopeSet: OneOf<[
|
|
5434
5438
|
"All",
|
|
@@ -12183,10 +12187,12 @@ export interface operations {
|
|
|
12183
12187
|
};
|
|
12184
12188
|
};
|
|
12185
12189
|
/**
|
|
12186
|
-
* Initiate registration of a FIDO key
|
|
12187
|
-
* @description Initiate registration of a FIDO key
|
|
12190
|
+
* Initiate registration of a FIDO key.
|
|
12191
|
+
* @description Initiate registration of a FIDO key.
|
|
12188
12192
|
*
|
|
12189
|
-
*
|
|
12193
|
+
* If a discoverable key is requested, user verification (PIN) is required.
|
|
12194
|
+
*
|
|
12195
|
+
* Generates a challenge that must be answered to prove ownership of a key.
|
|
12190
12196
|
*/
|
|
12191
12197
|
userRegisterFidoInit: {
|
|
12192
12198
|
parameters: {
|