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
@@ -11,6 +11,8 @@ import { UtxoPsbt } from '../UtxoPsbt';
11
11
  export interface WalletUnspent<TNumber extends number | bigint = number> extends Unspent<TNumber> {
12
12
  chain: ChainCode;
13
13
  index: number;
14
+ witnessScript?: string;
15
+ valueString?: string;
14
16
  }
15
17
  export interface NonWitnessWalletUnspent<TNumber extends number | bigint = number> extends UnspentWithPrevTx<TNumber>, WalletUnspent<TNumber> {
16
18
  }
@@ -34,11 +36,37 @@ export interface WalletUnspentLegacy<TNumber extends number | bigint = number> e
34
36
  /** @deprecated - obviated by verifyWithUnspent */
35
37
  witnessScript?: string;
36
38
  }
39
+ /**
40
+ * @param psbt
41
+ * @param inputIndex
42
+ * @param id Unspent ID
43
+ * @returns true iff the unspent ID on the unspent and psbt input match
44
+ */
45
+ export declare function psbtIncludesUnspentAtIndex(psbt: UtxoPsbt, inputIndex: number, id: string): boolean;
46
+ /**
47
+ * Update the psbt input at the given index
48
+ * @param psbt
49
+ * @param inputIndex
50
+ * @param u
51
+ * @param redeemScript Only overrides if there is no redeemScript in the input currently
52
+ */
53
+ export declare function updateReplayProtectionUnspentToPsbt(psbt: UtxoPsbt, inputIndex: number, u: Unspent<bigint>, redeemScript?: Buffer): void;
37
54
  export declare function addReplayProtectionUnspentToPsbt(psbt: UtxoPsbt, u: Unspent<bigint>, redeemScript: Buffer,
38
55
  /**
39
56
  * @deprecated
40
57
  */
41
58
  network?: Network): void;
59
+ /**
60
+ * Update the PSBT with the unspent data for the input at the given index if the data is not there already.
61
+ *
62
+ * @param psbt
63
+ * @param inputIndex
64
+ * @param u
65
+ * @param rootWalletKeys
66
+ * @param signer
67
+ * @param cosigner
68
+ */
69
+ export declare function updateWalletUnspentForPsbt(psbt: UtxoPsbt, inputIndex: number, u: WalletUnspent<bigint>, rootWalletKeys: RootWalletKeys, signer: KeyName, cosigner: KeyName): void;
42
70
  export declare function addWalletUnspentToPsbt(psbt: UtxoPsbt, u: WalletUnspent<bigint>, rootWalletKeys: RootWalletKeys, signer: KeyName, cosigner: KeyName,
43
71
  /**
44
72
  * @deprecated
@@ -1 +1 @@
1
- {"version":3,"file":"Unspent.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":";AAAA,OAAO,EAAc,OAAO,EAAY,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAWnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAS,MAAM,UAAU,CAAC;AACzC,OAAO,EAAY,iBAAiB,EAAE,OAAO,EAAqC,MAAM,YAAY,CAAC;AACrG,OAAO,EAAE,SAAS,EAAY,MAAM,UAAU,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAGvC,MAAM,WAAW,aAAa,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,OAAO,CAAC,OAAO,CAAC;IAC/F,KAAK,EAAE,SAAS,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,uBAAuB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAC/E,SAAQ,iBAAiB,CAAC,OAAO,CAAC,EAChC,aAAa,CAAC,OAAO,CAAC;CAAG;AAE7B,wBAAgB,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAAE,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,aAAa,CAAC,OAAO,CAAC,CAEjH;AAED,wBAAgB,oBAAoB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAClE,SAAS,EAAE,sBAAsB,CAAC,OAAO,CAAC,EAC1C,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,aAAa,CAAC,OAAO,CAAC,EAC/B,aAAa,EAAE,mBAAmB,CAAC,cAAc,CAAC,GACjD,IAAI,CAmBN;AAED;;;;;;GAMG;AACH,wBAAgB,0BAA0B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACxE,EAAE,EAAE,eAAe,CAAC,OAAO,CAAC,EAC5B,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,EAC5B,UAAU,EAAE,cAAc,GACzB,MAAM,CAAC,OAAO,CAAC,CAcjB;AAED;;;GAGG;AACH,MAAM,WAAW,mBAAmB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,aAAa,CAAC,OAAO,CAAC;IAC3G,gDAAgD;IAChD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,kDAAkD;IAClD,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,wBAAgB,gCAAgC,CAC9C,IAAI,EAAE,QAAQ,EACd,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,EAClB,YAAY,EAAE,MAAM;AACpB;;GAEG;AACH,OAAO,GAAE,OAAsB,GAC9B,IAAI,CAqBN;AAED,wBAAgB,sBAAsB,CACpC,IAAI,EAAE,QAAQ,EACd,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC,EACxB,cAAc,EAAE,cAAc,EAC9B,MAAM,EAAE,OAAO,EACf,QAAQ,EAAE,OAAO;AACjB;;GAEG;AACH,OAAO,GAAE,OAAsB,GAC9B,IAAI,CAkFN"}
1
+ {"version":3,"file":"Unspent.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.addWalletUnspentToPsbt = exports.addReplayProtectionUnspentToPsbt = exports.verifySignatureWithUnspent = exports.signInputWithUnspent = exports.isWalletUnspent = void 0;
3
+ exports.addWalletUnspentToPsbt = exports.updateWalletUnspentForPsbt = exports.addReplayProtectionUnspentToPsbt = exports.updateReplayProtectionUnspentToPsbt = exports.psbtIncludesUnspentAtIndex = exports.verifySignatureWithUnspent = exports.signInputWithUnspent = exports.isWalletUnspent = void 0;
4
4
  const __1 = require("../..");
5
5
  const outputScripts_1 = require("../outputScripts");
6
6
  const address_1 = require("../../address");
@@ -8,6 +8,10 @@ const signature_1 = require("../signature");
8
8
  const Unspent_1 = require("../Unspent");
9
9
  const chains_1 = require("./chains");
10
10
  const Musig2_1 = require("../Musig2");
11
+ const transaction_1 = require("../transaction");
12
+ const parseInput_1 = require("../parseInput");
13
+ const utils_1 = require("bip174/src/lib/utils");
14
+ const PsbtUtil_1 = require("../PsbtUtil");
11
15
  function isWalletUnspent(u) {
12
16
  return u.chain !== undefined;
13
17
  }
@@ -31,124 +35,225 @@ exports.signInputWithUnspent = signInputWithUnspent;
31
35
  * @return triple of booleans indicating a valid signature for each pubkey
32
36
  */
33
37
  function verifySignatureWithUnspent(tx, inputIndex, unspents, walletKeys) {
38
+ var _a, _b;
34
39
  if (tx.ins.length !== unspents.length) {
35
40
  throw new Error(`input length must match unspents length`);
36
41
  }
42
+ const input = tx.ins[inputIndex];
43
+ /* istanbul ignore next */
44
+ if (!input) {
45
+ throw new Error(`no input at index ${inputIndex}`);
46
+ }
37
47
  const unspent = unspents[inputIndex];
38
- if (!isWalletUnspent(unspent)) {
48
+ if (!isWalletUnspent(unspent) || (!((_a = input.script) === null || _a === void 0 ? void 0 : _a.length) && !((_b = input.witness) === null || _b === void 0 ? void 0 : _b.length))) {
39
49
  return [false, false, false];
40
50
  }
41
- return signature_1.verifySignatureWithPublicKeys(tx, inputIndex, unspents.map((u) => Unspent_1.toOutput(u, tx.network)), walletKeys.deriveForChainAndIndex(unspent.chain, unspent.index).publicKeys);
51
+ const parsedInput = parseInput_1.parseSignatureScript(input);
52
+ const prevOutputs = unspents.map((u) => Unspent_1.toOutput(u, tx.network));
53
+ // If it is a taproot keyPathSpend input, the only valid signature combinations is user-bitgo. We can
54
+ // only verify that the aggregated signature is valid, not that the individual partial-signature is valid.
55
+ // Therefore, we can only say that either all partial signatures are valid, or none are.
56
+ if (parsedInput.scriptType === 'taprootKeyPathSpend') {
57
+ const result = signature_1.getSignatureVerifications(tx, inputIndex, unspent.value, undefined, prevOutputs);
58
+ return result.length === 1 && result[0].signature ? [true, false, true] : [false, false, false];
59
+ }
60
+ return signature_1.verifySignatureWithPublicKeys(tx, inputIndex, prevOutputs, walletKeys.deriveForChainAndIndex(unspent.chain, unspent.index).publicKeys);
42
61
  }
43
62
  exports.verifySignatureWithUnspent = verifySignatureWithUnspent;
44
- function addReplayProtectionUnspentToPsbt(psbt, u, redeemScript,
45
63
  /**
46
- * @deprecated
64
+ * @param psbt
65
+ * @param inputIndex
66
+ * @param id Unspent ID
67
+ * @returns true iff the unspent ID on the unspent and psbt input match
47
68
  */
48
- network = psbt.network) {
49
- if (network !== psbt.network) {
50
- throw new Error(`network parameter does not match psbt.network`);
69
+ function psbtIncludesUnspentAtIndex(psbt, inputIndex, id) {
70
+ utils_1.checkForInput(psbt.data.inputs, inputIndex);
71
+ const { txid, vout } = Unspent_1.parseOutputId(id);
72
+ const psbtOutPoint = Unspent_1.getOutputIdForInput(psbt.txInputs[inputIndex]);
73
+ return psbtOutPoint.txid === txid && psbtOutPoint.vout === vout;
74
+ }
75
+ exports.psbtIncludesUnspentAtIndex = psbtIncludesUnspentAtIndex;
76
+ /**
77
+ * Update the psbt input at the given index
78
+ * @param psbt
79
+ * @param inputIndex
80
+ * @param u
81
+ * @param redeemScript Only overrides if there is no redeemScript in the input currently
82
+ */
83
+ function updateReplayProtectionUnspentToPsbt(psbt, inputIndex, u, redeemScript) {
84
+ if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {
85
+ throw new Error(`unspent does not correspond to psbt input`);
86
+ }
87
+ const input = utils_1.checkForInput(psbt.data.inputs, inputIndex);
88
+ if (redeemScript && !input.redeemScript) {
89
+ psbt.updateInput(inputIndex, { redeemScript });
51
90
  }
52
- const { txid, vout } = Unspent_1.toPrevOutput(u, psbt.network);
53
- const isZcash = __1.getMainnet(psbt.network) !== __1.networks.zcash;
54
91
  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly
55
92
  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin
56
93
  // segwit transactions
94
+ const isZcash = __1.getMainnet(psbt.network) === __1.networks.zcash;
57
95
  if (!Unspent_1.isUnspentWithPrevTx(u) && !isZcash) {
58
96
  throw new Error('Error, require previous tx to add to PSBT');
59
97
  }
98
+ if (isZcash && !input.witnessUtxo) {
99
+ const { script, value } = Unspent_1.toPrevOutput(u, psbt.network);
100
+ psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });
101
+ }
102
+ else if (!isZcash && !input.nonWitnessUtxo) {
103
+ psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });
104
+ }
105
+ }
106
+ exports.updateReplayProtectionUnspentToPsbt = updateReplayProtectionUnspentToPsbt;
107
+ function addUnspentToPsbt(psbt, id) {
108
+ const { txid, vout } = Unspent_1.parseOutputId(id);
60
109
  psbt.addInput({
61
110
  hash: txid,
62
111
  index: vout,
63
- redeemScript,
64
112
  });
65
- if (!isZcash) {
66
- psbt.updateInput(vout, { nonWitnessUtxo: u.prevTx });
67
- }
68
113
  }
69
- exports.addReplayProtectionUnspentToPsbt = addReplayProtectionUnspentToPsbt;
70
- function addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signer, cosigner,
114
+ function addReplayProtectionUnspentToPsbt(psbt, u, redeemScript,
71
115
  /**
72
116
  * @deprecated
73
117
  */
74
118
  network = psbt.network) {
75
- if (network !== psbt.network) {
76
- throw new Error(`network parameter does not match psbt.network`);
119
+ if (psbt.network !== network) {
120
+ throw new Error('psbt network does not match network');
77
121
  }
78
- const { txid, vout, script, value } = Unspent_1.toPrevOutput(u, psbt.network);
79
- const walletKeys = rootWalletKeys.deriveForChainAndIndex(u.chain, u.index);
80
- const scriptType = outputScripts_1.scriptTypeForChain(u.chain);
81
- psbt.addInput({
82
- hash: txid,
83
- index: vout,
84
- witnessUtxo: {
85
- script,
86
- value,
87
- },
88
- });
89
- const inputIndex = psbt.inputCount - 1;
122
+ addUnspentToPsbt(psbt, u.id);
123
+ updateReplayProtectionUnspentToPsbt(psbt, psbt.inputCount - 1, u, redeemScript);
124
+ }
125
+ exports.addReplayProtectionUnspentToPsbt = addReplayProtectionUnspentToPsbt;
126
+ /**
127
+ * Update the PSBT with the unspent data for the input at the given index if the data is not there already.
128
+ *
129
+ * @param psbt
130
+ * @param inputIndex
131
+ * @param u
132
+ * @param rootWalletKeys
133
+ * @param signer
134
+ * @param cosigner
135
+ */
136
+ function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer, cosigner) {
137
+ if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {
138
+ throw new Error(`unspent does not correspond to psbt input`);
139
+ }
140
+ const input = utils_1.checkForInput(psbt.data.inputs, inputIndex);
90
141
  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly
91
142
  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin
92
143
  // segwit transactions
93
- if (!chains_1.isSegwit(u.chain) && __1.getMainnet(psbt.network) !== __1.networks.zcash) {
144
+ const isZcashOrSegwit = chains_1.isSegwit(u.chain) || __1.getMainnet(psbt.network) === __1.networks.zcash;
145
+ if (isZcashOrSegwit && !input.witnessUtxo) {
146
+ const { script, value } = Unspent_1.toPrevOutput(u, psbt.network);
147
+ psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });
148
+ }
149
+ else if (!isZcashOrSegwit) {
94
150
  if (!Unspent_1.isUnspentWithPrevTx(u)) {
95
151
  throw new Error('Error, require previous tx to add to PSBT');
96
152
  }
97
- psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });
153
+ if (!input.witnessUtxo && !input.nonWitnessUtxo) {
154
+ // Force the litecoin transaction to have no MWEB advanced transaction flag
155
+ if (__1.getMainnet(psbt.network) === __1.networks.litecoin) {
156
+ u.prevTx = transaction_1.createTransactionFromBuffer(u.prevTx, psbt.network, { amountType: 'bigint' }).toBuffer();
157
+ }
158
+ psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });
159
+ }
160
+ }
161
+ const walletKeys = rootWalletKeys.deriveForChainAndIndex(u.chain, u.index);
162
+ const scriptType = outputScripts_1.scriptTypeForChain(u.chain);
163
+ const sighashType = signature_1.getDefaultSigHash(psbt.network, scriptType);
164
+ if (psbt.data.inputs[inputIndex].sighashType === undefined) {
165
+ psbt.updateInput(inputIndex, { sighashType });
98
166
  }
99
167
  const isBackupFlow = signer === 'backup' || cosigner === 'backup';
100
168
  if (scriptType === 'p2tr' || (scriptType === 'p2trMusig2' && isBackupFlow)) {
169
+ if (input.tapLeafScript && input.tapBip32Derivation) {
170
+ return;
171
+ }
101
172
  const createSpendScriptP2trFn = scriptType === 'p2tr' ? outputScripts_1.createSpendScriptP2tr : outputScripts_1.createSpendScriptP2trMusig2;
102
173
  const { controlBlock, witnessScript, leafVersion, leafHash } = createSpendScriptP2trFn(walletKeys.publicKeys, [
103
174
  walletKeys[signer].publicKey,
104
175
  walletKeys[cosigner].publicKey,
105
176
  ]);
106
- psbt.updateInput(inputIndex, {
107
- tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],
108
- tapBip32Derivation: [signer, cosigner].map((key) => ({
109
- leafHashes: [leafHash],
110
- pubkey: outputScripts_1.toXOnlyPublicKey(walletKeys[key].publicKey),
111
- path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
112
- masterFingerprint: rootWalletKeys[key].fingerprint,
113
- })),
114
- });
177
+ if (!input.tapLeafScript) {
178
+ psbt.updateInput(inputIndex, {
179
+ tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],
180
+ });
181
+ }
182
+ if (!input.tapBip32Derivation) {
183
+ psbt.updateInput(inputIndex, {
184
+ tapBip32Derivation: [signer, cosigner].map((key) => ({
185
+ leafHashes: [leafHash],
186
+ pubkey: outputScripts_1.toXOnlyPublicKey(walletKeys[key].publicKey),
187
+ path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
188
+ masterFingerprint: rootWalletKeys[key].fingerprint,
189
+ })),
190
+ });
191
+ }
115
192
  }
116
193
  else if (scriptType === 'p2trMusig2') {
117
194
  const { internalPubkey: tapInternalKey, outputPubkey: tapOutputKey, taptreeRoot, } = outputScripts_1.createKeyPathP2trMusig2(walletKeys.publicKeys);
118
- const participantPubKeys = [walletKeys.user.publicKey, walletKeys.bitgo.publicKey];
119
- const participantsKeyValData = Musig2_1.encodePsbtMusig2ParticipantsKeyValData({
120
- tapOutputKey,
121
- tapInternalKey,
122
- participantPubKeys,
123
- });
124
- psbt.addProprietaryKeyValToInput(inputIndex, participantsKeyValData);
125
- psbt.updateInput(inputIndex, {
126
- tapInternalKey: tapInternalKey,
127
- tapMerkleRoot: taptreeRoot,
128
- tapBip32Derivation: [signer, cosigner].map((key) => ({
129
- leafHashes: [],
130
- pubkey: outputScripts_1.toXOnlyPublicKey(walletKeys[key].publicKey),
131
- path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
132
- masterFingerprint: rootWalletKeys[key].fingerprint,
133
- })),
134
- });
195
+ if (psbt.getProprietaryKeyVals(inputIndex, {
196
+ identifier: PsbtUtil_1.PSBT_PROPRIETARY_IDENTIFIER,
197
+ subtype: PsbtUtil_1.ProprietaryKeySubtype.MUSIG2_PARTICIPANT_PUB_KEYS,
198
+ }).length === 0) {
199
+ const participantsKeyValData = Musig2_1.encodePsbtMusig2Participants({
200
+ tapOutputKey,
201
+ tapInternalKey,
202
+ participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],
203
+ });
204
+ psbt.addProprietaryKeyValToInput(inputIndex, participantsKeyValData);
205
+ }
206
+ if (!input.tapInternalKey) {
207
+ psbt.updateInput(inputIndex, {
208
+ tapInternalKey: tapInternalKey,
209
+ });
210
+ }
211
+ if (!input.tapMerkleRoot) {
212
+ psbt.updateInput(inputIndex, {
213
+ tapMerkleRoot: taptreeRoot,
214
+ });
215
+ }
216
+ if (!input.tapBip32Derivation) {
217
+ psbt.updateInput(inputIndex, {
218
+ tapBip32Derivation: [signer, cosigner].map((key) => ({
219
+ leafHashes: [],
220
+ pubkey: outputScripts_1.toXOnlyPublicKey(walletKeys[key].publicKey),
221
+ path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
222
+ masterFingerprint: rootWalletKeys[key].fingerprint,
223
+ })),
224
+ });
225
+ }
135
226
  }
136
227
  else {
228
+ if (!input.bip32Derivation) {
229
+ psbt.updateInput(inputIndex, {
230
+ bip32Derivation: [0, 1, 2].map((idx) => ({
231
+ pubkey: walletKeys.triple[idx].publicKey,
232
+ path: walletKeys.paths[idx],
233
+ masterFingerprint: rootWalletKeys.triple[idx].fingerprint,
234
+ })),
235
+ });
236
+ }
137
237
  const { witnessScript, redeemScript } = outputScripts_1.createOutputScript2of3(walletKeys.publicKeys, scriptType);
138
- psbt.updateInput(inputIndex, {
139
- bip32Derivation: [0, 1, 2].map((idx) => ({
140
- pubkey: walletKeys.triple[idx].publicKey,
141
- path: walletKeys.paths[idx],
142
- masterFingerprint: rootWalletKeys.triple[idx].fingerprint,
143
- })),
144
- });
145
- if (witnessScript) {
238
+ if (witnessScript && !input.witnessScript) {
146
239
  psbt.updateInput(inputIndex, { witnessScript });
147
240
  }
148
- if (redeemScript) {
241
+ if (redeemScript && !input.redeemScript) {
149
242
  psbt.updateInput(inputIndex, { redeemScript });
150
243
  }
151
244
  }
152
245
  }
246
+ exports.updateWalletUnspentForPsbt = updateWalletUnspentForPsbt;
247
+ function addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signer, cosigner,
248
+ /**
249
+ * @deprecated
250
+ */
251
+ network = psbt.network) {
252
+ if (psbt.network !== network) {
253
+ throw new Error('psbt network does not match network');
254
+ }
255
+ addUnspentToPsbt(psbt, u.id);
256
+ updateWalletUnspentForPsbt(psbt, psbt.inputCount - 1, u, rootWalletKeys, signer, cosigner);
257
+ }
153
258
  exports.addWalletUnspentToPsbt = addWalletUnspentToPsbt;
154
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Unspent.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":";;;AAAA,6BAAsD;AAEtD,oDAO0B;AAC1B,2CAA+C;AAC/C,4CAA4E;AAK5E,wCAAqG;AACrG,qCAA+C;AAE/C,sCAAmE;AAWnE,SAAgB,eAAe,CAAkC,CAAmB;IAClF,OAAQ,CAA4B,CAAC,KAAK,KAAK,SAAS,CAAC;AAC3D,CAAC;AAFD,0CAEC;AAED,SAAgB,oBAAoB,CAClC,SAA0C,EAC1C,UAAkB,EAClB,OAA+B,EAC/B,aAAkD;IAElD,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IAC5G,MAAM,UAAU,GAAG,kCAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACrD,MAAM,SAAS,GAAG,sCAAsB,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC,YAAY,CAAC;IACzF,MAAM,iBAAiB,GAAG,wBAAc,CAAC,OAAO,CAAC,OAAO,EAAE,SAAS,CAAC,OAAkB,CAAC,CAAC;IACxF,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE;QACxC,MAAM,IAAI,KAAK,CACb,gCAAgC,iBAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CACrG,CAAC;KACH;IACD,yBAAa,CACX,SAAS,EACT,UAAU,EACV,UAAU,EACV,UAAU,CAAC,UAAU,EACrB,MAAM,EACN,QAAQ,CAAC,SAAS,EAClB,OAAO,CAAC,KAAK,CACd,CAAC;AACJ,CAAC;AAxBD,oDAwBC;AAED;;;;;;GAMG;AACH,SAAgB,0BAA0B,CACxC,EAA4B,EAC5B,UAAkB,EAClB,QAA4B,EAC5B,UAA0B;IAE1B,IAAI,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,QAAQ,CAAC,MAAM,EAAE;QACrC,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;KAC5D;IACD,MAAM,OAAO,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;IACrC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE;QAC7B,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;KAC9B;IACD,OAAO,yCAA6B,CAClC,EAAE,EACF,UAAU,EACV,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,kBAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,EAC5C,UAAU,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CACxD,CAAC;AACvB,CAAC;AAnBD,gEAmBC;AAaD,SAAgB,gCAAgC,CAC9C,IAAc,EACd,CAAkB,EAClB,YAAoB;AACpB;;GAEG;AACH,UAAmB,IAAI,CAAC,OAAO;IAE/B,IAAI,OAAO,KAAK,IAAI,CAAC,OAAO,EAAE;QAC5B,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;KAClE;IACD,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,sBAAY,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACrD,MAAM,OAAO,GAAG,cAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,YAAQ,CAAC,KAAK,CAAC;IAE5D,0GAA0G;IAC1G,kGAAkG;IAClG,sBAAsB;IACtB,IAAI,CAAC,6BAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE;QACvC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;KAC9D;IACD,IAAI,CAAC,QAAQ,CAAC;QACZ,IAAI,EAAE,IAAI;QACV,KAAK,EAAE,IAAI;QACX,YAAY;KACb,CAAC,CAAC;IACH,IAAI,CAAC,OAAO,EAAE;QACZ,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,cAAc,EAAG,CAA+B,CAAC,MAAM,EAAE,CAAC,CAAC;KACrF;AACH,CAAC;AA7BD,4EA6BC;AAED,SAAgB,sBAAsB,CACpC,IAAc,EACd,CAAwB,EACxB,cAA8B,EAC9B,MAAe,EACf,QAAiB;AACjB;;GAEG;AACH,UAAmB,IAAI,CAAC,OAAO;IAE/B,IAAI,OAAO,KAAK,IAAI,CAAC,OAAO,EAAE;QAC5B,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;KAClE;IACD,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,sBAAY,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACpE,MAAM,UAAU,GAAG,cAAc,CAAC,sBAAsB,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;IAC3E,MAAM,UAAU,GAAG,kCAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC/C,IAAI,CAAC,QAAQ,CAAC;QACZ,IAAI,EAAE,IAAI;QACV,KAAK,EAAE,IAAI;QACX,WAAW,EAAE;YACX,MAAM;YACN,KAAK;SACN;KACF,CAAC,CAAC;IACH,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;IACvC,0GAA0G;IAC1G,kGAAkG;IAClG,sBAAsB;IACtB,IAAI,CAAC,iBAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,cAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,YAAQ,CAAC,KAAK,EAAE;QACrE,IAAI,CAAC,6BAAmB,CAAC,CAAC,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAC9D;QACD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;KAC5D;IAED,MAAM,YAAY,GAAG,MAAM,KAAK,QAAQ,IAAI,QAAQ,KAAK,QAAQ,CAAC;IAElE,IAAI,UAAU,KAAK,MAAM,IAAI,CAAC,UAAU,KAAK,YAAY,IAAI,YAAY,CAAC,EAAE;QAC1E,MAAM,uBAAuB,GAAG,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,qCAAqB,CAAC,CAAC,CAAC,2CAA2B,CAAC;QAC5G,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,uBAAuB,CAAC,UAAU,CAAC,UAAU,EAAE;YAC5G,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS;YAC5B,UAAU,CAAC,QAAQ,CAAC,CAAC,SAAS;SAC/B,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YAC3B,aAAa,EAAE,CAAC,EAAE,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC;YACrE,kBAAkB,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACnD,UAAU,EAAE,CAAC,QAAQ,CAAC;gBACtB,MAAM,EAAE,gCAAgB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;gBACnD,IAAI,EAAE,cAAc,CAAC,iBAAiB,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC;gBAC7E,iBAAiB,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,WAAW;aACnD,CAAC,CAAC;SACJ,CAAC,CAAC;KACJ;SAAM,IAAI,UAAU,KAAK,YAAY,EAAE;QACtC,MAAM,EACJ,cAAc,EAAE,cAAc,EAC9B,YAAY,EAAE,YAAY,EAC1B,WAAW,GACZ,GAAG,uCAAuB,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QACnD,MAAM,kBAAkB,GAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAClG,MAAM,sBAAsB,GAAG,+CAAsC,CAAC;YACpE,YAAY;YACZ,cAAc;YACd,kBAAkB;SACnB,CAAC,CAAC;QACH,IAAI,CAAC,2BAA2B,CAAC,UAAU,EAAE,sBAAsB,CAAC,CAAC;QACrE,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YAC3B,cAAc,EAAE,cAAc;YAC9B,aAAa,EAAE,WAAW;YAC1B,kBAAkB,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACnD,UAAU,EAAE,EAAE;gBACd,MAAM,EAAE,gCAAgB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;gBACnD,IAAI,EAAE,cAAc,CAAC,iBAAiB,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC;gBAC7E,iBAAiB,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,WAAW;aACnD,CAAC,CAAC;SACJ,CAAC,CAAC;KACJ;SAAM;QACL,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,GAAG,sCAAsB,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAClG,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YAC3B,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACvC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS;gBACxC,IAAI,EAAE,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC;gBAC3B,iBAAiB,EAAE,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW;aAC1D,CAAC,CAAC;SACJ,CAAC,CAAC;QACH,IAAI,aAAa,EAAE;YACjB,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;SACjD;QACD,IAAI,YAAY,EAAE;YAChB,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC;SAChD;KACF;AACH,CAAC;AA5FD,wDA4FC","sourcesContent":["import { getMainnet, Network, networks } from '../..';\nimport { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';\nimport {\n  createKeyPathP2trMusig2,\n  createOutputScript2of3,\n  createSpendScriptP2tr,\n  createSpendScriptP2trMusig2,\n  scriptTypeForChain,\n  toXOnlyPublicKey,\n} from '../outputScripts';\nimport { toOutputScript } from '../../address';\nimport { signInput2Of3, verifySignatureWithPublicKeys } from '../signature';\nimport { WalletUnspentSigner } from './WalletUnspentSigner';\nimport { KeyName, RootWalletKeys } from './WalletKeys';\nimport { UtxoTransaction } from '../UtxoTransaction';\nimport { Triple, Tuple } from '../types';\nimport { toOutput, UnspentWithPrevTx, Unspent, isUnspentWithPrevTx, toPrevOutput } from '../Unspent';\nimport { ChainCode, isSegwit } from './chains';\nimport { UtxoPsbt } from '../UtxoPsbt';\nimport { encodePsbtMusig2ParticipantsKeyValData } from '../Musig2';\n\nexport interface WalletUnspent<TNumber extends number | bigint = number> extends Unspent<TNumber> {\n  chain: ChainCode;\n  index: number;\n}\n\nexport interface NonWitnessWalletUnspent<TNumber extends number | bigint = number>\n  extends UnspentWithPrevTx<TNumber>,\n    WalletUnspent<TNumber> {}\n\nexport function isWalletUnspent<TNumber extends number | bigint>(u: Unspent<TNumber>): u is WalletUnspent<TNumber> {\n  return (u as WalletUnspent<TNumber>).chain !== undefined;\n}\n\nexport function signInputWithUnspent<TNumber extends number | bigint>(\n  txBuilder: UtxoTransactionBuilder<TNumber>,\n  inputIndex: number,\n  unspent: WalletUnspent<TNumber>,\n  unspentSigner: WalletUnspentSigner<RootWalletKeys>\n): void {\n  const { walletKeys, signer, cosigner } = unspentSigner.deriveForChainAndIndex(unspent.chain, unspent.index);\n  const scriptType = scriptTypeForChain(unspent.chain);\n  const pubScript = createOutputScript2of3(walletKeys.publicKeys, scriptType).scriptPubKey;\n  const pubScriptExpected = toOutputScript(unspent.address, txBuilder.network as Network);\n  if (!pubScript.equals(pubScriptExpected)) {\n    throw new Error(\n      `pubscript mismatch: expected ${pubScriptExpected.toString('hex')} got ${pubScript.toString('hex')}`\n    );\n  }\n  signInput2Of3<TNumber>(\n    txBuilder,\n    inputIndex,\n    scriptType,\n    walletKeys.publicKeys,\n    signer,\n    cosigner.publicKey,\n    unspent.value\n  );\n}\n\n/**\n * @param tx\n * @param inputIndex\n * @param unspents\n * @param walletKeys\n * @return triple of booleans indicating a valid signature for each pubkey\n */\nexport function verifySignatureWithUnspent<TNumber extends number | bigint>(\n  tx: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  unspents: Unspent<TNumber>[],\n  walletKeys: RootWalletKeys\n): Triple<boolean> {\n  if (tx.ins.length !== unspents.length) {\n    throw new Error(`input length must match unspents length`);\n  }\n  const unspent = unspents[inputIndex];\n  if (!isWalletUnspent(unspent)) {\n    return [false, false, false];\n  }\n  return verifySignatureWithPublicKeys(\n    tx,\n    inputIndex,\n    unspents.map((u) => toOutput(u, tx.network)),\n    walletKeys.deriveForChainAndIndex(unspent.chain, unspent.index).publicKeys\n  ) as Triple<boolean>;\n}\n\n/**\n * @deprecated\n * Used in certain legacy signing methods that do not derive signing data from index/chain\n */\nexport interface WalletUnspentLegacy<TNumber extends number | bigint = number> extends WalletUnspent<TNumber> {\n  /** @deprecated - obviated by signWithUnspent */\n  redeemScript?: string;\n  /** @deprecated - obviated by verifyWithUnspent */\n  witnessScript?: string;\n}\n\nexport function addReplayProtectionUnspentToPsbt(\n  psbt: UtxoPsbt,\n  u: Unspent<bigint>,\n  redeemScript: Buffer,\n  /**\n   * @deprecated\n   */\n  network: Network = psbt.network\n): void {\n  if (network !== psbt.network) {\n    throw new Error(`network parameter does not match psbt.network`);\n  }\n  const { txid, vout } = toPrevOutput(u, psbt.network);\n  const isZcash = getMainnet(psbt.network) !== networks.zcash;\n\n  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly\n  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin\n  // segwit transactions\n  if (!isUnspentWithPrevTx(u) && !isZcash) {\n    throw new Error('Error, require previous tx to add to PSBT');\n  }\n  psbt.addInput({\n    hash: txid,\n    index: vout,\n    redeemScript,\n  });\n  if (!isZcash) {\n    psbt.updateInput(vout, { nonWitnessUtxo: (u as UnspentWithPrevTx<bigint>).prevTx });\n  }\n}\n\nexport function addWalletUnspentToPsbt(\n  psbt: UtxoPsbt,\n  u: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName,\n  /**\n   * @deprecated\n   */\n  network: Network = psbt.network\n): void {\n  if (network !== psbt.network) {\n    throw new Error(`network parameter does not match psbt.network`);\n  }\n  const { txid, vout, script, value } = toPrevOutput(u, psbt.network);\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(u.chain, u.index);\n  const scriptType = scriptTypeForChain(u.chain);\n  psbt.addInput({\n    hash: txid,\n    index: vout,\n    witnessUtxo: {\n      script,\n      value,\n    },\n  });\n  const inputIndex = psbt.inputCount - 1;\n  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly\n  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin\n  // segwit transactions\n  if (!isSegwit(u.chain) && getMainnet(psbt.network) !== networks.zcash) {\n    if (!isUnspentWithPrevTx(u)) {\n      throw new Error('Error, require previous tx to add to PSBT');\n    }\n    psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });\n  }\n\n  const isBackupFlow = signer === 'backup' || cosigner === 'backup';\n\n  if (scriptType === 'p2tr' || (scriptType === 'p2trMusig2' && isBackupFlow)) {\n    const createSpendScriptP2trFn = scriptType === 'p2tr' ? createSpendScriptP2tr : createSpendScriptP2trMusig2;\n    const { controlBlock, witnessScript, leafVersion, leafHash } = createSpendScriptP2trFn(walletKeys.publicKeys, [\n      walletKeys[signer].publicKey,\n      walletKeys[cosigner].publicKey,\n    ]);\n    psbt.updateInput(inputIndex, {\n      tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],\n      tapBip32Derivation: [signer, cosigner].map((key) => ({\n        leafHashes: [leafHash],\n        pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n        path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),\n        masterFingerprint: rootWalletKeys[key].fingerprint,\n      })),\n    });\n  } else if (scriptType === 'p2trMusig2') {\n    const {\n      internalPubkey: tapInternalKey,\n      outputPubkey: tapOutputKey,\n      taptreeRoot,\n    } = createKeyPathP2trMusig2(walletKeys.publicKeys);\n    const participantPubKeys: Tuple<Buffer> = [walletKeys.user.publicKey, walletKeys.bitgo.publicKey];\n    const participantsKeyValData = encodePsbtMusig2ParticipantsKeyValData({\n      tapOutputKey,\n      tapInternalKey,\n      participantPubKeys,\n    });\n    psbt.addProprietaryKeyValToInput(inputIndex, participantsKeyValData);\n    psbt.updateInput(inputIndex, {\n      tapInternalKey: tapInternalKey,\n      tapMerkleRoot: taptreeRoot,\n      tapBip32Derivation: [signer, cosigner].map((key) => ({\n        leafHashes: [],\n        pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n        path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),\n        masterFingerprint: rootWalletKeys[key].fingerprint,\n      })),\n    });\n  } else {\n    const { witnessScript, redeemScript } = createOutputScript2of3(walletKeys.publicKeys, scriptType);\n    psbt.updateInput(inputIndex, {\n      bip32Derivation: [0, 1, 2].map((idx) => ({\n        pubkey: walletKeys.triple[idx].publicKey,\n        path: walletKeys.paths[idx],\n        masterFingerprint: rootWalletKeys.triple[idx].fingerprint,\n      })),\n    });\n    if (witnessScript) {\n      psbt.updateInput(inputIndex, { witnessScript });\n    }\n    if (redeemScript) {\n      psbt.updateInput(inputIndex, { redeemScript });\n    }\n  }\n}\n"]}
259
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Unspent.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":"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","sourcesContent":["import { getMainnet, Network, networks } from '../..';\nimport { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';\nimport {\n  createKeyPathP2trMusig2,\n  createOutputScript2of3,\n  createSpendScriptP2tr,\n  createSpendScriptP2trMusig2,\n  scriptTypeForChain,\n  toXOnlyPublicKey,\n} from '../outputScripts';\nimport { toOutputScript } from '../../address';\nimport {\n  getDefaultSigHash,\n  getSignatureVerifications,\n  signInput2Of3,\n  verifySignatureWithPublicKeys,\n} from '../signature';\nimport { WalletUnspentSigner } from './WalletUnspentSigner';\nimport { KeyName, RootWalletKeys } from './WalletKeys';\nimport { UtxoTransaction } from '../UtxoTransaction';\nimport { Triple } from '../types';\nimport {\n  toOutput,\n  UnspentWithPrevTx,\n  Unspent,\n  isUnspentWithPrevTx,\n  toPrevOutput,\n  parseOutputId,\n  getOutputIdForInput,\n} from '../Unspent';\nimport { ChainCode, isSegwit } from './chains';\nimport { UtxoPsbt } from '../UtxoPsbt';\nimport { encodePsbtMusig2Participants } from '../Musig2';\nimport { createTransactionFromBuffer } from '../transaction';\nimport { parseSignatureScript } from '../parseInput';\nimport { checkForInput } from 'bip174/src/lib/utils';\nimport { ProprietaryKeySubtype, PSBT_PROPRIETARY_IDENTIFIER } from '../PsbtUtil';\n\nexport interface WalletUnspent<TNumber extends number | bigint = number> extends Unspent<TNumber> {\n  chain: ChainCode;\n  index: number;\n  witnessScript?: string;\n  valueString?: string;\n}\n\nexport interface NonWitnessWalletUnspent<TNumber extends number | bigint = number>\n  extends UnspentWithPrevTx<TNumber>,\n    WalletUnspent<TNumber> {}\n\nexport function isWalletUnspent<TNumber extends number | bigint>(u: Unspent<TNumber>): u is WalletUnspent<TNumber> {\n  return (u as WalletUnspent<TNumber>).chain !== undefined;\n}\n\nexport function signInputWithUnspent<TNumber extends number | bigint>(\n  txBuilder: UtxoTransactionBuilder<TNumber>,\n  inputIndex: number,\n  unspent: WalletUnspent<TNumber>,\n  unspentSigner: WalletUnspentSigner<RootWalletKeys>\n): void {\n  const { walletKeys, signer, cosigner } = unspentSigner.deriveForChainAndIndex(unspent.chain, unspent.index);\n  const scriptType = scriptTypeForChain(unspent.chain);\n  const pubScript = createOutputScript2of3(walletKeys.publicKeys, scriptType).scriptPubKey;\n  const pubScriptExpected = toOutputScript(unspent.address, txBuilder.network as Network);\n  if (!pubScript.equals(pubScriptExpected)) {\n    throw new Error(\n      `pubscript mismatch: expected ${pubScriptExpected.toString('hex')} got ${pubScript.toString('hex')}`\n    );\n  }\n  signInput2Of3<TNumber>(\n    txBuilder,\n    inputIndex,\n    scriptType,\n    walletKeys.publicKeys,\n    signer,\n    cosigner.publicKey,\n    unspent.value\n  );\n}\n\n/**\n * @param tx\n * @param inputIndex\n * @param unspents\n * @param walletKeys\n * @return triple of booleans indicating a valid signature for each pubkey\n */\nexport function verifySignatureWithUnspent<TNumber extends number | bigint>(\n  tx: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  unspents: Unspent<TNumber>[],\n  walletKeys: RootWalletKeys\n): Triple<boolean> {\n  if (tx.ins.length !== unspents.length) {\n    throw new Error(`input length must match unspents length`);\n  }\n\n  const input = tx.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  const unspent = unspents[inputIndex];\n  if (!isWalletUnspent(unspent) || (!input.script?.length && !input.witness?.length)) {\n    return [false, false, false];\n  }\n\n  const parsedInput = parseSignatureScript(input);\n  const prevOutputs = unspents.map((u) => toOutput(u, tx.network));\n\n  // If it is a taproot keyPathSpend input, the only valid signature combinations is user-bitgo. We can\n  // only verify that the aggregated signature is valid, not that the individual partial-signature is valid.\n  // Therefore, we can only say that either all partial signatures are valid, or none are.\n  if (parsedInput.scriptType === 'taprootKeyPathSpend') {\n    const result = getSignatureVerifications(tx, inputIndex, unspent.value, undefined, prevOutputs);\n    return result.length === 1 && result[0].signature ? [true, false, true] : [false, false, false];\n  }\n\n  return verifySignatureWithPublicKeys(\n    tx,\n    inputIndex,\n    prevOutputs,\n    walletKeys.deriveForChainAndIndex(unspent.chain, unspent.index).publicKeys\n  ) as Triple<boolean>;\n}\n\n/**\n * @deprecated\n * Used in certain legacy signing methods that do not derive signing data from index/chain\n */\nexport interface WalletUnspentLegacy<TNumber extends number | bigint = number> extends WalletUnspent<TNumber> {\n  /** @deprecated - obviated by signWithUnspent */\n  redeemScript?: string;\n  /** @deprecated - obviated by verifyWithUnspent */\n  witnessScript?: string;\n}\n\n/**\n * @param psbt\n * @param inputIndex\n * @param id Unspent ID\n * @returns true iff the unspent ID on the unspent and psbt input match\n */\nexport function psbtIncludesUnspentAtIndex(psbt: UtxoPsbt, inputIndex: number, id: string): boolean {\n  checkForInput(psbt.data.inputs, inputIndex);\n\n  const { txid, vout } = parseOutputId(id);\n  const psbtOutPoint = getOutputIdForInput(psbt.txInputs[inputIndex]);\n  return psbtOutPoint.txid === txid && psbtOutPoint.vout === vout;\n}\n\n/**\n * Update the psbt input at the given index\n * @param psbt\n * @param inputIndex\n * @param u\n * @param redeemScript Only overrides if there is no redeemScript in the input currently\n */\nexport function updateReplayProtectionUnspentToPsbt(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  u: Unspent<bigint>,\n  redeemScript?: Buffer\n): void {\n  if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {\n    throw new Error(`unspent does not correspond to psbt input`);\n  }\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n\n  if (redeemScript && !input.redeemScript) {\n    psbt.updateInput(inputIndex, { redeemScript });\n  }\n\n  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly\n  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin\n  // segwit transactions\n  const isZcash = getMainnet(psbt.network) === networks.zcash;\n  if (!isUnspentWithPrevTx(u) && !isZcash) {\n    throw new Error('Error, require previous tx to add to PSBT');\n  }\n  if (isZcash && !input.witnessUtxo) {\n    const { script, value } = toPrevOutput(u, psbt.network);\n    psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });\n  } else if (!isZcash && !input.nonWitnessUtxo) {\n    psbt.updateInput(inputIndex, { nonWitnessUtxo: (u as UnspentWithPrevTx<bigint>).prevTx });\n  }\n}\n\nfunction addUnspentToPsbt(psbt: UtxoPsbt, id: string): void {\n  const { txid, vout } = parseOutputId(id);\n  psbt.addInput({\n    hash: txid,\n    index: vout,\n  });\n}\n\nexport function addReplayProtectionUnspentToPsbt(\n  psbt: UtxoPsbt,\n  u: Unspent<bigint>,\n  redeemScript: Buffer,\n  /**\n   * @deprecated\n   */\n  network: Network = psbt.network\n): void {\n  if (psbt.network !== network) {\n    throw new Error('psbt network does not match network');\n  }\n  addUnspentToPsbt(psbt, u.id);\n  updateReplayProtectionUnspentToPsbt(psbt, psbt.inputCount - 1, u, redeemScript);\n}\n\n/**\n * Update the PSBT with the unspent data for the input at the given index if the data is not there already.\n *\n * @param psbt\n * @param inputIndex\n * @param u\n * @param rootWalletKeys\n * @param signer\n * @param cosigner\n */\nexport function updateWalletUnspentForPsbt(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  u: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName\n): void {\n  if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {\n    throw new Error(`unspent does not correspond to psbt input`);\n  }\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n\n  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly\n  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin\n  // segwit transactions\n  const isZcashOrSegwit = isSegwit(u.chain) || getMainnet(psbt.network) === networks.zcash;\n  if (isZcashOrSegwit && !input.witnessUtxo) {\n    const { script, value } = toPrevOutput(u, psbt.network);\n    psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });\n  } else if (!isZcashOrSegwit) {\n    if (!isUnspentWithPrevTx(u)) {\n      throw new Error('Error, require previous tx to add to PSBT');\n    }\n\n    if (!input.witnessUtxo && !input.nonWitnessUtxo) {\n      // Force the litecoin transaction to have no MWEB advanced transaction flag\n      if (getMainnet(psbt.network) === networks.litecoin) {\n        u.prevTx = createTransactionFromBuffer(u.prevTx, psbt.network, { amountType: 'bigint' }).toBuffer();\n      }\n\n      psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });\n    }\n  }\n\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(u.chain, u.index);\n  const scriptType = scriptTypeForChain(u.chain);\n  const sighashType = getDefaultSigHash(psbt.network, scriptType);\n  if (psbt.data.inputs[inputIndex].sighashType === undefined) {\n    psbt.updateInput(inputIndex, { sighashType });\n  }\n  const isBackupFlow = signer === 'backup' || cosigner === 'backup';\n\n  if (scriptType === 'p2tr' || (scriptType === 'p2trMusig2' && isBackupFlow)) {\n    if (input.tapLeafScript && input.tapBip32Derivation) {\n      return;\n    }\n    const createSpendScriptP2trFn = scriptType === 'p2tr' ? createSpendScriptP2tr : createSpendScriptP2trMusig2;\n    const { controlBlock, witnessScript, leafVersion, leafHash } = createSpendScriptP2trFn(walletKeys.publicKeys, [\n      walletKeys[signer].publicKey,\n      walletKeys[cosigner].publicKey,\n    ]);\n    if (!input.tapLeafScript) {\n      psbt.updateInput(inputIndex, {\n        tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],\n      });\n    }\n    if (!input.tapBip32Derivation) {\n      psbt.updateInput(inputIndex, {\n        tapBip32Derivation: [signer, cosigner].map((key) => ({\n          leafHashes: [leafHash],\n          pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n          path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),\n          masterFingerprint: rootWalletKeys[key].fingerprint,\n        })),\n      });\n    }\n  } else if (scriptType === 'p2trMusig2') {\n    const {\n      internalPubkey: tapInternalKey,\n      outputPubkey: tapOutputKey,\n      taptreeRoot,\n    } = createKeyPathP2trMusig2(walletKeys.publicKeys);\n\n    if (\n      psbt.getProprietaryKeyVals(inputIndex, {\n        identifier: PSBT_PROPRIETARY_IDENTIFIER,\n        subtype: ProprietaryKeySubtype.MUSIG2_PARTICIPANT_PUB_KEYS,\n      }).length === 0\n    ) {\n      const participantsKeyValData = encodePsbtMusig2Participants({\n        tapOutputKey,\n        tapInternalKey,\n        participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],\n      });\n      psbt.addProprietaryKeyValToInput(inputIndex, participantsKeyValData);\n    }\n\n    if (!input.tapInternalKey) {\n      psbt.updateInput(inputIndex, {\n        tapInternalKey: tapInternalKey,\n      });\n    }\n\n    if (!input.tapMerkleRoot) {\n      psbt.updateInput(inputIndex, {\n        tapMerkleRoot: taptreeRoot,\n      });\n    }\n\n    if (!input.tapBip32Derivation) {\n      psbt.updateInput(inputIndex, {\n        tapBip32Derivation: [signer, cosigner].map((key) => ({\n          leafHashes: [],\n          pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n          path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),\n          masterFingerprint: rootWalletKeys[key].fingerprint,\n        })),\n      });\n    }\n  } else {\n    if (!input.bip32Derivation) {\n      psbt.updateInput(inputIndex, {\n        bip32Derivation: [0, 1, 2].map((idx) => ({\n          pubkey: walletKeys.triple[idx].publicKey,\n          path: walletKeys.paths[idx],\n          masterFingerprint: rootWalletKeys.triple[idx].fingerprint,\n        })),\n      });\n    }\n\n    const { witnessScript, redeemScript } = createOutputScript2of3(walletKeys.publicKeys, scriptType);\n    if (witnessScript && !input.witnessScript) {\n      psbt.updateInput(inputIndex, { witnessScript });\n    }\n    if (redeemScript && !input.redeemScript) {\n      psbt.updateInput(inputIndex, { redeemScript });\n    }\n  }\n}\n\nexport function addWalletUnspentToPsbt(\n  psbt: UtxoPsbt,\n  u: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName,\n  /**\n   * @deprecated\n   */\n  network: Network = psbt.network\n): void {\n  if (psbt.network !== network) {\n    throw new Error('psbt network does not match network');\n  }\n  addUnspentToPsbt(psbt, u.id);\n  updateWalletUnspentForPsbt(psbt, psbt.inputCount - 1, u, rootWalletKeys, signer, cosigner);\n}\n"]}
@@ -4,7 +4,7 @@ import { ChainCode } from './chains';
4
4
  /**
5
5
  * Add a verifiable wallet output to the PSBT. The output and all data
6
6
  * needed to verify it from public keys only are added to the PSBT.
7
- * Typically these are change outputs
7
+ * Typically these are change outputs.
8
8
  *
9
9
  * @param psbt the PSBT to add change output to
10
10
  * @param rootWalletKeys keys that will be able to spend the output
@@ -15,4 +15,20 @@ import { ChainCode } from './chains';
15
15
  * @param value value of the change output
16
16
  */
17
17
  export declare function addWalletOutputToPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys, chain: ChainCode, index: number, value: bigint): void;
18
+ /**
19
+ * Update the wallet output with the required information when necessary. If the
20
+ * information is there already, it will skip over it.
21
+ *
22
+ * This function assumes that the output script and value have already been set.
23
+ *
24
+ * @param psbt the PSBT to update change output at
25
+ * @param rootWalletKeys keys that will be able to spend the output
26
+ * @param outputIndex output index where to update the output
27
+ * @param chain chain code to use for deriving scripts (and to determine script
28
+ * type) chain is an API parameter in the BitGo API, and may be
29
+ * any valid ChainCode
30
+ * @param index derivation index for the change address
31
+ * @param value value of the change output
32
+ */
33
+ export declare function updateWalletOutputForPsbt(psbt: UtxoPsbt, rootWalletKeys: RootWalletKeys, outputIndex: number, chain: ChainCode, index: number): void;
18
34
  //# sourceMappingURL=WalletOutput.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"WalletOutput.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletOutput.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAsB,MAAM,UAAU,CAAC;AAGzD;;;;;;;;;;;;GAYG;AACH,wBAAgB,qBAAqB,CACnC,IAAI,EAAE,QAAQ,EACd,cAAc,EAAE,cAAc,EAC9B,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM,GACZ,IAAI,CAgDN"}
1
+ {"version":3,"file":"WalletOutput.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletOutput.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAsB,MAAM,UAAU,CAAC;AAGzD;;;;;;;;;;;;GAYG;AACH,wBAAgB,qBAAqB,CACnC,IAAI,EAAE,QAAQ,EACd,cAAc,EAAE,cAAc,EAC9B,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM,GACZ,IAAI,CAYN;AAED;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,yBAAyB,CACvC,IAAI,EAAE,QAAQ,EACd,cAAc,EAAE,cAAc,EAC9B,WAAW,EAAE,MAAM,EACnB,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,MAAM,GACZ,IAAI,CAgEN"}