@cubist-labs/cubesigner-sdk 0.4.239 → 0.4.244
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/audit_log.d.ts +4 -4
- package/dist/src/audit_log.js +1 -1
- package/dist/src/client/api_client.d.ts +35 -14
- package/dist/src/client/api_client.d.ts.map +1 -1
- package/dist/src/client/api_client.js +63 -29
- package/dist/src/client/base_client.d.ts +7 -0
- package/dist/src/client/base_client.d.ts.map +1 -1
- package/dist/src/client/base_client.js +15 -7
- package/dist/src/client.d.ts +24 -32
- package/dist/src/client.d.ts.map +1 -1
- package/dist/src/client.js +21 -29
- package/dist/src/fetch.d.ts.map +1 -1
- package/dist/src/fetch.js +2 -3
- package/dist/src/key.d.ts +17 -1
- package/dist/src/key.d.ts.map +1 -1
- package/dist/src/key.js +17 -1
- package/dist/src/response.d.ts +27 -3
- package/dist/src/response.d.ts.map +1 -1
- package/dist/src/response.js +60 -19
- package/dist/src/schema.d.ts +819 -81
- package/dist/src/schema.d.ts.map +1 -1
- package/dist/src/schema.js +1 -1
- package/dist/src/schema_types.d.ts +10 -1
- package/dist/src/schema_types.d.ts.map +1 -1
- package/dist/src/schema_types.js +1 -1
- package/dist/src/scopes.d.ts.map +1 -1
- package/dist/src/scopes.js +20 -3
- package/package.json +1 -1
- package/src/audit_log.ts +3 -5
- package/src/client/api_client.ts +80 -18
- package/src/client/base_client.ts +22 -9
- package/src/client.ts +23 -57
- package/src/fetch.ts +1 -2
- package/src/key.ts +24 -0
- package/src/response.ts +67 -17
- package/src/schema.ts +879 -90
- package/src/schema_types.ts +11 -1
- package/src/scopes.ts +19 -2
package/dist/src/key.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,KAAK,EACV,OAAO,EAEP,aAAa,EACb,aAAa,EACb,cAAc,EACd,eAAe,EACf,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,kBAAkB,EAClB,KAAK,EACL,eAAe,EACf,cAAc,EACd,iBAAiB,EACjB,kBAAkB,EAClB,sBAAsB,EACtB,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,mBAAmB,EACnB,gBAAgB,EAChB,uBAAuB,EACvB,eAAe,EACf,gBAAgB,EAEhB,qBAAqB,EACrB,UAAU,EACV,mBAAmB,
|
|
1
|
+
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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"}
|
package/dist/src/key.js
CHANGED
|
@@ -61,6 +61,7 @@ var Ed25519;
|
|
|
61
61
|
Ed25519["Stellar"] = "Ed25519StellarAddr";
|
|
62
62
|
Ed25519["Substrate"] = "Ed25519SubstrateAddr";
|
|
63
63
|
Ed25519["Tendermint"] = "Ed25519TendermintAddr";
|
|
64
|
+
Ed25519["BinanceApi"] = "Ed25519BinanceApi";
|
|
64
65
|
Ed25519["Ton"] = "Ed25519TonAddr";
|
|
65
66
|
Ed25519["Xrp"] = "Ed25519XrpAddr";
|
|
66
67
|
})(Ed25519 || (exports.Ed25519 = Ed25519 = {}));
|
|
@@ -173,6 +174,19 @@ class Key {
|
|
|
173
174
|
async setMetadata(metadata, mfaReceipt) {
|
|
174
175
|
return await this.update({ metadata }, mfaReceipt);
|
|
175
176
|
}
|
|
177
|
+
/**
|
|
178
|
+
* Set key properties. Each field in the provided patch is independent: missing
|
|
179
|
+
* means leave alone, `null` clears, a value sets. Sending `null` for the whole
|
|
180
|
+
* field clears all properties on the key.
|
|
181
|
+
*
|
|
182
|
+
* @param patch Type-specific properties
|
|
183
|
+
* @param mfaReceipt Optional MFA receipt(s)
|
|
184
|
+
* @throws if MFA is required and no receipts are provided
|
|
185
|
+
* @returns The updated key info
|
|
186
|
+
*/
|
|
187
|
+
async setProperties(patch, mfaReceipt) {
|
|
188
|
+
return await this.update({ properties: patch }, mfaReceipt);
|
|
189
|
+
}
|
|
176
190
|
/**
|
|
177
191
|
* Retrieves the existing metadata, asserts that it is an object (throws if it is not),
|
|
178
192
|
* then sets the value of the {@link name} property in that object to {@link value},
|
|
@@ -634,6 +648,8 @@ function fromSchemaKeyType(ty) {
|
|
|
634
648
|
return Ed25519.Tendermint;
|
|
635
649
|
case "Ed25519TonAddr":
|
|
636
650
|
return Ed25519.Ton;
|
|
651
|
+
case "Ed25519BinanceApi":
|
|
652
|
+
return Ed25519.BinanceApi;
|
|
637
653
|
case "Stark":
|
|
638
654
|
return exports.Stark;
|
|
639
655
|
case "Mnemonic":
|
|
@@ -657,4 +673,4 @@ function fromSchemaKeyType(ty) {
|
|
|
657
673
|
// NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts
|
|
658
674
|
}
|
|
659
675
|
}
|
|
660
|
-
//# 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  DiffieHellmanRequest,\n  DiffieHellmanResponse,\n  KeyInfoJwt,\n  KeyAttestationQuery,\n} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  BabylonRegistrationRequest,\n  BabylonRegistrationResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  BtcMessageSignRequest,\n  CubeSignerResponse,\n  EditPolicy,\n  Empty,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n  SuiSignRequest,\n  SuiSignResponse,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { loadSubtleCrypto } from \"./user_export\";\nimport { encodeToHex, encodeToBase64 } from \"./util\";\n\n// these types are used in doc comments only\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport type { KeyAttestationClaims } from \"./schema_types\";\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  Canton = \"Ed25519CantonAddr\",\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/** Baby Jubjub key type */\nexport const BabyJubjub = \"BabyJubjub\" as const;\nexport type BabyJubjub = typeof BabyJubjub;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256 | BabyJubjub;\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  /**\n   * Attest to key properties.\n   *\n   * @param query Query parameters:\n   * @param query.include_roles If specified, include all the roles the key is in.\n   * @returns A JWT whose claims are the properties of the key. The type of the returned JWT payload is {@link KeyAttestationClaims}.\n   */\n  async attest(query?: KeyAttestationQuery): Promise<KeyInfoJwt> {\n    return await this.#apiClient.keyAttest(this.id, query);\n  }\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 new edit policy (overwriting any edit policies previously set for this key)\n   *\n   * @param editPolicy The new edit policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ edit_policy: editPolicy }, 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 across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async appendPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy], mfaReceipt);\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   * Get the edit policy for the key.\n   *\n   * @returns The edit policy for the key, undefined if there is no edit policy\n   */\n  async editPolicy(): Promise<EditPolicy | undefined> {\n    const data = await this.fetch();\n    return data.edit_policy;\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   * Perform a Diffie-Hellman exchange with one or more public keys.\n   *\n   * This requires the key to have a '\"AllowDiffieHellmanExchange\"' {@link KeyPolicy}.\n   * This is because performing arbitrary Diffie-Hellman exchanges using signing keys\n   * is, in general, dangerous. You should only use this API if you are 100% sure that\n   * you know what you're doing!\n   *\n   * @param points Up to 32 elliptic curve points with which to perform Diffie-Hellman exchanges. These points must be serialized in a key-type--specific format; see the CubeSigner documentation for more info.\n   * @param publicKey The NIST P-256 public key with which the responses will be encrypted. This should be the `publicKey` property of a value returned by `userExportKeygen`.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns The response. On success, the result can be decrypted with `diffieHellmanDecrypt`.\n   */\n  async diffieHellmanExchange(\n    points: Uint8Array[],\n    publicKey: CryptoKey,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<DiffieHellmanResponse>> {\n    if (points.length > 32) {\n      throw new Error(\"maximum 32 DH exchanges per request\");\n    }\n\n    // construct the request\n    const subtle = await loadSubtleCrypto();\n    const req: DiffieHellmanRequest = {\n      points: points.map((pt) => encodeToBase64(Buffer.from(pt))),\n      public_key: encodeToBase64(Buffer.from(await subtle.exportKey(\"raw\", publicKey))),\n    };\n\n    // send\n    return await this.#apiClient.diffieHellmanExchange(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 \"Ed25519CantonAddr\":\n      return Ed25519.Canton;\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    case \"BabyJubjub\":\n      return BabyJubjub;\n    // NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts\n  }\n}\n"]}
|
|
676
|
+
//# 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  DiffieHellmanRequest,\n  DiffieHellmanResponse,\n  KeyInfoJwt,\n  KeyAttestationQuery,\n  BinanceApiProperties,\n} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  BabylonRegistrationRequest,\n  BabylonRegistrationResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  BtcMessageSignRequest,\n  CubeSignerResponse,\n  EditPolicy,\n  Empty,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n  SuiSignRequest,\n  SuiSignResponse,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { loadSubtleCrypto } from \"./user_export\";\nimport { encodeToHex, encodeToBase64 } from \"./util\";\n\n// these types are used in doc comments only\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport type { KeyAttestationClaims } from \"./schema_types\";\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  Canton = \"Ed25519CantonAddr\",\n  Cardano = \"Ed25519CardanoAddrVk\",\n  Stellar = \"Ed25519StellarAddr\",\n  Substrate = \"Ed25519SubstrateAddr\",\n  Tendermint = \"Ed25519TendermintAddr\",\n  BinanceApi = \"Ed25519BinanceApi\",\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/** Baby Jubjub key type */\nexport const BabyJubjub = \"BabyJubjub\" as const;\nexport type BabyJubjub = typeof BabyJubjub;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256 | BabyJubjub;\n\n/** The type representing all different kinds of key properties. */\nexport type KeyPropertiesPatch = { kind: \"BinanceApi\" } & BinanceApiProperties;\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  /**\n   * Attest to key properties.\n   *\n   * @param query Query parameters:\n   * @param query.include_roles If specified, include all the roles the key is in.\n   * @returns A JWT whose claims are the properties of the key. The type of the returned JWT payload is {@link KeyAttestationClaims}.\n   */\n  async attest(query?: KeyAttestationQuery): Promise<KeyInfoJwt> {\n    return await this.#apiClient.keyAttest(this.id, query);\n  }\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 new edit policy (overwriting any edit policies previously set for this key)\n   *\n   * @param editPolicy The new edit policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ edit_policy: editPolicy }, 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   * Set key properties. Each field in the provided patch is independent: missing\n   * means leave alone, `null` clears, a value sets. Sending `null` for the whole\n   * field clears all properties on the key.\n   *\n   * @param patch Type-specific properties\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 setProperties(\n    patch: KeyPropertiesPatch | null,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    return await this.update({ properties: patch }, 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 across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws If MFA is required and no MFA receipts are provided\n   */\n  async appendPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy], mfaReceipt);\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   * Get the edit policy for the key.\n   *\n   * @returns The edit policy for the key, undefined if there is no edit policy\n   */\n  async editPolicy(): Promise<EditPolicy | undefined> {\n    const data = await this.fetch();\n    return data.edit_policy;\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   * Perform a Diffie-Hellman exchange with one or more public keys.\n   *\n   * This requires the key to have a '\"AllowDiffieHellmanExchange\"' {@link KeyPolicy}.\n   * This is because performing arbitrary Diffie-Hellman exchanges using signing keys\n   * is, in general, dangerous. You should only use this API if you are 100% sure that\n   * you know what you're doing!\n   *\n   * @param points Up to 32 elliptic curve points with which to perform Diffie-Hellman exchanges. These points must be serialized in a key-type--specific format; see the CubeSigner documentation for more info.\n   * @param publicKey The NIST P-256 public key with which the responses will be encrypted. This should be the `publicKey` property of a value returned by `userExportKeygen`.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns The response. On success, the result can be decrypted with `diffieHellmanDecrypt`.\n   */\n  async diffieHellmanExchange(\n    points: Uint8Array[],\n    publicKey: CryptoKey,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<DiffieHellmanResponse>> {\n    if (points.length > 32) {\n      throw new Error(\"maximum 32 DH exchanges per request\");\n    }\n\n    // construct the request\n    const subtle = await loadSubtleCrypto();\n    const req: DiffieHellmanRequest = {\n      points: points.map((pt) => encodeToBase64(Buffer.from(pt))),\n      public_key: encodeToBase64(Buffer.from(await subtle.exportKey(\"raw\", publicKey))),\n    };\n\n    // send\n    return await this.#apiClient.diffieHellmanExchange(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 \"Ed25519CantonAddr\":\n      return Ed25519.Canton;\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 \"Ed25519BinanceApi\":\n      return Ed25519.BinanceApi;\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    case \"BabyJubjub\":\n      return BabyJubjub;\n    // NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts\n  }\n}\n"]}
|
package/dist/src/response.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import type { EnvInterface, MfaReceipts } from ".";
|
|
1
|
+
import type { EnvInterface, MfaReceipts, MfaRequired } from ".";
|
|
2
2
|
import { CubeSignerClient } from ".";
|
|
3
|
-
import type { AcceptedResponse } from "./schema_types";
|
|
3
|
+
import type { AcceptedResponse, AcceptedValue, BinanceDryRun, SignDryRun } from "./schema_types";
|
|
4
4
|
/**
|
|
5
5
|
* Response type, which can be either a value of type {@link U}
|
|
6
6
|
* or {@link AcceptedResponse} (status code 202) which requires MFA.
|
|
@@ -29,6 +29,30 @@ export declare function mapResponse<U, V>(resp: Response<U>, mapFn: MapFn<U, V>)
|
|
|
29
29
|
*/
|
|
30
30
|
export declare class CubeSignerResponse<U> {
|
|
31
31
|
#private;
|
|
32
|
+
/**
|
|
33
|
+
* @returns The {@link AcceptedValue} if the response status code is 202.
|
|
34
|
+
*/
|
|
35
|
+
asAccepted(): AcceptedValue | undefined;
|
|
36
|
+
/**
|
|
37
|
+
* @returns The associated {@link MfaRequired} value, if the response status code is 202 and the response indicates that MFA is required.
|
|
38
|
+
*/
|
|
39
|
+
asMfaRequired(): MfaRequired | undefined;
|
|
40
|
+
/**
|
|
41
|
+
* @returns The associated {@link SignDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.
|
|
42
|
+
*/
|
|
43
|
+
asSignDryRun(): SignDryRun | undefined;
|
|
44
|
+
/**
|
|
45
|
+
* @returns The associated {@link BinanceDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.
|
|
46
|
+
*/
|
|
47
|
+
asBinanceDryRun(): BinanceDryRun | undefined;
|
|
48
|
+
/**
|
|
49
|
+
* @returns Whether this response is a "200 Success" (in which case it is safe to call {@link data})
|
|
50
|
+
*/
|
|
51
|
+
isSuccess(): boolean;
|
|
52
|
+
/**
|
|
53
|
+
* @returns The underlying {@link MfaRequired} response (if any).
|
|
54
|
+
*/
|
|
55
|
+
private get mfaRequired();
|
|
32
56
|
/** @returns The first MFA id associated with this request (if any) */
|
|
33
57
|
mfaId(): string | undefined;
|
|
34
58
|
/** @returns The MFA ids associated with this request (if any) */
|
|
@@ -86,7 +110,7 @@ export declare class CubeSignerResponse<U> {
|
|
|
86
110
|
* @param resp The response as returned by the OpenAPI client.
|
|
87
111
|
* @internal
|
|
88
112
|
*/
|
|
89
|
-
protected constructor(env: EnvInterface, requestFn: RequestFn<U>, resp: U
|
|
113
|
+
protected constructor(env: EnvInterface, requestFn: RequestFn<U>, resp: Response<U>);
|
|
90
114
|
/**
|
|
91
115
|
* Static constructor.
|
|
92
116
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"response.d.ts","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAW,YAAY,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"response.d.ts","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAW,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,GAAG,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAqB,MAAM,GAAG,CAAC;AAExD,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjG;;;GAGG;AACH,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,gBAAgB,CAAC;AAE/C;;;GAGG;AACH,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;AAE3E;;GAEG;AACH,MAAM,MAAM,KAAK,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;AAEtC;;;;;;;GAOG;AACH,wBAAgB,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAMpF;AAaD;;GAEG;AACH,qBAAa,kBAAkB,CAAC,CAAC;;IAK/B;;OAEG;IACH,UAAU,IAAI,aAAa,GAAG,SAAS;IAIvC;;OAEG;IACH,aAAa,IAAI,WAAW,GAAG,SAAS;IAIxC;;OAEG;IACH,YAAY,IAAI,UAAU,GAAG,SAAS;IAItC;;OAEG;IACH,eAAe,IAAI,aAAa,GAAG,SAAS;IAI5C;;OAEG;IACH,SAAS,IAAI,OAAO;IAIpB;;OAEG;IACH,OAAO,KAAK,WAAW,GAEtB;IAED,sEAAsE;IACtE,KAAK,IAAI,MAAM,GAAG,SAAS;IAI3B,iEAAiE;IACjE,MAAM,IAAI,MAAM,EAAE;IAIlB,6DAA6D;IAC7D,WAAW,IAAI,OAAO;IAItB;;OAEG;IACG,SAAS,IAAI,OAAO,CAAC,gBAAgB,GAAG,SAAS,CAAC;IAkBxD,wDAAwD;IACxD,IAAI,IAAI,CAAC;IAST;;;;;;OAMG;IACG,WAAW,CAAC,MAAM,EAAE,gBAAgB,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;IAIzF;;;;;OAKG;IACG,UAAU,CAAC,MAAM,EAAE,gBAAgB,EAAE,IAAI,EAAE,MAAM;IAiCvD;;;;;OAKG;IACG,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;IAIvE;;;;OAIG;IACG,MAAM,CAAC,MAAM,EAAE,gBAAgB;IA6BrC;;;;;OAKG;IACG,mBAAmB,CAAC,UAAU,EAAE,WAAW,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;IASlF;;;;;;;;;OASG;IACH,SAAS,aAAa,GAAG,EAAE,YAAY,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;IAMnF;;;;;;;;;;OAUG;WACU,MAAM,CAAC,CAAC,EACnB,GAAG,EAAE,YAAY,EACjB,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,EACvB,UAAU,CAAC,EAAE,WAAW,GACvB,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;IAKjC;;;;;;OAMG;IACH,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,EAAE,WAAW,GAAG,WAAW,GAAG,SAAS;CA2BxE"}
|
package/dist/src/response.js
CHANGED
|
@@ -10,7 +10,7 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
10
10
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
11
11
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
12
12
|
};
|
|
13
|
-
var _CubeSignerResponse_instances, _CubeSignerResponse_env, _CubeSignerResponse_requestFn, _CubeSignerResponse_resp,
|
|
13
|
+
var _CubeSignerResponse_instances, _CubeSignerResponse_env, _CubeSignerResponse_requestFn, _CubeSignerResponse_resp, _CubeSignerResponse_mfaTotpVote, _CubeSignerResponse_mfaVote;
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.CubeSignerResponse = void 0;
|
|
16
16
|
exports.mapResponse = mapResponse;
|
|
@@ -25,36 +25,82 @@ const util_1 = require("./util");
|
|
|
25
25
|
* @returns Response whose value for status code 200 is mapped from U to V
|
|
26
26
|
*/
|
|
27
27
|
function mapResponse(resp, mapFn) {
|
|
28
|
-
if (resp
|
|
28
|
+
if (asAccepted(resp) !== undefined) {
|
|
29
29
|
return resp;
|
|
30
30
|
}
|
|
31
31
|
else {
|
|
32
32
|
return mapFn(resp);
|
|
33
33
|
}
|
|
34
34
|
}
|
|
35
|
+
/**
|
|
36
|
+
* @param resp The response to check
|
|
37
|
+
* @returns The {@link AcceptedValue} if the response status code is 202.
|
|
38
|
+
*/
|
|
39
|
+
function asAccepted(resp) {
|
|
40
|
+
const acceptedResp = resp;
|
|
41
|
+
return acceptedResp.error_code === "SignDryRun" || acceptedResp.error_code === "MfaRequired"
|
|
42
|
+
? (acceptedResp.accepted ?? undefined)
|
|
43
|
+
: undefined;
|
|
44
|
+
}
|
|
35
45
|
/**
|
|
36
46
|
* A response of a CubeSigner request.
|
|
37
47
|
*/
|
|
38
48
|
class CubeSignerResponse {
|
|
49
|
+
/**
|
|
50
|
+
* @returns The {@link AcceptedValue} if the response status code is 202.
|
|
51
|
+
*/
|
|
52
|
+
asAccepted() {
|
|
53
|
+
return asAccepted(__classPrivateFieldGet(this, _CubeSignerResponse_resp, "f"));
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* @returns The associated {@link MfaRequired} value, if the response status code is 202 and the response indicates that MFA is required.
|
|
57
|
+
*/
|
|
58
|
+
asMfaRequired() {
|
|
59
|
+
return this.asAccepted()?.MfaRequired ?? undefined;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* @returns The associated {@link SignDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.
|
|
63
|
+
*/
|
|
64
|
+
asSignDryRun() {
|
|
65
|
+
return this.asAccepted()?.SignDryRun ?? undefined;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* @returns The associated {@link BinanceDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.
|
|
69
|
+
*/
|
|
70
|
+
asBinanceDryRun() {
|
|
71
|
+
return this.asAccepted()?.BinanceDryRun ?? undefined;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* @returns Whether this response is a "200 Success" (in which case it is safe to call {@link data})
|
|
75
|
+
*/
|
|
76
|
+
isSuccess() {
|
|
77
|
+
return this.asAccepted() === undefined;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* @returns The underlying {@link MfaRequired} response (if any).
|
|
81
|
+
*/
|
|
82
|
+
get mfaRequired() {
|
|
83
|
+
return this.asAccepted()?.MfaRequired;
|
|
84
|
+
}
|
|
39
85
|
/** @returns The first MFA id associated with this request (if any) */
|
|
40
86
|
mfaId() {
|
|
41
|
-
return
|
|
87
|
+
return this.mfaRequired?.id;
|
|
42
88
|
}
|
|
43
89
|
/** @returns The MFA ids associated with this request (if any) */
|
|
44
90
|
mfaIds() {
|
|
45
|
-
return
|
|
91
|
+
return this.mfaRequired?.ids ?? [];
|
|
46
92
|
}
|
|
47
93
|
/** @returns True if this request requires an MFA approval */
|
|
48
94
|
requiresMfa() {
|
|
49
|
-
return
|
|
95
|
+
return this.mfaRequired !== undefined;
|
|
50
96
|
}
|
|
51
97
|
/**
|
|
52
98
|
* @returns Session information to use for any MFA approval requests (if any was included in the response).
|
|
53
99
|
*/
|
|
54
100
|
async mfaClient() {
|
|
55
|
-
if (
|
|
101
|
+
if (this.mfaRequired === undefined)
|
|
56
102
|
return;
|
|
57
|
-
const session =
|
|
103
|
+
const session = this.asMfaRequired()?.session ?? undefined;
|
|
58
104
|
if (session === undefined)
|
|
59
105
|
return;
|
|
60
106
|
const env = __classPrivateFieldGet(this, _CubeSignerResponse_env, "f");
|
|
@@ -62,7 +108,7 @@ class CubeSignerResponse {
|
|
|
62
108
|
env: {
|
|
63
109
|
"Dev-CubeSignerStack": env,
|
|
64
110
|
},
|
|
65
|
-
org_id:
|
|
111
|
+
org_id: this.mfaRequired.org_id,
|
|
66
112
|
session_exp: session.expiration,
|
|
67
113
|
session_info: session.session_info,
|
|
68
114
|
token: session.token,
|
|
@@ -71,8 +117,8 @@ class CubeSignerResponse {
|
|
|
71
117
|
}
|
|
72
118
|
/** @returns The response data, if no MFA is required */
|
|
73
119
|
data() {
|
|
74
|
-
if (this.
|
|
75
|
-
throw new Error("Cannot call `data()`
|
|
120
|
+
if (!this.isSuccess()) {
|
|
121
|
+
throw new Error("Cannot call `data()` on a 202 Accepted response; use `asMfaRequired()` or `asSignDryRun()`");
|
|
76
122
|
}
|
|
77
123
|
return __classPrivateFieldGet(this, _CubeSignerResponse_resp, "f");
|
|
78
124
|
}
|
|
@@ -140,14 +186,9 @@ class CubeSignerResponse {
|
|
|
140
186
|
_CubeSignerResponse_env.set(this, void 0);
|
|
141
187
|
_CubeSignerResponse_requestFn.set(this, void 0);
|
|
142
188
|
_CubeSignerResponse_resp.set(this, void 0);
|
|
143
|
-
/**
|
|
144
|
-
* Optional MFA id. Only set if there is an MFA request associated with the request
|
|
145
|
-
*/
|
|
146
|
-
_CubeSignerResponse_mfaRequired.set(this, void 0);
|
|
147
189
|
__classPrivateFieldSet(this, _CubeSignerResponse_env, env, "f");
|
|
148
190
|
__classPrivateFieldSet(this, _CubeSignerResponse_requestFn, requestFn, "f");
|
|
149
191
|
__classPrivateFieldSet(this, _CubeSignerResponse_resp, resp, "f");
|
|
150
|
-
__classPrivateFieldSet(this, _CubeSignerResponse_mfaRequired, __classPrivateFieldGet(this, _CubeSignerResponse_resp, "f").accepted?.MfaRequired, "f");
|
|
151
192
|
}
|
|
152
193
|
/**
|
|
153
194
|
* Static constructor.
|
|
@@ -197,7 +238,7 @@ class CubeSignerResponse {
|
|
|
197
238
|
}
|
|
198
239
|
}
|
|
199
240
|
exports.CubeSignerResponse = CubeSignerResponse;
|
|
200
|
-
_CubeSignerResponse_env = new WeakMap(), _CubeSignerResponse_requestFn = new WeakMap(), _CubeSignerResponse_resp = new WeakMap(),
|
|
241
|
+
_CubeSignerResponse_env = new WeakMap(), _CubeSignerResponse_requestFn = new WeakMap(), _CubeSignerResponse_resp = new WeakMap(), _CubeSignerResponse_instances = new WeakSet(), _CubeSignerResponse_mfaTotpVote =
|
|
201
242
|
/**
|
|
202
243
|
* Approve or reject an MFA request using a given session and a TOTP code.
|
|
203
244
|
*
|
|
@@ -211,7 +252,7 @@ async function _CubeSignerResponse_mfaTotpVote(client, code, vote) {
|
|
|
211
252
|
if (mfaId === undefined) {
|
|
212
253
|
return this;
|
|
213
254
|
}
|
|
214
|
-
const mfaOrgId =
|
|
255
|
+
const mfaOrgId = this.mfaRequired.org_id;
|
|
215
256
|
const mfaApproval = await client.apiClient.mfaVoteTotp(mfaId, code, vote);
|
|
216
257
|
const mfaConf = mfaApproval.receipt?.confirmation;
|
|
217
258
|
if (!mfaConf) {
|
|
@@ -231,7 +272,7 @@ async function _CubeSignerResponse_mfaVote(client, mfaVote) {
|
|
|
231
272
|
if (mfaId === undefined) {
|
|
232
273
|
return this;
|
|
233
274
|
}
|
|
234
|
-
const mfaOrgId =
|
|
275
|
+
const mfaOrgId = this.mfaRequired.org_id;
|
|
235
276
|
const mfaApproval = await client.apiClient.mfaVoteCs(mfaId, mfaVote);
|
|
236
277
|
const mfaConf = mfaApproval.receipt?.confirmation;
|
|
237
278
|
if (!mfaConf) {
|
|
@@ -239,4 +280,4 @@ async function _CubeSignerResponse_mfaVote(client, mfaVote) {
|
|
|
239
280
|
}
|
|
240
281
|
return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });
|
|
241
282
|
};
|
|
242
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"response.js","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"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","sourcesContent":["import type { MfaVote, EnvInterface, MfaReceipts, MfaRequired } from \".\";\nimport { CubeSignerClient, isManyMfaReceipts } from \".\";\nimport { encodeToBase64Url } from \"./util\";\nimport type { AcceptedResponse } from \"./schema_types\";\n\n/**\n * Response type, which can be either a value of type {@link U}\n * or {@link AcceptedResponse} (status code 202) which requires MFA.\n */\nexport type Response<U> = U | AcceptedResponse;\n\n/**\n * Request function which optionally takes additional headers\n * (which, for example, can be used to attach an MFA receipt).\n */\nexport type RequestFn<U> = (headers?: HeadersInit) => Promise<Response<U>>;\n\n/**\n * Map function occasionally used to map a response from the API into a higher-level type.\n */\nexport type MapFn<U, V> = (u: U) => V;\n\n/**\n * Take a {@link Response<U>} and a {@link MapFn<U, V>} function and return\n * a {@link Response<V>} that maps the value of the original response when its status code is 200.\n *\n * @param resp Original response\n * @param mapFn Map to apply to the response value when its status code is 200.\n * @returns Response whose value for status code 200 is mapped from U to V\n */\nexport function mapResponse<U, V>(resp: Response<U>, mapFn: MapFn<U, V>): Response<V> {\n  if ((resp as AcceptedResponse).accepted?.MfaRequired) {\n    return resp as AcceptedResponse;\n  } else {\n    return mapFn(resp as U);\n  }\n}\n\n/**\n * A response of a CubeSigner request.\n */\nexport class CubeSignerResponse<U> {\n  readonly #env: EnvInterface;\n  readonly #requestFn: RequestFn<U>;\n  readonly #resp: U | AcceptedResponse;\n  /**\n   * Optional MFA id. Only set if there is an MFA request associated with the request\n   */\n  readonly #mfaRequired?: MfaRequired;\n\n  /** @returns The first MFA id associated with this request (if any) */\n  mfaId(): string | undefined {\n    return this.#mfaRequired?.id;\n  }\n\n  /** @returns The MFA ids associated with this request (if any) */\n  mfaIds(): string[] {\n    return this.#mfaRequired?.ids ?? [];\n  }\n\n  /** @returns True if this request requires an MFA approval */\n  requiresMfa(): boolean {\n    return this.#mfaRequired !== undefined;\n  }\n\n  /**\n   * @returns Session information to use for any MFA approval requests (if any was included in the response).\n   */\n  async mfaClient(): Promise<CubeSignerClient | undefined> {\n    if (this.#mfaRequired === undefined) return;\n    const session = (this.#resp as AcceptedResponse).accepted?.MfaRequired?.session ?? undefined;\n    if (session === undefined) return;\n\n    const env = this.#env;\n    return await CubeSignerClient.create({\n      env: {\n        \"Dev-CubeSignerStack\": env,\n      },\n      org_id: this.#mfaRequired.org_id,\n      session_exp: session.expiration,\n      session_info: session.session_info,\n      token: session.token,\n      refresh_token: session.refresh_token,\n    });\n  }\n\n  /** @returns The response data, if no MFA is required */\n  data(): U {\n    if (this.requiresMfa()) {\n      throw new Error(\"Cannot call `data()` while MFA is required\");\n    }\n    return this.#resp as U;\n  }\n\n  /**\n   * Approve the MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   * @returns The result of resubmitting the request with the approval\n   */\n  async totpApprove(client: CubeSignerClient, code: string): Promise<CubeSignerResponse<U>> {\n    return await this.#mfaTotpVote(client, code, \"approve\");\n  }\n\n  /**\n   * Reject the MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   */\n  async totpReject(client: CubeSignerClient, code: string) {\n    await this.#mfaTotpVote(client, code, \"reject\");\n  }\n\n  /**\n   * Approve or reject an MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   * @param vote Approve or reject\n   * @returns The result of resubmitting the request with the approval\n   */\n  async #mfaTotpVote(\n    client: CubeSignerClient,\n    code: string,\n    vote: MfaVote,\n  ): Promise<CubeSignerResponse<U>> {\n    const mfaId = this.mfaId();\n    if (mfaId === undefined) {\n      return this;\n    }\n\n    const mfaOrgId = this.#mfaRequired!.org_id;\n    const mfaApproval = await client.apiClient.mfaVoteTotp(mfaId, code, vote);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Approve the MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   * @returns The result of resubmitting the request with the approval\n   */\n  async approve(client: CubeSignerClient): Promise<CubeSignerResponse<U>> {\n    return await this.#mfaVote(client, \"approve\");\n  }\n\n  /**\n   * Reject the MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   */\n  async reject(client: CubeSignerClient) {\n    await this.#mfaVote(client, \"reject\");\n  }\n\n  /**\n   * Approve or reject an MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   * @param mfaVote Approve or reject\n   * @returns The result of resubmitting the request with the approval\n   */\n  async #mfaVote(client: CubeSignerClient, mfaVote: MfaVote): Promise<CubeSignerResponse<U>> {\n    const mfaId = this.mfaId();\n    if (mfaId === undefined) {\n      return this;\n    }\n\n    const mfaOrgId = this.#mfaRequired!.org_id;\n\n    const mfaApproval = await client.apiClient.mfaVoteCs(mfaId, mfaVote);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Resubmits the request with a given MFA receipt(s) attached.\n   *\n   * @param mfaReceipt The MFA receipt(s)\n   * @returns The result of signing after MFA approval\n   */\n  async execWithMfaApproval(mfaReceipt: MfaReceipts): Promise<CubeSignerResponse<U>> {\n    const headers = CubeSignerResponse.getMfaHeaders(mfaReceipt);\n    return new CubeSignerResponse(this.#env, this.#requestFn, await this.#requestFn(headers));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param env The environment where the response comes from\n   * @param requestFn\n   *    The function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param resp The response as returned by the OpenAPI client.\n   * @internal\n   */\n  protected constructor(env: EnvInterface, requestFn: RequestFn<U>, resp: U | AcceptedResponse) {\n    this.#env = env;\n    this.#requestFn = requestFn;\n    this.#resp = resp;\n    this.#mfaRequired = (this.#resp as AcceptedResponse).accepted?.MfaRequired;\n  }\n\n  /**\n   * Static constructor.\n   *\n   * @param env The environment where the response comes from\n   * @param requestFn\n   *    The request function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns New instance of this class.\n   * @internal\n   */\n  static async create<U>(\n    env: EnvInterface,\n    requestFn: RequestFn<U>,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<U>> {\n    const seed = await requestFn(this.getMfaHeaders(mfaReceipt));\n    return new CubeSignerResponse(env, requestFn, seed);\n  }\n\n  /**\n   * Return HTTP headers containing a given MFA receipt.\n   *\n   * @param mfaReceipt MFA receipt(s)\n   * @returns Headers including {@link mfaReceipt}\n   * @internal\n   */\n  static getMfaHeaders(mfaReceipt?: MfaReceipts): HeadersInit | undefined {\n    if (mfaReceipt === undefined) {\n      return undefined;\n    }\n\n    const rec = isManyMfaReceipts(mfaReceipt)\n      ? mfaReceipt\n      : {\n          orgId: mfaReceipt.mfaOrgId,\n          receipts: [\n            {\n              id: mfaReceipt.mfaId,\n              confirmation: mfaReceipt.mfaConf,\n            },\n          ],\n        };\n\n    if (rec.receipts.length === 0) {\n      return undefined;\n    }\n\n    const textEncoder = new TextEncoder();\n    return {\n      \"x-cubist-mfa-org-id\": rec.orgId,\n      \"x-cubist-mfa-receipts\": encodeToBase64Url(textEncoder.encode(JSON.stringify(rec.receipts))),\n    };\n  }\n}\n"]}
|
|
283
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"response.js","sourceRoot":"","sources":["../../src/response.ts"],"names":[],"mappings":"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","sourcesContent":["import type { MfaVote, EnvInterface, MfaReceipts, MfaRequired } from \".\";\nimport { CubeSignerClient, isManyMfaReceipts } from \".\";\nimport { encodeToBase64Url } from \"./util\";\nimport type { AcceptedResponse, AcceptedValue, BinanceDryRun, SignDryRun } from \"./schema_types\";\n\n/**\n * Response type, which can be either a value of type {@link U}\n * or {@link AcceptedResponse} (status code 202) which requires MFA.\n */\nexport type Response<U> = U | AcceptedResponse;\n\n/**\n * Request function which optionally takes additional headers\n * (which, for example, can be used to attach an MFA receipt).\n */\nexport type RequestFn<U> = (headers?: HeadersInit) => Promise<Response<U>>;\n\n/**\n * Map function occasionally used to map a response from the API into a higher-level type.\n */\nexport type MapFn<U, V> = (u: U) => V;\n\n/**\n * Take a {@link Response<U>} and a {@link MapFn<U, V>} function and return\n * a {@link Response<V>} that maps the value of the original response when its status code is 200.\n *\n * @param resp Original response\n * @param mapFn Map to apply to the response value when its status code is 200.\n * @returns Response whose value for status code 200 is mapped from U to V\n */\nexport function mapResponse<U, V>(resp: Response<U>, mapFn: MapFn<U, V>): Response<V> {\n  if (asAccepted(resp) !== undefined) {\n    return resp as AcceptedResponse;\n  } else {\n    return mapFn(resp as U);\n  }\n}\n\n/**\n * @param resp The response to check\n * @returns The {@link AcceptedValue} if the response status code is 202.\n */\nfunction asAccepted<U>(resp: Response<U>): AcceptedValue | undefined {\n  const acceptedResp = resp as AcceptedResponse;\n  return acceptedResp.error_code === \"SignDryRun\" || acceptedResp.error_code === \"MfaRequired\"\n    ? (acceptedResp.accepted ?? undefined)\n    : undefined;\n}\n\n/**\n * A response of a CubeSigner request.\n */\nexport class CubeSignerResponse<U> {\n  readonly #env: EnvInterface;\n  readonly #requestFn: RequestFn<U>;\n  readonly #resp: Response<U>;\n\n  /**\n   * @returns The {@link AcceptedValue} if the response status code is 202.\n   */\n  asAccepted(): AcceptedValue | undefined {\n    return asAccepted(this.#resp);\n  }\n\n  /**\n   * @returns The associated {@link MfaRequired} value, if the response status code is 202 and the response indicates that MFA is required.\n   */\n  asMfaRequired(): MfaRequired | undefined {\n    return this.asAccepted()?.MfaRequired ?? undefined;\n  }\n\n  /**\n   * @returns The associated {@link SignDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.\n   */\n  asSignDryRun(): SignDryRun | undefined {\n    return this.asAccepted()?.SignDryRun ?? undefined;\n  }\n\n  /**\n   * @returns The associated {@link BinanceDryRun} value, if the response status code is 202 and the response is a dry run of a sign operation.\n   */\n  asBinanceDryRun(): BinanceDryRun | undefined {\n    return this.asAccepted()?.BinanceDryRun ?? undefined;\n  }\n\n  /**\n   * @returns Whether this response is a \"200 Success\" (in which case it is safe to call {@link data})\n   */\n  isSuccess(): boolean {\n    return this.asAccepted() === undefined;\n  }\n\n  /**\n   * @returns The underlying {@link MfaRequired} response (if any).\n   */\n  private get mfaRequired() {\n    return this.asAccepted()?.MfaRequired;\n  }\n\n  /** @returns The first MFA id associated with this request (if any) */\n  mfaId(): string | undefined {\n    return this.mfaRequired?.id;\n  }\n\n  /** @returns The MFA ids associated with this request (if any) */\n  mfaIds(): string[] {\n    return this.mfaRequired?.ids ?? [];\n  }\n\n  /** @returns True if this request requires an MFA approval */\n  requiresMfa(): boolean {\n    return this.mfaRequired !== undefined;\n  }\n\n  /**\n   * @returns Session information to use for any MFA approval requests (if any was included in the response).\n   */\n  async mfaClient(): Promise<CubeSignerClient | undefined> {\n    if (this.mfaRequired === undefined) return;\n    const session = this.asMfaRequired()?.session ?? undefined;\n    if (session === undefined) return;\n\n    const env = this.#env;\n    return await CubeSignerClient.create({\n      env: {\n        \"Dev-CubeSignerStack\": env,\n      },\n      org_id: this.mfaRequired.org_id,\n      session_exp: session.expiration,\n      session_info: session.session_info,\n      token: session.token,\n      refresh_token: session.refresh_token,\n    });\n  }\n\n  /** @returns The response data, if no MFA is required */\n  data(): U {\n    if (!this.isSuccess()) {\n      throw new Error(\n        \"Cannot call `data()` on a 202 Accepted response; use `asMfaRequired()` or `asSignDryRun()`\",\n      );\n    }\n    return this.#resp as U;\n  }\n\n  /**\n   * Approve the MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   * @returns The result of resubmitting the request with the approval\n   */\n  async totpApprove(client: CubeSignerClient, code: string): Promise<CubeSignerResponse<U>> {\n    return await this.#mfaTotpVote(client, code, \"approve\");\n  }\n\n  /**\n   * Reject the MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   */\n  async totpReject(client: CubeSignerClient, code: string) {\n    await this.#mfaTotpVote(client, code, \"reject\");\n  }\n\n  /**\n   * Approve or reject an MFA request using a given session and a TOTP code.\n   *\n   * @param client CubeSigner whose session to use\n   * @param code 6-digit TOTP code\n   * @param vote Approve or reject\n   * @returns The result of resubmitting the request with the approval\n   */\n  async #mfaTotpVote(\n    client: CubeSignerClient,\n    code: string,\n    vote: MfaVote,\n  ): Promise<CubeSignerResponse<U>> {\n    const mfaId = this.mfaId();\n    if (mfaId === undefined) {\n      return this;\n    }\n\n    const mfaOrgId = this.mfaRequired!.org_id;\n    const mfaApproval = await client.apiClient.mfaVoteTotp(mfaId, code, vote);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Approve the MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   * @returns The result of resubmitting the request with the approval\n   */\n  async approve(client: CubeSignerClient): Promise<CubeSignerResponse<U>> {\n    return await this.#mfaVote(client, \"approve\");\n  }\n\n  /**\n   * Reject the MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   */\n  async reject(client: CubeSignerClient) {\n    await this.#mfaVote(client, \"reject\");\n  }\n\n  /**\n   * Approve or reject an MFA request using a given {@link CubeSignerClient} instance (i.e., its session).\n   *\n   * @param client CubeSigner whose session to use\n   * @param mfaVote Approve or reject\n   * @returns The result of resubmitting the request with the approval\n   */\n  async #mfaVote(client: CubeSignerClient, mfaVote: MfaVote): Promise<CubeSignerResponse<U>> {\n    const mfaId = this.mfaId();\n    if (mfaId === undefined) {\n      return this;\n    }\n\n    const mfaOrgId = this.mfaRequired!.org_id;\n\n    const mfaApproval = await client.apiClient.mfaVoteCs(mfaId, mfaVote);\n    const mfaConf = mfaApproval.receipt?.confirmation;\n\n    if (!mfaConf) {\n      return this;\n    }\n\n    return await this.execWithMfaApproval({ mfaId, mfaOrgId, mfaConf });\n  }\n\n  /**\n   * Resubmits the request with a given MFA receipt(s) attached.\n   *\n   * @param mfaReceipt The MFA receipt(s)\n   * @returns The result of signing after MFA approval\n   */\n  async execWithMfaApproval(mfaReceipt: MfaReceipts): Promise<CubeSignerResponse<U>> {\n    const headers = CubeSignerResponse.getMfaHeaders(mfaReceipt);\n    return new CubeSignerResponse(this.#env, this.#requestFn, await this.#requestFn(headers));\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param env The environment where the response comes from\n   * @param requestFn\n   *    The function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param resp The response as returned by the OpenAPI client.\n   * @internal\n   */\n  protected constructor(env: EnvInterface, requestFn: RequestFn<U>, resp: Response<U>) {\n    this.#env = env;\n    this.#requestFn = requestFn;\n    this.#resp = resp;\n  }\n\n  /**\n   * Static constructor.\n   *\n   * @param env The environment where the response comes from\n   * @param requestFn\n   *    The request function that this response is from.\n   *    This argument is used to resend requests with different headers if needed.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns New instance of this class.\n   * @internal\n   */\n  static async create<U>(\n    env: EnvInterface,\n    requestFn: RequestFn<U>,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<U>> {\n    const seed = await requestFn(this.getMfaHeaders(mfaReceipt));\n    return new CubeSignerResponse(env, requestFn, seed);\n  }\n\n  /**\n   * Return HTTP headers containing a given MFA receipt.\n   *\n   * @param mfaReceipt MFA receipt(s)\n   * @returns Headers including {@link mfaReceipt}\n   * @internal\n   */\n  static getMfaHeaders(mfaReceipt?: MfaReceipts): HeadersInit | undefined {\n    if (mfaReceipt === undefined) {\n      return undefined;\n    }\n\n    const rec = isManyMfaReceipts(mfaReceipt)\n      ? mfaReceipt\n      : {\n          orgId: mfaReceipt.mfaOrgId,\n          receipts: [\n            {\n              id: mfaReceipt.mfaId,\n              confirmation: mfaReceipt.mfaConf,\n            },\n          ],\n        };\n\n    if (rec.receipts.length === 0) {\n      return undefined;\n    }\n\n    const textEncoder = new TextEncoder();\n    return {\n      \"x-cubist-mfa-org-id\": rec.orgId,\n      \"x-cubist-mfa-receipts\": encodeToBase64Url(textEncoder.encode(JSON.stringify(rec.receipts))),\n    };\n  }\n}\n"]}
|