@bitgo-beta/sdk-core 8.2.1-beta.76 → 8.2.1-beta.77

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.
@@ -1,6 +1,21 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EncryptedSignerShareType = exports.CommitmentType = exports.SignatureShareType = exports.RequestType = exports.TokenType = void 0;
3
+ exports.EncryptedSignerShareType = exports.CommitmentType = exports.SignatureShareType = exports.RequestType = exports.TokenType = exports.MPCType = exports.ShareType = void 0;
4
+ var ShareType;
5
+ (function (ShareType) {
6
+ ShareType["R"] = "R";
7
+ ShareType["Commitment"] = "commitment";
8
+ ShareType["G"] = "G";
9
+ ShareType["S"] = "S";
10
+ ShareType["K"] = "K";
11
+ ShareType["MuDelta"] = "MuDelta";
12
+ ShareType["PaillierModulus"] = "PaillierModulus";
13
+ })(ShareType = exports.ShareType || (exports.ShareType = {}));
14
+ var MPCType;
15
+ (function (MPCType) {
16
+ MPCType["EDDSA"] = "eddsa";
17
+ MPCType["ECDSA"] = "ecdsa";
18
+ })(MPCType = exports.MPCType || (exports.MPCType = {}));
4
19
  var TokenType;
5
20
  (function (TokenType) {
6
21
  TokenType["ERC721"] = "ERC721";
@@ -27,4 +42,4 @@ var EncryptedSignerShareType;
27
42
  EncryptedSignerShareType["ENCRYPTED_SIGNER_SHARE"] = "encryptedSignerShare";
28
43
  EncryptedSignerShareType["ENCRYPTED_R_SHARE"] = "encryptedRShare";
29
44
  })(EncryptedSignerShareType = exports.EncryptedSignerShareType || (exports.EncryptedSignerShareType = {}));
30
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTypes.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTypes.ts"],"names":[],"mappings":";;;AAyDA,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,gCAAmB,CAAA;IACnB,4BAAe,CAAA;AACjB,CAAC,EAJW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAIpB;AA4ID,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,yCAAE,CAAA;IACF,mDAAO,CAAA;AACT,CAAC,EAHW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAGtB;AAgDD,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,mCAAa,CAAA;IACb,uCAAiB,CAAA;IACjB,qCAAe,CAAA;AACjB,CAAC,EAJW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAI7B;AAcD,IAAY,cAEX;AAFD,WAAY,cAAc;IACxB,2CAAyB,CAAA;AAC3B,CAAC,EAFW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAEzB;AASD,IAAY,wBAGX;AAHD,WAAY,wBAAwB;IAClC,2EAA+C,CAAA;IAC/C,iEAAqC,CAAA;AACvC,CAAC,EAHW,wBAAwB,GAAxB,gCAAwB,KAAxB,gCAAwB,QAGnC","sourcesContent":["import { Key, SerializedKeyPair } from 'openpgp';\nimport { IRequestTracer } from '../../../api';\nimport { KeychainsTriplet } from '../../baseCoin';\nimport { ApiKeyShare, Keychain } from '../../keychain';\nimport { ApiVersion, Memo, WalletType } from '../../wallet';\nimport { EDDSA, GShare, SignShare } from '../../../account-lib/mpc/tss';\nimport { KeyShare } from './ecdsa';\nimport { Hash } from 'crypto';\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 interface CustomCommitmentGeneratingFunction {\n  (params: { txRequest: TxRequest }): 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}\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}\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  // 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}\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    commitmentShares?: CommitmentShareRecord[];\n  }[];\n  messages?: {\n    state: TransactionState;\n    signatureShares: SignatureShareRecord[];\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 enum SignatureShareType {\n  USER = 'user',\n  BACKUP = 'backup',\n  BITGO = 'bitgo',\n}\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 enum CommitmentType {\n  COMMITMENT = 'commitment',\n}\nexport interface CommitmentShareRecord extends ShareBaseRecord {\n  type: CommitmentType;\n}\n\nexport interface ExchangeCommitmentResponse {\n  commitmentShare: CommitmentShareRecord;\n}\n\nexport enum EncryptedSignerShareType {\n  ENCRYPTED_SIGNER_SHARE = 'encryptedSignerShare',\n  ENCRYPTED_R_SHARE = 'encryptedRShare',\n}\nexport interface EncryptedSignerShareRecord extends ShareBaseRecord {\n  type: EncryptedSignerShareType;\n}\n\nexport type TSSParams = {\n  txRequest: string | TxRequest; // can be either a string or TxRequest\n  prv: string;\n  reqId: IRequestTracer;\n  apiVersion?: ApiVersion;\n  hash?: Hash;\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  enterpriseId: 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  signUsingExternalSigner(\n    txRequest: string | TxRequest,\n    externalSignerCommitmentGenerator: CustomCommitmentGeneratingFunction,\n    externalSignerRShareGenerator: CustomRShareGeneratingFunction,\n    externalSignerGShareGenerator: CustomGShareGeneratingFunction\n  ): Promise<TxRequest>;\n  createCommitmentShareFromTxRequest(params: { txRequest: TxRequest; prv: string; walletPassphrase: string }): 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}\n"]}
45
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTypes.js","sourceRoot":"","sources":["../../../../../src/bitgo/utils/tss/baseTypes.ts"],"names":[],"mappings":";;;AAsCA,IAAY,SAQX;AARD,WAAY,SAAS;IACnB,oBAAO,CAAA;IACP,sCAAyB,CAAA;IACzB,oBAAO,CAAA;IACP,oBAAO,CAAA;IACP,oBAAO,CAAA;IACP,gCAAmB,CAAA;IACnB,gDAAmC,CAAA;AACrC,CAAC,EARW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAQpB;AAED,IAAY,OAGX;AAHD,WAAY,OAAO;IACjB,0BAAe,CAAA;IACf,0BAAe,CAAA;AACjB,CAAC,EAHW,OAAO,GAAP,eAAO,KAAP,eAAO,QAGlB;AA2DD,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,gCAAmB,CAAA;IACnB,4BAAe,CAAA;AACjB,CAAC,EAJW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAIpB;AA4ID,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,yCAAE,CAAA;IACF,mDAAO,CAAA;AACT,CAAC,EAHW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAGtB;AAgDD,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,mCAAa,CAAA;IACb,uCAAiB,CAAA;IACjB,qCAAe,CAAA;AACjB,CAAC,EAJW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAI7B;AAcD,IAAY,cAEX;AAFD,WAAY,cAAc;IACxB,2CAAyB,CAAA;AAC3B,CAAC,EAFW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAEzB;AASD,IAAY,wBAGX;AAHD,WAAY,wBAAwB;IAClC,2EAA+C,CAAA;IAC/C,iEAAqC,CAAA;AACvC,CAAC,EAHW,wBAAwB,GAAxB,gCAAwB,KAAxB,gCAAwB,QAGnC","sourcesContent":["import { Key, SerializedKeyPair } from 'openpgp';\nimport { IRequestTracer } from '../../../api';\nimport { KeychainsTriplet } from '../../baseCoin';\nimport { ApiKeyShare, Keychain } from '../../keychain';\nimport { ApiVersion, Memo, WalletType } from '../../wallet';\nimport { EDDSA, GShare, SignShare } from '../../../account-lib/mpc/tss';\nimport { KeyShare } from './ecdsa';\nimport { Hash } from 'crypto';\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}\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 }): 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}\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}\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  // 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}\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    commitmentShares?: CommitmentShareRecord[];\n  }[];\n  messages?: {\n    state: TransactionState;\n    signatureShares: SignatureShareRecord[];\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 enum SignatureShareType {\n  USER = 'user',\n  BACKUP = 'backup',\n  BITGO = 'bitgo',\n}\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 enum CommitmentType {\n  COMMITMENT = 'commitment',\n}\nexport interface CommitmentShareRecord extends ShareBaseRecord {\n  type: CommitmentType;\n}\n\nexport interface ExchangeCommitmentResponse {\n  commitmentShare: CommitmentShareRecord;\n}\n\nexport enum EncryptedSignerShareType {\n  ENCRYPTED_SIGNER_SHARE = 'encryptedSignerShare',\n  ENCRYPTED_R_SHARE = 'encryptedRShare',\n}\nexport interface EncryptedSignerShareRecord extends ShareBaseRecord {\n  type: EncryptedSignerShareType;\n}\n\nexport type TSSParams = {\n  txRequest: string | TxRequest; // can be either a string or TxRequest\n  prv: string;\n  reqId: IRequestTracer;\n  apiVersion?: ApiVersion;\n  hash?: Hash;\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  enterpriseId: 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: { txRequest: TxRequest; prv: string; walletPassphrase: string }): 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}\n"]}
@@ -6,11 +6,11 @@ import { ApiKeyShare, Keychain } from '../../../keychain';
6
6
  import { IBaseCoin, KeychainsTriplet } from '../../../baseCoin';
7
7
  import baseTSSUtils from '../baseTSSUtils';
8
8
  import { BitGoProofSignatures, CreateEcdsaBitGoKeychainParams, CreateEcdsaKeychainParams, GetBitGoChallengesApi, KeyShare } from './types';
9
- import { BackupGpgKey, BackupKeyShare, BitgoHeldBackupKeyShare, RequestType, TSSParams, TSSParamsForMessage, TxRequest } from '../baseTypes';
10
- import { EncryptedNShare } from '../../../tss/ecdsa/types';
9
+ import { BackupGpgKey, BackupKeyShare, BitgoHeldBackupKeyShare, CustomKShareGeneratingFunction, CustomMuDeltaShareGeneratingFunction, CustomPaillierModulusGetterFunction, CustomSShareGeneratingFunction, RequestType, TSSParams, TSSParamsForMessage, TxRequest } from '../baseTypes';
10
+ import { AShare, DShare, EncryptedNShare, SShare } from '../../../tss/ecdsa/types';
11
11
  import { BitGoBase } from '../../../bitgoBase';
12
12
  import { BackupProvider, IWallet } from '../../../wallet';
13
- import { TxRequestChallengeResponse } from '../../../tss/types';
13
+ import { TssEcdsaStep1ReturnMessage, TssEcdsaStep2ReturnMessage, TxRequestChallengeResponse } from '../../../tss/types';
14
14
  /** @inheritdoc */
15
15
  export declare class EcdsaUtils extends baseTSSUtils<KeyShare> {
16
16
  private bitgoPublicGpgKey;
@@ -64,6 +64,37 @@ export declare class EcdsaUtils extends baseTSSUtils<KeyShare> {
64
64
  createUserKeychainFromThirdPartyBackup(userGpgKey: openpgp.SerializedKeyPair<string>, bitgoPublicGpgKey: Key, thirdPartyBackupPublicGpgKey: Key, userKeyShare: KeyShare, thirdPartybackupKeyShares: ApiKeyShare[], bitgoKeychain: Keychain, passphrase: string, originalPasscodeEncryptionCode?: string): Promise<Keychain>;
65
65
  /** @inheritdoc */
66
66
  createParticipantKeychain(userGpgKey: openpgp.SerializedKeyPair<string>, userLocalBackupGpgKey: openpgp.SerializedKeyPair<string>, bitgoPublicGpgKey: Key, recipientIndex: number, userKeyShare: KeyShare, backupKeyShare: KeyShare, bitgoKeychain: Keychain, passphrase: string, originalPasscodeEncryptionCode?: string): Promise<Keychain>;
67
+ private createTssEcdsaStep1SigningMaterial;
68
+ private createTssEcdsaStep2SigningMaterial;
69
+ getOfflineSignerPaillierModulus(params: {
70
+ prv: string;
71
+ }): {
72
+ userPaillierModulus: string;
73
+ };
74
+ createOfflineKShare(params: {
75
+ tssParams: TSSParams | TSSParamsForMessage;
76
+ challenges: {
77
+ enterpriseChallenge: EcdsaTypes.SerializedEcdsaChallenges;
78
+ bitgoChallenge: TxRequestChallengeResponse;
79
+ };
80
+ requestType: RequestType;
81
+ prv: string;
82
+ walletPassphrase: string;
83
+ }): Promise<TssEcdsaStep1ReturnMessage>;
84
+ createOfflineMuDeltaShare(params: {
85
+ aShareFromBitgo: Omit<AShare, 'ntilde' | 'h1' | 'h2'>;
86
+ bitgoChallenge: TxRequestChallengeResponse;
87
+ encryptedWShare: string;
88
+ walletPassphrase: string;
89
+ }): Promise<TssEcdsaStep2ReturnMessage>;
90
+ createOfflineSShare(params: {
91
+ tssParams: TSSParams | TSSParamsForMessage;
92
+ dShareFromBitgo: DShare;
93
+ requestType: RequestType;
94
+ encryptedOShare: string;
95
+ walletPassphrase: string;
96
+ }): Promise<SShare>;
97
+ signEcdsaTssUsingExternalSigner(params: TSSParams | TSSParamsForMessage, requestType: RequestType, externalSignerPaillierModulusGetter: CustomPaillierModulusGetterFunction, externalSignerKShareGenerator: CustomKShareGeneratingFunction, externalSignerMuDeltaShareGenerator: CustomMuDeltaShareGeneratingFunction, externalSignerSShareGenerator: CustomSShareGeneratingFunction): Promise<TxRequest>;
67
98
  /**
68
99
  * Gets signing key, txRequestResolved and txRequestId
69
100
  * @param {string | TxRequest} params.txRequest - transaction request object or id
@@ -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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"}