@bitgo-beta/sdk-core 8.2.1-beta.763 → 8.2.1-beta.765

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.
@@ -43,4 +43,4 @@ exports.EncryptedSignerShareType = {
43
43
  ENCRYPTED_SIGNER_SHARE: 'encryptedSignerShare',
44
44
  ENCRYPTED_R_SHARE: 'encryptedRShare',
45
45
  };
46
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTypes.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTypes.ts"],"names":[],"mappings":";;;AAqCA,IAAY,SAWX;AAXD,WAAY,SAAS;IACnB,oBAAO,CAAA;IACP,sCAAyB,CAAA;IACzB,oBAAO,CAAA;IACP,oBAAO,CAAA;IACP,oBAAO,CAAA;IACP,gCAAmB,CAAA;IACnB,gDAAmC,CAAA;IACnC,wCAA2B,CAAA;IAC3B,wCAA2B,CAAA;IAC3B,wCAA2B,CAAA;AAC7B,CAAC,EAXW,SAAS,yBAAT,SAAS,QAWpB;AAED,IAAY,OAGX;AAHD,WAAY,OAAO;IACjB,0BAAe,CAAA;IACf,0BAAe,CAAA;AACjB,CAAC,EAHW,OAAO,uBAAP,OAAO,QAGlB;AA4FD,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,gCAAmB,CAAA;IACnB,4BAAe,CAAA;AACjB,CAAC,EAJW,SAAS,yBAAT,SAAS,QAIpB;AAwJD,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,yCAAE,CAAA;IACF,mDAAO,CAAA;AACT,CAAC,EAHW,WAAW,2BAAX,WAAW,QAGtB;AA0DY,QAAA,kBAAkB,GAAG;IAChC,IAAI,EAAE,MAAM;IACZ,MAAM,EAAE,QAAQ;IAChB,KAAK,EAAE,OAAO;CACN,CAAC;AAgBE,QAAA,cAAc,GAAG;IAC5B,UAAU,EAAE,YAAY;IACxB,YAAY,EAAE,cAAc;CACpB,CAAC;AAYE,QAAA,wBAAwB,GAAG;IACtC,sBAAsB,EAAE,sBAAsB;IAC9C,iBAAiB,EAAE,iBAAiB;CAC5B,CAAC","sourcesContent":["import { Key, SerializedKeyPair } from 'openpgp';\nimport { IRequestTracer } from '../../../api';\nimport { KeychainsTriplet, ParsedTransaction } from '../../baseCoin';\nimport { ApiKeyShare, Keychain } from '../../keychain';\nimport { ApiVersion, Memo, WalletType } from '../../wallet';\nimport { EDDSA, GShare, Signature, SignShare } from '../../../account-lib/mpc/tss';\nimport { KeyShare } from './ecdsa';\nimport { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';\nimport { TssEcdsaStep1ReturnMessage, TssEcdsaStep2ReturnMessage, TxRequestChallengeResponse } from '../../tss/types';\nimport { AShare, DShare, SShare } from '../../tss/ecdsa/types';\n\nexport type TxRequestVersion = 'full' | 'lite';\nexport interface HopParams {\n  paymentId?: string;\n  userReqSig?: string;\n  gasPriceMax?: number;\n}\n\nexport interface EIP1559FeeOptions {\n  gasLimit?: number;\n  maxFeePerGas?: number;\n  maxPriorityFeePerGas?: number;\n}\n\nexport interface FeeOption {\n  unit?: 'baseUnit' | 'cpu' | 'ram';\n  formula?: 'fixed' | 'feeRate' | 'perKB' | 'custom' | 'perVKB';\n  feeType?: 'base' | 'max' | 'tip';\n  gasLimit?: number;\n  gasPrice?: number;\n}\n\nexport interface TokenEnablement {\n  name: string;\n  address?: string; // Some chains like Solana require tokens to be enabled for specific address. If absent, we will enable it for the wallet's root address\n}\n\nexport enum ShareType {\n  R = 'R',\n  Commitment = 'commitment',\n  G = 'G',\n  S = 'S',\n  K = 'K',\n  MuDelta = 'MuDelta',\n  PaillierModulus = 'PaillierModulus',\n  MPCv2Round1 = 'MPCv2Round1',\n  MPCv2Round2 = 'MPCv2Round2',\n  MPCv2Round3 = 'MPCv2Round3',\n}\n\nexport enum MPCType {\n  EDDSA = 'eddsa',\n  ECDSA = 'ecdsa',\n}\n\nexport interface CustomPaillierModulusGetterFunction {\n  (params: { txRequest: TxRequest }): Promise<{\n    userPaillierModulus: string;\n  }>;\n}\n\nexport interface CustomKShareGeneratingFunction {\n  (params: {\n    tssParams: TSSParams | TSSParamsForMessage;\n    challenges: {\n      enterpriseChallenge: EcdsaTypes.SerializedEcdsaChallenges;\n      bitgoChallenge: TxRequestChallengeResponse;\n    };\n    requestType: RequestType;\n  }): Promise<TssEcdsaStep1ReturnMessage>;\n}\n\nexport interface CustomMuDeltaShareGeneratingFunction {\n  (params: {\n    txRequest: TxRequest;\n    aShareFromBitgo: Omit<AShare, 'ntilde' | 'h1' | 'h2'>;\n    bitgoChallenge: TxRequestChallengeResponse;\n    encryptedWShare: string;\n  }): Promise<TssEcdsaStep2ReturnMessage>;\n}\n\nexport interface CustomSShareGeneratingFunction {\n  (params: {\n    tssParams: TSSParams | TSSParamsForMessage;\n    dShareFromBitgo: DShare;\n    requestType: RequestType;\n    encryptedOShare: string;\n  }): Promise<SShare>;\n}\n\nexport interface CustomCommitmentGeneratingFunction {\n  (params: { txRequest: TxRequest; bitgoGpgPubKey?: string }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }>;\n}\n\nexport interface CustomRShareGeneratingFunction {\n  (params: { txRequest: TxRequest; encryptedUserToBitgoRShare: EncryptedSignerShareRecord }): Promise<{\n    rShare: SignShare;\n  }>;\n}\n\nexport interface CustomGShareGeneratingFunction {\n  (params: {\n    txRequest: TxRequest;\n    userToBitgoRShare: SignShare;\n    bitgoToUserRShare: SignatureShareRecord;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare>;\n}\n\nexport interface CustomMPCv2SigningRound1GeneratingFunction {\n  (params: { txRequest: TxRequest }): Promise<{\n    signatureShareRound1: SignatureShareRecord;\n    encryptedRound1Session: string;\n    userGpgPubKey: string;\n    encryptedUserGpgPrvKey: string;\n  }>;\n}\n\nexport interface CustomMPCv2SigningRound2GeneratingFunction {\n  (params: {\n    txRequest: TxRequest;\n    bitgoPublicGpgKey: string;\n    encryptedUserGpgPrvKey: string;\n    encryptedRound1Session: string;\n  }): Promise<{\n    signatureShareRound2: SignatureShareRecord;\n    encryptedRound2Session: string;\n  }>;\n}\n\nexport interface CustomMPCv2SigningRound3GeneratingFunction {\n  (params: {\n    txRequest: TxRequest;\n    bitgoPublicGpgKey: string;\n    encryptedUserGpgPrvKey: string;\n    encryptedRound2Session: string;\n  }): Promise<{\n    signatureShareRound3: SignatureShareRecord;\n  }>;\n}\n\nexport enum TokenType {\n  ERC721 = 'ERC721',\n  ERC1155 = 'ERC1155',\n  ERC20 = 'ERC20',\n}\nexport interface TokenTransferRecipientParams {\n  tokenType: TokenType;\n  tokenQuantity: string;\n  tokenContractAddress?: string;\n  tokenName?: string;\n  tokenId?: string;\n  decimalPlaces?: number;\n}\ninterface IntentOptionsBase {\n  reqId: IRequestTracer;\n  intentType: string;\n  sequenceId?: string;\n  isTss?: boolean;\n  comment?: string;\n  memo?: Memo;\n  custodianTransactionId?: string;\n  custodianMessageId?: string;\n}\n\nexport interface IntentOptionsForMessage extends IntentOptionsBase {\n  messageRaw: string;\n  messageEncoded?: string;\n}\n\nexport interface IntentOptionsForTypedData extends IntentOptionsBase {\n  typedDataRaw: string;\n  typedDataEncoded?: string;\n}\n\nexport interface PrebuildTransactionWithIntentOptions extends IntentOptionsBase {\n  recipients?: {\n    address: string;\n    amount: string | number;\n    data?: string;\n    tokenName?: string;\n    tokenData?: TokenTransferRecipientParams;\n  }[];\n  tokenName?: string;\n  enableTokens?: TokenEnablement[];\n  nonce?: string;\n  selfSend?: boolean;\n  feeOptions?: FeeOption | EIP1559FeeOptions;\n  hopParams?: HopParams;\n  lowFeeTxid?: string;\n  custodianTransactionId?: string;\n  receiveAddress?: string;\n  unspents?: string[];\n  /**\n   * The receive address from which funds will be withdrawn.\n   * This feature is supported only for specific coins, like ADA.\n   */\n  senderAddress?: string;\n}\nexport interface IntentRecipient {\n  address: {\n    address: string;\n  };\n  amount: {\n    value: string | number;\n    symbol: string;\n  };\n  data?: string;\n  tokenData?: TokenTransferRecipientParams;\n}\ninterface PopulatedIntentBase {\n  intentType: string;\n  sequenceId?: string;\n  comment?: string;\n  memo?: string;\n  isTss?: boolean;\n}\n\nexport interface PopulatedIntentForMessageSigning extends PopulatedIntentBase {\n  messageRaw: string;\n  messageEncoded: string;\n  custodianMessageId?: string;\n}\n\nexport interface PopulatedIntentForTypedDataSigning extends PopulatedIntentBase {\n  messageRaw: string;\n  messageEncoded: string;\n  custodianMessageId?: string;\n}\n\nexport interface PopulatedIntent extends PopulatedIntentBase {\n  recipients?: IntentRecipient[];\n  nonce?: string;\n  token?: string;\n  enableTokens?: TokenEnablement[];\n  unspents?: string[];\n  /**\n   * The receive address from which funds will be withdrawn.\n   * This feature is supported only for specific coins, like ADA.\n   */\n  senderAddress?: string;\n  // ETH & ETH-like params\n  selfSend?: boolean;\n  feeOptions?: FeeOption | EIP1559FeeOptions;\n  hopParams?: HopParams;\n  txid?: string;\n  receiveAddress?: string;\n  custodianTransactionId?: string;\n  custodianMessageId?: string;\n}\n\nexport type TxRequestState =\n  | 'pendingCommitment'\n  | 'pendingApproval'\n  | 'canceled'\n  | 'rejected'\n  | 'initialized'\n  | 'pendingDelivery'\n  | 'delivered'\n  | 'pendingUserSignature'\n  | 'signed';\n\nexport type TransactionState =\n  | 'initialized'\n  | 'pendingCommitment'\n  | 'pendingSignature'\n  | 'signed'\n  | 'held'\n  | 'delivered'\n  | 'invalidSignature'\n  | 'rejected';\n\n// Type used to sign a TSS transaction\nexport type SignableTransaction = {\n  // unsigned transaction in broadcast format\n  serializedTxHex: string;\n  // portion of a transaction used to generate a signature\n  signableHex: string;\n};\n\nexport type UnsignedTransactionTss = SignableTransaction & {\n  // derivation path of the signer\n  derivationPath: string;\n  // transaction fees\n  feeInfo?: {\n    fee: number;\n    feeString: string;\n  };\n  coinSpecific?: Record<string, unknown>;\n  parsedTx?: unknown;\n};\n\nexport type UnsignedMessageTss = {\n  derivationPath: string;\n  message: string;\n};\n\nexport enum RequestType {\n  tx,\n  message,\n}\nexport type SignedTx = {\n  id: string;\n  tx: string;\n  publicKey?: string;\n  signature?: string;\n};\n\nexport type TxRequest = {\n  txRequestId: string;\n  walletId: string;\n  walletType: WalletType;\n  version: number;\n  enterpriseId?: string;\n  state: TxRequestState;\n  date: string;\n  userId: string;\n  intent: unknown; // Should override with sig scheme specific intent\n  pendingApprovalId?: string;\n  policiesChecked: boolean;\n  signatureShares?: SignatureShareRecord[];\n  commitmentShares?: CommitmentShareRecord[];\n  pendingTxHashes?: string[];\n  txHashes?: string[];\n  unsignedMessages?: UnsignedMessageTss[];\n  // Only available in 'lite' version\n  unsignedTxs: UnsignedTransactionTss[]; // Should override with blockchain / sig scheme specific unsigned tx\n  // Only available in 'full' version\n  transactions?: {\n    state: TransactionState;\n    unsignedTx: UnsignedTransactionTss; // Should override with blockchain / sig specific unsigned tx\n    signatureShares: SignatureShareRecord[];\n    signedTx?: SignedTx;\n    commitmentShares?: CommitmentShareRecord[];\n  }[];\n  messages?: {\n    state: TransactionState;\n    signatureShares: SignatureShareRecord[];\n    messageRaw: string;\n    messageEncoded?: string;\n    derivationPath: string;\n    combineSigShare?: string;\n    txHash?: string;\n  }[];\n  apiVersion?: TxRequestVersion;\n  latest: boolean;\n};\n\nexport type CreateKeychainParamsBase = {\n  userGpgKey: SerializedKeyPair<string>;\n  bitgoKeychain: Keychain;\n  passphrase?: string;\n  enterprise?: string;\n  originalPasscodeEncryptionCode?: string;\n};\n\nexport type CreateBitGoKeychainParamsBase = Omit<CreateKeychainParamsBase, 'bitgoKeychain'>;\n\nexport const SignatureShareType = {\n  USER: 'user',\n  BACKUP: 'backup',\n  BITGO: 'bitgo',\n} as const;\n\nexport type SignatureShareType = (typeof SignatureShareType)[keyof typeof SignatureShareType];\n\ninterface ShareBaseRecord {\n  from: SignatureShareType;\n  to: SignatureShareType;\n  share: string;\n}\n\nexport interface SignatureShareRecord extends ShareBaseRecord {\n  vssProof?: string;\n  privateShareProof?: string;\n  publicShare?: string;\n}\n\nexport const CommitmentType = {\n  COMMITMENT: 'commitment',\n  DECOMMITMENT: 'decommitment',\n} as const;\n\nexport type CommitmentType = (typeof CommitmentType)[keyof typeof CommitmentType];\n\nexport interface CommitmentShareRecord extends ShareBaseRecord {\n  type: CommitmentType;\n}\n\nexport interface ExchangeCommitmentResponse {\n  commitmentShare: CommitmentShareRecord;\n}\n\nexport const EncryptedSignerShareType = {\n  ENCRYPTED_SIGNER_SHARE: 'encryptedSignerShare',\n  ENCRYPTED_R_SHARE: 'encryptedRShare',\n} as const;\n\nexport type EncryptedSignerShareType = (typeof EncryptedSignerShareType)[keyof typeof EncryptedSignerShareType];\n\nexport interface EncryptedSignerShareRecord extends ShareBaseRecord {\n  type: EncryptedSignerShareType;\n}\n\nexport type TSSParamsWithPrv = TSSParams & {\n  prv: string;\n  mpcv2PartyId?: 0 | 1;\n};\n\nexport type TSSParamsForMessageWithPrv = TSSParamsForMessage & {\n  prv: string;\n  mpcv2PartyId?: 0 | 1;\n};\n\nexport type BitgoPubKeyType = 'nitro' | 'onprem';\n\nexport type TSSParams = {\n  txRequest: string | TxRequest; // can be either a string or TxRequest\n  reqId: IRequestTracer;\n  apiVersion?: ApiVersion;\n};\n\nexport type TSSParamsForMessage = TSSParams & {\n  messageRaw: string;\n  messageEncoded?: string;\n  bufferToSign: Buffer;\n};\n\nexport interface BitgoHeldBackupKeyShare {\n  commonKeychain?: string;\n  id: string;\n  keyShares: ApiKeyShare[];\n}\n\nexport interface BackupKeyShare {\n  bitGoHeldKeyShares?: BitgoHeldBackupKeyShare;\n  userHeldKeyShare?: KeyShare;\n}\n\nexport interface BitgoGPGPublicKey {\n  name: string;\n  publicKey: string;\n  mpcv2PublicKey?: string;\n  enterpriseId: string;\n}\n\nexport interface MPCTx {\n  serializedTx: string;\n  scanIndex: number;\n  coin?: string;\n  signableHex?: string;\n  derivationPath?: string;\n  parsedTx?: ParsedTransaction;\n  feeInfo?: {\n    fee: number;\n    feeString: string;\n  };\n  coinSpecific?: {\n    firstValid?: number;\n    maxDuration?: number;\n    commonKeychain?: string;\n    lastScanIndex?: number;\n  };\n  // the amount recovered using WRW\n  recoveryAmount?: string;\n  // the transaction signature used for broadcasting the transaction\n  signature?: string;\n}\n\nexport interface MPCRecoveryOptions {\n  userKey?: string; // Box A\n  backupKey?: string; // Box B\n  bitgoKey: string; // Box C - this is bitgo's xpub and will be used to derive their root address\n  recoveryDestination: string;\n  walletPassphrase?: string;\n  seed?: string;\n  index?: number;\n  // the starting receive address index to scan from for WRW recovery\n  startingScanIndex?: number;\n  // the number of addresses to scan from the starting index\n  scan?: number;\n  // token contract address of the token to recover\n  tokenContractAddress?: string;\n}\n\nexport interface MPCConsolidationRecoveryOptions {\n  userKey?: string; // Box A\n  backupKey?: string; // Box B\n  bitgoKey: string; // Box C\n  walletPassphrase?: string;\n  startingScanIndex?: number; // default to 1 (inclusive)\n  endingScanIndex?: number; // default to startingScanIndex + 20 (exclusive)\n  seed?: string;\n  tokenContractAddress?: string;\n}\n\nexport interface MPCSweepTxs {\n  txRequests: RecoveryTxRequest[];\n}\n\nexport interface RecoveryTxRequest {\n  walletCoin: string;\n  transactions: MPCUnsignedTx[] | OvcTransaction[];\n}\n\nexport interface MPCUnsignedTx {\n  unsignedTx: MPCTx;\n  signatureShares: [];\n}\n\nexport interface MPCSweepRecoveryOptions {\n  signatureShares: SignatureShares[];\n}\n\ninterface SignatureShares {\n  txRequest: RecoveryTxRequest;\n  tssVersion: string;\n  ovc: Ovc[];\n}\n\ninterface OvcTransaction {\n  unsignedTx: MPCTx;\n  signatureShares: SignatureShareRecord[];\n  signatureShare: SignatureShare;\n}\n\ninterface SignatureShare {\n  from: string;\n  to: string;\n  share: string;\n  publicShare: string;\n}\n\ninterface Ovc {\n  eddsaSignature: Signature;\n}\n\nexport interface MPCTxs {\n  transactions: MPCTx[];\n  lastScanIndex: number;\n}\n\nexport interface OvcInput {\n  address: string;\n  value: number;\n  valueString: string;\n}\n\nexport interface OvcOutput {\n  address: string;\n  valueString: string;\n  coinName?: string;\n}\n\nexport type BackupGpgKey = SerializedKeyPair<string> | Key;\n\n/**\n * Common Interface for implementing signature scheme specific\n * util functions\n */\nexport interface ITssUtils<KeyShare = EDDSA.KeyShare> {\n  createBitgoHeldBackupKeyShare(\n    userGpgKey: SerializedKeyPair<string>,\n    enterprise: string | undefined\n  ): Promise<BitgoHeldBackupKeyShare>;\n  finalizeBitgoHeldBackupKeyShare(\n    keyId: string,\n    commonKeychain: string,\n    userKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    gpgKey: SerializedKeyPair<string>,\n    bitgoPublicGpgKey?: Key\n  ): Promise<BitgoHeldBackupKeyShare>;\n  createUserKeychain(params: CreateKeychainParamsBase): Promise<Keychain>;\n  createBackupKeychain(params: CreateKeychainParamsBase): Promise<Keychain>;\n  createBitgoKeychain(params: CreateBitGoKeychainParamsBase): Promise<Keychain>;\n  createKeychains(params: {\n    passphrase: string;\n    enterprise?: string;\n    originalPasscodeEncryptionCode?: string;\n    isThirdPartyBackup?: boolean;\n  }): Promise<KeychainsTriplet>;\n  signTxRequest(params: { txRequest: string | TxRequest; prv: string; reqId: IRequestTracer }): Promise<TxRequest>;\n  signTxRequestForMessage(params: TSSParams): Promise<TxRequest>;\n  signEddsaTssUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest>;\n  signEcdsaTssUsingExternalSigner(\n    params: TSSParams | TSSParamsForMessage,\n    requestType: RequestType,\n    externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction,\n    externalSignerKShareGenerator: CustomKShareGeneratingFunction,\n    externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction,\n    externalSignerSShareGenerator: CustomSShareGeneratingFunction\n  ): Promise<TxRequest>;\n  createCommitmentShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    walletPassphrase: string;\n    bitgoGpgPubKey: string;\n  }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }>;\n  createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    walletPassphrase: string;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }): Promise<{ rShare: SignShare }>;\n  createGShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare>;\n  prebuildTxWithIntent(\n    params: PrebuildTransactionWithIntentOptions,\n    apiVersion?: TxRequestVersion,\n    preview?: boolean\n  ): Promise<TxRequest>;\n  deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]>;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  sendTxRequest(txRequestId: string): Promise<any>;\n  recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest>;\n  getTxRequest(txRequestId: string): Promise<TxRequest>;\n  supportedTxRequestVersions(): TxRequestVersion[];\n}\n"]}
46
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTypes.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTypes.ts"],"names":[],"mappings":";;;AAqCA,IAAY,SAWX;AAXD,WAAY,SAAS;IACnB,oBAAO,CAAA;IACP,sCAAyB,CAAA;IACzB,oBAAO,CAAA;IACP,oBAAO,CAAA;IACP,oBAAO,CAAA;IACP,gCAAmB,CAAA;IACnB,gDAAmC,CAAA;IACnC,wCAA2B,CAAA;IAC3B,wCAA2B,CAAA;IAC3B,wCAA2B,CAAA;AAC7B,CAAC,EAXW,SAAS,yBAAT,SAAS,QAWpB;AAED,IAAY,OAGX;AAHD,WAAY,OAAO;IACjB,0BAAe,CAAA;IACf,0BAAe,CAAA;AACjB,CAAC,EAHW,OAAO,uBAAP,OAAO,QAGlB;AA4FD,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,gCAAmB,CAAA;IACnB,4BAAe,CAAA;AACjB,CAAC,EAJW,SAAS,yBAAT,SAAS,QAIpB;AAwJD,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,yCAAE,CAAA;IACF,mDAAO,CAAA;AACT,CAAC,EAHW,WAAW,2BAAX,WAAW,QAGtB;AA0DY,QAAA,kBAAkB,GAAG;IAChC,IAAI,EAAE,MAAM;IACZ,MAAM,EAAE,QAAQ;IAChB,KAAK,EAAE,OAAO;CACN,CAAC;AAgBE,QAAA,cAAc,GAAG;IAC5B,UAAU,EAAE,YAAY;IACxB,YAAY,EAAE,cAAc;CACpB,CAAC;AAYE,QAAA,wBAAwB,GAAG;IACtC,sBAAsB,EAAE,sBAAsB;IAC9C,iBAAiB,EAAE,iBAAiB;CAC5B,CAAC","sourcesContent":["import { Key, SerializedKeyPair } from 'openpgp';\nimport { IRequestTracer } from '../../../api';\nimport { KeychainsTriplet, ParsedTransaction, TransactionParams } from '../../baseCoin';\nimport { ApiKeyShare, Keychain } from '../../keychain';\nimport { ApiVersion, Memo, WalletType } from '../../wallet';\nimport { EDDSA, GShare, Signature, SignShare } from '../../../account-lib/mpc/tss';\nimport { KeyShare } from './ecdsa';\nimport { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';\nimport { TssEcdsaStep1ReturnMessage, TssEcdsaStep2ReturnMessage, TxRequestChallengeResponse } from '../../tss/types';\nimport { AShare, DShare, SShare } from '../../tss/ecdsa/types';\n\nexport type TxRequestVersion = 'full' | 'lite';\nexport interface HopParams {\n  paymentId?: string;\n  userReqSig?: string;\n  gasPriceMax?: number;\n}\n\nexport interface EIP1559FeeOptions {\n  gasLimit?: number;\n  maxFeePerGas?: number;\n  maxPriorityFeePerGas?: number;\n}\n\nexport interface FeeOption {\n  unit?: 'baseUnit' | 'cpu' | 'ram';\n  formula?: 'fixed' | 'feeRate' | 'perKB' | 'custom' | 'perVKB';\n  feeType?: 'base' | 'max' | 'tip';\n  gasLimit?: number;\n  gasPrice?: number;\n}\n\nexport interface TokenEnablement {\n  name: string;\n  address?: string; // Some chains like Solana require tokens to be enabled for specific address. If absent, we will enable it for the wallet's root address\n}\n\nexport enum ShareType {\n  R = 'R',\n  Commitment = 'commitment',\n  G = 'G',\n  S = 'S',\n  K = 'K',\n  MuDelta = 'MuDelta',\n  PaillierModulus = 'PaillierModulus',\n  MPCv2Round1 = 'MPCv2Round1',\n  MPCv2Round2 = 'MPCv2Round2',\n  MPCv2Round3 = 'MPCv2Round3',\n}\n\nexport enum MPCType {\n  EDDSA = 'eddsa',\n  ECDSA = 'ecdsa',\n}\n\nexport interface CustomPaillierModulusGetterFunction {\n  (params: { txRequest: TxRequest }): Promise<{\n    userPaillierModulus: string;\n  }>;\n}\n\nexport interface CustomKShareGeneratingFunction {\n  (params: {\n    tssParams: TSSParams | TSSParamsForMessage;\n    challenges: {\n      enterpriseChallenge: EcdsaTypes.SerializedEcdsaChallenges;\n      bitgoChallenge: TxRequestChallengeResponse;\n    };\n    requestType: RequestType;\n  }): Promise<TssEcdsaStep1ReturnMessage>;\n}\n\nexport interface CustomMuDeltaShareGeneratingFunction {\n  (params: {\n    txRequest: TxRequest;\n    aShareFromBitgo: Omit<AShare, 'ntilde' | 'h1' | 'h2'>;\n    bitgoChallenge: TxRequestChallengeResponse;\n    encryptedWShare: string;\n  }): Promise<TssEcdsaStep2ReturnMessage>;\n}\n\nexport interface CustomSShareGeneratingFunction {\n  (params: {\n    tssParams: TSSParams | TSSParamsForMessage;\n    dShareFromBitgo: DShare;\n    requestType: RequestType;\n    encryptedOShare: string;\n  }): Promise<SShare>;\n}\n\nexport interface CustomCommitmentGeneratingFunction {\n  (params: { txRequest: TxRequest; bitgoGpgPubKey?: string }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }>;\n}\n\nexport interface CustomRShareGeneratingFunction {\n  (params: { txRequest: TxRequest; encryptedUserToBitgoRShare: EncryptedSignerShareRecord }): Promise<{\n    rShare: SignShare;\n  }>;\n}\n\nexport interface CustomGShareGeneratingFunction {\n  (params: {\n    txRequest: TxRequest;\n    userToBitgoRShare: SignShare;\n    bitgoToUserRShare: SignatureShareRecord;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare>;\n}\n\nexport interface CustomMPCv2SigningRound1GeneratingFunction {\n  (params: { txRequest: TxRequest }): Promise<{\n    signatureShareRound1: SignatureShareRecord;\n    encryptedRound1Session: string;\n    userGpgPubKey: string;\n    encryptedUserGpgPrvKey: string;\n  }>;\n}\n\nexport interface CustomMPCv2SigningRound2GeneratingFunction {\n  (params: {\n    txRequest: TxRequest;\n    bitgoPublicGpgKey: string;\n    encryptedUserGpgPrvKey: string;\n    encryptedRound1Session: string;\n  }): Promise<{\n    signatureShareRound2: SignatureShareRecord;\n    encryptedRound2Session: string;\n  }>;\n}\n\nexport interface CustomMPCv2SigningRound3GeneratingFunction {\n  (params: {\n    txRequest: TxRequest;\n    bitgoPublicGpgKey: string;\n    encryptedUserGpgPrvKey: string;\n    encryptedRound2Session: string;\n  }): Promise<{\n    signatureShareRound3: SignatureShareRecord;\n  }>;\n}\n\nexport enum TokenType {\n  ERC721 = 'ERC721',\n  ERC1155 = 'ERC1155',\n  ERC20 = 'ERC20',\n}\nexport interface TokenTransferRecipientParams {\n  tokenType: TokenType;\n  tokenQuantity: string;\n  tokenContractAddress?: string;\n  tokenName?: string;\n  tokenId?: string;\n  decimalPlaces?: number;\n}\ninterface IntentOptionsBase {\n  reqId: IRequestTracer;\n  intentType: string;\n  sequenceId?: string;\n  isTss?: boolean;\n  comment?: string;\n  memo?: Memo;\n  custodianTransactionId?: string;\n  custodianMessageId?: string;\n}\n\nexport interface IntentOptionsForMessage extends IntentOptionsBase {\n  messageRaw: string;\n  messageEncoded?: string;\n}\n\nexport interface IntentOptionsForTypedData extends IntentOptionsBase {\n  typedDataRaw: string;\n  typedDataEncoded?: string;\n}\n\nexport interface PrebuildTransactionWithIntentOptions extends IntentOptionsBase {\n  recipients?: {\n    address: string;\n    amount: string | number;\n    data?: string;\n    tokenName?: string;\n    tokenData?: TokenTransferRecipientParams;\n  }[];\n  tokenName?: string;\n  enableTokens?: TokenEnablement[];\n  nonce?: string;\n  selfSend?: boolean;\n  feeOptions?: FeeOption | EIP1559FeeOptions;\n  hopParams?: HopParams;\n  lowFeeTxid?: string;\n  custodianTransactionId?: string;\n  receiveAddress?: string;\n  unspents?: string[];\n  /**\n   * The receive address from which funds will be withdrawn.\n   * This feature is supported only for specific coins, like ADA.\n   */\n  senderAddress?: string;\n}\nexport interface IntentRecipient {\n  address: {\n    address: string;\n  };\n  amount: {\n    value: string | number;\n    symbol: string;\n  };\n  data?: string;\n  tokenData?: TokenTransferRecipientParams;\n}\ninterface PopulatedIntentBase {\n  intentType: string;\n  sequenceId?: string;\n  comment?: string;\n  memo?: string;\n  isTss?: boolean;\n}\n\nexport interface PopulatedIntentForMessageSigning extends PopulatedIntentBase {\n  messageRaw: string;\n  messageEncoded: string;\n  custodianMessageId?: string;\n}\n\nexport interface PopulatedIntentForTypedDataSigning extends PopulatedIntentBase {\n  messageRaw: string;\n  messageEncoded: string;\n  custodianMessageId?: string;\n}\n\nexport interface PopulatedIntent extends PopulatedIntentBase {\n  recipients?: IntentRecipient[];\n  nonce?: string;\n  token?: string;\n  enableTokens?: TokenEnablement[];\n  unspents?: string[];\n  /**\n   * The receive address from which funds will be withdrawn.\n   * This feature is supported only for specific coins, like ADA.\n   */\n  senderAddress?: string;\n  // ETH & ETH-like params\n  selfSend?: boolean;\n  feeOptions?: FeeOption | EIP1559FeeOptions;\n  hopParams?: HopParams;\n  txid?: string;\n  receiveAddress?: string;\n  custodianTransactionId?: string;\n  custodianMessageId?: string;\n}\n\nexport type TxRequestState =\n  | 'pendingCommitment'\n  | 'pendingApproval'\n  | 'canceled'\n  | 'rejected'\n  | 'initialized'\n  | 'pendingDelivery'\n  | 'delivered'\n  | 'pendingUserSignature'\n  | 'signed';\n\nexport type TransactionState =\n  | 'initialized'\n  | 'pendingCommitment'\n  | 'pendingSignature'\n  | 'signed'\n  | 'held'\n  | 'delivered'\n  | 'invalidSignature'\n  | 'rejected';\n\n// Type used to sign a TSS transaction\nexport type SignableTransaction = {\n  // unsigned transaction in broadcast format\n  serializedTxHex: string;\n  // portion of a transaction used to generate a signature\n  signableHex: string;\n};\n\nexport type UnsignedTransactionTss = SignableTransaction & {\n  // derivation path of the signer\n  derivationPath: string;\n  // transaction fees\n  feeInfo?: {\n    fee: number;\n    feeString: string;\n  };\n  coinSpecific?: Record<string, unknown>;\n  parsedTx?: unknown;\n};\n\nexport type UnsignedMessageTss = {\n  derivationPath: string;\n  message: string;\n};\n\nexport enum RequestType {\n  tx,\n  message,\n}\nexport type SignedTx = {\n  id: string;\n  tx: string;\n  publicKey?: string;\n  signature?: string;\n};\n\nexport type TxRequest = {\n  txRequestId: string;\n  walletId: string;\n  walletType: WalletType;\n  version: number;\n  enterpriseId?: string;\n  state: TxRequestState;\n  date: string;\n  userId: string;\n  intent: unknown; // Should override with sig scheme specific intent\n  pendingApprovalId?: string;\n  policiesChecked: boolean;\n  signatureShares?: SignatureShareRecord[];\n  commitmentShares?: CommitmentShareRecord[];\n  pendingTxHashes?: string[];\n  txHashes?: string[];\n  unsignedMessages?: UnsignedMessageTss[];\n  // Only available in 'lite' version\n  unsignedTxs: UnsignedTransactionTss[]; // Should override with blockchain / sig scheme specific unsigned tx\n  // Only available in 'full' version\n  transactions?: {\n    state: TransactionState;\n    unsignedTx: UnsignedTransactionTss; // Should override with blockchain / sig specific unsigned tx\n    signatureShares: SignatureShareRecord[];\n    signedTx?: SignedTx;\n    commitmentShares?: CommitmentShareRecord[];\n  }[];\n  messages?: {\n    state: TransactionState;\n    signatureShares: SignatureShareRecord[];\n    messageRaw: string;\n    messageEncoded?: string;\n    derivationPath: string;\n    combineSigShare?: string;\n    txHash?: string;\n  }[];\n  apiVersion?: TxRequestVersion;\n  latest: boolean;\n};\n\nexport type CreateKeychainParamsBase = {\n  userGpgKey: SerializedKeyPair<string>;\n  bitgoKeychain: Keychain;\n  passphrase?: string;\n  enterprise?: string;\n  originalPasscodeEncryptionCode?: string;\n};\n\nexport type CreateBitGoKeychainParamsBase = Omit<CreateKeychainParamsBase, 'bitgoKeychain'>;\n\nexport const SignatureShareType = {\n  USER: 'user',\n  BACKUP: 'backup',\n  BITGO: 'bitgo',\n} as const;\n\nexport type SignatureShareType = (typeof SignatureShareType)[keyof typeof SignatureShareType];\n\ninterface ShareBaseRecord {\n  from: SignatureShareType;\n  to: SignatureShareType;\n  share: string;\n}\n\nexport interface SignatureShareRecord extends ShareBaseRecord {\n  vssProof?: string;\n  privateShareProof?: string;\n  publicShare?: string;\n}\n\nexport const CommitmentType = {\n  COMMITMENT: 'commitment',\n  DECOMMITMENT: 'decommitment',\n} as const;\n\nexport type CommitmentType = (typeof CommitmentType)[keyof typeof CommitmentType];\n\nexport interface CommitmentShareRecord extends ShareBaseRecord {\n  type: CommitmentType;\n}\n\nexport interface ExchangeCommitmentResponse {\n  commitmentShare: CommitmentShareRecord;\n}\n\nexport const EncryptedSignerShareType = {\n  ENCRYPTED_SIGNER_SHARE: 'encryptedSignerShare',\n  ENCRYPTED_R_SHARE: 'encryptedRShare',\n} as const;\n\nexport type EncryptedSignerShareType = (typeof EncryptedSignerShareType)[keyof typeof EncryptedSignerShareType];\n\nexport interface EncryptedSignerShareRecord extends ShareBaseRecord {\n  type: EncryptedSignerShareType;\n}\n\nexport type TSSParamsWithPrv = TSSParams & {\n  prv: string;\n  mpcv2PartyId?: 0 | 1;\n};\n\nexport type TSSParamsForMessageWithPrv = TSSParamsForMessage & {\n  prv: string;\n  mpcv2PartyId?: 0 | 1;\n};\n\nexport type BitgoPubKeyType = 'nitro' | 'onprem';\n\nexport type TSSParams = {\n  txRequest: string | TxRequest; // can be either a string or TxRequest\n  reqId: IRequestTracer;\n  apiVersion?: ApiVersion;\n  txParams?: TransactionParams;\n};\n\nexport type TSSParamsForMessage = TSSParams & {\n  messageRaw: string;\n  messageEncoded?: string;\n  bufferToSign: Buffer;\n};\n\nexport interface BitgoHeldBackupKeyShare {\n  commonKeychain?: string;\n  id: string;\n  keyShares: ApiKeyShare[];\n}\n\nexport interface BackupKeyShare {\n  bitGoHeldKeyShares?: BitgoHeldBackupKeyShare;\n  userHeldKeyShare?: KeyShare;\n}\n\nexport interface BitgoGPGPublicKey {\n  name: string;\n  publicKey: string;\n  mpcv2PublicKey?: string;\n  enterpriseId: string;\n}\n\nexport interface MPCTx {\n  serializedTx: string;\n  scanIndex: number;\n  coin?: string;\n  signableHex?: string;\n  derivationPath?: string;\n  parsedTx?: ParsedTransaction;\n  feeInfo?: {\n    fee: number;\n    feeString: string;\n  };\n  coinSpecific?: {\n    firstValid?: number;\n    maxDuration?: number;\n    commonKeychain?: string;\n    lastScanIndex?: number;\n  };\n  // the amount recovered using WRW\n  recoveryAmount?: string;\n  // the transaction signature used for broadcasting the transaction\n  signature?: string;\n}\n\nexport interface MPCRecoveryOptions {\n  userKey?: string; // Box A\n  backupKey?: string; // Box B\n  bitgoKey: string; // Box C - this is bitgo's xpub and will be used to derive their root address\n  recoveryDestination: string;\n  walletPassphrase?: string;\n  seed?: string;\n  index?: number;\n  // the starting receive address index to scan from for WRW recovery\n  startingScanIndex?: number;\n  // the number of addresses to scan from the starting index\n  scan?: number;\n  // token contract address of the token to recover\n  tokenContractAddress?: string;\n}\n\nexport interface MPCConsolidationRecoveryOptions {\n  userKey?: string; // Box A\n  backupKey?: string; // Box B\n  bitgoKey: string; // Box C\n  walletPassphrase?: string;\n  startingScanIndex?: number; // default to 1 (inclusive)\n  endingScanIndex?: number; // default to startingScanIndex + 20 (exclusive)\n  seed?: string;\n  tokenContractAddress?: string;\n}\n\nexport interface MPCSweepTxs {\n  txRequests: RecoveryTxRequest[];\n}\n\nexport interface RecoveryTxRequest {\n  walletCoin: string;\n  transactions: MPCUnsignedTx[] | OvcTransaction[];\n}\n\nexport interface MPCUnsignedTx {\n  unsignedTx: MPCTx;\n  signatureShares: [];\n}\n\nexport interface MPCSweepRecoveryOptions {\n  signatureShares: SignatureShares[];\n}\n\ninterface SignatureShares {\n  txRequest: RecoveryTxRequest;\n  tssVersion: string;\n  ovc: Ovc[];\n}\n\ninterface OvcTransaction {\n  unsignedTx: MPCTx;\n  signatureShares: SignatureShareRecord[];\n  signatureShare: SignatureShare;\n}\n\ninterface SignatureShare {\n  from: string;\n  to: string;\n  share: string;\n  publicShare: string;\n}\n\ninterface Ovc {\n  eddsaSignature: Signature;\n}\n\nexport interface MPCTxs {\n  transactions: MPCTx[];\n  lastScanIndex: number;\n}\n\nexport interface OvcInput {\n  address: string;\n  value: number;\n  valueString: string;\n}\n\nexport interface OvcOutput {\n  address: string;\n  valueString: string;\n  coinName?: string;\n}\n\nexport type BackupGpgKey = SerializedKeyPair<string> | Key;\n\n/**\n * Common Interface for implementing signature scheme specific\n * util functions\n */\nexport interface ITssUtils<KeyShare = EDDSA.KeyShare> {\n  createBitgoHeldBackupKeyShare(\n    userGpgKey: SerializedKeyPair<string>,\n    enterprise: string | undefined\n  ): Promise<BitgoHeldBackupKeyShare>;\n  finalizeBitgoHeldBackupKeyShare(\n    keyId: string,\n    commonKeychain: string,\n    userKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    gpgKey: SerializedKeyPair<string>,\n    bitgoPublicGpgKey?: Key\n  ): Promise<BitgoHeldBackupKeyShare>;\n  createUserKeychain(params: CreateKeychainParamsBase): Promise<Keychain>;\n  createBackupKeychain(params: CreateKeychainParamsBase): Promise<Keychain>;\n  createBitgoKeychain(params: CreateBitGoKeychainParamsBase): Promise<Keychain>;\n  createKeychains(params: {\n    passphrase: string;\n    enterprise?: string;\n    originalPasscodeEncryptionCode?: string;\n    isThirdPartyBackup?: boolean;\n  }): Promise<KeychainsTriplet>;\n  signTxRequest(params: { txRequest: string | TxRequest; prv: string; reqId: IRequestTracer }): Promise<TxRequest>;\n  signTxRequestForMessage(params: TSSParams): Promise<TxRequest>;\n  signEddsaTssUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest>;\n  signEcdsaTssUsingExternalSigner(\n    params: TSSParams | TSSParamsForMessage,\n    requestType: RequestType,\n    externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction,\n    externalSignerKShareGenerator: CustomKShareGeneratingFunction,\n    externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction,\n    externalSignerSShareGenerator: CustomSShareGeneratingFunction\n  ): Promise<TxRequest>;\n  createCommitmentShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    walletPassphrase: string;\n    bitgoGpgPubKey: string;\n  }): Promise<{\n    userToBitgoCommitment: CommitmentShareRecord;\n    encryptedSignerShare: EncryptedSignerShareRecord;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }>;\n  createRShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    walletPassphrase: string;\n    encryptedUserToBitgoRShare: EncryptedSignerShareRecord;\n  }): Promise<{ rShare: SignShare }>;\n  createGShareFromTxRequest(params: {\n    txRequest: TxRequest;\n    prv: string;\n    bitgoToUserRShare: SignatureShareRecord;\n    userToBitgoRShare: SignShare;\n    bitgoToUserCommitment: CommitmentShareRecord;\n  }): Promise<GShare>;\n  prebuildTxWithIntent(\n    params: PrebuildTransactionWithIntentOptions,\n    apiVersion?: TxRequestVersion,\n    preview?: boolean\n  ): Promise<TxRequest>;\n  deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]>;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  sendTxRequest(txRequestId: string): Promise<any>;\n  recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest>;\n  getTxRequest(txRequestId: string): Promise<TxRequest>;\n  supportedTxRequestVersions(): TxRequestVersion[];\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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"}