@cubist-labs/cubesigner-sdk 0.4.86-0 → 0.4.87-0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/package.json +1 -1
- package/dist/src/key.d.ts +3 -1
- package/dist/src/key.d.ts.map +1 -1
- package/dist/src/key.js +7 -1
- package/dist/src/schema.d.ts +32 -6
- package/dist/src/schema.d.ts.map +1 -1
- package/dist/src/schema.js +1 -1
- package/package.json +1 -1
- package/src/key.ts +6 -0
- package/src/schema.ts +37 -6
package/dist/package.json
CHANGED
package/dist/src/key.d.ts
CHANGED
|
@@ -16,7 +16,9 @@ export declare enum Secp256k1 {
|
|
|
16
16
|
AvaTest = "SecpAvaTestAddr",// eslint-disable-line no-unused-vars
|
|
17
17
|
Tron = "SecpTronAddr",// eslint-disable-line no-unused-vars
|
|
18
18
|
BtcLegacy = "SecpBtcLegacy",
|
|
19
|
-
BtcLegacyTest = "SecpBtcLegacyTest"
|
|
19
|
+
BtcLegacyTest = "SecpBtcLegacyTest",
|
|
20
|
+
Doge = "SecpDogeAddr",
|
|
21
|
+
DogeTest = "SecpDogeTestAddr"
|
|
20
22
|
}
|
|
21
23
|
/** BLS key type */
|
|
22
24
|
export declare enum Bls {
|
package/dist/src/key.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,KAAK,EACV,OAAO,EAEP,aAAa,EACb,aAAa,EACb,cAAc,EACd,eAAe,EACf,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,kBAAkB,EAClB,KAAK,EACL,eAAe,EACf,cAAc,EACd,iBAAiB,EACjB,kBAAkB,EAClB,sBAAsB,EACtB,eAAe,EACf,gBAAgB,EAChB,eAAe,EACf,mBAAmB,EACnB,gBAAgB,EAChB,uBAAuB,EACvB,eAAe,EACf,gBAAgB,EACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EACV,SAAS,EACT,QAAQ,EACR,kBAAkB,EAElB,YAAY,EACZ,SAAS,EACT,WAAW,EACZ,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,gBAAgB,EAAS,MAAM,GAAG,CAAC;AAG5C,yBAAyB;AACzB,oBAAY,SAAS;IACnB,GAAG,gBAAgB,CAAE,qCAAqC;IAC1D,GAAG,YAAY,CAAE,qCAAqC;IACtD,OAAO,gBAAgB,CAAE,qCAAqC;IAC9D,MAAM,mBAAmB,CAAE,qCAAqC;IAChE,OAAO,eAAe,CAAE,qCAAqC;IAC7D,WAAW,mBAAmB,CAAE,qCAAqC;IACrE,WAAW,gBAAgB;IAC3B,GAAG,gBAAgB,CAAE,qCAAqC;IAC1D,OAAO,oBAAoB,CAAE,qCAAqC;IAClE,IAAI,iBAAiB,CAAE,qCAAqC;IAC5D,SAAS,kBAAkB;IAC3B,aAAa,sBAAsB;
|
|
1
|
+
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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"}
|
package/dist/src/key.js
CHANGED
|
@@ -31,6 +31,8 @@ var Secp256k1;
|
|
|
31
31
|
Secp256k1["Tron"] = "SecpTronAddr";
|
|
32
32
|
Secp256k1["BtcLegacy"] = "SecpBtcLegacy";
|
|
33
33
|
Secp256k1["BtcLegacyTest"] = "SecpBtcLegacyTest";
|
|
34
|
+
Secp256k1["Doge"] = "SecpDogeAddr";
|
|
35
|
+
Secp256k1["DogeTest"] = "SecpDogeTestAddr";
|
|
34
36
|
})(Secp256k1 || (exports.Secp256k1 = Secp256k1 = {}));
|
|
35
37
|
/** BLS key type */
|
|
36
38
|
var Bls;
|
|
@@ -456,6 +458,10 @@ function fromSchemaKeyType(ty) {
|
|
|
456
458
|
return Secp256k1.TaprootTest;
|
|
457
459
|
case "SecpTronAddr":
|
|
458
460
|
return Secp256k1.Tron;
|
|
461
|
+
case "SecpDogeAddr":
|
|
462
|
+
return Secp256k1.Doge;
|
|
463
|
+
case "SecpDogeTestAddr":
|
|
464
|
+
return Secp256k1.DogeTest;
|
|
459
465
|
case "BlsPub":
|
|
460
466
|
return Bls.Eth2Deposited;
|
|
461
467
|
case "BlsInactive":
|
|
@@ -484,4 +490,4 @@ function fromSchemaKeyType(ty) {
|
|
|
484
490
|
return P256.Cosmos;
|
|
485
491
|
}
|
|
486
492
|
}
|
|
487
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import type { KeyPolicy } from \"./role\";\nimport type { PageOpts } from \"./paginator\";\nimport type {\n  KeyInfo,\n  UpdateKeyRequest,\n  SchemaKeyType,\n  KeyInRoleInfo,\n  EvmSignRequest,\n  EvmSignResponse,\n  Eip191SignRequest,\n  Eip712SignRequest,\n  Eth2SignRequest,\n  Eth2UnstakeRequest,\n  AvaTx,\n  BlobSignRequest,\n  BtcSignRequest,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  BtcMessageSignResponse,\n  BtcSignResponse,\n  BlobSignResponse,\n  AvaSignResponse,\n  Eth2UnstakeResponse,\n  Eth2SignResponse,\n  Eip191Or712SignResponse,\n  PsbtSignRequest,\n  PsbtSignResponse,\n} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  CubeSignerResponse,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { encodeToHex } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\", // eslint-disable-line no-unused-vars\n  Btc = \"SecpBtc\", // eslint-disable-line no-unused-vars\n  BtcTest = \"SecpBtcTest\", // eslint-disable-line no-unused-vars\n  Cosmos = \"SecpCosmosAddr\", // eslint-disable-line no-unused-vars\n  Taproot = \"TaprootBtc\", // eslint-disable-line no-unused-vars\n  TaprootTest = \"TaprootBtcTest\", // eslint-disable-line no-unused-vars\n  BabylonEots = \"BabylonEots\",\n  Ava = \"SecpAvaAddr\", // eslint-disable-line no-unused-vars\n  AvaTest = \"SecpAvaTestAddr\", // eslint-disable-line no-unused-vars\n  Tron = \"SecpTronAddr\", // eslint-disable-line no-unused-vars\n  BtcLegacy = \"SecpBtcLegacy\",\n  BtcLegacyTest = \"SecpBtcLegacyTest\",\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\", // eslint-disable-line no-unused-vars\n  Eth2Inactive = \"BlsInactive\", // eslint-disable-line no-unused-vars\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\", // eslint-disable-line no-unused-vars\n  Sui = \"Ed25519SuiAddr\", // eslint-disable-line no-unused-vars\n  Aptos = \"Ed25519AptosAddr\", // eslint-disable-line no-unused-vars\n  Cardano = \"Ed25519CardanoAddrVk\", // eslint-disable-line no-unused-vars\n  Stellar = \"Ed25519StellarAddr\", // eslint-disable-line no-unused-vars\n  Substrate = \"Ed25519SubstrateAddr\", // eslint-disable-line no-unused-vars\n  Tendermint = \"Ed25519TendermintAddr\", // eslint-disable-line no-unused-vars\n  Ton = \"Ed25519TonAddr\",\n}\n\n/** P256 key type */\nexport enum P256 {\n  Cosmos = \"P256CosmosAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256;\n\n/**\n * A representation of a signing key.\n */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #apiClient: ApiClient;\n\n  /** 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   * @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   * @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  /** The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** Is the key enabled? */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the key. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the key. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /**\n   * List roles this key is in.\n   * @param {PageOpts} page Optional pagination options; by default, retrieves all roles this key is in.\n   * @return {Promise<KeyInRoleInfo[]>} 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   * @param {PageOpts} page Optional pagination options; by default, retrieves all historical transactions for this key.\n   * @return {Promise<HistoricalTx[]>} 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   * @param {KeyPolicy} policy The new policy to set\n   */\n  async setPolicy(policy: KeyPolicy) {\n    await this.update({ policy: policy as unknown as Record<string, never>[] });\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 {string} metadata The new metadata to set.\n   */\n  async setMetadata(metadata: JsonValue): Promise<KeyInfo> {\n    return await this.update({ metadata });\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 {string} name The name of the property to set\n   * @param {JsonValue} value The new value of the property\n   * @return {Promise<KeyInfo>} Updated key information\n   */\n  async setMetadataProperty(name: string, value: JsonValue): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(name, value, this.#apiClient.config.updateRetryDelaysMs);\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 {string} name The name of the property to set\n   * @return {Promise<KeyInfo>} Updated key information\n   */\n  async deleteMetadataProperty(name: string): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      undefined,\n      this.#apiClient.config.updateRetryDelaysMs,\n    );\n  }\n\n  /**\n   * @param {string} name The name of the property to set\n   * @param {JsonValue} value The new value of the property\n   * @param {number[]} delaysMs Delays in milliseconds between retries\n   * @return {Promise<KeyInfo>} Updated key information\n   * @internal\n   */\n  async #setMetadataProperty(\n    name: string,\n    value: JsonValue | undefined,\n    delaysMs: number[],\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        metadata: updated,\n        version: data.version,\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 {KeyPolicy} 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   * @return {Promise<KeyPolicy>} 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   * @return {Promise<JsonValue>} 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   * @description 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   * @param {string} owner The user-id of the new owner of the key.\n   */\n  async setOwner(owner: string) {\n    await this.update({ owner });\n  }\n\n  /**\n   * Delete this key.\n   */\n  async delete() {\n    await this.#apiClient.keyDelete(this.id);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Create a new key.\n   *\n   * @param {ApiClient | CubeSignerClient} client The API client to use.\n   * @param {KeyInfo} 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 {EvmSignRequest} req What to sign.\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEvm(\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    return await this.#apiClient.signEvm(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 {BlobSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip191(\n    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 {BlobSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip712(\n    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 {Eth2SignRequest} req What to sign.\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<Eth2SignResponse | AcceptedResponse>} 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 {Eth2UnstakeRequest} req The request to sign.\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} 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 {AvaTx} tx Avalanche message (transaction) to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signAva(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} avaChain Avalanche chain\n   * @param {string} tx Hex encoded transaction\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSerializedAva(\n    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 {BlobSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BlobSignResponse | AcceptedResponse>} The response.\n   */\n  async signBlob(\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    return await this.#apiClient.signBlob(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin transaction.\n   *\n   * @param {BtcSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.\n   */\n  async signBtc(\n    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 { PsbtSignRequest } req What to sign\n   * @param { MfaReceipts } mfaReceipt Optional MFA receipt(s)\n   * @return { Promise<PsbtSignResponse | AcceptedResponse>} 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   * @typedef { Object } BtcMessageOptions\n   * @property { boolean } 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   * @property { MfaReceipts } mfaReceipt Optional MFA receipt(s)\n   */\n\n  /**\n   * Sign a Bitcoin message.\n   *\n   * @param { Uint8Array | string } req The message to sign\n   * @param { BtcMessageOptions } opts Options for this request\n   * @return { Promise<BtcMessageSignResponse | AcceptedResponse> } The response\n   */\n  async signBtcMessage(\n    req: Uint8Array | string,\n    opts: { p2sh?: boolean; mfaReceipt?: MfaReceipts },\n  ): Promise<CubeSignerResponse<BtcMessageSignResponse>> {\n    const request = {\n      data: encodeToHex(req),\n      is_p2sh: opts.p2sh ?? false,\n    };\n    return await this.#apiClient.signBtcMessage(this, request, opts.mfaReceipt);\n  }\n\n  /**\n   * Sign a Solana message.\n   *\n   * @param {SolanaSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSolana(\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SolanaSignResponse>> {\n    return await this.#apiClient.signSolana(this, req, mfaReceipt);\n  }\n\n  /**\n   * Update the key.\n   * @param {UpdateKeyRequest} request The JSON request to send to the API server.\n   * @return {KeyInfo} The JSON response from the API server.\n   * @internal\n   */\n  private async update(request: UpdateKeyRequest): Promise<KeyInfo> {\n    this.cached = await this.#apiClient.keyUpdate(this.id, request);\n    return this.cached;\n  }\n\n  /**\n   * Fetch the key information.\n   *\n   * @return {KeyInfo} 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 {SchemaKeyType} ty The schema key type.\n * @return {KeyType} 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 \"TaprootBtc\":\n      return Secp256k1.Taproot;\n    case \"TaprootBtcTest\":\n      return Secp256k1.TaprootTest;\n    case \"SecpTronAddr\":\n      return Secp256k1.Tron;\n    case \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\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  }\n}\n"]}
|
|
493
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import type { KeyPolicy } from \"./role\";\nimport type { PageOpts } from \"./paginator\";\nimport type {\n  KeyInfo,\n  UpdateKeyRequest,\n  SchemaKeyType,\n  KeyInRoleInfo,\n  EvmSignRequest,\n  EvmSignResponse,\n  Eip191SignRequest,\n  Eip712SignRequest,\n  Eth2SignRequest,\n  Eth2UnstakeRequest,\n  AvaTx,\n  BlobSignRequest,\n  BtcSignRequest,\n  SolanaSignRequest,\n  SolanaSignResponse,\n  BtcMessageSignResponse,\n  BtcSignResponse,\n  BlobSignResponse,\n  AvaSignResponse,\n  Eth2UnstakeResponse,\n  Eth2SignResponse,\n  Eip191Or712SignResponse,\n  PsbtSignRequest,\n  PsbtSignResponse,\n} from \"./schema_types\";\nimport type {\n  ApiClient,\n  AvaChain,\n  CubeSignerResponse,\n  ErrResponse,\n  HistoricalTx,\n  JsonValue,\n  MfaReceipts,\n} from \".\";\nimport { CubeSignerClient, delay } from \".\";\nimport { encodeToHex } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\", // eslint-disable-line no-unused-vars\n  Btc = \"SecpBtc\", // eslint-disable-line no-unused-vars\n  BtcTest = \"SecpBtcTest\", // eslint-disable-line no-unused-vars\n  Cosmos = \"SecpCosmosAddr\", // eslint-disable-line no-unused-vars\n  Taproot = \"TaprootBtc\", // eslint-disable-line no-unused-vars\n  TaprootTest = \"TaprootBtcTest\", // eslint-disable-line no-unused-vars\n  BabylonEots = \"BabylonEots\",\n  Ava = \"SecpAvaAddr\", // eslint-disable-line no-unused-vars\n  AvaTest = \"SecpAvaTestAddr\", // eslint-disable-line no-unused-vars\n  Tron = \"SecpTronAddr\", // eslint-disable-line no-unused-vars\n  BtcLegacy = \"SecpBtcLegacy\",\n  BtcLegacyTest = \"SecpBtcLegacyTest\",\n  Doge = \"SecpDogeAddr\",\n  DogeTest = \"SecpDogeTestAddr\",\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\", // eslint-disable-line no-unused-vars\n  Eth2Inactive = \"BlsInactive\", // eslint-disable-line no-unused-vars\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\", // eslint-disable-line no-unused-vars\n  Sui = \"Ed25519SuiAddr\", // eslint-disable-line no-unused-vars\n  Aptos = \"Ed25519AptosAddr\", // eslint-disable-line no-unused-vars\n  Cardano = \"Ed25519CardanoAddrVk\", // eslint-disable-line no-unused-vars\n  Stellar = \"Ed25519StellarAddr\", // eslint-disable-line no-unused-vars\n  Substrate = \"Ed25519SubstrateAddr\", // eslint-disable-line no-unused-vars\n  Tendermint = \"Ed25519TendermintAddr\", // eslint-disable-line no-unused-vars\n  Ton = \"Ed25519TonAddr\",\n}\n\n/** P256 key type */\nexport enum P256 {\n  Cosmos = \"P256CosmosAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark | P256;\n\n/**\n * A representation of a signing key.\n */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #apiClient: ApiClient;\n\n  /** 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   * @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   * @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  /** The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** Is the key enabled? */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the key. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the key. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /**\n   * List roles this key is in.\n   * @param {PageOpts} page Optional pagination options; by default, retrieves all roles this key is in.\n   * @return {Promise<KeyInRoleInfo[]>} 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   * @param {PageOpts} page Optional pagination options; by default, retrieves all historical transactions for this key.\n   * @return {Promise<HistoricalTx[]>} 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   * @param {KeyPolicy} policy The new policy to set\n   */\n  async setPolicy(policy: KeyPolicy) {\n    await this.update({ policy: policy as unknown as Record<string, never>[] });\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 {string} metadata The new metadata to set.\n   */\n  async setMetadata(metadata: JsonValue): Promise<KeyInfo> {\n    return await this.update({ metadata });\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 {string} name The name of the property to set\n   * @param {JsonValue} value The new value of the property\n   * @return {Promise<KeyInfo>} Updated key information\n   */\n  async setMetadataProperty(name: string, value: JsonValue): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(name, value, this.#apiClient.config.updateRetryDelaysMs);\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 {string} name The name of the property to set\n   * @return {Promise<KeyInfo>} Updated key information\n   */\n  async deleteMetadataProperty(name: string): Promise<KeyInfo> {\n    return await this.#setMetadataProperty(\n      name,\n      undefined,\n      this.#apiClient.config.updateRetryDelaysMs,\n    );\n  }\n\n  /**\n   * @param {string} name The name of the property to set\n   * @param {JsonValue} value The new value of the property\n   * @param {number[]} delaysMs Delays in milliseconds between retries\n   * @return {Promise<KeyInfo>} Updated key information\n   * @internal\n   */\n  async #setMetadataProperty(\n    name: string,\n    value: JsonValue | undefined,\n    delaysMs: number[],\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        metadata: updated,\n        version: data.version,\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 {KeyPolicy} 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   * @return {Promise<KeyPolicy>} 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   * @return {Promise<JsonValue>} 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   * @description 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   * @param {string} owner The user-id of the new owner of the key.\n   */\n  async setOwner(owner: string) {\n    await this.update({ owner });\n  }\n\n  /**\n   * Delete this key.\n   */\n  async delete() {\n    await this.#apiClient.keyDelete(this.id);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Create a new key.\n   *\n   * @param {ApiClient | CubeSignerClient} client The API client to use.\n   * @param {KeyInfo} 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 {EvmSignRequest} req What to sign.\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s).\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEvm(\n    req: EvmSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<EvmSignResponse>> {\n    return await this.#apiClient.signEvm(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 {BlobSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip191(\n    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 {BlobSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<EvmSignResponse | AcceptedResponse>} Signature (or MFA approval request).\n   */\n  async signEip712(\n    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 {Eth2SignRequest} req What to sign.\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<Eth2SignResponse | AcceptedResponse>} 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 {Eth2UnstakeRequest} req The request to sign.\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<Eth2UnstakeResponse | AcceptedResponse>} 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 {AvaTx} tx Avalanche message (transaction) to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signAva(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} avaChain Avalanche chain\n   * @param {string} tx Hex encoded transaction\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<AvaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSerializedAva(\n    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 {BlobSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BlobSignResponse | AcceptedResponse>} The response.\n   */\n  async signBlob(\n    req: BlobSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<BlobSignResponse>> {\n    return await this.#apiClient.signBlob(this, req, mfaReceipt);\n  }\n\n  /**\n   * Sign a Bitcoin transaction.\n   *\n   * @param {BtcSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<BtcSignResponse | AcceptedResponse>} The response.\n   */\n  async signBtc(\n    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 { PsbtSignRequest } req What to sign\n   * @param { MfaReceipts } mfaReceipt Optional MFA receipt(s)\n   * @return { Promise<PsbtSignResponse | AcceptedResponse>} 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   * @typedef { Object } BtcMessageOptions\n   * @property { boolean } 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   * @property { MfaReceipts } mfaReceipt Optional MFA receipt(s)\n   */\n\n  /**\n   * Sign a Bitcoin message.\n   *\n   * @param { Uint8Array | string } req The message to sign\n   * @param { BtcMessageOptions } opts Options for this request\n   * @return { Promise<BtcMessageSignResponse | AcceptedResponse> } The response\n   */\n  async signBtcMessage(\n    req: Uint8Array | string,\n    opts: { p2sh?: boolean; mfaReceipt?: MfaReceipts },\n  ): Promise<CubeSignerResponse<BtcMessageSignResponse>> {\n    const request = {\n      data: encodeToHex(req),\n      is_p2sh: opts.p2sh ?? false,\n    };\n    return await this.#apiClient.signBtcMessage(this, request, opts.mfaReceipt);\n  }\n\n  /**\n   * Sign a Solana message.\n   *\n   * @param {SolanaSignRequest} req What to sign\n   * @param {MfaReceipts} mfaReceipt Optional MFA receipt(s)\n   * @return {Promise<SolanaSignResponse | AcceptedResponse>} The response.\n   */\n  async signSolana(\n    req: SolanaSignRequest,\n    mfaReceipt?: MfaReceipts,\n  ): Promise<CubeSignerResponse<SolanaSignResponse>> {\n    return await this.#apiClient.signSolana(this, req, mfaReceipt);\n  }\n\n  /**\n   * Update the key.\n   * @param {UpdateKeyRequest} request The JSON request to send to the API server.\n   * @return {KeyInfo} The JSON response from the API server.\n   * @internal\n   */\n  private async update(request: UpdateKeyRequest): Promise<KeyInfo> {\n    this.cached = await this.#apiClient.keyUpdate(this.id, request);\n    return this.cached;\n  }\n\n  /**\n   * Fetch the key information.\n   *\n   * @return {KeyInfo} 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 {SchemaKeyType} ty The schema key type.\n * @return {KeyType} 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 \"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 \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\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  }\n}\n"]}
|
package/dist/src/schema.d.ts
CHANGED
|
@@ -1773,7 +1773,7 @@ export interface components {
|
|
|
1773
1773
|
/** @enum {string} */
|
|
1774
1774
|
BadGatewayErrorCode: "EsploraApiError" | "OAuthProviderError" | "OidcDisoveryFailed" | "OidcIssuerJwkEndpointUnavailable" | "SmtpServerUnavailable";
|
|
1775
1775
|
/** @enum {string} */
|
|
1776
|
-
BadRequestErrorCode: "GenericBadRequest" | "EmailPasswordNotFound" | "PasswordAuthNotAllowedByInvitation" | "OneTimeCodeExpired" | "InvalidBody" | "InvalidJwt" | "InvitationNoLongerValid" | "TokenRequestError" | "InvalidMfaReceipt" | "InvalidMfaPolicyCount" | "InvalidMfaPolicyNumAuthFactors" | "InvalidMfaPolicyNumAllowedApprovers" | "InvalidMfaPolicyGracePeriodTooLong" | "InvalidBabylonStakingPolicyParams" | "InvalidBtcTxReceiversEmptyAllowlist" | "InvalidRequireRoleSessionAllowlist" | "InvalidCreateKeyCount" | "OrgInviteExistingUser" | "OrgUserAlreadyExists" | "OrgNameTaken" | "OrgIsNotOrgExport" | "RoleNameTaken" | "PolicyNameTaken" | "PolicyNotFound" | "PolicyVersionNotFound" | "PolicyRuleDisallowedByType" | "AddKeyToRoleCountTooHigh" | "InvalidKeyId" | "InvalidTimeLockAlreadyInThePast" | "InvalidRestrictedScopes" | "InvalidUpdate" | "InvalidMetadataLength" | "InvalidKeyMaterialId" | "KeyNotFound" | "UserExportDerivedKey" | "UserExportPublicKeyInvalid" | "UnableToAccessSmtpRelay" | "UserExportInProgress" | "RoleNotFound" | "InvalidRoleNameOrId" | "InvalidMfaReceiptOrgIdMissing" | "InvalidMfaReceiptInvalidOrgId" | "MfaRequestNotFound" | "InvalidKeyType" | "InvalidKeyMaterial" | "InvalidHexValue" | "InvalidBase32Value" | "InvalidBase58Value" | "InvalidSs58Value" | "InvalidForkVersionLength" | "InvalidEthAddress" | "InvalidStellarAddress" | "InvalidOrgNameOrId" | "InvalidStakeDeposit" | "InvalidBlobSignRequest" | "InvalidSolanaSignRequest" | "InvalidEip712SignRequest" | "OnlySpecifyOne" | "NoOidcDataInProof" | "InvalidEvmSignRequest" | "InvalidEth2SignRequest" | "InvalidDeriveKeyRequest" | "InvalidStakingAmount" | "CustomStakingAmountNotAllowedForWrapperContract" | "InvalidUnstakeRequest" | "InvalidCreateUserRequest" | "UserAlreadyExists" | "IdpUserAlreadyExists" | "CognitoUserAlreadyOrgMember" | "UserNotFound" | "PolicyRuleKeyMismatch" | "EmptyScopes" | "InvalidScopesForRoleSession" | "InvalidLifetime" | "NoSingleKeyForUser" | "InvalidOrgPolicyRule" | "SourceIpAllowlistEmpty" | "LimitWindowTooLong" | "Erc20ContractDisallowed" | "EmptyRuleError" | "OptionalListEmpty" | "InvalidRange" | "InvalidOrgPolicyRepeatedRule" | "AvaSignHashError" | "AvaSignError" | "BtcSegwitHashError" | "BtcTaprootHashError" | "BtcSignError" | "TaprootSignError" | "Eip712SignError" | "InvalidMemberRoleInUserAdd" | "InvalidMemberRoleInRecipientAdd" | "ThirdPartyUserAlreadyExists" | "OidcIdentityAlreadyExists" | "ThirdPartyUserNotFound" | "DeleteOidcUserError" | "DeleteUserError" | "SessionRoleMismatch" | "InvalidOidcToken" | "InvalidOidcIdentity" | "OidcIssuerUnsupported" | "OidcIssuerNotAllowed" | "OidcIssuerNoApplicableJwk" | "FidoKeyAlreadyRegistered" | "FidoKeySignCountTooLow" | "FidoVerificationFailed" | "FidoChallengeMfaMismatch" | "UnsupportedLegacyCognitoSession" | "InvalidIdentityProof" | "PaginationDataExpired" | "ExistingKeysViolateExclusiveKeyAccess" | "ExportDelayTooShort" | "ExportWindowTooLong" | "InvalidTotpFailureLimit" | "InvalidEip191SignRequest" | "CannotResendUserInvitation" | "InvalidNotificationEndpointCount" | "CannotDeletePendingSubscription" | "InvalidNotificationUrlProtocol" | "EmptyOneOfOrgEventFilter" | "EmptyAllExceptOrgEventFilter" | "InvalidTapNodeHash" | "InvalidOneTimeCode" | "MessageNotFound" | "MessageAlreadySigned" | "MessageRejected" | "MessageReplaced" | "InvalidMessageType" | "EmptyAddress" | "InvalidEth2SigningPolicySlotRange" | "InvalidEth2SigningPolicyEpochRange" | "InvalidEth2SigningPolicyTimestampRange" | "InvalidEth2SigningPolicyOverlappingRule" | "MmiRpcUrlMissing" | "MmiChainIdMissing" | "EthersInvalidRpcUrl" | "EthersGetTransactionCountError" | "InvalidPassword" | "BabylonStakingFeePlusDustOverflow" | "BabylonStaking" | "BabylonStakingIncorrectKey" | "BabylonStakingSegwitNonDeposit" | "PsbtSigning" | "TooManyResets" | "TooManyFailedLogins" | "BadBtcMessageSignP2shFlag" | "InvalidTendermintRequest" | "PolicyVersionMaxReached" | "PolicyVersionInvalid" | "PolicyAlienOwnerInvalid" | "EmptyUpdateRequest";
|
|
1776
|
+
BadRequestErrorCode: "GenericBadRequest" | "EmailPasswordNotFound" | "PasswordAuthNotAllowedByInvitation" | "OneTimeCodeExpired" | "InvalidBody" | "InvalidJwt" | "InvitationNoLongerValid" | "TokenRequestError" | "InvalidMfaReceipt" | "InvalidMfaPolicyCount" | "InvalidMfaPolicyNumAuthFactors" | "InvalidMfaPolicyNumAllowedApprovers" | "InvalidMfaPolicyGracePeriodTooLong" | "InvalidBabylonStakingPolicyParams" | "InvalidBtcTxReceiversEmptyAllowlist" | "InvalidRequireRoleSessionAllowlist" | "InvalidCreateKeyCount" | "OrgInviteExistingUser" | "OrgUserAlreadyExists" | "OrgNameTaken" | "OrgIsNotOrgExport" | "RoleNameTaken" | "PolicyNameTaken" | "PolicyNotFound" | "PolicyVersionNotFound" | "PolicyRuleDisallowedByType" | "PolicyTypeDisallowed" | "AddKeyToRoleCountTooHigh" | "InvalidKeyId" | "InvalidTimeLockAlreadyInThePast" | "InvalidRestrictedScopes" | "InvalidUpdate" | "InvalidMetadataLength" | "InvalidKeyMaterialId" | "KeyNotFound" | "UserExportDerivedKey" | "UserExportPublicKeyInvalid" | "UnableToAccessSmtpRelay" | "UserExportInProgress" | "RoleNotFound" | "InvalidRoleNameOrId" | "InvalidMfaReceiptOrgIdMissing" | "InvalidMfaReceiptInvalidOrgId" | "MfaRequestNotFound" | "InvalidKeyType" | "InvalidKeyMaterial" | "InvalidHexValue" | "InvalidBase32Value" | "InvalidBase58Value" | "InvalidSs58Value" | "InvalidForkVersionLength" | "InvalidEthAddress" | "InvalidStellarAddress" | "InvalidOrgNameOrId" | "InvalidStakeDeposit" | "InvalidBlobSignRequest" | "InvalidSolanaSignRequest" | "InvalidEip712SignRequest" | "OnlySpecifyOne" | "NoOidcDataInProof" | "InvalidEvmSignRequest" | "InvalidEth2SignRequest" | "InvalidDeriveKeyRequest" | "InvalidStakingAmount" | "CustomStakingAmountNotAllowedForWrapperContract" | "InvalidUnstakeRequest" | "InvalidCreateUserRequest" | "UserAlreadyExists" | "IdpUserAlreadyExists" | "CognitoUserAlreadyOrgMember" | "UserNotFound" | "PolicyKeyMismatch" | "PolicyRuleKeyMismatch" | "EmptyScopes" | "InvalidScopesForRoleSession" | "InvalidLifetime" | "NoSingleKeyForUser" | "InvalidOrgPolicyRule" | "SourceIpAllowlistEmpty" | "LimitWindowTooLong" | "Erc20ContractDisallowed" | "EmptyRuleError" | "OptionalListEmpty" | "InvalidRange" | "InvalidOrgPolicyRepeatedRule" | "AvaSignHashError" | "AvaSignError" | "BtcSegwitHashError" | "BtcTaprootHashError" | "BtcSignError" | "TaprootSignError" | "Eip712SignError" | "InvalidMemberRoleInUserAdd" | "InvalidMemberRoleInRecipientAdd" | "ThirdPartyUserAlreadyExists" | "OidcIdentityAlreadyExists" | "ThirdPartyUserNotFound" | "DeleteOidcUserError" | "DeleteUserError" | "SessionRoleMismatch" | "InvalidOidcToken" | "InvalidOidcIdentity" | "OidcIssuerUnsupported" | "OidcIssuerNotAllowed" | "OidcIssuerNoApplicableJwk" | "FidoKeyAlreadyRegistered" | "FidoKeySignCountTooLow" | "FidoVerificationFailed" | "FidoChallengeMfaMismatch" | "UnsupportedLegacyCognitoSession" | "InvalidIdentityProof" | "PaginationDataExpired" | "ExistingKeysViolateExclusiveKeyAccess" | "ExportDelayTooShort" | "ExportWindowTooLong" | "InvalidTotpFailureLimit" | "InvalidEip191SignRequest" | "CannotResendUserInvitation" | "InvalidNotificationEndpointCount" | "CannotDeletePendingSubscription" | "InvalidNotificationUrlProtocol" | "EmptyOneOfOrgEventFilter" | "EmptyAllExceptOrgEventFilter" | "InvalidTapNodeHash" | "InvalidOneTimeCode" | "MessageNotFound" | "MessageAlreadySigned" | "MessageRejected" | "MessageReplaced" | "InvalidMessageType" | "EmptyAddress" | "InvalidEth2SigningPolicySlotRange" | "InvalidEth2SigningPolicyEpochRange" | "InvalidEth2SigningPolicyTimestampRange" | "InvalidEth2SigningPolicyOverlappingRule" | "MmiRpcUrlMissing" | "MmiChainIdMissing" | "EthersInvalidRpcUrl" | "EthersGetTransactionCountError" | "InvalidPassword" | "BabylonStakingFeePlusDustOverflow" | "BabylonStaking" | "BabylonStakingIncorrectKey" | "BabylonStakingSegwitNonDeposit" | "PsbtSigning" | "TooManyResets" | "TooManyFailedLogins" | "BadBtcMessageSignP2shFlag" | "InvalidTendermintRequest" | "PolicyVersionMaxReached" | "PolicyVersionInvalid" | "PolicyAlienOwnerInvalid" | "EmptyUpdateRequest" | "InvalidPolicyReference";
|
|
1777
1777
|
/**
|
|
1778
1778
|
* @example {
|
|
1779
1779
|
* "message_base64": "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXoxMjM0NTYK"
|
|
@@ -3025,7 +3025,7 @@ export interface components {
|
|
|
3025
3025
|
keys: components["schemas"]["KeyInfo"][];
|
|
3026
3026
|
};
|
|
3027
3027
|
/** @enum {string} */
|
|
3028
|
-
KeyType: "SecpEthAddr" | "SecpBtc" | "SecpBtcTest" | "SecpBtcLegacy" | "SecpBtcLegacyTest" | "SecpAvaAddr" | "SecpAvaTestAddr" | "BlsPub" | "BlsInactive" | "Ed25519SolanaAddr" | "Ed25519SuiAddr" | "Ed25519AptosAddr" | "Ed25519CardanoAddrVk" | "Ed25519StellarAddr" | "Ed25519SubstrateAddr" | "Mnemonic" | "Stark" | "BabylonEots" | "TaprootBtc" | "TaprootBtcTest" | "SecpCosmosAddr" | "P256CosmosAddr" | "Ed25519TendermintAddr" | "SecpTronAddr" | "Ed25519TonAddr";
|
|
3028
|
+
KeyType: "SecpEthAddr" | "SecpBtc" | "SecpBtcTest" | "SecpBtcLegacy" | "SecpBtcLegacyTest" | "SecpAvaAddr" | "SecpAvaTestAddr" | "BlsPub" | "BlsInactive" | "Ed25519SolanaAddr" | "Ed25519SuiAddr" | "Ed25519AptosAddr" | "Ed25519CardanoAddrVk" | "Ed25519StellarAddr" | "Ed25519SubstrateAddr" | "Mnemonic" | "Stark" | "BabylonEots" | "TaprootBtc" | "TaprootBtcTest" | "SecpCosmosAddr" | "P256CosmosAddr" | "Ed25519TendermintAddr" | "SecpTronAddr" | "Ed25519TonAddr" | "SecpDogeAddr" | "SecpDogeTestAddr";
|
|
3029
3029
|
/**
|
|
3030
3030
|
* @description Wrapper around encrypted [UnencryptedLastEvalKey] bytes.
|
|
3031
3031
|
*
|
|
@@ -3091,9 +3091,16 @@ export interface components {
|
|
|
3091
3091
|
};
|
|
3092
3092
|
/** @description Returned as a response from multiple routes (e.g., 'get mfa', 'approve mfa', 'approve totp'). */
|
|
3093
3093
|
MfaRequestInfo: {
|
|
3094
|
+
/** @description The session identity (user or role) that created this request. */
|
|
3095
|
+
created_by: string;
|
|
3094
3096
|
expires_at: components["schemas"]["EpochDateTime"];
|
|
3095
3097
|
/** @description Approval request ID. */
|
|
3096
3098
|
id: string;
|
|
3099
|
+
/**
|
|
3100
|
+
* @description MFA policy provenance
|
|
3101
|
+
* @enum {string}
|
|
3102
|
+
*/
|
|
3103
|
+
provenance: "Key" | "KeyInRole" | "Role" | "User" | "EditPolicy";
|
|
3097
3104
|
receipt?: components["schemas"]["Receipt"] | null;
|
|
3098
3105
|
/**
|
|
3099
3106
|
* @description If set, contains the IDs of all MFA requests (including this one!) that
|
|
@@ -3756,7 +3763,7 @@ export interface components {
|
|
|
3756
3763
|
* about the current and all future versions of a [NamedPolicy].
|
|
3757
3764
|
* @enum {string}
|
|
3758
3765
|
*/
|
|
3759
|
-
PolicyType: "Key" | "
|
|
3766
|
+
PolicyType: "Key" | "Role";
|
|
3760
3767
|
PreconditionErrorCode: components["schemas"]["PreconditionErrorOwnCodes"] | components["schemas"]["PolicyErrorCode"];
|
|
3761
3768
|
/** @enum {string} */
|
|
3762
3769
|
PreconditionErrorOwnCodes: "Eth2ProposerSlotTooLow" | "Eth2AttestationSourceEpochTooLow" | "Eth2AttestationTargetEpochTooLow" | "Eth2ConcurrentBlockSigning" | "Eth2ConcurrentAttestationSigning" | "Eth2MultiDepositToNonGeneratedKey" | "Eth2MultiDepositUnknownInitialDeposit" | "Eth2MultiDepositWithdrawalAddressMismatch" | "ConcurrentSigningWhenTimeLimitPolicyIsDefined" | "BabylonEotsConcurrentSigning" | "TendermintStateError" | "TendermintConcurrentSigning";
|
|
@@ -4140,7 +4147,7 @@ export interface components {
|
|
|
4140
4147
|
org_id: string;
|
|
4141
4148
|
};
|
|
4142
4149
|
/** @enum {string} */
|
|
4143
|
-
Purpose: "
|
|
4150
|
+
Purpose: "otp" | "alien_password_reset" | "alien_invite";
|
|
4144
4151
|
RatchetConfig: {
|
|
4145
4152
|
/** @default default_auth_lifetime */
|
|
4146
4153
|
auth_lifetime?: components["schemas"]["Seconds"];
|
|
@@ -4261,6 +4268,12 @@ export interface components {
|
|
|
4261
4268
|
AllOf: components["schemas"]["Scope"][];
|
|
4262
4269
|
}
|
|
4263
4270
|
]>;
|
|
4271
|
+
/**
|
|
4272
|
+
* @description Represents the number of MFA approvals required for a given operation
|
|
4273
|
+
* (e.g. login). Can be used to produce a concrete policy for a given user
|
|
4274
|
+
* @enum {string}
|
|
4275
|
+
*/
|
|
4276
|
+
SecondFactorRequirement: "none" | "if_registered" | "required";
|
|
4264
4277
|
/**
|
|
4265
4278
|
* Format: int64
|
|
4266
4279
|
* @description Duration measured in seconds
|
|
@@ -4767,12 +4780,14 @@ export interface components {
|
|
|
4767
4780
|
version?: number | null;
|
|
4768
4781
|
};
|
|
4769
4782
|
UpdateOrgRequest: {
|
|
4783
|
+
alien_login_requirement?: components["schemas"]["SecondFactorRequirement"] | null;
|
|
4770
4784
|
default_invite_kind?: components["schemas"]["InviteKind"] | null;
|
|
4771
4785
|
email_preferences?: components["schemas"]["EmailPreferences"] | null;
|
|
4772
4786
|
/** @description If set, update this org's `enabled` field to this value. */
|
|
4773
4787
|
enabled?: boolean | null;
|
|
4774
4788
|
historical_data_configuration?: components["schemas"]["HistoricalDataConfiguration"] | null;
|
|
4775
4789
|
idp_configuration?: components["schemas"]["IdpConfig"] | null;
|
|
4790
|
+
member_login_requirement?: components["schemas"]["SecondFactorRequirement"] | null;
|
|
4776
4791
|
/**
|
|
4777
4792
|
* @description If set, update this org's alias. Org aliases are globally unique.
|
|
4778
4793
|
* @example my_org
|
|
@@ -4870,12 +4885,14 @@ export interface components {
|
|
|
4870
4885
|
user_export_window?: number | null;
|
|
4871
4886
|
};
|
|
4872
4887
|
UpdateOrgResponse: {
|
|
4888
|
+
alien_login_requirement?: components["schemas"]["SecondFactorRequirement"] | null;
|
|
4873
4889
|
default_invite_kind?: components["schemas"]["InviteKind"] | null;
|
|
4874
4890
|
email_preferences?: components["schemas"]["EmailPreferences"] | null;
|
|
4875
4891
|
/** @description The new value of the 'enabled' property */
|
|
4876
4892
|
enabled?: boolean | null;
|
|
4877
4893
|
historical_data_configuration?: components["schemas"]["HistoricalDataConfiguration"] | null;
|
|
4878
4894
|
idp_configuration?: components["schemas"]["IdpConfig"] | null;
|
|
4895
|
+
member_login_requirement?: components["schemas"]["SecondFactorRequirement"] | null;
|
|
4879
4896
|
/**
|
|
4880
4897
|
* @description The new human-readable name for the org (must be alphanumeric)
|
|
4881
4898
|
* @example my_org_name
|
|
@@ -4935,7 +4952,7 @@ export interface components {
|
|
|
4935
4952
|
/** @description A new owner for the policy. */
|
|
4936
4953
|
owner?: string | null;
|
|
4937
4954
|
/** @description New policy rules. */
|
|
4938
|
-
|
|
4955
|
+
rules?: unknown[] | null;
|
|
4939
4956
|
};
|
|
4940
4957
|
UpdateRoleRequest: {
|
|
4941
4958
|
edit_policy?: components["schemas"]["EditPolicy"] | null;
|
|
@@ -5520,9 +5537,16 @@ export interface components {
|
|
|
5520
5537
|
MfaRequestInfo: {
|
|
5521
5538
|
content: {
|
|
5522
5539
|
"application/json": {
|
|
5540
|
+
/** @description The session identity (user or role) that created this request. */
|
|
5541
|
+
created_by: string;
|
|
5523
5542
|
expires_at: components["schemas"]["EpochDateTime"];
|
|
5524
5543
|
/** @description Approval request ID. */
|
|
5525
5544
|
id: string;
|
|
5545
|
+
/**
|
|
5546
|
+
* @description MFA policy provenance
|
|
5547
|
+
* @enum {string}
|
|
5548
|
+
*/
|
|
5549
|
+
provenance: "Key" | "KeyInRole" | "Role" | "User" | "EditPolicy";
|
|
5526
5550
|
receipt?: components["schemas"]["Receipt"] | null;
|
|
5527
5551
|
/**
|
|
5528
5552
|
* @description If set, contains the IDs of all MFA requests (including this one!) that
|
|
@@ -6140,12 +6164,14 @@ export interface components {
|
|
|
6140
6164
|
UpdateOrgResponse: {
|
|
6141
6165
|
content: {
|
|
6142
6166
|
"application/json": {
|
|
6167
|
+
alien_login_requirement?: components["schemas"]["SecondFactorRequirement"] | null;
|
|
6143
6168
|
default_invite_kind?: components["schemas"]["InviteKind"] | null;
|
|
6144
6169
|
email_preferences?: components["schemas"]["EmailPreferences"] | null;
|
|
6145
6170
|
/** @description The new value of the 'enabled' property */
|
|
6146
6171
|
enabled?: boolean | null;
|
|
6147
6172
|
historical_data_configuration?: components["schemas"]["HistoricalDataConfiguration"] | null;
|
|
6148
6173
|
idp_configuration?: components["schemas"]["IdpConfig"] | null;
|
|
6174
|
+
member_login_requirement?: components["schemas"]["SecondFactorRequirement"] | null;
|
|
6149
6175
|
/**
|
|
6150
6176
|
* @description The new human-readable name for the org (must be alphanumeric)
|
|
6151
6177
|
* @example my_org_name
|
|
@@ -6864,7 +6890,7 @@ export interface operations {
|
|
|
6864
6890
|
*/
|
|
6865
6891
|
org_id: string;
|
|
6866
6892
|
/** @description Which email to configure */
|
|
6867
|
-
purpose: "
|
|
6893
|
+
purpose: "otp" | "alien_password_reset" | "alien_invite";
|
|
6868
6894
|
};
|
|
6869
6895
|
};
|
|
6870
6896
|
requestBody: {
|