@cubist-labs/cubesigner-sdk 0.4.191-0 → 0.4.199

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/package.json CHANGED
@@ -5,7 +5,7 @@
5
5
  "url": "git+https://github.com/cubist-labs/CubeSigner-TypeScript-SDK.git",
6
6
  "directory": "packages/sdk"
7
7
  },
8
- "version": "0.4.191-0",
8
+ "version": "0.4.199",
9
9
  "description": "CubeSigner TypeScript SDK",
10
10
  "license": "MIT OR Apache-2.0",
11
11
  "author": "Cubist, Inc.",
package/dist/src/key.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import type { KeyPolicy } from "./role";
2
2
  import type { PageOpts } from "./paginator";
3
3
  import type { KeyInfo, SchemaKeyType, KeyInRoleInfo, EvmSignRequest, EvmSignResponse, Eip191SignRequest, Eip712SignRequest, Eth2SignRequest, Eth2UnstakeRequest, AvaTx, BlobSignRequest, BtcSignRequest, SolanaSignRequest, SolanaSignResponse, BtcMessageSignResponse, BtcSignResponse, BlobSignResponse, AvaSignResponse, Eth2UnstakeResponse, Eth2SignResponse, Eip191Or712SignResponse, PsbtSignRequest, PsbtSignResponse, DiffieHellmanResponse } from "./schema_types";
4
- import type { ApiClient, AvaChain, BabylonRegistrationRequest, BabylonRegistrationResponse, BabylonStakingRequest, BabylonStakingResponse, CubeSignerResponse, Empty, HistoricalTx, JsonValue, MfaReceipts, SuiSignRequest, SuiSignResponse } from ".";
4
+ import type { ApiClient, AvaChain, BabylonRegistrationRequest, BabylonRegistrationResponse, BabylonStakingRequest, BabylonStakingResponse, CubeSignerResponse, EditPolicy, Empty, HistoricalTx, JsonValue, MfaReceipts, SuiSignRequest, SuiSignResponse } from ".";
5
5
  import { CubeSignerClient } from ".";
6
6
  /** Secp256k1 key type */
7
7
  export declare enum Secp256k1 {
@@ -136,6 +136,14 @@ export declare class Key {
136
136
  * @throws if MFA is required and no receipts are provided
137
137
  */
138
138
  setPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts): Promise<void>;
139
+ /**
140
+ * Set new edit policy (overwriting any edit policies previously set for this key)
141
+ *
142
+ * @param editPolicy The new edit policy to set
143
+ * @param mfaReceipt Optional MFA receipt(s)
144
+ * @throws if MFA is required and no receipts are provided
145
+ */
146
+ setEditPolicy(editPolicy: EditPolicy, mfaReceipt?: MfaReceipts): Promise<void>;
139
147
  /**
140
148
  * Set key metadata. The metadata must be at most 1024 characters
141
149
  * and must match the following regex: ^[A-Za-z0-9_=+/ \-\.\,]{0,1024}$.
@@ -182,17 +190,25 @@ export declare class Key {
182
190
  /**
183
191
  * Append to existing key policy. This append is not atomic -- it uses {@link policy}
184
192
  * to fetch the current policy and then {@link setPolicy} to set the policy -- and
185
- * should not be used in across concurrent sessions.
193
+ * should not be used across concurrent sessions.
186
194
  *
187
195
  * @param policy The policy to append to the existing one.
196
+ * @param mfaReceipt Optional MFA receipt(s)
197
+ * @throws If MFA is required and no MFA receipts are provided
188
198
  */
189
- appendPolicy(policy: KeyPolicy): Promise<void>;
199
+ appendPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts): Promise<void>;
190
200
  /**
191
201
  * Get the policy for the key.
192
202
  *
193
203
  * @returns The policy for the key.
194
204
  */
195
205
  policy(): Promise<KeyPolicy>;
206
+ /**
207
+ * Get the edit policy for the key.
208
+ *
209
+ * @returns The edit policy for the key, undefined if there is no edit policy
210
+ */
211
+ editPolicy(): Promise<EditPolicy | undefined>;
196
212
  /**
197
213
  * Fetch the metadata for the key.
198
214
  *
@@ -1 +1 @@
1
- {"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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"}
package/dist/src/key.js CHANGED
@@ -140,6 +140,16 @@ class Key {
140
140
  async setPolicy(policy, mfaReceipt) {
141
141
  await this.update({ policy }, mfaReceipt);
142
142
  }
143
+ /**
144
+ * Set new edit policy (overwriting any edit policies previously set for this key)
145
+ *
146
+ * @param editPolicy The new edit policy to set
147
+ * @param mfaReceipt Optional MFA receipt(s)
148
+ * @throws if MFA is required and no receipts are provided
149
+ */
150
+ async setEditPolicy(editPolicy, mfaReceipt) {
151
+ await this.update({ edit_policy: editPolicy }, mfaReceipt);
152
+ }
143
153
  /**
144
154
  * Set key metadata. The metadata must be at most 1024 characters
145
155
  * and must match the following regex: ^[A-Za-z0-9_=+/ \-\.\,]{0,1024}$.
@@ -192,13 +202,15 @@ class Key {
192
202
  /**
193
203
  * Append to existing key policy. This append is not atomic -- it uses {@link policy}
194
204
  * to fetch the current policy and then {@link setPolicy} to set the policy -- and
195
- * should not be used in across concurrent sessions.
205
+ * should not be used across concurrent sessions.
196
206
  *
197
207
  * @param policy The policy to append to the existing one.
208
+ * @param mfaReceipt Optional MFA receipt(s)
209
+ * @throws If MFA is required and no MFA receipts are provided
198
210
  */
199
- async appendPolicy(policy) {
211
+ async appendPolicy(policy, mfaReceipt) {
200
212
  const existing = await this.policy();
201
- await this.setPolicy([...existing, ...policy]);
213
+ await this.setPolicy([...existing, ...policy], mfaReceipt);
202
214
  }
203
215
  /**
204
216
  * Get the policy for the key.
@@ -209,6 +221,15 @@ class Key {
209
221
  const data = await this.fetch();
210
222
  return (data.policy ?? []);
211
223
  }
224
+ /**
225
+ * Get the edit policy for the key.
226
+ *
227
+ * @returns The edit policy for the key, undefined if there is no edit policy
228
+ */
229
+ async editPolicy() {
230
+ const data = await this.fetch();
231
+ return data.edit_policy;
232
+ }
212
233
  /**
213
234
  * Fetch the metadata for the key.
214
235
  *
@@ -623,4 +644,4 @@ function fromSchemaKeyType(ty) {
623
644
  // NOTE: if you are adding a new key type, update the `create ${keyType} key` test in key.test.ts
624
645
  }
625
646
  }
626
- //# 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} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  BabylonRegistrationRequest,\n  BabylonRegistrationResponse,\n  BabylonStakingRequest,\n  BabylonStakingResponse,\n  BtcMessageSignRequest,\n  CubeSignerResponse,\n  Empty,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n  SuiSignRequest,\n  SuiSignResponse,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { loadSubtleCrypto } from \"./user_export\";\nimport { encodeToHex, encodeToBase64 } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\",\n  Btc = \"SecpBtc\",\n  BtcTest = \"SecpBtcTest\",\n  Ltc = \"SecpLtc\",\n  LtcTest = \"SecpLtcTest\",\n  Xrp = \"SecpXrpAddr\",\n  Cosmos = \"SecpCosmosAddr\",\n  Taproot = \"TaprootBtc\",\n  TaprootTest = \"TaprootBtcTest\",\n  BabylonEots = \"BabylonEots\",\n  BabylonCov = \"BabylonCov\",\n  Ava = \"SecpAvaAddr\",\n  AvaTest = \"SecpAvaTestAddr\",\n  Tron = \"SecpTronAddr\",\n  BtcLegacy = \"SecpBtcLegacy\",\n  BtcLegacyTest = \"SecpBtcLegacyTest\",\n  Doge = \"SecpDogeAddr\",\n  DogeTest = \"SecpDogeTestAddr\",\n  Kaspa = \"SecpKaspaAddr\",\n  KaspaTest = \"SecpKaspaTestAddr\",\n  KaspaSchnorr = \"SchnorrKaspaAddr\",\n  KaspaTestSchnorr = \"SchnorrKaspaTestAddr\",\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\",\n  Eth2Inactive = \"BlsInactive\",\n  AvaIcm = \"BlsAvaIcm\",\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\",\n  Sui = \"Ed25519SuiAddr\",\n  Aptos = \"Ed25519AptosAddr\",\n  Cardano = \"Ed25519CardanoAddrVk\",\n  Stellar = \"Ed25519StellarAddr\",\n  Substrate = \"Ed25519SubstrateAddr\",\n  Tendermint = \"Ed25519TendermintAddr\",\n  Ton = \"Ed25519TonAddr\",\n  Xrp = \"Ed25519XrpAddr\",\n}\n\n/** P256 key type */\nexport enum P256 {\n  Cosmos = \"P256CosmosAddr\",\n  Ontology = \"P256OntologyAddr\",\n  Neo3 = \"P256Neo3Addr\",\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** 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  /** @returns The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** @returns Whether the key is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /**\n   * Enable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async enable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: true }, mfaReceipt);\n  }\n\n  /**\n   * Disable the key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async disable(mfaReceipt?: MfaReceipts) {\n    await this.update({ enabled: false }, mfaReceipt);\n  }\n\n  /**\n   * List roles this key is in.\n   *\n   * @param page Optional pagination options; by default, retrieves all roles this key is in.\n   * @returns Roles this key is in.\n   */\n  async roles(page?: PageOpts): Promise<KeyInRoleInfo[]> {\n    return await this.#apiClient.keyRolesList(this.id, page).fetch();\n  }\n\n  /**\n   * List historical transactions for this key.\n   *\n   * @param page Optional pagination options; by default, retrieves all historical transactions for this key.\n   * @returns Historical key transactions.\n   */\n  async history(page?: PageOpts): Promise<HistoricalTx[]> {\n    return await this.#apiClient.keyHistory(this.id, page).fetch();\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   *\n   * @param policy The new policy to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setPolicy(policy: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ policy }, mfaReceipt);\n  }\n\n  /**\n   * Set key metadata. The metadata must be at most 1024 characters\n   * and must match the following regex: ^[A-Za-z0-9_=+/ \\-\\.\\,]{0,1024}$.\n   *\n   * @param metadata The new metadata to set.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns The updated key info\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is an object (throws if it is not),\n   * then sets the value of the {@link name} property in that object to {@link value},\n   * and finally submits the request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async setMetadataProperty(\n    name: string,\n    value: JsonValue,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      value,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * Retrieves the existing metadata, asserts that it is in object (throws if it is not),\n   * then deletes the {@link name} property in that object, and finally submits the\n   * request to update the metadata.\n   *\n   * This whole process is done atomically, meaning, that if the metadata changes between the\n   * time this method first retrieves it and the time it submits a request to update it, the\n   * request will be rejected. When that happens, this method will retry a few times, as per\n   * {@link ApiClient.config}.\n   *\n   * @param name The name of the property to set\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   */\n  async deleteMetadataProperty(name: string, mfaReceipt?: MfaReceipts): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      undefined,\n      this.#apiClient.config.updateRetryDelaysMs,\n      mfaReceipt,\n    );\n  }\n\n  /**\n   * @param name The name of the property to set\n   * @param value The new value of the property\n   * @param delaysMs Delays in milliseconds between retries\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   * @returns Updated key information\n   * @internal\n   */\n  async #setMetadataProperty(\n    name: string,\n    value: JsonValue | undefined,\n    delaysMs: number[],\n    mfaReceipt?: MfaReceipts,\n  ): Promise<KeyInfo> {\n    const data = await this.fetch();\n    const current = data.metadata ?? {};\n    if (typeof current !== \"object\") {\n      throw new Error(\"Current metadata is not a JSON object\");\n    }\n    const updated = {\n      ...current,\n      [name]: value,\n    };\n    try {\n      return await this.update(\n        {\n          metadata: updated,\n          version: data.version,\n        },\n        mfaReceipt,\n      );\n    } catch (e) {\n      if ((e as ErrResponse).errorCode === \"InvalidUpdate\" && delaysMs.length > 0) {\n        await delay(delaysMs[0]);\n        return await this.#setMetadataProperty(name, value, delaysMs.slice(1));\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy}\n   * to fetch the current policy and then {@link setPolicy} to set the policy -- and\n   * should not be used in across concurrent sessions.\n   *\n   * @param policy The policy to append to the existing one.\n   */\n  async appendPolicy(policy: KeyPolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\n  }\n\n  /**\n   * Get the policy for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * Fetch the metadata for the key.\n   *\n   * @returns The policy for the key.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * @returns The user id for the owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /**\n   * Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   *\n   * @param owner The user-id of the new owner of the key.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setOwner(owner: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ owner }, mfaReceipt);\n  }\n\n  /**\n   * Delete this key.\n   *\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns A response which can be used to approve MFA if needed\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.#apiClient.keyDelete(this.id, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Create a new key.\n   *\n   * @param client The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(client: ApiClient | CubeSignerClient, data: KeyInfo) {\n    this.#apiClient = client instanceof CubeSignerClient ? client.apiClient : client;\n    this.id = data.key_id;\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n    this.cached = data;\n  }\n\n  /**\n   * Sign an EVM transaction.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signEvm(\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    return await this.#apiClient.signEvm(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon staking transaction.\n   *\n   * @param req The staking transaction to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Signature (or MFA approval request).\n   */\n  async signBabylonStakingTxn(\n    req: BabylonStakingRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonStakingResponse>> {\n    return this.#apiClient.signBabylonStakingTxn(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Babylon registration.\n   *\n   * @param req The registration request to sign\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns Babylon staking registration data (or MFA approval request).\n   */\n  async signBabylonRegistration(\n    req: BabylonRegistrationRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BabylonRegistrationResponse>> {\n    return this.#apiClient.signBabylonRegistration(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign EIP-191 typed data.\n   *\n   * This requires the key to have a '\"AllowEip191Signing\"' {@link KeyPolicy}.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip191(\n    req: Eip191SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip191(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign EIP-712 typed data.\n   *\n   * This requires the key to have a '\"AllowEip712Signing\"' {@link KeyPolicy}.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature (or MFA approval request).\n   */\n  async signEip712(\n    req: Eip712SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eip191Or712SignResponse>> {\n    return await this.#apiClient.signEip712(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain validation message.\n   *\n   * @param req What to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns Signature\n   */\n  async signEth2(\n    req: Eth2SignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2SignResponse>> {\n    return await this.#apiClient.signEth2(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain unstake/exit request.\n   *\n   * @param req The request to sign.\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async unstake(\n    req: Eth2UnstakeRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<Eth2UnstakeResponse>> {\n    return await this.#apiClient.signUnstake(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign an Avalanche P- or X-chain message.\n   *\n   * @param tx Avalanche message (transaction) to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signAva(tx: AvaTx, mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signAva(this, tx, mfaReceipt);\n  }\n\n  /**\n   * Sign a serialized Avalanche C-/X-/P-chain message.\n   *\n   * @param avaChain Avalanche chain\n   * @param tx Hex encoded transaction\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signSerializedAva(\n    avaChain: AvaChain,\n    tx: string,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<AvaSignResponse>> {\n    return await this.#apiClient.signSerializedAva(this, avaChain, tx, mfaReceipt);\n  }\n\n  /**\n   * Sign a raw blob.\n   *\n   * This requires the key to have a '\"AllowRawBlobSigning\"' {@link KeyPolicy}. This is because\n   * signing arbitrary messages is, in general, dangerous (and you should instead\n   * prefer typed end-points as used by, for example, {@link signEvm}). For Secp256k1 keys,\n   * for example, you **must** call this function with a message that is 32 bytes long and\n   * the output of a secure hash function.\n   *\n   * This function returns signatures serialized as;\n   *\n   * - ECDSA signatures are serialized as big-endian r and s plus recovery-id\n   *    byte v, which can in general take any of the values 0, 1, 2, or 3.\n   *\n   * - EdDSA signatures are serialized in the standard format.\n   *\n   * - BLS signatures are not supported on the blob-sign endpoint.\n   *\n   * @param req What to sign\n   * @param mfaReceipt Optional MFA receipt(s)\n   * @returns The response.\n   */\n  async signBlob(\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    return await this.#apiClient.signBlob(this, req, mfaReceipt);\n  }\n\n  /**\n   * 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 \"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"]}
647
+ //# 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} 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/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\",\n  Btc = \"SecpBtc\",\n  BtcTest = \"SecpBtcTest\",\n  Ltc = \"SecpLtc\",\n  LtcTest = \"SecpLtcTest\",\n  Xrp = \"SecpXrpAddr\",\n  Cosmos = \"SecpCosmosAddr\",\n  Taproot = \"TaprootBtc\",\n  TaprootTest = \"TaprootBtcTest\",\n  BabylonEots = \"BabylonEots\",\n  BabylonCov = \"BabylonCov\",\n  Ava = \"SecpAvaAddr\",\n  AvaTest = \"SecpAvaTestAddr\",\n  Tron = \"SecpTronAddr\",\n  BtcLegacy = \"SecpBtcLegacy\",\n  BtcLegacyTest = \"SecpBtcLegacyTest\",\n  Doge = \"SecpDogeAddr\",\n  DogeTest = \"SecpDogeTestAddr\",\n  Kaspa = \"SecpKaspaAddr\",\n  KaspaTest = \"SecpKaspaTestAddr\",\n  KaspaSchnorr = \"SchnorrKaspaAddr\",\n  KaspaTestSchnorr = \"SchnorrKaspaTestAddr\",\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\",\n  Eth2Inactive = \"BlsInactive\",\n  AvaIcm = \"BlsAvaIcm\",\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\",\n  Sui = \"Ed25519SuiAddr\",\n  Aptos = \"Ed25519AptosAddr\",\n  Cardano = \"Ed25519CardanoAddrVk\",\n  Stellar = \"Ed25519StellarAddr\",\n  Substrate = \"Ed25519SubstrateAddr\",\n  Tendermint = \"Ed25519TendermintAddr\",\n  Ton = \"Ed25519TonAddr\",\n  Xrp = \"Ed25519XrpAddr\",\n}\n\n/** P256 key type */\nexport enum P256 {\n  Cosmos = \"P256CosmosAddr\",\n  Ontology = \"P256OntologyAddr\",\n  Neo3 = \"P256Neo3Addr\",\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** 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  /** @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 \"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"]}
@@ -226,14 +226,14 @@ export declare class NamedWasmPolicy extends NamedPolicy {
226
226
  /**
227
227
  * Invoke this wasm policy.
228
228
  *
229
- * @param keyId The key id that the policy will be invoked with.
229
+ * @param keyId The optional key id that the policy will be invoked with.
230
230
  * @param version The version of the policy to invoke. Defaults to "latest".
231
231
  * @param request The optional sign request body that will be sent to the policy.
232
232
  * @param roleId The optional role id that the policy will be invoked by.
233
233
  * If `undefined`, the policy will be invoked by the user session.
234
234
  * @returns The result of invoking the policy.
235
235
  */
236
- invoke(keyId: string, version?: Version, request?: JsonValue, roleId?: string): Promise<PolicyInvocation>;
236
+ invoke(keyId?: string, version?: Version, request?: JsonValue, roleId?: string): Promise<PolicyInvocation>;
237
237
  /**
238
238
  * Constructor.
239
239
  *
@@ -1 +1 @@
1
- {"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../src/policy.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../src/policy.ts"],"names":[],"mappings":"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"}
@@ -329,7 +329,7 @@ class NamedWasmPolicy extends NamedPolicy {
329
329
  /**
330
330
  * Invoke this wasm policy.
331
331
  *
332
- * @param keyId The key id that the policy will be invoked with.
332
+ * @param keyId The optional key id that the policy will be invoked with.
333
333
  * @param version The version of the policy to invoke. Defaults to "latest".
334
334
  * @param request The optional sign request body that will be sent to the policy.
335
335
  * @param roleId The optional role id that the policy will be invoked by.
@@ -337,6 +337,8 @@ class NamedWasmPolicy extends NamedPolicy {
337
337
  * @returns The result of invoking the policy.
338
338
  */
339
339
  async invoke(keyId, version = "latest", request, roleId) {
340
+ // TODO Ideally, `version` should be the first parameter. But for backwards
341
+ // compatibility, we keep `keyId` as the first parameter for now.
340
342
  const resp = await this.apiClient.policyInvoke(this.id, version, {
341
343
  key_id: keyId,
342
344
  request,
@@ -465,4 +467,4 @@ class PolicyInvocation {
465
467
  }
466
468
  exports.PolicyInvocation = PolicyInvocation;
467
469
  _PolicyInvocation_data = new WeakMap();
468
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy.js","sourceRoot":"","sources":["../../src/policy.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  ApiClient,\n  CubeSignerResponse,\n  EditPolicy,\n  Empty,\n  InvokePolicyResponse,\n  JsonValue,\n  KeyPolicy,\n  KeyPolicyRule,\n  MfaReceipts,\n  PolicyAttachedToId,\n  PolicyInfo,\n  PolicyType,\n  RolePolicy,\n  RolePolicyRule,\n  UpdatePolicyRequest,\n  WasmPolicyResponse,\n  WasmRule,\n} from \".\";\n\nimport { loadSubtleCrypto } from \".\";\n\n/**\n * Named policy rule type.\n */\nexport type PolicyRule = KeyPolicyRule | RolePolicyRule | WasmRule;\n\n/**\n * The policy info for a named key policy.\n */\nexport type KeyPolicyInfo = PolicyInfo & {\n  policy_type: \"Key\";\n};\n\n/**\n * The policy info for a named role policy.\n */\nexport type RolePolicyInfo = PolicyInfo & {\n  policy_type: \"Role\";\n};\n\n/**\n * The policy info for a named wasm policy.\n */\nexport type WasmPolicyInfo = PolicyInfo & {\n  policy_type: \"Wasm\";\n};\n\n/**\n * A helper type for valid named policy version strings.\n */\nexport type Version = `v${number}` | `latest`;\n\n/**\n * Upload the given Wasm policy object.\n *\n * @param apiClient The API client to use.\n * @param policy The Wasm policy object.\n * @returns The Wasm policy object hash to use for creating/updating policies.\n * @throws if uploading the policy fails.\n * @internal\n */\nexport async function uploadWasmPolicy(apiClient: ApiClient, policy: Uint8Array): Promise<string> {\n  // get the SHA-256 hash of the policy to get the upload url.\n  const subtle = await loadSubtleCrypto();\n  const hashBytes = await subtle.digest(\"SHA-256\", policy);\n  const hash = \"0x\" + Buffer.from(hashBytes).toString(\"hex\");\n\n  // get the upload URL\n  const { signed_url } = await apiClient.wasmPolicyUpload({ hash });\n\n  // upload the policy object\n  const resp = await fetch(signed_url, {\n    method: \"PUT\",\n    body: policy,\n  });\n\n  if (!resp.ok) {\n    throw new Error(`Failed to upload policy with status: ${resp.status}: ${resp.statusText}`);\n  }\n\n  return hash;\n}\n\n/**\n * Abstract class for shared methods between key, role and Wasm policies.\n */\nexport abstract class NamedPolicy {\n  protected readonly apiClient: ApiClient;\n  protected data: PolicyInfo;\n\n  /**\n   * Helper method for creating a named policy from a policy info.\n   *\n   * @param apiClient The api client to use.\n   * @param info The policy info.\n   * @returns The named policy object for the given info.\n   */\n  static fromInfo(apiClient: ApiClient, info: PolicyInfo): NamedPolicy {\n    switch (info.policy_type) {\n      case \"Key\":\n        return new NamedKeyPolicy(apiClient, info as KeyPolicyInfo);\n      case \"Role\":\n        return new NamedRolePolicy(apiClient, info as RolePolicyInfo);\n      case \"Wasm\":\n        return new NamedWasmPolicy(apiClient, info as WasmPolicyInfo);\n    }\n  }\n\n  /** @returns The policy id */\n  get id(): string {\n    return this.data.policy_id;\n  }\n\n  /** @returns The policy type */\n  get policyType(): PolicyType {\n    return this.data.policy_type;\n  }\n\n  /**\n   * Get a specific version of the policy.\n   *\n   * @param version The policy version to get.\n   * @returns The specific version of the policy.\n   */\n  async version(version: Version): Promise<NamedPolicyRules> {\n    let versionInfo;\n\n    if (version == `v${this.data.version}`) {\n      versionInfo = this.data;\n    } else {\n      versionInfo = await this.apiClient.policyGet(this.id, version);\n    }\n\n    return new NamedPolicyRules(this.apiClient, versionInfo);\n  }\n\n  /**\n   * Get the latest version of the policy.\n   *\n   * @returns The latest version of the policy.\n   */\n  async latest(): Promise<NamedPolicyRules> {\n    const data = await this.fetch(\"latest\");\n    return new NamedPolicyRules(this.apiClient, data);\n  }\n\n  /**\n   * Fetch and return the current name of the policy.\n   *\n   * @returns The policy name.\n   */\n  async name(): Promise<string> {\n    const data = await this.fetch();\n    return data.name;\n  }\n\n  /**\n   * Set a new name for the policy.\n   *\n   * @param name The new policy name.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setName(name: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ name }, mfaReceipt);\n  }\n\n  /**\n   * Fetch and return the current owner of the policy.\n   *\n   * @returns The user id of the policy owner.\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 a new owner for the policy.\n   *\n   * @param owner The new owner of the policy.\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   * Fetch and return the metadata value for the policy.\n   *\n   * @returns The policy metadata.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * Sets a new metadata value for the contact (overwriting the existing value).\n   *\n   * @param metadata The new metadata for the contact.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts) {\n    await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Fetch and return the edit policy for the contact.\n   *\n   * @returns The edit policy for this named policy.\n   */\n  async editPolicy(): Promise<EditPolicy | undefined> {\n    const data = await this.fetch();\n    return data.edit_policy;\n  }\n\n  /**\n   * Set a new edit policy for the named policy.\n   *\n   * @param editPolicy The new edit policy.\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   * @returns a list of all keys, roles, and key-in-roles that all versions of this policy\n   * are attached to.\n   */\n  async allAttached(): Promise<PolicyAttachedToId[]> {\n    // there is no single-call way to achieve this. So instead, we\n    // 1. Get the latest version of the policy\n    // 2. For all versions `v0` to `latest`, fetch the policy info\n    // 3. Join all policy `attached_to` arrays\n    const data = await this.fetch(\"latest\");\n\n    const latest = data.version;\n    const versions = Array.from(Array(latest + 1).keys());\n    const batchSize = 10;\n    let allAttached: PolicyAttachedToId[] = [];\n\n    for (let batch = 0; batch < versions.length; batch += batchSize) {\n      const rs = await Promise.all(\n        versions.slice(batch, batch + batchSize).map((version) => {\n          return this.apiClient.policyGet(this.id, `v${version}`);\n        }),\n      );\n      allAttached = allAttached.concat(rs.flatMap((policy) => policy.attached_to));\n    }\n\n    return allAttached.concat(data.attached_to);\n  }\n\n  /**\n   * Delete this policy.\n   *\n   * This can fail if the policy is still attached to any key, role, or key in role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns A response which can be used to approve MFA if needed\n   * @throws if MFA is required and no receipts are provided\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.apiClient.policyDelete(this.id, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  protected constructor(apiClient: ApiClient, data: PolicyInfo) {\n    this.apiClient = apiClient;\n    this.data = data;\n  }\n\n  /**\n   * Update the policy.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns The updated policy information.\n   * @throws if MFA is required and no receipts are provided\n   * @internal\n   */\n  protected async update(\n    request: UpdatePolicyRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<PolicyInfo> {\n    const resp = await this.apiClient.policyUpdate(this.id, request, mfaReceipt);\n    this.data = resp.data();\n    return this.data;\n  }\n\n  /**\n   * Fetch the policy information.\n   *\n   * @param version The version of the policy to fetch. Defaults to \"latest\".\n   * @returns The policy information.\n   * @internal\n   */\n  protected async fetch(version: Version = \"latest\"): Promise<PolicyInfo> {\n    this.data = await this.apiClient.policyGet(this.id, version);\n    return this.data;\n  }\n}\n\n/**\n * A representation of a named key policy.\n */\nexport class NamedKeyPolicy extends NamedPolicy {\n  override data: KeyPolicyInfo;\n\n  /**\n   * Update the policy with new rules.\n   *\n   * @param rules The new rules to update the policy with.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setRules(rules: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ rules }, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: KeyPolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A representation of a named role policy.\n */\nexport class NamedRolePolicy extends NamedPolicy {\n  override data: RolePolicyInfo;\n\n  /**\n   * Update the policy with new rules.\n   *\n   * @param rules The new rules to update the policy with.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setRules(rules: RolePolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ rules }, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: RolePolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A representation of a Wasm policy.\n */\nexport class NamedWasmPolicy extends NamedPolicy {\n  override data: WasmPolicyInfo;\n\n  /**\n   * Update the policy with the new Wasm policy.\n   *\n   * @param policy The new Wasm policy object.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if uploading the policy object fails.\n   * @throws if MFA is required and no receipts are provided.\n   */\n  async setWasmPolicy(policy: Uint8Array, mfaReceipt?: MfaReceipts) {\n    // upload the policy object\n    const hash = await uploadWasmPolicy(this.apiClient, policy);\n\n    // update this policy with the new policy verison.\n    const body: UpdatePolicyRequest = { rules: [{ hash }] };\n    this.data = (await this.update(body, mfaReceipt)) as WasmPolicyInfo;\n  }\n\n  /**\n   * Invoke this wasm policy.\n   *\n   * @param keyId The key id that the policy will be invoked with.\n   * @param version The version of the policy to invoke. Defaults to \"latest\".\n   * @param request The optional sign request body that will be sent to the policy.\n   * @param roleId The optional role id that the policy will be invoked by.\n   * If `undefined`, the policy will be invoked by the user session.\n   * @returns The result of invoking the policy.\n   */\n  async invoke(\n    keyId: string,\n    version: Version = \"latest\",\n    request?: JsonValue,\n    roleId?: string,\n  ): Promise<PolicyInvocation> {\n    const resp = await this.apiClient.policyInvoke(this.id, version, {\n      key_id: keyId,\n      request,\n      role_id: roleId,\n    });\n    return new PolicyInvocation(resp);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: WasmPolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A specific version of a named policy.\n */\nexport class NamedPolicyRules {\n  /** The CubeSigner instance that this policy is associated with */\n  readonly #apiClient: ApiClient;\n  #data: PolicyInfo;\n\n  /**\n   * @returns The ID of the policy.\n   *\n   * @example NamedPolicy#a4a45cc2-0642-4c98-b6bd-0da347d608a4\n   */\n  get id(): string {\n    return this.#data.policy_id;\n  }\n\n  /**\n   * @returns The version of the policy this object contains.\n   */\n  get version(): Version {\n    return `v${this.#data.version}`;\n  }\n\n  /**\n   * @returns The policy rules.\n   *\n   * @example [ \"AssertErc20Tx\" ]\n   */\n  get rules(): PolicyRule[] {\n    return this.#data.rules as PolicyRule[];\n  }\n\n  /**\n   * @returns a list of all keys, roles, and key-in-roles this version of the policy\n   *          is attached to.\n   */\n  async allAttached(): Promise<PolicyAttachedToId[]> {\n    const data = await this.fetch();\n    return data.attached_to;\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: PolicyInfo) {\n    this.#apiClient = apiClient;\n    this.#data = data;\n  }\n\n  /**\n   * Fetch the policy information.\n   *\n   * @returns The policy information.\n   * @internal\n   */\n  private async fetch(): Promise<PolicyInfo> {\n    this.#data = await this.#apiClient.policyGet(this.id, this.version);\n    return this.#data;\n  }\n}\n\n/**\n * The result of invoking a named wasm policy.\n */\nexport class PolicyInvocation {\n  readonly #data: InvokePolicyResponse;\n\n  /** @returns The policy response itself. */\n  get response(): WasmPolicyResponse {\n    return this.#data.response;\n  }\n\n  /** @returns The standard output stream. Usually a UTF-8 encoded string. */\n  get stdout(): Buffer {\n    return this.fromHex(this.#data.stdout);\n  }\n\n  /** @returns The standard error stream. Usually a UTF-8 encoded string. */\n  get stderr(): Buffer {\n    return this.fromHex(this.#data.stderr);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Helper method for converting hex-encoded data to a `Buffer`.\n   *\n   * @param hex The hex-encoded data.\n   * @returns The data.\n   */\n  private fromHex(hex: string): Buffer {\n    return Buffer.from(hex.startsWith(\"0x\") ? hex.slice(2) : hex, \"hex\");\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(data: InvokePolicyResponse) {\n    this.#data = data;\n  }\n}\n"]}
470
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy.js","sourceRoot":"","sources":["../../src/policy.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AA8DA,4CAoBC;AA9DD,wBAAqC;AAiCrC;;;;;;;;GAQG;AACI,KAAK,UAAU,gBAAgB,CAAC,SAAoB,EAAE,MAAkB;IAC7E,4DAA4D;IAC5D,MAAM,MAAM,GAAG,MAAM,IAAA,mBAAgB,GAAE,CAAC;IACxC,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IACzD,MAAM,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE3D,qBAAqB;IACrB,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,SAAS,CAAC,gBAAgB,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IAElE,2BAA2B;IAC3B,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,UAAU,EAAE;QACnC,MAAM,EAAE,KAAK;QACb,IAAI,EAAE,MAAM;KACb,CAAC,CAAC;IAEH,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,wCAAwC,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;GAEG;AACH,MAAsB,WAAW;IAI/B;;;;;;OAMG;IACH,MAAM,CAAC,QAAQ,CAAC,SAAoB,EAAE,IAAgB;QACpD,QAAQ,IAAI,CAAC,WAAW,EAAE,CAAC;YACzB,KAAK,KAAK;gBACR,OAAO,IAAI,cAAc,CAAC,SAAS,EAAE,IAAqB,CAAC,CAAC;YAC9D,KAAK,MAAM;gBACT,OAAO,IAAI,eAAe,CAAC,SAAS,EAAE,IAAsB,CAAC,CAAC;YAChE,KAAK,MAAM;gBACT,OAAO,IAAI,eAAe,CAAC,SAAS,EAAE,IAAsB,CAAC,CAAC;QAClE,CAAC;IACH,CAAC;IAED,6BAA6B;IAC7B,IAAI,EAAE;QACJ,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC;IAC7B,CAAC;IAED,+BAA+B;IAC/B,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC;IAC/B,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,OAAO,CAAC,OAAgB;QAC5B,IAAI,WAAW,CAAC;QAEhB,IAAI,OAAO,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YACvC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC;QAC1B,CAAC;aAAM,CAAC;YACN,WAAW,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;QACjE,CAAC;QAED,OAAO,IAAI,gBAAgB,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IAC3D,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM;QACV,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACxC,OAAO,IAAI,gBAAgB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACpD,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,IAAI;QACR,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CAAC,IAAY,EAAE,UAAwB;QAClD,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,KAAK;QACT,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CAAC,KAAa,EAAE,UAAwB;QACpD,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,CAAC,CAAC;IAC3C,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,QAAQ;QACZ,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,QAAqB,CAAC;IACpC,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,WAAW,CAAC,QAAmB,EAAE,UAAwB;QAC7D,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,EAAE,UAAU,CAAC,CAAC;IAC9C,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,UAAU;QACd,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,aAAa,CAAC,UAAsB,EAAE,UAAwB;QAClE,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,UAAU,EAAE,EAAE,UAAU,CAAC,CAAC;IAC7D,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,WAAW;QACf,8DAA8D;QAC9D,0CAA0C;QAC1C,8DAA8D;QAC9D,0CAA0C;QAC1C,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAExC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5B,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QACtD,MAAM,SAAS,GAAG,EAAE,CAAC;QACrB,IAAI,WAAW,GAAyB,EAAE,CAAC;QAE3C,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAC,MAAM,EAAE,KAAK,IAAI,SAAS,EAAE,CAAC;YAChE,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC,GAAG,CAC1B,QAAQ,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,GAAG,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;gBACvD,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,OAAO,EAAE,CAAC,CAAC;YAC1D,CAAC,CAAC,CACH,CAAC;YACF,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;QAC/E,CAAC;QAED,OAAO,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC9C,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,MAAM,CAAC,UAAwB;QACnC,OAAO,MAAM,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IAChE,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;;OAMG;IACH,YAAsB,SAAoB,EAAE,IAAgB;QAC1D,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED;;;;;;;;OAQG;IACO,KAAK,CAAC,MAAM,CACpB,OAA4B,EAC5B,UAAwB;QAExB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;QAC7E,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QACxB,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED;;;;;;OAMG;IACO,KAAK,CAAC,KAAK,CAAC,UAAmB,QAAQ;QAC/C,IAAI,CAAC,IAAI,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;QAC7D,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;CACF;AAvOD,kCAuOC;AAED;;GAEG;AACH,MAAa,cAAe,SAAQ,WAAW;IAG7C;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CAAC,KAAgB,EAAE,UAAwB;QACvD,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,CAAC,CAAC;IAC3C,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;;OAMG;IACH,YAAY,SAAoB,EAAE,IAAmB;QACnD,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;CACF;AA7BD,wCA6BC;AAED;;GAEG;AACH,MAAa,eAAgB,SAAQ,WAAW;IAG9C;;;;;;OAMG;IACH,KAAK,CAAC,QAAQ,CAAC,KAAiB,EAAE,UAAwB;QACxD,MAAM,IAAI,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,EAAE,UAAU,CAAC,CAAC;IAC3C,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;;OAMG;IACH,YAAY,SAAoB,EAAE,IAAoB;QACpD,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;CACF;AA7BD,0CA6BC;AAED;;GAEG;AACH,MAAa,eAAgB,SAAQ,WAAW;IAG9C;;;;;;;OAOG;IACH,KAAK,CAAC,aAAa,CAAC,MAAkB,EAAE,UAAwB;QAC9D,2BAA2B;QAC3B,MAAM,IAAI,GAAG,MAAM,gBAAgB,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QAE5D,kDAAkD;QAClD,MAAM,IAAI,GAAwB,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC;QACxD,IAAI,CAAC,IAAI,GAAG,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAmB,CAAC;IACtE,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,MAAM,CACV,KAAc,EACd,UAAmB,QAAQ,EAC3B,OAAmB,EACnB,MAAe;QAEf,2EAA2E;QAC3E,iEAAiE;QACjE,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,EAAE;YAC/D,MAAM,EAAE,KAAK;YACb,OAAO;YACP,OAAO,EAAE,MAAM;SAChB,CAAC,CAAC;QACH,OAAO,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;;OAMG;IACH,YAAY,SAAoB,EAAE,IAAoB;QACpD,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;CACF;AA7DD,0CA6DC;AAED;;GAEG;AACH,MAAa,gBAAgB;IAK3B;;;;OAIG;IACH,IAAI,EAAE;QACJ,OAAO,uBAAA,IAAI,8BAAM,CAAC,SAAS,CAAC;IAC9B,CAAC;IAED;;OAEG;IACH,IAAI,OAAO;QACT,OAAO,IAAI,uBAAA,IAAI,8BAAM,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;IAED;;;;OAIG;IACH,IAAI,KAAK;QACP,OAAO,uBAAA,IAAI,8BAAM,CAAC,KAAqB,CAAC;IAC1C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,WAAW;QACf,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;;OAMG;IACH,YAAY,SAAoB,EAAE,IAAgB;QAjDlD,kEAAkE;QACzD,8CAAsB;QAC/B,yCAAkB;QAgDhB,uBAAA,IAAI,+BAAc,SAAS,MAAA,CAAC;QAC5B,uBAAA,IAAI,0BAAS,IAAI,MAAA,CAAC;IACpB,CAAC;IAED;;;;;OAKG;IACK,KAAK,CAAC,KAAK;QACjB,uBAAA,IAAI,0BAAS,MAAM,uBAAA,IAAI,mCAAW,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,MAAA,CAAC;QACpE,OAAO,uBAAA,IAAI,8BAAM,CAAC;IACpB,CAAC;CACF;AAjED,4CAiEC;;AAED;;GAEG;AACH,MAAa,gBAAgB;IAG3B,2CAA2C;IAC3C,IAAI,QAAQ;QACV,OAAO,uBAAA,IAAI,8BAAM,CAAC,QAAQ,CAAC;IAC7B,CAAC;IAED,2EAA2E;IAC3E,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,uBAAA,IAAI,8BAAM,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;IAED,0EAA0E;IAC1E,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,uBAAA,IAAI,8BAAM,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;IAED,6EAA6E;IAC7E,6EAA6E;IAC7E,6EAA6E;IAE7E;;;;;OAKG;IACK,OAAO,CAAC,GAAW;QACzB,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACvE,CAAC;IAED;;;;;OAKG;IACH,YAAY,IAA0B;QArC7B,yCAA4B;QAsCnC,uBAAA,IAAI,0BAAS,IAAI,MAAA,CAAC;IACpB,CAAC;CACF;AAzCD,4CAyCC","sourcesContent":["import type {\n  ApiClient,\n  CubeSignerResponse,\n  EditPolicy,\n  Empty,\n  InvokePolicyResponse,\n  JsonValue,\n  KeyPolicy,\n  KeyPolicyRule,\n  MfaReceipts,\n  PolicyAttachedToId,\n  PolicyInfo,\n  PolicyType,\n  RolePolicy,\n  RolePolicyRule,\n  UpdatePolicyRequest,\n  WasmPolicyResponse,\n  WasmRule,\n} from \".\";\n\nimport { loadSubtleCrypto } from \".\";\n\n/**\n * Named policy rule type.\n */\nexport type PolicyRule = KeyPolicyRule | RolePolicyRule | WasmRule;\n\n/**\n * The policy info for a named key policy.\n */\nexport type KeyPolicyInfo = PolicyInfo & {\n  policy_type: \"Key\";\n};\n\n/**\n * The policy info for a named role policy.\n */\nexport type RolePolicyInfo = PolicyInfo & {\n  policy_type: \"Role\";\n};\n\n/**\n * The policy info for a named wasm policy.\n */\nexport type WasmPolicyInfo = PolicyInfo & {\n  policy_type: \"Wasm\";\n};\n\n/**\n * A helper type for valid named policy version strings.\n */\nexport type Version = `v${number}` | `latest`;\n\n/**\n * Upload the given Wasm policy object.\n *\n * @param apiClient The API client to use.\n * @param policy The Wasm policy object.\n * @returns The Wasm policy object hash to use for creating/updating policies.\n * @throws if uploading the policy fails.\n * @internal\n */\nexport async function uploadWasmPolicy(apiClient: ApiClient, policy: Uint8Array): Promise<string> {\n  // get the SHA-256 hash of the policy to get the upload url.\n  const subtle = await loadSubtleCrypto();\n  const hashBytes = await subtle.digest(\"SHA-256\", policy);\n  const hash = \"0x\" + Buffer.from(hashBytes).toString(\"hex\");\n\n  // get the upload URL\n  const { signed_url } = await apiClient.wasmPolicyUpload({ hash });\n\n  // upload the policy object\n  const resp = await fetch(signed_url, {\n    method: \"PUT\",\n    body: policy,\n  });\n\n  if (!resp.ok) {\n    throw new Error(`Failed to upload policy with status: ${resp.status}: ${resp.statusText}`);\n  }\n\n  return hash;\n}\n\n/**\n * Abstract class for shared methods between key, role and Wasm policies.\n */\nexport abstract class NamedPolicy {\n  protected readonly apiClient: ApiClient;\n  protected data: PolicyInfo;\n\n  /**\n   * Helper method for creating a named policy from a policy info.\n   *\n   * @param apiClient The api client to use.\n   * @param info The policy info.\n   * @returns The named policy object for the given info.\n   */\n  static fromInfo(apiClient: ApiClient, info: PolicyInfo): NamedPolicy {\n    switch (info.policy_type) {\n      case \"Key\":\n        return new NamedKeyPolicy(apiClient, info as KeyPolicyInfo);\n      case \"Role\":\n        return new NamedRolePolicy(apiClient, info as RolePolicyInfo);\n      case \"Wasm\":\n        return new NamedWasmPolicy(apiClient, info as WasmPolicyInfo);\n    }\n  }\n\n  /** @returns The policy id */\n  get id(): string {\n    return this.data.policy_id;\n  }\n\n  /** @returns The policy type */\n  get policyType(): PolicyType {\n    return this.data.policy_type;\n  }\n\n  /**\n   * Get a specific version of the policy.\n   *\n   * @param version The policy version to get.\n   * @returns The specific version of the policy.\n   */\n  async version(version: Version): Promise<NamedPolicyRules> {\n    let versionInfo;\n\n    if (version == `v${this.data.version}`) {\n      versionInfo = this.data;\n    } else {\n      versionInfo = await this.apiClient.policyGet(this.id, version);\n    }\n\n    return new NamedPolicyRules(this.apiClient, versionInfo);\n  }\n\n  /**\n   * Get the latest version of the policy.\n   *\n   * @returns The latest version of the policy.\n   */\n  async latest(): Promise<NamedPolicyRules> {\n    const data = await this.fetch(\"latest\");\n    return new NamedPolicyRules(this.apiClient, data);\n  }\n\n  /**\n   * Fetch and return the current name of the policy.\n   *\n   * @returns The policy name.\n   */\n  async name(): Promise<string> {\n    const data = await this.fetch();\n    return data.name;\n  }\n\n  /**\n   * Set a new name for the policy.\n   *\n   * @param name The new policy name.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setName(name: string, mfaReceipt?: MfaReceipts) {\n    await this.update({ name }, mfaReceipt);\n  }\n\n  /**\n   * Fetch and return the current owner of the policy.\n   *\n   * @returns The user id of the policy owner.\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 a new owner for the policy.\n   *\n   * @param owner The new owner of the policy.\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   * Fetch and return the metadata value for the policy.\n   *\n   * @returns The policy metadata.\n   */\n  async metadata(): Promise<JsonValue> {\n    const data = await this.fetch();\n    return data.metadata as JsonValue;\n  }\n\n  /**\n   * Sets a new metadata value for the contact (overwriting the existing value).\n   *\n   * @param metadata The new metadata for the contact.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setMetadata(metadata: JsonValue, mfaReceipt?: MfaReceipts) {\n    await this.update({ metadata }, mfaReceipt);\n  }\n\n  /**\n   * Fetch and return the edit policy for the contact.\n   *\n   * @returns The edit policy for this named policy.\n   */\n  async editPolicy(): Promise<EditPolicy | undefined> {\n    const data = await this.fetch();\n    return data.edit_policy;\n  }\n\n  /**\n   * Set a new edit policy for the named policy.\n   *\n   * @param editPolicy The new edit policy.\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   * @returns a list of all keys, roles, and key-in-roles that all versions of this policy\n   * are attached to.\n   */\n  async allAttached(): Promise<PolicyAttachedToId[]> {\n    // there is no single-call way to achieve this. So instead, we\n    // 1. Get the latest version of the policy\n    // 2. For all versions `v0` to `latest`, fetch the policy info\n    // 3. Join all policy `attached_to` arrays\n    const data = await this.fetch(\"latest\");\n\n    const latest = data.version;\n    const versions = Array.from(Array(latest + 1).keys());\n    const batchSize = 10;\n    let allAttached: PolicyAttachedToId[] = [];\n\n    for (let batch = 0; batch < versions.length; batch += batchSize) {\n      const rs = await Promise.all(\n        versions.slice(batch, batch + batchSize).map((version) => {\n          return this.apiClient.policyGet(this.id, `v${version}`);\n        }),\n      );\n      allAttached = allAttached.concat(rs.flatMap((policy) => policy.attached_to));\n    }\n\n    return allAttached.concat(data.attached_to);\n  }\n\n  /**\n   * Delete this policy.\n   *\n   * This can fail if the policy is still attached to any key, role, or key in role.\n   *\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns A response which can be used to approve MFA if needed\n   * @throws if MFA is required and no receipts are provided\n   */\n  async delete(mfaReceipt?: MfaReceipts): Promise<CubeSignerResponse<Empty>> {\n    return await this.apiClient.policyDelete(this.id, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  protected constructor(apiClient: ApiClient, data: PolicyInfo) {\n    this.apiClient = apiClient;\n    this.data = data;\n  }\n\n  /**\n   * Update the policy.\n   *\n   * @param request The JSON request to send to the API server.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @returns The updated policy information.\n   * @throws if MFA is required and no receipts are provided\n   * @internal\n   */\n  protected async update(\n    request: UpdatePolicyRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<PolicyInfo> {\n    const resp = await this.apiClient.policyUpdate(this.id, request, mfaReceipt);\n    this.data = resp.data();\n    return this.data;\n  }\n\n  /**\n   * Fetch the policy information.\n   *\n   * @param version The version of the policy to fetch. Defaults to \"latest\".\n   * @returns The policy information.\n   * @internal\n   */\n  protected async fetch(version: Version = \"latest\"): Promise<PolicyInfo> {\n    this.data = await this.apiClient.policyGet(this.id, version);\n    return this.data;\n  }\n}\n\n/**\n * A representation of a named key policy.\n */\nexport class NamedKeyPolicy extends NamedPolicy {\n  override data: KeyPolicyInfo;\n\n  /**\n   * Update the policy with new rules.\n   *\n   * @param rules The new rules to update the policy with.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setRules(rules: KeyPolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ rules }, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: KeyPolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A representation of a named role policy.\n */\nexport class NamedRolePolicy extends NamedPolicy {\n  override data: RolePolicyInfo;\n\n  /**\n   * Update the policy with new rules.\n   *\n   * @param rules The new rules to update the policy with.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if MFA is required and no receipts are provided\n   */\n  async setRules(rules: RolePolicy, mfaReceipt?: MfaReceipts) {\n    await this.update({ rules }, mfaReceipt);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: RolePolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A representation of a Wasm policy.\n */\nexport class NamedWasmPolicy extends NamedPolicy {\n  override data: WasmPolicyInfo;\n\n  /**\n   * Update the policy with the new Wasm policy.\n   *\n   * @param policy The new Wasm policy object.\n   * @param mfaReceipt Optional MFA receipt(s).\n   * @throws if uploading the policy object fails.\n   * @throws if MFA is required and no receipts are provided.\n   */\n  async setWasmPolicy(policy: Uint8Array, mfaReceipt?: MfaReceipts) {\n    // upload the policy object\n    const hash = await uploadWasmPolicy(this.apiClient, policy);\n\n    // update this policy with the new policy verison.\n    const body: UpdatePolicyRequest = { rules: [{ hash }] };\n    this.data = (await this.update(body, mfaReceipt)) as WasmPolicyInfo;\n  }\n\n  /**\n   * Invoke this wasm policy.\n   *\n   * @param keyId The optional key id that the policy will be invoked with.\n   * @param version The version of the policy to invoke. Defaults to \"latest\".\n   * @param request The optional sign request body that will be sent to the policy.\n   * @param roleId The optional role id that the policy will be invoked by.\n   * If `undefined`, the policy will be invoked by the user session.\n   * @returns The result of invoking the policy.\n   */\n  async invoke(\n    keyId?: string,\n    version: Version = \"latest\",\n    request?: JsonValue,\n    roleId?: string,\n  ): Promise<PolicyInvocation> {\n    // TODO Ideally, `version` should be the first parameter. But for backwards\n    // compatibility, we keep `keyId` as the first parameter for now.\n    const resp = await this.apiClient.policyInvoke(this.id, version, {\n      key_id: keyId,\n      request,\n      role_id: roleId,\n    });\n    return new PolicyInvocation(resp);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: WasmPolicyInfo) {\n    super(apiClient, data);\n    this.data = data;\n  }\n}\n\n/**\n * A specific version of a named policy.\n */\nexport class NamedPolicyRules {\n  /** The CubeSigner instance that this policy is associated with */\n  readonly #apiClient: ApiClient;\n  #data: PolicyInfo;\n\n  /**\n   * @returns The ID of the policy.\n   *\n   * @example NamedPolicy#a4a45cc2-0642-4c98-b6bd-0da347d608a4\n   */\n  get id(): string {\n    return this.#data.policy_id;\n  }\n\n  /**\n   * @returns The version of the policy this object contains.\n   */\n  get version(): Version {\n    return `v${this.#data.version}`;\n  }\n\n  /**\n   * @returns The policy rules.\n   *\n   * @example [ \"AssertErc20Tx\" ]\n   */\n  get rules(): PolicyRule[] {\n    return this.#data.rules as PolicyRule[];\n  }\n\n  /**\n   * @returns a list of all keys, roles, and key-in-roles this version of the policy\n   *          is attached to.\n   */\n  async allAttached(): Promise<PolicyAttachedToId[]> {\n    const data = await this.fetch();\n    return data.attached_to;\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(apiClient: ApiClient, data: PolicyInfo) {\n    this.#apiClient = apiClient;\n    this.#data = data;\n  }\n\n  /**\n   * Fetch the policy information.\n   *\n   * @returns The policy information.\n   * @internal\n   */\n  private async fetch(): Promise<PolicyInfo> {\n    this.#data = await this.#apiClient.policyGet(this.id, this.version);\n    return this.#data;\n  }\n}\n\n/**\n * The result of invoking a named wasm policy.\n */\nexport class PolicyInvocation {\n  readonly #data: InvokePolicyResponse;\n\n  /** @returns The policy response itself. */\n  get response(): WasmPolicyResponse {\n    return this.#data.response;\n  }\n\n  /** @returns The standard output stream. Usually a UTF-8 encoded string. */\n  get stdout(): Buffer {\n    return this.fromHex(this.#data.stdout);\n  }\n\n  /** @returns The standard error stream. Usually a UTF-8 encoded string. */\n  get stderr(): Buffer {\n    return this.fromHex(this.#data.stderr);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Helper method for converting hex-encoded data to a `Buffer`.\n   *\n   * @param hex The hex-encoded data.\n   * @returns The data.\n   */\n  private fromHex(hex: string): Buffer {\n    return Buffer.from(hex.startsWith(\"0x\") ? hex.slice(2) : hex, \"hex\");\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param data The JSON response from the API server.\n   * @internal\n   */\n  constructor(data: InvokePolicyResponse) {\n    this.#data = data;\n  }\n}\n"]}