utxo-lib 1.0.9 → 1.1.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (101) hide show
  1. package/README.md +19 -16
  2. package/dist/src/address.d.ts.map +1 -1
  3. package/dist/src/address.js +11 -1
  4. package/dist/src/addressFormat.d.ts +1 -1
  5. package/dist/src/addressFormat.d.ts.map +1 -1
  6. package/dist/src/addressFormat.js +1 -1
  7. package/dist/src/bitgo/Musig2.d.ts +115 -17
  8. package/dist/src/bitgo/Musig2.d.ts.map +1 -1
  9. package/dist/src/bitgo/Musig2.js +283 -100
  10. package/dist/src/bitgo/PsbtUtil.d.ts +59 -0
  11. package/dist/src/bitgo/PsbtUtil.d.ts.map +1 -0
  12. package/dist/src/bitgo/PsbtUtil.js +92 -0
  13. package/dist/src/bitgo/UtxoPsbt.d.ts +180 -47
  14. package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -1
  15. package/dist/src/bitgo/UtxoPsbt.js +673 -113
  16. package/dist/src/bitgo/UtxoTransaction.js +2 -2
  17. package/dist/src/bitgo/bitcoincash/address.js +2 -2
  18. package/dist/src/bitgo/index.d.ts +11 -0
  19. package/dist/src/bitgo/index.d.ts.map +1 -1
  20. package/dist/src/bitgo/index.js +6 -2
  21. package/dist/src/bitgo/legacysafe/index.d.ts +15 -0
  22. package/dist/src/bitgo/legacysafe/index.d.ts.map +1 -0
  23. package/dist/src/bitgo/legacysafe/index.js +61 -0
  24. package/dist/src/bitgo/litecoin/LitecoinPsbt.d.ts +10 -0
  25. package/dist/src/bitgo/litecoin/LitecoinPsbt.d.ts.map +1 -0
  26. package/dist/src/bitgo/litecoin/LitecoinPsbt.js +17 -0
  27. package/dist/src/bitgo/litecoin/LitecoinTransaction.d.ts +16 -0
  28. package/dist/src/bitgo/litecoin/LitecoinTransaction.d.ts.map +1 -0
  29. package/dist/src/bitgo/litecoin/LitecoinTransaction.js +46 -0
  30. package/dist/src/bitgo/litecoin/LitecoinTransactionBuilder.d.ts +10 -0
  31. package/dist/src/bitgo/litecoin/LitecoinTransactionBuilder.d.ts.map +1 -0
  32. package/dist/src/bitgo/litecoin/LitecoinTransactionBuilder.js +15 -0
  33. package/dist/src/bitgo/litecoin/index.d.ts +4 -0
  34. package/dist/src/bitgo/litecoin/index.d.ts.map +1 -0
  35. package/dist/src/bitgo/litecoin/index.js +16 -0
  36. package/dist/src/bitgo/outputScripts.d.ts +3 -1
  37. package/dist/src/bitgo/outputScripts.d.ts.map +1 -1
  38. package/dist/src/bitgo/outputScripts.js +20 -12
  39. package/dist/src/bitgo/parseInput.d.ts +49 -20
  40. package/dist/src/bitgo/parseInput.d.ts.map +1 -1
  41. package/dist/src/bitgo/parseInput.js +110 -26
  42. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +1 -1
  43. package/dist/src/bitgo/psbt/fromHalfSigned.js +9 -6
  44. package/dist/src/bitgo/psbt/scriptTypes.js +3 -3
  45. package/dist/src/bitgo/signature.d.ts +3 -3
  46. package/dist/src/bitgo/signature.d.ts.map +1 -1
  47. package/dist/src/bitgo/signature.js +48 -16
  48. package/dist/src/bitgo/transaction.d.ts +18 -3
  49. package/dist/src/bitgo/transaction.d.ts.map +1 -1
  50. package/dist/src/bitgo/transaction.js +28 -15
  51. package/dist/src/bitgo/types.d.ts +2 -0
  52. package/dist/src/bitgo/types.d.ts.map +1 -1
  53. package/dist/src/bitgo/types.js +1 -1
  54. package/dist/src/bitgo/wallet/Psbt.d.ts +104 -12
  55. package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -1
  56. package/dist/src/bitgo/wallet/Psbt.js +288 -70
  57. package/dist/src/bitgo/wallet/Unspent.d.ts +28 -0
  58. package/dist/src/bitgo/wallet/Unspent.d.ts.map +1 -1
  59. package/dist/src/bitgo/wallet/Unspent.js +173 -68
  60. package/dist/src/bitgo/wallet/WalletOutput.d.ts +17 -1
  61. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -1
  62. package/dist/src/bitgo/wallet/WalletOutput.js +64 -23
  63. package/dist/src/bitgo/wallet/chains.d.ts +2 -2
  64. package/dist/src/bitgo/wallet/chains.d.ts.map +1 -1
  65. package/dist/src/bitgo/wallet/chains.js +1 -1
  66. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +0 -1
  67. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -1
  68. package/dist/src/bitgo/zcash/ZcashPsbt.js +8 -15
  69. package/dist/src/bitgo/zcash/ZcashTransaction.js +2 -2
  70. package/dist/src/musig.d.ts +0 -1
  71. package/dist/src/musig.d.ts.map +1 -1
  72. package/dist/src/musig.js +15 -29
  73. package/dist/src/networks.d.ts +1 -2
  74. package/dist/src/networks.d.ts.map +1 -1
  75. package/dist/src/networks.js +22 -29
  76. package/dist/src/noble_ecc.d.ts +1 -1
  77. package/dist/src/noble_ecc.d.ts.map +1 -1
  78. package/dist/src/noble_ecc.js +9 -5
  79. package/dist/src/payments/p2tr.d.ts.map +1 -1
  80. package/dist/src/payments/p2tr.js +25 -15
  81. package/dist/src/payments/p2tr_ns.js +3 -2
  82. package/dist/src/taproot.d.ts +16 -0
  83. package/dist/src/taproot.d.ts.map +1 -1
  84. package/dist/src/taproot.js +46 -3
  85. package/dist/src/testutil/index.d.ts +2 -0
  86. package/dist/src/testutil/index.d.ts.map +1 -1
  87. package/dist/src/testutil/index.js +3 -1
  88. package/dist/src/testutil/keys.d.ts +3 -0
  89. package/dist/src/testutil/keys.d.ts.map +1 -1
  90. package/dist/src/testutil/keys.js +17 -2
  91. package/dist/src/testutil/mock.d.ts +1 -1
  92. package/dist/src/testutil/mock.d.ts.map +1 -1
  93. package/dist/src/testutil/mock.js +12 -4
  94. package/dist/src/testutil/psbt.d.ts +89 -0
  95. package/dist/src/testutil/psbt.d.ts.map +1 -0
  96. package/dist/src/testutil/psbt.js +150 -0
  97. package/dist/src/testutil/transaction.d.ts +70 -0
  98. package/dist/src/testutil/transaction.d.ts.map +1 -0
  99. package/dist/src/testutil/transaction.js +107 -0
  100. package/dist/src/transaction_builder.js +2 -2
  101. package/package.json +7 -6
@@ -0,0 +1,92 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.withUnsafeNonSegwit = exports.isPsbt = exports.isPsbtInputFinalized = exports.getPsbtInputSignatureCount = exports.getPsbtInputProprietaryKeyVals = exports.ProprietaryKeySubtype = exports.PSBT_PROPRIETARY_IDENTIFIER = void 0;
4
+ const proprietaryKeyVal_1 = require("bip174/src/lib/proprietaryKeyVal");
5
+ /**
6
+ * bitgo proprietary key identifier
7
+ */
8
+ exports.PSBT_PROPRIETARY_IDENTIFIER = 'BITGO';
9
+ /**
10
+ * subtype for proprietary keys that bitgo uses
11
+ */
12
+ var ProprietaryKeySubtype;
13
+ (function (ProprietaryKeySubtype) {
14
+ ProprietaryKeySubtype[ProprietaryKeySubtype["ZEC_CONSENSUS_BRANCH_ID"] = 0] = "ZEC_CONSENSUS_BRANCH_ID";
15
+ ProprietaryKeySubtype[ProprietaryKeySubtype["MUSIG2_PARTICIPANT_PUB_KEYS"] = 1] = "MUSIG2_PARTICIPANT_PUB_KEYS";
16
+ ProprietaryKeySubtype[ProprietaryKeySubtype["MUSIG2_PUB_NONCE"] = 2] = "MUSIG2_PUB_NONCE";
17
+ ProprietaryKeySubtype[ProprietaryKeySubtype["MUSIG2_PARTIAL_SIG"] = 3] = "MUSIG2_PARTIAL_SIG";
18
+ })(ProprietaryKeySubtype = exports.ProprietaryKeySubtype || (exports.ProprietaryKeySubtype = {}));
19
+ /**
20
+ * Search any data from psbt proprietary key value against keydata.
21
+ * Default identifierEncoding is utf-8 for identifier.
22
+ */
23
+ function getPsbtInputProprietaryKeyVals(input, keySearch) {
24
+ var _a;
25
+ if (!((_a = input.unknownKeyVals) === null || _a === void 0 ? void 0 : _a.length)) {
26
+ return [];
27
+ }
28
+ if (keySearch && keySearch.subtype === undefined && Buffer.isBuffer(keySearch.keydata)) {
29
+ throw new Error('invalid proprietary key search filter combination. subtype is required');
30
+ }
31
+ const keyVals = input.unknownKeyVals.map(({ key, value }, i) => {
32
+ return { key: proprietaryKeyVal_1.decodeProprietaryKey(key), value };
33
+ });
34
+ return keyVals.filter((keyVal) => {
35
+ return (keySearch === undefined ||
36
+ (keySearch.identifier === keyVal.key.identifier &&
37
+ (keySearch.subtype === undefined ||
38
+ (keySearch.subtype === keyVal.key.subtype &&
39
+ (!Buffer.isBuffer(keySearch.keydata) || keySearch.keydata.equals(keyVal.key.keydata))))));
40
+ });
41
+ }
42
+ exports.getPsbtInputProprietaryKeyVals = getPsbtInputProprietaryKeyVals;
43
+ /**
44
+ * @return partialSig/tapScriptSig/MUSIG2_PARTIAL_SIG count iff input is not finalized
45
+ */
46
+ function getPsbtInputSignatureCount(input) {
47
+ if (isPsbtInputFinalized(input)) {
48
+ throw new Error('Input is already finalized');
49
+ }
50
+ return Math.max(Array.isArray(input.partialSig) ? input.partialSig.length : 0, Array.isArray(input.tapScriptSig) ? input.tapScriptSig.length : 0, getPsbtInputProprietaryKeyVals(input, {
51
+ identifier: exports.PSBT_PROPRIETARY_IDENTIFIER,
52
+ subtype: ProprietaryKeySubtype.MUSIG2_PARTIAL_SIG,
53
+ }).length);
54
+ }
55
+ exports.getPsbtInputSignatureCount = getPsbtInputSignatureCount;
56
+ /**
57
+ * @return true iff PSBT input is finalized
58
+ */
59
+ function isPsbtInputFinalized(input) {
60
+ return Buffer.isBuffer(input.finalScriptSig) || Buffer.isBuffer(input.finalScriptWitness);
61
+ }
62
+ exports.isPsbtInputFinalized = isPsbtInputFinalized;
63
+ /**
64
+ * @return true iff data starts with magic PSBT byte sequence
65
+ * @param data byte array or hex string
66
+ * */
67
+ function isPsbt(data) {
68
+ // https://github.com/bitcoin/bips/blob/master/bip-0174.mediawiki#specification
69
+ // 0x70736274 - ASCII for 'psbt'. 0xff - separator
70
+ if (typeof data === 'string') {
71
+ if (data.length < 10) {
72
+ return false;
73
+ }
74
+ data = Buffer.from(data.slice(0, 10), 'hex');
75
+ }
76
+ return 5 <= data.length && data.readUInt32BE(0) === 0x70736274 && data.readUInt8(4) === 0xff;
77
+ }
78
+ exports.isPsbt = isPsbt;
79
+ /**
80
+ * This function allows signing or validating a psbt with non-segwit inputs those do not contain nonWitnessUtxo.
81
+ */
82
+ function withUnsafeNonSegwit(psbt, fn, unsafe = true) {
83
+ psbt.__CACHE.__UNSAFE_SIGN_NONSEGWIT = unsafe;
84
+ try {
85
+ return fn();
86
+ }
87
+ finally {
88
+ psbt.__CACHE.__UNSAFE_SIGN_NONSEGWIT = false;
89
+ }
90
+ }
91
+ exports.withUnsafeNonSegwit = withUnsafeNonSegwit;
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PsbtUtil.js","sourceRoot":"","sources":["../../../src/bitgo/PsbtUtil.ts"],"names":[],"mappings":"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","sourcesContent":["import { decodeProprietaryKey, ProprietaryKey } from 'bip174/src/lib/proprietaryKeyVal';\nimport { PsbtInput } from 'bip174/src/lib/interfaces';\nimport { Psbt } from 'bitcoinjs-lib/src/psbt';\n\n/**\n * bitgo proprietary key identifier\n */\nexport const PSBT_PROPRIETARY_IDENTIFIER = 'BITGO';\n\n/**\n * subtype for proprietary keys that bitgo uses\n */\nexport enum ProprietaryKeySubtype {\n  ZEC_CONSENSUS_BRANCH_ID = 0x00,\n  MUSIG2_PARTICIPANT_PUB_KEYS = 0x01,\n  MUSIG2_PUB_NONCE = 0x02,\n  MUSIG2_PARTIAL_SIG = 0x03,\n}\n\n/**\n * Psbt proprietary keydata object.\n * <compact size uint identifier length> <bytes identifier> <compact size uint subtype> <bytes subkeydata>\n * => <bytes valuedata>\n */\nexport interface ProprietaryKeyValue {\n  key: ProprietaryKey;\n  value: Buffer;\n}\n\n/**\n * Psbt proprietary keydata object search fields.\n * <compact size uint identifier length> <bytes identifier> <compact size uint subtype> <bytes subkeydata>\n */\nexport interface ProprietaryKeySearch {\n  identifier: string;\n  subtype?: number;\n  keydata?: Buffer;\n  identifierEncoding?: BufferEncoding;\n}\n\n/**\n * Search any data from psbt proprietary key value against keydata.\n * Default identifierEncoding is utf-8 for identifier.\n */\nexport function getPsbtInputProprietaryKeyVals(\n  input: PsbtInput,\n  keySearch?: ProprietaryKeySearch\n): ProprietaryKeyValue[] {\n  if (!input.unknownKeyVals?.length) {\n    return [];\n  }\n  if (keySearch && keySearch.subtype === undefined && Buffer.isBuffer(keySearch.keydata)) {\n    throw new Error('invalid proprietary key search filter combination. subtype is required');\n  }\n  const keyVals = input.unknownKeyVals.map(({ key, value }, i) => {\n    return { key: decodeProprietaryKey(key), value };\n  });\n  return keyVals.filter((keyVal) => {\n    return (\n      keySearch === undefined ||\n      (keySearch.identifier === keyVal.key.identifier &&\n        (keySearch.subtype === undefined ||\n          (keySearch.subtype === keyVal.key.subtype &&\n            (!Buffer.isBuffer(keySearch.keydata) || keySearch.keydata.equals(keyVal.key.keydata)))))\n    );\n  });\n}\n\n/**\n * @return partialSig/tapScriptSig/MUSIG2_PARTIAL_SIG count iff input is not finalized\n */\nexport function getPsbtInputSignatureCount(input: PsbtInput): number {\n  if (isPsbtInputFinalized(input)) {\n    throw new Error('Input is already finalized');\n  }\n  return Math.max(\n    Array.isArray(input.partialSig) ? input.partialSig.length : 0,\n    Array.isArray(input.tapScriptSig) ? input.tapScriptSig.length : 0,\n    getPsbtInputProprietaryKeyVals(input, {\n      identifier: PSBT_PROPRIETARY_IDENTIFIER,\n      subtype: ProprietaryKeySubtype.MUSIG2_PARTIAL_SIG,\n    }).length\n  );\n}\n\n/**\n * @return true iff PSBT input is finalized\n */\nexport function isPsbtInputFinalized(input: PsbtInput): boolean {\n  return Buffer.isBuffer(input.finalScriptSig) || Buffer.isBuffer(input.finalScriptWitness);\n}\n\n/**\n * @return true iff data starts with magic PSBT byte sequence\n * @param data byte array or hex string\n * */\nexport function isPsbt(data: Buffer | string): boolean {\n  // https://github.com/bitcoin/bips/blob/master/bip-0174.mediawiki#specification\n  // 0x70736274 - ASCII for 'psbt'. 0xff - separator\n  if (typeof data === 'string') {\n    if (data.length < 10) {\n      return false;\n    }\n    data = Buffer.from(data.slice(0, 10), 'hex');\n  }\n  return 5 <= data.length && data.readUInt32BE(0) === 0x70736274 && data.readUInt8(4) === 0xff;\n}\n\n/**\n * This function allows signing or validating a psbt with non-segwit inputs those do not contain nonWitnessUtxo.\n */\nexport function withUnsafeNonSegwit<T>(psbt: Psbt, fn: () => T, unsafe = true): T {\n  (psbt as any).__CACHE.__UNSAFE_SIGN_NONSEGWIT = unsafe;\n  try {\n    return fn();\n  } finally {\n    (psbt as any).__CACHE.__UNSAFE_SIGN_NONSEGWIT = false;\n  }\n}\n"]}
@@ -1,14 +1,20 @@
1
1
  /// <reference types="node" />
2
2
  import { Psbt as PsbtBase } from 'bip174';
3
+ import { Bip32Derivation, PsbtInput } from 'bip174/src/lib/interfaces';
4
+ import { BIP32Interface } from 'bip32';
3
5
  import { HDSigner, Psbt, TxOutput, Network } from '..';
4
6
  import { UtxoTransaction } from './UtxoTransaction';
5
- import { ProprietaryKey } from 'bip174/src/lib/proprietaryKeyVal';
6
- export declare const PSBT_PROPRIETARY_IDENTIFIER = "BITGO";
7
- export declare enum ProprietaryKeySubtype {
8
- ZEC_CONSENSUS_BRANCH_ID = 0,
9
- MUSIG2_PARTICIPANT_PUB_KEYS = 1,
10
- MUSIG2_PUB_NONCE = 2
11
- }
7
+ import { Triple } from './types';
8
+ import { ProprietaryKeySearch, ProprietaryKeyValue } from './PsbtUtil';
9
+ declare type SignatureParams = {
10
+ /** When true, and add the second (last) nonce and signature for a taproot key
11
+ * path spend deterministically. Throws an error if done for the first nonce/signature
12
+ * of a taproot keypath spend. Ignore for all other input types.
13
+ */
14
+ deterministic: boolean;
15
+ /** Allowed sighash types */
16
+ sighashTypes: number[];
17
+ };
12
18
  export interface HDTaprootSigner extends HDSigner {
13
19
  /**
14
20
  * The path string must match /^m(\/\d+'?)+$/
@@ -21,10 +27,28 @@ export interface HDTaprootSigner extends HDSigner {
21
27
  */
22
28
  signSchnorr(hash: Buffer): Buffer;
23
29
  }
30
+ /**
31
+ * HD signer object for taproot p2tr musig2 key path sign
32
+ */
33
+ export interface HDTaprootMusig2Signer extends HDSigner {
34
+ /**
35
+ * Musig2 requires signer's 32-bytes private key to be passed to it.
36
+ */
37
+ privateKey: Buffer;
38
+ /**
39
+ * The path string must match /^m(\/\d+'?)+$/
40
+ * ex. m/44'/0'/0'/1/23 levels with ' must be hard derivations
41
+ */
42
+ derivePath(path: string): HDTaprootMusig2Signer;
43
+ }
24
44
  export interface SchnorrSigner {
25
45
  publicKey: Buffer;
26
46
  signSchnorr(hash: Buffer): Buffer;
27
47
  }
48
+ export interface Musig2Signer {
49
+ publicKey: Buffer;
50
+ privateKey: Buffer;
51
+ }
28
52
  export interface TaprootSigner {
29
53
  leafHashes: Buffer[];
30
54
  signer: SchnorrSigner;
@@ -34,40 +58,33 @@ export interface PsbtOpts {
34
58
  maximumFeeRate?: number;
35
59
  bip32PathsAbsolute?: boolean;
36
60
  }
37
- /**
38
- * Psbt proprietary keydata object.
39
- * <compact size uint identifier length> <bytes identifier> <compact size uint subtype> <bytes subkeydata>
40
- * => <bytes valuedata>
41
- */
42
- export interface ProprietaryKeyValueData {
43
- key: ProprietaryKey;
44
- value: Buffer;
45
- }
46
- /**
47
- * Psbt proprietary keydata object search fields.
48
- * <compact size uint identifier length> <bytes identifier> <compact size uint subtype> <bytes subkeydata>
49
- */
50
- export interface ProprietaryKeySearch {
51
- identifier: string;
52
- subtype: number;
53
- keydata?: Buffer;
54
- identifierEncoding?: BufferEncoding;
55
- }
56
61
  export declare class UtxoPsbt<Tx extends UtxoTransaction<bigint> = UtxoTransaction<bigint>> extends Psbt {
62
+ private nonceStore;
57
63
  protected static transactionFromBuffer(buffer: Buffer, network: Network): UtxoTransaction<bigint>;
58
64
  static createPsbt(opts: PsbtOpts, data?: PsbtBase): UtxoPsbt;
59
65
  static fromBuffer(buffer: Buffer, opts: PsbtOpts): UtxoPsbt;
60
66
  static fromHex(data: string, opts: PsbtOpts): UtxoPsbt;
61
- get network(): Network;
62
- toHex(): string;
63
67
  /**
64
- * @return true iff PSBT input is finalized
68
+ * @param parent - Parent key. Matched with `bip32Derivations` using `fingerprint` property.
69
+ * @param bip32Derivations - possible derivations for input or output
70
+ * @param ignoreY - when true, ignore the y coordinate when matching public keys
71
+ * @return derived bip32 node if matching derivation is found, undefined if none is found
72
+ * @throws Error if more than one match is found
65
73
  */
66
- isInputFinalized(inputIndex: number): boolean;
74
+ static deriveKeyPair(parent: BIP32Interface, bip32Derivations: Bip32Derivation[], { ignoreY }: {
75
+ ignoreY: boolean;
76
+ }): BIP32Interface | undefined;
77
+ static deriveKeyPairForInput(bip32: BIP32Interface, input: PsbtInput): Buffer | undefined;
78
+ get network(): Network;
79
+ toHex(): string;
67
80
  /**
68
- * @return partialSig/tapScriptSig count iff input is not finalized
81
+ * It is expensive to attempt to compute every output address using psbt.txOutputs[outputIndex]
82
+ * to then just get the script. Here, we are doing the same thing as what txOutputs() does in
83
+ * bitcoinjs-lib, but without iterating over each output.
84
+ * @param outputIndex
85
+ * @returns output script at the given index
69
86
  */
70
- getSignatureCount(inputIndex: number): number;
87
+ getOutputScript(outputIndex: number): Buffer;
71
88
  getNonWitnessPreviousTxids(): string[];
72
89
  addNonWitnessUtxos(txBufs: Record<string, Buffer>): this;
73
90
  static fromTransaction(transaction: UtxoTransaction<bigint>, prevOutputs: TxOutput<bigint>[]): UtxoPsbt;
@@ -75,11 +92,31 @@ export declare class UtxoPsbt<Tx extends UtxoTransaction<bigint> = UtxoTransacti
75
92
  protected static newTransaction(network: Network): UtxoTransaction<bigint>;
76
93
  protected get tx(): Tx;
77
94
  protected checkForSignatures(propName?: string): void;
95
+ /**
96
+ * @returns true if the input at inputIndex is a taproot key path.
97
+ * Checks for presence of minimum required key path input fields and absence of any script path only input fields.
98
+ */
99
+ isTaprootKeyPathInput(inputIndex: number): boolean;
100
+ /**
101
+ * @returns true if the input at inputIndex is a taproot script path.
102
+ * Checks for presence of minimum required script path input fields and absence of any key path only input fields.
103
+ */
104
+ isTaprootScriptPathInput(inputIndex: number): boolean;
105
+ /**
106
+ * @returns true if the input at inputIndex is a taproot
107
+ */
108
+ isTaprootInput(inputIndex: number): boolean;
109
+ private isMultisigTaprootScript;
78
110
  /**
79
111
  * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts
80
112
  */
81
113
  finalizeAllInputs(): this;
82
114
  finalizeTaprootInput(inputIndex: number): this;
115
+ /**
116
+ * Finalizes a taproot musig2 input by aggregating all partial sigs.
117
+ * IMPORTANT: Always call validate* function before finalizing.
118
+ */
119
+ finalizeTaprootMusig2Input(inputIndex: number): this;
83
120
  finalizeTapInputWithSingleLeafScriptAndSignature(inputIndex: number): this;
84
121
  /**
85
122
  * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts
@@ -89,44 +126,140 @@ export declare class UtxoPsbt<Tx extends UtxoTransaction<bigint> = UtxoTransacti
89
126
  * validator.
90
127
  */
91
128
  validateSignaturesOfAllInputs(): boolean;
129
+ /**
130
+ * @returns true iff any matching valid signature is found for a derived pub key from given HD key pair.
131
+ */
132
+ validateSignaturesOfInputHD(inputIndex: number, hdKeyPair: BIP32Interface): boolean;
133
+ /**
134
+ * @returns true iff any valid signature(s) are found from bip32 data of PSBT or for given pub key.
135
+ */
136
+ validateSignaturesOfInputCommon(inputIndex: number, pubkey?: Buffer): boolean;
137
+ private getMusig2SessionKey;
138
+ /**
139
+ * @returns true for following cases.
140
+ * If valid musig2 partial signatures exists for both 2 keys, it will also verify aggregated sig
141
+ * for aggregated tweaked key (output key), otherwise only verifies partial sig.
142
+ * If pubkey is passed in input, it will check sig only for that pubkey,
143
+ * if no sig exits for such key, throws error.
144
+ * For invalid state of input data, it will throw errors.
145
+ */
146
+ validateTaprootMusig2SignaturesOfInput(inputIndex: number, pubkey?: Buffer): boolean;
92
147
  validateTaprootSignaturesOfInput(inputIndex: number, pubkey?: Buffer): boolean;
93
148
  /**
149
+ * @param inputIndex
150
+ * @param rootNodes optional input root bip32 nodes to verify with. If it is not provided, globalXpub will be used.
94
151
  * @return array of boolean values. True when corresponding index in `publicKeys` has signed the transaction.
95
152
  * If no signature in the tx or no public key matching signature, the validation is considered as false.
96
153
  */
97
- getSignatureValidationArray(inputIndex: number): boolean[];
154
+ getSignatureValidationArray(inputIndex: number, { rootNodes }?: {
155
+ rootNodes?: Triple<BIP32Interface>;
156
+ }): Triple<boolean>;
98
157
  /**
99
158
  * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts
100
159
  */
101
- signAllInputsHD(hdKeyPair: HDTaprootSigner, sighashTypes?: number[]): this;
160
+ signAllInputsHD(hdKeyPair: HDTaprootSigner | HDTaprootMusig2Signer, params?: number[] | Partial<SignatureParams>): this;
102
161
  /**
103
162
  * Mostly copied from bitcoinjs-lib/ts_src/psbt.ts:signInputHD
104
163
  */
105
- signTaprootInputHD(inputIndex: number, hdKeyPair: HDTaprootSigner, sighashTypes?: number[]): this;
164
+ signTaprootInputHD(inputIndex: number, hdKeyPair: HDTaprootSigner | HDTaprootMusig2Signer, { sighashTypes, deterministic }?: {
165
+ sighashTypes?: number[] | undefined;
166
+ deterministic?: boolean | undefined;
167
+ }): this;
168
+ signInputHD(inputIndex: number, hdKeyPair: HDTaprootSigner | HDTaprootMusig2Signer, params?: number[] | Partial<SignatureParams>): this;
169
+ private getMusig2Participants;
170
+ private getMusig2Nonces;
171
+ /**
172
+ * Signs p2tr musig2 key path input with 2 aggregated keys.
173
+ *
174
+ * Note: Only can sign deterministically as the cosigner
175
+ * @param inputIndex
176
+ * @param signer - XY public key and private key are required
177
+ * @param sighashTypes
178
+ * @param deterministic If true, sign the musig input deterministically
179
+ */
180
+ signTaprootMusig2Input(inputIndex: number, signer: Musig2Signer, { sighashTypes, deterministic }?: {
181
+ sighashTypes?: number[] | undefined;
182
+ deterministic?: boolean | undefined;
183
+ }): this;
106
184
  signTaprootInput(inputIndex: number, signer: SchnorrSigner, leafHashes: Buffer[], sighashTypes?: number[]): this;
185
+ private getTaprootOutputScript;
107
186
  private getTaprootHashForSig;
108
187
  /**
109
- * @retuns true iff the input is taproot.
188
+ * Adds proprietary key value pair to PSBT input.
189
+ * Default identifierEncoding is utf-8 for identifier.
110
190
  */
111
- isTaprootInput(inputIndex: number): boolean;
191
+ addProprietaryKeyValToInput(inputIndex: number, keyValueData: ProprietaryKeyValue): this;
112
192
  /**
113
- * @returns hash and hashType for taproot input at inputIndex
114
- * @throws error if input at inputIndex is not a taproot input
193
+ * Adds or updates (if exists) proprietary key value pair to PSBT input.
194
+ * Default identifierEncoding is utf-8 for identifier.
115
195
  */
116
- getTaprootHashForSigChecked(inputIndex: number, sighashTypes?: number[], leafHash?: Buffer): {
117
- hash: Buffer;
118
- sighashType: number;
119
- };
196
+ addOrUpdateProprietaryKeyValToInput(inputIndex: number, keyValueData: ProprietaryKeyValue): this;
120
197
  /**
121
- * Adds proprietary key value pair to PSBT input.
198
+ * To search any data from proprietary key value against keydata.
122
199
  * Default identifierEncoding is utf-8 for identifier.
123
200
  */
124
- addProprietaryKeyValToInput(inputIndex: number, keyValueData: ProprietaryKeyValueData): this;
201
+ getProprietaryKeyVals(inputIndex: number, keySearch?: ProprietaryKeySearch): ProprietaryKeyValue[];
125
202
  /**
126
- * To search any data from proprietary key value againts keydata.
203
+ * To delete any data from proprietary key value.
127
204
  * Default identifierEncoding is utf-8 for identifier.
128
205
  */
129
- getProprietaryKeyVals(inputIndex: number, keySearch?: ProprietaryKeySearch): ProprietaryKeyValueData[];
206
+ deleteProprietaryKeyVals(inputIndex: number, keysToDelete?: ProprietaryKeySearch): this;
207
+ private createMusig2NonceForInput;
208
+ private setMusig2NoncesInner;
209
+ /**
210
+ * Generates and sets MuSig2 nonce to taproot key path input at inputIndex.
211
+ * If input is not a taproot key path, no action.
212
+ *
213
+ * @param inputIndex input index
214
+ * @param keyPair derived key pair
215
+ * @param sessionId Optional extra entropy. If provided it must either be a counter unique to this secret key,
216
+ * (converted to an array of 32 bytes), or 32 uniformly random bytes.
217
+ * @param deterministic If true, set the cosigner nonce deterministically
218
+ */
219
+ setInputMusig2Nonce(inputIndex: number, derivedKeyPair: BIP32Interface, params?: {
220
+ sessionId?: Buffer;
221
+ deterministic?: boolean;
222
+ }): this;
223
+ /**
224
+ * Generates and sets MuSig2 nonce to taproot key path input at inputIndex.
225
+ * If input is not a taproot key path, no action.
226
+ *
227
+ * @param inputIndex input index
228
+ * @param keyPair HD root key pair
229
+ * @param sessionId Optional extra entropy. If provided it must either be a counter unique to this secret key,
230
+ * (converted to an array of 32 bytes), or 32 uniformly random bytes.
231
+ * @param deterministic If true, set the cosigner nonce deterministically
232
+ */
233
+ setInputMusig2NonceHD(inputIndex: number, keyPair: BIP32Interface, params?: {
234
+ sessionId?: Buffer;
235
+ deterministic?: boolean;
236
+ }): this;
237
+ /**
238
+ * Generates and sets MuSig2 nonce to all taproot key path inputs. Other inputs will be skipped.
239
+ *
240
+ * @param inputIndex input index
241
+ * @param keyPair derived key pair
242
+ * @param sessionId Optional extra entropy. If provided it must either be a counter unique to this secret key,
243
+ * (converted to an array of 32 bytes), or 32 uniformly random bytes.
244
+ */
245
+ setAllInputsMusig2Nonce(keyPair: BIP32Interface, params?: {
246
+ sessionId?: Buffer;
247
+ deterministic?: boolean;
248
+ }): this;
249
+ /**
250
+ * Generates and sets MuSig2 nonce to all taproot key path inputs. Other inputs will be skipped.
251
+ *
252
+ * @param inputIndex input index
253
+ * @param keyPair HD root key pair
254
+ * @param sessionId Optional extra entropy. If provided it must either be a counter unique to this secret key,
255
+ * (converted to an array of 32 bytes), or 32 uniformly random bytes.
256
+ */
257
+ setAllInputsMusig2NonceHD(keyPair: BIP32Interface, params?: {
258
+ sessionId?: Buffer;
259
+ deterministic?: boolean;
260
+ }): this;
130
261
  clone(): this;
262
+ extractTransaction(disableFeeCheck?: boolean): UtxoTransaction<bigint>;
131
263
  }
264
+ export {};
132
265
  //# sourceMappingURL=UtxoPsbt.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"UtxoPsbt.d.ts","sourceRoot":"","sources":["../../../src/bitgo/UtxoPsbt.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"UtxoPsbt.d.ts","sourceRoot":"","sources":["../../../src/bitgo/UtxoPsbt.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,IAAI,IAAI,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,EACL,eAAe,EACf,SAAS,EAIV,MAAM,2BAA2B,CAAC;AAInC,OAAO,EAAgB,cAAc,EAAE,MAAM,OAAO,CAAC;AAIrD,OAAO,EAEL,QAAQ,EACR,IAAI,EAGJ,QAAQ,EACR,OAAO,EAIR,MAAM,IAAI,CAAC;AACZ,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAyBpD,OAAO,EAAqB,MAAM,EAAS,MAAM,SAAS,CAAC;AAE3D,OAAO,EAGL,oBAAoB,EAEpB,mBAAmB,EAEpB,MAAM,YAAY,CAAC;AAEpB,aAAK,eAAe,GAAG;IACrB;;;OAGG;IACH,aAAa,EAAE,OAAO,CAAC;IACvB,4BAA4B;IAC5B,YAAY,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AA6BF,MAAM,WAAW,eAAgB,SAAQ,QAAQ;IAC/C;;;OAGG;IACH,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,CAAC;IAC1C;;;OAGG;IACH,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC;CACnC;AAED;;GAEG;AACH,MAAM,WAAW,qBAAsB,SAAQ,QAAQ;IACrD;;OAEG;IACH,UAAU,EAAE,MAAM,CAAC;IAEnB;;;OAGG;IACH,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,qBAAqB,CAAC;CACjD;AAED,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC;CACnC;AAED,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,aAAa;IAC5B,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,MAAM,EAAE,aAAa,CAAC;CACvB;AAED,MAAM,WAAW,QAAQ;IACvB,OAAO,EAAE,OAAO,CAAC;IACjB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B;AAKD,qBAAa,QAAQ,CAAC,EAAE,SAAS,eAAe,CAAC,MAAM,CAAC,GAAG,eAAe,CAAC,MAAM,CAAC,CAAE,SAAQ,IAAI;IAC9F,OAAO,CAAC,UAAU,CAA0B;IAE5C,SAAS,CAAC,MAAM,CAAC,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,eAAe,CAAC,MAAM,CAAC;IAIjG,MAAM,CAAC,UAAU,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAE,QAAQ,GAAG,QAAQ;IAO5D,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,GAAG,QAAQ;IAa3D,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,GAAG,QAAQ;IAItD;;;;;;OAMG;IACH,MAAM,CAAC,aAAa,CAClB,MAAM,EAAE,cAAc,EACtB,gBAAgB,EAAE,eAAe,EAAE,EACnC,EAAE,OAAO,EAAE,EAAE;QAAE,OAAO,EAAE,OAAO,CAAA;KAAE,GAChC,cAAc,GAAG,SAAS;IA8B7B,MAAM,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,EAAE,KAAK,EAAE,SAAS,GAAG,MAAM,GAAG,SAAS;IAQzF,IAAI,OAAO,IAAI,OAAO,CAErB;IAED,KAAK,IAAI,MAAM;IAIf;;;;;;OAMG;IACH,eAAe,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM;IAI5C,0BAA0B,IAAI,MAAM,EAAE;IActC,kBAAkB,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI;IAiBxD,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,eAAe,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,QAAQ,CAAC,MAAM,CAAC,EAAE,GAAG,QAAQ;IAsBvG,aAAa,IAAI,eAAe,CAAC,MAAM,CAAC;IAIxC,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,eAAe,CAAC,MAAM,CAAC;IAI1E,SAAS,KAAK,EAAE,IAAI,EAAE,CAErB;IAED,SAAS,CAAC,kBAAkB,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI;IAQrD;;;OAGG;IACH,qBAAqB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO;IAalD;;;OAGG;IACH,wBAAwB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO;IAqBrD;;OAEG;IACH,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO;IAgC3C,OAAO,CAAC,uBAAuB;IAS/B;;OAEG;IACH,iBAAiB,IAAI,IAAI;IAezB,oBAAoB,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAmC9C;;;OAGG;IACH,0BAA0B,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IA4BpD,gDAAgD,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAuB1E;;;;;;OAMG;IACH,6BAA6B,IAAI,OAAO;IAQxC;;OAEG;IACH,2BAA2B,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,cAAc,GAAG,OAAO;IASnF;;OAEG;IACH,+BAA+B,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO;IAiB7E,OAAO,CAAC,mBAAmB;IA6B3B;;;;;;;OAOG;IACH,sCAAsC,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO;IAwCpF,gCAAgC,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO;IA8C9E;;;;;OAKG;IACH,2BAA2B,CACzB,UAAU,EAAE,MAAM,EAClB,EAAE,SAAS,EAAE,GAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAC,cAAc,CAAC,CAAA;KAAO,GACzD,MAAM,CAAC,OAAO,CAAC;IAqClB;;OAEG;IACH,eAAe,CACb,SAAS,EAAE,eAAe,GAAG,qBAAqB,EAClD,MAAM,CAAC,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC,GAC3C,IAAI;IAqBP;;OAEG;IACH,kBAAkB,CAChB,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,eAAe,GAAG,qBAAqB,EAClD,EAAE,YAAqE,EAAE,aAAqB,EAAE;;;KAAK,GACpG,IAAI;IAoDP,WAAW,CACT,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,eAAe,GAAG,qBAAqB,EAClD,MAAM,CAAC,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC,GAC3C,IAAI;IASP,OAAO,CAAC,qBAAqB;IAS7B,OAAO,CAAC,eAAe;IAWvB;;;;;;;;OAQG;IACH,sBAAsB,CACpB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,YAAY,EACpB,EAAE,YAAqE,EAAE,aAAqB,EAAE;;;KAAK,GACpG,IAAI;IAsEP,gBAAgB,CACd,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,aAAa,EACrB,UAAU,EAAE,MAAM,EAAE,EACpB,YAAY,GAAE,MAAM,EAA2D,GAC9E,IAAI;IA8CP,OAAO,CAAC,sBAAsB;IAgB9B,OAAO,CAAC,oBAAoB;IAyD5B;;;OAGG;IACH,2BAA2B,CAAC,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,mBAAmB,GAAG,IAAI;IAOxF;;;OAGG;IACH,mCAAmC,CAAC,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,mBAAmB,GAAG,IAAI;IAkBhG;;;OAGG;IACH,qBAAqB,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,oBAAoB,GAAG,mBAAmB,EAAE;IAKlG;;;OAGG;IACH,wBAAwB,CAAC,UAAU,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,oBAAoB,GAAG,IAAI;IAqBvF,OAAO,CAAC,yBAAyB;IAuFjC,OAAO,CAAC,oBAAoB;IAwB5B;;;;;;;;;OASG;IACH,mBAAmB,CACjB,UAAU,EAAE,MAAM,EAClB,cAAc,EAAE,cAAc,EAC9B,MAAM,GAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,aAAa,CAAC,EAAE,OAAO,CAAA;KAA6B,GACjF,IAAI;IAIP;;;;;;;;;OASG;IACH,qBAAqB,CACnB,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,cAAc,EACvB,MAAM,GAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,aAAa,CAAC,EAAE,OAAO,CAAA;KAA6B,GACjF,IAAI;IAKP;;;;;;;OAOG;IACH,uBAAuB,CACrB,OAAO,EAAE,cAAc,EACvB,MAAM,GAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,aAAa,CAAC,EAAE,OAAO,CAAA;KAA6B,GACjF,IAAI;IAIP;;;;;;;OAOG;IACH,yBAAyB,CACvB,OAAO,EAAE,cAAc,EACvB,MAAM,GAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,aAAa,CAAC,EAAE,OAAO,CAAA;KAA6B,GACjF,IAAI;IAIP,KAAK,IAAI,IAAI;IAIb,kBAAkB,CAAC,eAAe,CAAC,EAAE,OAAO,GAAG,eAAe,CAAC,MAAM,CAAC;CAOvE"}