@bitgo-beta/unspents 0.13.2-beta.9 → 0.13.2-beta.91

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.
Files changed (56) hide show
  1. package/CHANGELOG.md +60 -0
  2. package/bin/generate_tables.ts +94 -0
  3. package/dist/bin/generate_tables.d.ts +2 -0
  4. package/dist/bin/generate_tables.d.ts.map +1 -0
  5. package/dist/bin/generate_tables.js +94 -0
  6. package/dist/{codes.d.ts → src/codes.d.ts} +1 -0
  7. package/dist/src/codes.d.ts.map +1 -0
  8. package/dist/src/codes.js +168 -0
  9. package/dist/{dimensions.d.ts → src/dimensions.d.ts} +6 -7
  10. package/dist/src/dimensions.d.ts.map +1 -0
  11. package/dist/src/dimensions.js +485 -0
  12. package/dist/{index.d.ts → src/index.d.ts} +1 -0
  13. package/dist/src/index.d.ts.map +1 -0
  14. package/dist/{index.js → src/index.js} +1 -1
  15. package/dist/{inputWeights.d.ts → src/inputWeights.d.ts} +1 -0
  16. package/dist/src/inputWeights.d.ts.map +1 -0
  17. package/dist/src/inputWeights.js +97 -0
  18. package/dist/{scriptSizes.d.ts → src/scriptSizes.d.ts} +1 -0
  19. package/dist/src/scriptSizes.d.ts.map +1 -0
  20. package/dist/src/scriptSizes.js +51 -0
  21. package/dist/{types.d.ts → src/types.d.ts} +1 -0
  22. package/dist/src/types.d.ts.map +1 -0
  23. package/dist/{types.js → src/types.js} +1 -1
  24. package/dist/{virtualSizes.d.ts → src/virtualSizes.d.ts} +1 -0
  25. package/dist/src/virtualSizes.d.ts.map +1 -0
  26. package/dist/src/virtualSizes.js +114 -0
  27. package/dist/test/chain.d.ts +2 -0
  28. package/dist/test/chain.d.ts.map +1 -0
  29. package/dist/test/chain.js +92 -0
  30. package/dist/test/dimensions.d.ts +2 -0
  31. package/dist/test/dimensions.d.ts.map +1 -0
  32. package/dist/test/dimensions.js +211 -0
  33. package/dist/test/signedTx/inputWeights.d.ts +2 -0
  34. package/dist/test/signedTx/inputWeights.d.ts.map +1 -0
  35. package/dist/test/signedTx/inputWeights.js +113 -0
  36. package/dist/test/signedTx/txCombinations.d.ts +3 -0
  37. package/dist/test/signedTx/txCombinations.d.ts.map +1 -0
  38. package/dist/test/signedTx/txCombinations.js +116 -0
  39. package/dist/test/signedTx/txGen.d.ts +75 -0
  40. package/dist/test/signedTx/txGen.d.ts.map +1 -0
  41. package/dist/test/signedTx/txGen.js +219 -0
  42. package/dist/test/testutils.d.ts +36 -0
  43. package/dist/test/testutils.d.ts.map +1 -0
  44. package/dist/test/testutils.js +176 -0
  45. package/dist/test/virtualSizes.d.ts +2 -0
  46. package/dist/test/virtualSizes.d.ts.map +1 -0
  47. package/dist/test/virtualSizes.js +18 -0
  48. package/dist/tsconfig.build.tsbuildinfo +1 -0
  49. package/dist/tsconfig.tsbuildinfo +1 -0
  50. package/docs/input-costs.md +13 -0
  51. package/package.json +5 -5
  52. package/dist/codes.js +0 -168
  53. package/dist/dimensions.js +0 -490
  54. package/dist/inputWeights.js +0 -97
  55. package/dist/scriptSizes.js +0 -51
  56. package/dist/virtualSizes.js +0 -114
@@ -0,0 +1,75 @@
1
+ /// <reference types="node" />
2
+ import * as utxolib from '@bitgo-beta/utxo-lib';
3
+ import { BIP32Interface } from '@bitgo-beta/utxo-lib';
4
+ import 'lodash.combinations';
5
+ import { Dimensions } from '../../src';
6
+ import { InputScriptType, TestUnspentType } from '../testutils';
7
+ interface IUnspent {
8
+ scriptPubKey: Buffer;
9
+ redeemScript?: Buffer;
10
+ witnessScript?: Buffer;
11
+ value: number;
12
+ inputType: utxolib.bitgo.outputScripts.ScriptType;
13
+ }
14
+ /**
15
+ *
16
+ * @param keys - Pubkeys to use for generating the address.
17
+ * If unspentType is one of UnspentTypePubKeyHash is used, the first key will be used.
18
+ * @param unspentType {String} - one of UnspentTypeScript2of3 or UnspentTypePubKeyHash
19
+ * @return {String} address
20
+ */
21
+ export declare const createScriptPubKey: (keys: BIP32Interface[], unspentType: TestUnspentType) => Buffer;
22
+ declare class TxCombo {
23
+ walletKeys: BIP32Interface[];
24
+ inputTypes: string[];
25
+ outputTypes: TestUnspentType[];
26
+ expectedDims: Readonly<Dimensions>;
27
+ signKeys?: utxolib.BIP32Interface[] | undefined;
28
+ inputValue: number;
29
+ unspents: IUnspent[];
30
+ inputTx: any;
31
+ constructor(walletKeys: BIP32Interface[], inputTypes: string[], outputTypes: TestUnspentType[], expectedDims?: Readonly<Dimensions>, signKeys?: utxolib.BIP32Interface[] | undefined, inputValue?: number);
32
+ getBuilderWithUnsignedTx(): utxolib.bitgo.UtxoTransactionBuilder;
33
+ getUnsignedTx(): utxolib.bitgo.UtxoTransaction;
34
+ getSignedTx(): utxolib.Transaction;
35
+ }
36
+ declare const runCombinations: ({ inputTypes, maxNInputs, outputTypes, maxNOutputs, }: {
37
+ inputTypes: InputScriptType[];
38
+ maxNInputs: number;
39
+ outputTypes: TestUnspentType[];
40
+ maxNOutputs: number;
41
+ }, callback: (inputCombo: InputScriptType[], outputCombo: TestUnspentType[]) => void) => void;
42
+ declare class Histogram {
43
+ map: Map<number, number>;
44
+ total: number;
45
+ constructor(map?: Map<number, number>);
46
+ add(size: number): void;
47
+ asSortedArray(): number[][];
48
+ asFullSortedArray(): number[][];
49
+ getPercentile(p: number): number;
50
+ toString(): string;
51
+ }
52
+ /**
53
+ *
54
+ * Calls `callback` with a variety of signed txs, based on input parameters
55
+ * Callback arguments are
56
+ * inputType, inputCount, outputType, txs
57
+ * where `txs` implements `forEach()`
58
+ *
59
+ * @param inputTypes - input types to test
60
+ * @param nInputKeyTriplets - number of different input key triples to cycle through
61
+ * @param outputTypes - output types to test
62
+ * @param nOutputKeyTriplets - number of different output key triplets to cycle through
63
+ * @param callback
64
+ */
65
+ declare const runSignedTransactions: ({ inputTypes, nInputKeyTriplets, outputTypes, nOutputKeyTriplets, }: {
66
+ inputTypes: Array<{
67
+ inputType: string;
68
+ count: number;
69
+ }>;
70
+ nInputKeyTriplets: number;
71
+ outputTypes: TestUnspentType[];
72
+ nOutputKeyTriplets: number;
73
+ }, callback: (inputType: string, inputCount: number, outputType: TestUnspentType, txs: any) => void) => void;
74
+ export { TxCombo, Histogram, runCombinations, runSignedTransactions };
75
+ //# sourceMappingURL=txGen.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"txGen.d.ts","sourceRoot":"","sources":["../../../test/signedTx/txGen.ts"],"names":[],"mappings":";AAEA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAS,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE7D,OAAO,qBAAqB,CAAC;AAC7B,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EACL,eAAe,EACf,eAAe,EAKhB,MAAM,cAAc,CAAC;AAEtB,UAAU,QAAQ;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,UAAU,CAAC;CACnD;AAoBD;;;;;;GAMG;AACH,eAAO,MAAM,kBAAkB,SAAU,cAAc,EAAE,eAAe,eAAe,KAAG,MAoBzF,CAAC;AAqCF,cAAM,OAAO;IAKF,UAAU,EAAE,cAAc,EAAE;IAC5B,UAAU,EAAE,MAAM,EAAE;IACpB,WAAW,EAAE,eAAe,EAAE;IAC9B,YAAY,EAAE,QAAQ,CAAC,UAAU,CAAC;IAClC,QAAQ,CAAC;IACT,UAAU,EAAE,MAAM;IATpB,QAAQ,EAAE,QAAQ,EAAE,CAAC;IACrB,OAAO,EAAE,GAAG,CAAC;gBAGX,UAAU,EAAE,cAAc,EAAE,EAC5B,UAAU,EAAE,MAAM,EAAE,EACpB,WAAW,EAAE,eAAe,EAAE,EAC9B,YAAY,GAAE,QAAQ,CAAC,UAAU,CAAmB,EACpD,QAAQ,CAAC,sCAAkB,EAC3B,UAAU,GAAE,MAAW;IAYzB,wBAAwB,IAAI,OAAO,CAAC,KAAK,CAAC,sBAAsB;IAShE,aAAa,IAAI,OAAO,CAAC,KAAK,CAAC,eAAe;IAI9C,WAAW,IAAI,OAAO,CAAC,WAAW;CAO1C;AAED,QAAA,MAAM,eAAe;gBAOL,eAAe,EAAE;gBACjB,MAAM;iBACL,eAAe,EAAE;iBACjB,MAAM;0BAEE,eAAe,EAAE,eAAe,eAAe,EAAE,KAAK,IAAI,KAChF,IAgBF,CAAC;AAEF,cAAM,SAAS;IAGM,GAAG,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC;IAFpC,KAAK,SAAK;gBAEE,GAAG,GAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAa;IAEhD,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAKvB,aAAa,IAAI,MAAM,EAAE,EAAE;IAI3B,iBAAiB,IAAI,MAAM,EAAE,EAAE;IAI/B,aAAa,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAgBhC,QAAQ,IAAI,MAAM;CAI1B;AAOD;;;;;;;;;;;;GAYG;AACH,QAAA,MAAM,qBAAqB;gBAOX,MAAM;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;uBACpC,MAAM;iBACZ,eAAe,EAAE;wBACV,MAAM;yBAEN,MAAM,cAAc,MAAM,cAAc,eAAe,OAAO,GAAG,KAAK,IAAI,KAC/F,IAyCF,CAAC;AAEF,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,qBAAqB,EAAE,CAAC"}
@@ -0,0 +1,219 @@
1
+ "use strict";
2
+ /* eslint-disable @typescript-eslint/ban-ts-comment */
3
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
+ if (k2 === undefined) k2 = k;
5
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
6
+ }) : (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ o[k2] = m[k];
9
+ }));
10
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
11
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
12
+ }) : function(o, v) {
13
+ o["default"] = v;
14
+ });
15
+ var __importStar = (this && this.__importStar) || function (mod) {
16
+ if (mod && mod.__esModule) return mod;
17
+ var result = {};
18
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
19
+ __setModuleDefault(result, mod);
20
+ return result;
21
+ };
22
+ var __importDefault = (this && this.__importDefault) || function (mod) {
23
+ return (mod && mod.__esModule) ? mod : { "default": mod };
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.runSignedTransactions = exports.runCombinations = exports.Histogram = exports.TxCombo = exports.createScriptPubKey = void 0;
27
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
28
+ const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
29
+ const lodash_1 = __importDefault(require("lodash"));
30
+ require("lodash.combinations");
31
+ const src_1 = require("../../src");
32
+ const testutils_1 = require("../testutils");
33
+ function createUnspent(pubkeys, inputType, value) {
34
+ let spendableScript;
35
+ const scriptType = inputType === 'taprootKeyPathSpend' ? 'p2trMusig2' : inputType;
36
+ if (scriptType === testutils_1.UnspentTypeP2shP2pk) {
37
+ spendableScript = utxolib.bitgo.outputScripts.createOutputScriptP2shP2pk(pubkeys[0]);
38
+ }
39
+ else if (utxolib.bitgo.outputScripts.isScriptType2Of3(scriptType)) {
40
+ spendableScript = utxolib.bitgo.outputScripts.createOutputScript2of3(pubkeys, scriptType);
41
+ }
42
+ else {
43
+ throw new Error(`unexpected inputType ${scriptType}`);
44
+ }
45
+ return {
46
+ ...spendableScript,
47
+ value,
48
+ inputType: scriptType,
49
+ };
50
+ }
51
+ /**
52
+ *
53
+ * @param keys - Pubkeys to use for generating the address.
54
+ * If unspentType is one of UnspentTypePubKeyHash is used, the first key will be used.
55
+ * @param unspentType {String} - one of UnspentTypeScript2of3 or UnspentTypePubKeyHash
56
+ * @return {String} address
57
+ */
58
+ const createScriptPubKey = (keys, unspentType) => {
59
+ const pubkeys = keys.map((key) => key.publicKey);
60
+ if (typeof unspentType === 'string' && unspentType in testutils_1.UnspentTypeScript2of3) {
61
+ return createUnspent(pubkeys, unspentType, 0).scriptPubKey;
62
+ }
63
+ const pkHash = utxolib.crypto.hash160(pubkeys[0]);
64
+ switch (unspentType) {
65
+ case testutils_1.UnspentTypePubKeyHash.p2pkh:
66
+ return utxolib.payments.p2pkh({ hash: pkHash }).output;
67
+ case testutils_1.UnspentTypePubKeyHash.p2wpkh:
68
+ return utxolib.payments.p2wpkh({ hash: pkHash }).output;
69
+ }
70
+ if (unspentType instanceof testutils_1.UnspentTypeOpReturn) {
71
+ const payload = Buffer.alloc(unspentType.size).fill(pubkeys[0]);
72
+ return utxolib.script.compile([0x6a, payload]);
73
+ }
74
+ throw new Error(`unsupported output type ${unspentType}`);
75
+ };
76
+ exports.createScriptPubKey = createScriptPubKey;
77
+ const createInputTx = (unspents, inputValue) => {
78
+ const txInputBuilder = new utxolib.bitgo.UtxoTransactionBuilder(utxolib.networks.bitcoin);
79
+ txInputBuilder.addInput(Array(32).fill('01').join(''), 0);
80
+ unspents.forEach(({ scriptPubKey }) => txInputBuilder.addOutput(scriptPubKey, inputValue));
81
+ return txInputBuilder.buildIncomplete();
82
+ };
83
+ function signInput(txBuilder, index, walletKeys, unspent, signKeys = unspent.inputType === 'p2shP2pk' ? [walletKeys[0]] : [walletKeys[0], walletKeys[2]]) {
84
+ signKeys.forEach((keyPair) => {
85
+ if (unspent.inputType === 'p2shP2pk') {
86
+ utxolib.bitgo.signInputP2shP2pk(txBuilder, index, keyPair);
87
+ }
88
+ else {
89
+ if (signKeys.length !== 2) {
90
+ throw new Error(`invalid signKeys length`);
91
+ }
92
+ const cosigner = keyPair === signKeys[0] ? signKeys[1] : signKeys[0];
93
+ utxolib.bitgo.signInput2Of3(txBuilder, index, unspent.inputType, walletKeys.map((k) => k.publicKey), keyPair, cosigner.publicKey, unspent.value);
94
+ }
95
+ });
96
+ }
97
+ class TxCombo {
98
+ constructor(walletKeys, inputTypes, outputTypes, expectedDims = src_1.Dimensions.ZERO, signKeys, inputValue = 10) {
99
+ this.walletKeys = walletKeys;
100
+ this.inputTypes = inputTypes;
101
+ this.outputTypes = outputTypes;
102
+ this.expectedDims = expectedDims;
103
+ this.signKeys = signKeys;
104
+ this.inputValue = inputValue;
105
+ this.unspents = inputTypes.map((inputType) => createUnspent(walletKeys.map((key) => key.publicKey), inputType, this.inputValue));
106
+ this.inputTx = createInputTx(this.unspents, inputValue);
107
+ }
108
+ getBuilderWithUnsignedTx() {
109
+ const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);
110
+ this.inputTx.outs.forEach(({}, i) => txBuilder.addInput(this.inputTx, i));
111
+ this.outputTypes.forEach((unspentType) => txBuilder.addOutput(exports.createScriptPubKey(this.walletKeys, unspentType), this.inputValue));
112
+ return txBuilder;
113
+ }
114
+ getUnsignedTx() {
115
+ return this.getBuilderWithUnsignedTx().buildIncomplete();
116
+ }
117
+ getSignedTx() {
118
+ const txBuilder = this.getBuilderWithUnsignedTx();
119
+ this.unspents.forEach((unspent, i) => {
120
+ signInput(txBuilder, i, this.walletKeys, unspent, this.signKeys);
121
+ });
122
+ return txBuilder.build();
123
+ }
124
+ }
125
+ exports.TxCombo = TxCombo;
126
+ const runCombinations = ({ inputTypes, maxNInputs, outputTypes, maxNOutputs, }, callback) => {
127
+ // Create combinations of different input and output types. Length between 1 and 3.
128
+ const inputCombinations = lodash_1.default.flatten(
129
+ // @ts-ignore
130
+ [...Array(maxNInputs)].map((__, i) => lodash_1.default.combinations(inputTypes, i + 1)));
131
+ const outputCombinations = lodash_1.default.flatten(
132
+ // @ts-ignore
133
+ [...Array(maxNOutputs)].map((__, i) => lodash_1.default.combinations(outputTypes, i + 1)));
134
+ inputCombinations.forEach((inputTypeCombo) => outputCombinations.forEach((outputTypeCombo) => {
135
+ callback(inputTypeCombo, outputTypeCombo);
136
+ }));
137
+ };
138
+ exports.runCombinations = runCombinations;
139
+ class Histogram {
140
+ constructor(map = new Map()) {
141
+ this.map = map;
142
+ this.total = 0;
143
+ }
144
+ add(size) {
145
+ this.map.set(size, (this.map.get(size) || 0) + 1);
146
+ this.total++;
147
+ }
148
+ asSortedArray() {
149
+ return [...this.map.entries()].sort(([a], [b]) => a - b);
150
+ }
151
+ asFullSortedArray() {
152
+ return lodash_1.default.range(this.getPercentile(0), this.getPercentile(1)).map((v) => [v, this.map.get(v) || 0]);
153
+ }
154
+ getPercentile(p) {
155
+ if (0 > p || p > 1) {
156
+ throw new Error(`p must be between 0 and 1`);
157
+ }
158
+ let sum = 0;
159
+ for (const [k, v] of this.asSortedArray()) {
160
+ sum += v;
161
+ if (sum / this.total >= p) {
162
+ return k;
163
+ }
164
+ }
165
+ throw new Error('could not find percentile');
166
+ }
167
+ toString() {
168
+ const keys = [...this.map.keys()].sort((a, b) => a - b);
169
+ return `[${keys.map((k) => `[${k}, ${this.map.get(k)}]`).join(' ')}]`;
170
+ }
171
+ }
172
+ exports.Histogram = Histogram;
173
+ const getKeyTriplets = (prefix, count) => [...Array(count)].map((v, i) => [1, 2, 3].map((j) => utxo_lib_1.bip32.fromSeed(Buffer.alloc(16, `${prefix}/${i}/${j}`), utxolib.networks.bitcoin)));
174
+ /**
175
+ *
176
+ * Calls `callback` with a variety of signed txs, based on input parameters
177
+ * Callback arguments are
178
+ * inputType, inputCount, outputType, txs
179
+ * where `txs` implements `forEach()`
180
+ *
181
+ * @param inputTypes - input types to test
182
+ * @param nInputKeyTriplets - number of different input key triples to cycle through
183
+ * @param outputTypes - output types to test
184
+ * @param nOutputKeyTriplets - number of different output key triplets to cycle through
185
+ * @param callback
186
+ */
187
+ const runSignedTransactions = ({ inputTypes, nInputKeyTriplets, outputTypes, nOutputKeyTriplets, }, callback) => {
188
+ const inputKeyTriplets = getKeyTriplets('test/input/', nInputKeyTriplets);
189
+ const outputKeyTriplets = getKeyTriplets('test/output/', nOutputKeyTriplets);
190
+ const outputValue = 1e8;
191
+ inputTypes.forEach(({ inputType, count: inputCount }) => {
192
+ const inputTxs = inputKeyTriplets.map((inputKeys) => {
193
+ const unspents = [...Array(inputCount)].map(() => createUnspent(inputKeys.map((key) => key.publicKey), inputType, outputValue));
194
+ const inputTx = createInputTx(unspents, outputValue);
195
+ return { inputKeys, unspents, inputTx };
196
+ });
197
+ outputTypes.forEach((outputType) => {
198
+ const outputs = outputKeyTriplets.map((outputKeys) => exports.createScriptPubKey(outputKeys, outputType));
199
+ const txs = {
200
+ forEach(cb) {
201
+ inputTxs.forEach(({ inputKeys, unspents, inputTx }) => {
202
+ outputs.forEach((scriptPubKey) => {
203
+ const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);
204
+ inputTx.outs.forEach((v, i) => txBuilder.addInput(inputTx, i));
205
+ txBuilder.addOutput(scriptPubKey, outputValue);
206
+ unspents.forEach((unspent, i) => {
207
+ signInput(txBuilder, i, inputKeys, unspent);
208
+ });
209
+ cb(txBuilder.build());
210
+ });
211
+ });
212
+ },
213
+ };
214
+ callback(inputType, inputCount, outputType, txs);
215
+ });
216
+ });
217
+ };
218
+ exports.runSignedTransactions = runSignedTransactions;
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"txGen.js","sourceRoot":"","sources":["../../../test/signedTx/txGen.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\n\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { bip32, BIP32Interface } from '@bitgo-beta/utxo-lib';\nimport _ from 'lodash';\nimport 'lodash.combinations';\nimport { Dimensions } from '../../src';\nimport {\n  InputScriptType,\n  TestUnspentType,\n  UnspentTypeOpReturn,\n  UnspentTypeP2shP2pk,\n  UnspentTypePubKeyHash,\n  UnspentTypeScript2of3,\n} from '../testutils';\n\ninterface IUnspent {\n  scriptPubKey: Buffer;\n  redeemScript?: Buffer;\n  witnessScript?: Buffer;\n  value: number;\n  inputType: utxolib.bitgo.outputScripts.ScriptType;\n}\n\nfunction createUnspent(pubkeys: Buffer[], inputType: string, value: number): IUnspent {\n  let spendableScript;\n  const scriptType = inputType === 'taprootKeyPathSpend' ? 'p2trMusig2' : inputType;\n  if (scriptType === UnspentTypeP2shP2pk) {\n    spendableScript = utxolib.bitgo.outputScripts.createOutputScriptP2shP2pk(pubkeys[0]);\n  } else if (utxolib.bitgo.outputScripts.isScriptType2Of3(scriptType)) {\n    spendableScript = utxolib.bitgo.outputScripts.createOutputScript2of3(pubkeys, scriptType);\n  } else {\n    throw new Error(`unexpected inputType ${scriptType}`);\n  }\n\n  return {\n    ...spendableScript,\n    value,\n    inputType: scriptType,\n  };\n}\n\n/**\n *\n * @param keys - Pubkeys to use for generating the address.\n *               If unspentType is one of UnspentTypePubKeyHash is used, the first key will be used.\n * @param unspentType {String} - one of UnspentTypeScript2of3 or UnspentTypePubKeyHash\n * @return {String} address\n */\nexport const createScriptPubKey = (keys: BIP32Interface[], unspentType: TestUnspentType): Buffer => {\n  const pubkeys = keys.map((key) => key.publicKey);\n  if (typeof unspentType === 'string' && unspentType in UnspentTypeScript2of3) {\n    return createUnspent(pubkeys, unspentType, 0).scriptPubKey;\n  }\n\n  const pkHash = utxolib.crypto.hash160(pubkeys[0]);\n  switch (unspentType) {\n    case UnspentTypePubKeyHash.p2pkh:\n      return utxolib.payments.p2pkh({ hash: pkHash }).output!;\n    case UnspentTypePubKeyHash.p2wpkh:\n      return utxolib.payments.p2wpkh({ hash: pkHash }).output!;\n  }\n\n  if (unspentType instanceof UnspentTypeOpReturn) {\n    const payload = Buffer.alloc(unspentType.size).fill(pubkeys[0]);\n    return utxolib.script.compile([0x6a, payload]);\n  }\n\n  throw new Error(`unsupported output type ${unspentType}`);\n};\n\nconst createInputTx = (unspents: any[], inputValue: number) => {\n  const txInputBuilder = new utxolib.bitgo.UtxoTransactionBuilder(utxolib.networks.bitcoin);\n  txInputBuilder.addInput(Array(32).fill('01').join(''), 0);\n  unspents.forEach(({ scriptPubKey }) => txInputBuilder.addOutput(scriptPubKey, inputValue));\n  return txInputBuilder.buildIncomplete();\n};\n\nfunction signInput(\n  txBuilder: utxolib.bitgo.UtxoTransactionBuilder,\n  index: number,\n  walletKeys: BIP32Interface[],\n  unspent: IUnspent,\n  signKeys: BIP32Interface[] = unspent.inputType === 'p2shP2pk' ? [walletKeys[0]] : [walletKeys[0], walletKeys[2]]\n) {\n  signKeys.forEach((keyPair) => {\n    if (unspent.inputType === 'p2shP2pk') {\n      utxolib.bitgo.signInputP2shP2pk(txBuilder, index, keyPair);\n    } else {\n      if (signKeys.length !== 2) {\n        throw new Error(`invalid signKeys length`);\n      }\n      const cosigner = keyPair === signKeys[0] ? signKeys[1] : signKeys[0];\n      utxolib.bitgo.signInput2Of3(\n        txBuilder,\n        index,\n        unspent.inputType,\n        walletKeys.map((k) => k.publicKey) as utxolib.bitgo.Triple<Buffer>,\n        keyPair,\n        cosigner.publicKey,\n        unspent.value\n      );\n    }\n  });\n}\n\nclass TxCombo {\n  public unspents: IUnspent[];\n  public inputTx: any;\n\n  constructor(\n    public walletKeys: BIP32Interface[],\n    public inputTypes: string[],\n    public outputTypes: TestUnspentType[],\n    public expectedDims: Readonly<Dimensions> = Dimensions.ZERO,\n    public signKeys?: BIP32Interface[],\n    public inputValue: number = 10\n  ) {\n    this.unspents = inputTypes.map((inputType) =>\n      createUnspent(\n        walletKeys.map((key) => key.publicKey),\n        inputType,\n        this.inputValue\n      )\n    );\n    this.inputTx = createInputTx(this.unspents, inputValue);\n  }\n\n  public getBuilderWithUnsignedTx(): utxolib.bitgo.UtxoTransactionBuilder {\n    const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);\n    this.inputTx.outs.forEach(({}, i: number) => txBuilder.addInput(this.inputTx, i));\n    this.outputTypes.forEach((unspentType) =>\n      txBuilder.addOutput(createScriptPubKey(this.walletKeys, unspentType), this.inputValue)\n    );\n    return txBuilder;\n  }\n\n  public getUnsignedTx(): utxolib.bitgo.UtxoTransaction {\n    return this.getBuilderWithUnsignedTx().buildIncomplete();\n  }\n\n  public getSignedTx(): utxolib.Transaction {\n    const txBuilder = this.getBuilderWithUnsignedTx();\n    this.unspents.forEach((unspent, i) => {\n      signInput(txBuilder, i, this.walletKeys, unspent, this.signKeys);\n    });\n    return txBuilder.build();\n  }\n}\n\nconst runCombinations = (\n  {\n    inputTypes,\n    maxNInputs,\n    outputTypes,\n    maxNOutputs,\n  }: {\n    inputTypes: InputScriptType[];\n    maxNInputs: number;\n    outputTypes: TestUnspentType[];\n    maxNOutputs: number;\n  },\n  callback: (inputCombo: InputScriptType[], outputCombo: TestUnspentType[]) => void\n): void => {\n  // Create combinations of different input and output types. Length between 1 and 3.\n  const inputCombinations = _.flatten(\n    // @ts-ignore\n    [...Array(maxNInputs)].map((__, i) => _.combinations(inputTypes, i + 1))\n  );\n  const outputCombinations = _.flatten(\n    // @ts-ignore\n    [...Array(maxNOutputs)].map((__, i) => _.combinations(outputTypes, i + 1))\n  );\n\n  inputCombinations.forEach((inputTypeCombo) =>\n    outputCombinations.forEach((outputTypeCombo) => {\n      callback(inputTypeCombo, outputTypeCombo);\n    })\n  );\n};\n\nclass Histogram {\n  public total = 0;\n\n  constructor(public map: Map<number, number> = new Map()) {}\n\n  public add(size: number): void {\n    this.map.set(size, (this.map.get(size) || 0) + 1);\n    this.total++;\n  }\n\n  public asSortedArray(): number[][] {\n    return [...this.map.entries()].sort(([a], [b]) => a - b);\n  }\n\n  public asFullSortedArray(): number[][] {\n    return _.range(this.getPercentile(0), this.getPercentile(1)).map((v) => [v, this.map.get(v) || 0]);\n  }\n\n  public getPercentile(p: number): number {\n    if (0 > p || p > 1) {\n      throw new Error(`p must be between 0 and 1`);\n    }\n\n    let sum = 0;\n    for (const [k, v] of this.asSortedArray()) {\n      sum += v;\n      if (sum / this.total >= p) {\n        return k;\n      }\n    }\n\n    throw new Error('could not find percentile');\n  }\n\n  public toString(): string {\n    const keys = [...this.map.keys()].sort((a, b) => a - b);\n    return `[${keys.map((k) => `[${k}, ${this.map.get(k)}]`).join(' ')}]`;\n  }\n}\n\nconst getKeyTriplets = (prefix: string, count: number) =>\n  [...Array(count)].map((v, i) =>\n    [1, 2, 3].map((j) => bip32.fromSeed(Buffer.alloc(16, `${prefix}/${i}/${j}`), utxolib.networks.bitcoin))\n  );\n\n/**\n *\n * Calls `callback` with a variety of signed txs, based on input parameters\n * Callback arguments are\n *   inputType, inputCount, outputType, txs\n *  where `txs` implements `forEach()`\n *\n * @param inputTypes - input types to test\n * @param nInputKeyTriplets - number of different input key triples to cycle through\n * @param outputTypes - output types to test\n * @param nOutputKeyTriplets - number of different output key triplets to cycle through\n * @param callback\n */\nconst runSignedTransactions = (\n  {\n    inputTypes,\n    nInputKeyTriplets,\n    outputTypes,\n    nOutputKeyTriplets,\n  }: {\n    inputTypes: Array<{ inputType: string; count: number }>;\n    nInputKeyTriplets: number;\n    outputTypes: TestUnspentType[];\n    nOutputKeyTriplets: number;\n  },\n  callback: (inputType: string, inputCount: number, outputType: TestUnspentType, txs: any) => void\n): void => {\n  const inputKeyTriplets = getKeyTriplets('test/input/', nInputKeyTriplets);\n  const outputKeyTriplets = getKeyTriplets('test/output/', nOutputKeyTriplets);\n  const outputValue = 1e8;\n\n  inputTypes.forEach(({ inputType, count: inputCount }) => {\n    const inputTxs = inputKeyTriplets.map((inputKeys) => {\n      const unspents = [...Array(inputCount)].map(() =>\n        createUnspent(\n          inputKeys.map((key) => key.publicKey),\n          inputType,\n          outputValue\n        )\n      );\n      const inputTx = createInputTx(unspents, outputValue);\n      return { inputKeys, unspents, inputTx };\n    });\n\n    outputTypes.forEach((outputType) => {\n      const outputs = outputKeyTriplets.map((outputKeys) => createScriptPubKey(outputKeys, outputType));\n\n      const txs = {\n        forEach(cb: (tx: utxolib.Transaction) => void) {\n          inputTxs.forEach(({ inputKeys, unspents, inputTx }) => {\n            outputs.forEach((scriptPubKey) => {\n              const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);\n              inputTx.outs.forEach((v: any, i: number) => txBuilder.addInput(inputTx, i));\n              txBuilder.addOutput(scriptPubKey, outputValue);\n              unspents.forEach((unspent, i) => {\n                signInput(txBuilder, i, inputKeys, unspent);\n              });\n\n              cb(txBuilder.build());\n            });\n          });\n        },\n      };\n\n      callback(inputType, inputCount, outputType, txs);\n    });\n  });\n};\n\nexport { TxCombo, Histogram, runCombinations, runSignedTransactions };\n"]}
@@ -0,0 +1,36 @@
1
+ import * as unspents from '../src';
2
+ import * as utxolib from '@bitgo-beta/utxo-lib';
3
+ export declare const UnspentTypeP2shP2pk = "p2shP2pk";
4
+ export declare const UnspentTypeScript2of3: {
5
+ p2sh: string;
6
+ p2shP2wsh: string;
7
+ p2wsh: string;
8
+ p2tr: string;
9
+ p2trMusig2: string;
10
+ taprootKeyPathSpend: string;
11
+ };
12
+ export declare const UnspentTypePubKeyHash: {
13
+ p2pkh: 'p2pkh';
14
+ p2wpkh: 'p2wpkh';
15
+ };
16
+ export declare type TestUnspentType = string | UnspentTypeOpReturn;
17
+ export declare class UnspentTypeOpReturn {
18
+ size: number;
19
+ constructor(size: number);
20
+ toString(): string;
21
+ }
22
+ export declare type InputScriptType = utxolib.bitgo.outputScripts.ScriptType | 'taprootKeyPathSpend';
23
+ export declare function getInputScriptTypes(): InputScriptType[];
24
+ /**
25
+ * Return the input dimensions based on unspent type
26
+ * @param unspentType - one of UnspentTypeScript2of3
27
+ * @return Dimensions
28
+ */
29
+ export declare const getInputDimensionsForUnspentType: (unspentType: TestUnspentType) => unspents.Dimensions;
30
+ export declare const getOutputDimensionsForUnspentType: (unspentType: TestUnspentType) => unspents.Dimensions;
31
+ export declare function constructPsbt(keys: utxolib.bitgo.RootWalletKeys, inputTypes: InputScriptType[], outputTypes: TestUnspentType[], signatureStatus: 'unsigned' | 'halfsigned' | 'fullysigned', signers?: {
32
+ signerName: utxolib.bitgo.KeyName;
33
+ cosignerName: utxolib.bitgo.KeyName;
34
+ }): utxolib.bitgo.UtxoPsbt<utxolib.bitgo.UtxoTransaction<bigint>>;
35
+ export declare function getSignedTransaction(keys: utxolib.bitgo.RootWalletKeys, signerName: utxolib.bitgo.KeyName, cosignerName: utxolib.bitgo.KeyName, inputTypes: InputScriptType[], outputTypes: TestUnspentType[]): utxolib.bitgo.UtxoTransaction;
36
+ //# sourceMappingURL=testutils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"testutils.d.ts","sourceRoot":"","sources":["../../test/testutils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,QAAQ,CAAC;AACnC,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAYhD,eAAO,MAAM,mBAAmB,aAAa,CAAC;AAG9C,eAAO,MAAM,qBAAqB,EAAE;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,mBAAmB,EAAE,MAAM,CAAC;CACyD,CAAC;AAExF,eAAO,MAAM,qBAAqB,EAAE;IAClC,KAAK,EAAE,OAAO,CAAC;IACf,MAAM,EAAE,QAAQ,CAAC;CACY,CAAC;AAEhC,oBAAY,eAAe,GAAG,MAAM,GAAG,mBAAmB,CAAC;AAE3D,qBAAa,mBAAmB;IACX,IAAI,EAAE,MAAM;gBAAZ,IAAI,EAAE,MAAM;IAExB,QAAQ,IAAI,MAAM;CAG1B;AAED,oBAAY,eAAe,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,UAAU,GAAG,qBAAqB,CAAC;AAE7F,wBAAgB,mBAAmB,IAAI,eAAe,EAAE,CAEvD;AAED;;;;GAIG;AACH,eAAO,MAAM,gCAAgC,gBAAiB,eAAe,KAAG,SAAS,UAiBxF,CAAC;AAEF,eAAO,MAAM,iCAAiC,gBAAiB,eAAe,KAAG,SAAS,UAuBzF,CAAC;AAkBF,wBAAgB,aAAa,CAC3B,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,cAAc,EAClC,UAAU,EAAE,eAAe,EAAE,EAC7B,WAAW,EAAE,eAAe,EAAE,EAC9B,eAAe,EAAE,UAAU,GAAG,YAAY,GAAG,aAAa,EAC1D,OAAO,CAAC,EAAE;IAAE,UAAU,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC;IAAC,YAAY,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAA;CAAE,GACnF,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAwD/D;AAED,wBAAgB,oBAAoB,CAClC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,cAAc,EAClC,UAAU,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,EACjC,YAAY,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,EACnC,UAAU,EAAE,eAAe,EAAE,EAC7B,WAAW,EAAE,eAAe,EAAE,GAC7B,OAAO,CAAC,KAAK,CAAC,eAAe,CAI/B"}
@@ -0,0 +1,176 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.getSignedTransaction = exports.constructPsbt = exports.getOutputDimensionsForUnspentType = exports.getInputDimensionsForUnspentType = exports.getInputScriptTypes = exports.UnspentTypeOpReturn = exports.UnspentTypePubKeyHash = exports.UnspentTypeScript2of3 = exports.UnspentTypeP2shP2pk = void 0;
26
+ const unspents = __importStar(require("../src"));
27
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
28
+ const assert_1 = __importDefault(require("assert"));
29
+ const txGen_1 = require("./signedTx/txGen");
30
+ /**
31
+ * makeEnum('a', 'b') returns `{ a: 'a', b: 'b' }`
32
+ *
33
+ * @param args
34
+ * @return map with string keys and symbol values
35
+ */
36
+ const makeEnum = (...args) => args.reduce((obj, key) => Object.assign(obj, { [key]: key }), {});
37
+ exports.UnspentTypeP2shP2pk = 'p2shP2pk';
38
+ // p2trMusig2 is assumed to be script path only. taprootKeyPathSpend is for p2trMusig2 key path
39
+ exports.UnspentTypeScript2of3 = makeEnum('p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2', 'taprootKeyPathSpend');
40
+ exports.UnspentTypePubKeyHash = makeEnum('p2pkh', 'p2wpkh');
41
+ class UnspentTypeOpReturn {
42
+ constructor(size) {
43
+ this.size = size;
44
+ }
45
+ toString() {
46
+ return `opReturn(${this.size})`;
47
+ }
48
+ }
49
+ exports.UnspentTypeOpReturn = UnspentTypeOpReturn;
50
+ function getInputScriptTypes() {
51
+ return [...utxolib.bitgo.outputScripts.scriptTypes2Of3, 'p2shP2pk', 'taprootKeyPathSpend'];
52
+ }
53
+ exports.getInputScriptTypes = getInputScriptTypes;
54
+ /**
55
+ * Return the input dimensions based on unspent type
56
+ * @param unspentType - one of UnspentTypeScript2of3
57
+ * @return Dimensions
58
+ */
59
+ const getInputDimensionsForUnspentType = (unspentType) => {
60
+ switch (unspentType) {
61
+ case exports.UnspentTypeScript2of3.p2sh:
62
+ return unspents.Dimensions.sum({ nP2shInputs: 1 });
63
+ case exports.UnspentTypeScript2of3.p2shP2wsh:
64
+ return unspents.Dimensions.sum({ nP2shP2wshInputs: 1 });
65
+ case exports.UnspentTypeScript2of3.p2wsh:
66
+ return unspents.Dimensions.sum({ nP2wshInputs: 1 });
67
+ case exports.UnspentTypeScript2of3.p2tr:
68
+ case exports.UnspentTypeScript2of3.p2trMusig2:
69
+ return unspents.Dimensions.sum({ nP2trScriptPathLevel1Inputs: 1 });
70
+ case exports.UnspentTypeScript2of3.taprootKeyPathSpend:
71
+ return unspents.Dimensions.sum({ nP2trKeypathInputs: 1 });
72
+ case exports.UnspentTypeP2shP2pk:
73
+ return unspents.Dimensions.sum({ nP2shP2pkInputs: 1 });
74
+ }
75
+ throw new Error(`no input dimensions for ${unspentType}`);
76
+ };
77
+ exports.getInputDimensionsForUnspentType = getInputDimensionsForUnspentType;
78
+ const getOutputDimensionsForUnspentType = (unspentType) => {
79
+ /* The values here are validated in the test 'calculates output dimensions dynamically' */
80
+ switch (unspentType) {
81
+ case exports.UnspentTypeScript2of3.p2sh:
82
+ case exports.UnspentTypeScript2of3.p2shP2wsh:
83
+ case exports.UnspentTypeP2shP2pk:
84
+ return unspents.Dimensions.fromOutputScriptLength(23);
85
+ case exports.UnspentTypeScript2of3.p2wsh:
86
+ return unspents.Dimensions.fromOutputScriptLength(34);
87
+ case exports.UnspentTypeScript2of3.p2tr:
88
+ case exports.UnspentTypeScript2of3.p2trMusig2:
89
+ case exports.UnspentTypeScript2of3.taprootKeyPathSpend:
90
+ return unspents.Dimensions.fromOutputScriptLength(34);
91
+ case exports.UnspentTypePubKeyHash.p2pkh:
92
+ return unspents.Dimensions.fromOutputScriptLength(25);
93
+ case exports.UnspentTypePubKeyHash.p2wpkh:
94
+ return unspents.Dimensions.fromOutputScriptLength(22);
95
+ default:
96
+ if (unspentType instanceof UnspentTypeOpReturn) {
97
+ return unspents.Dimensions.fromOutputScriptLength(1 + unspentType.size);
98
+ }
99
+ throw new TypeError(`unknown unspentType ${unspentType}`);
100
+ }
101
+ };
102
+ exports.getOutputDimensionsForUnspentType = getOutputDimensionsForUnspentType;
103
+ function getDefaultSignerNames(inputType, signers) {
104
+ if (signers) {
105
+ return [signers.signerName, signers.cosignerName];
106
+ }
107
+ if (inputType === 'p2shP2pk') {
108
+ return ['user'];
109
+ }
110
+ if (inputType === 'p2trMusig2') {
111
+ return ['user', 'backup'];
112
+ }
113
+ return ['user', 'bitgo'];
114
+ }
115
+ function constructPsbt(keys, inputTypes, outputTypes, signatureStatus, signers) {
116
+ const psbt = utxolib.bitgo.createPsbtForNetwork({ network: utxolib.networks.bitcoin });
117
+ inputTypes.forEach((t, i) => {
118
+ if (t === 'p2shP2pk') {
119
+ const signer = keys[getDefaultSignerNames(t, signers)[0]];
120
+ const unspent = utxolib.testutil.mockReplayProtectionUnspent(utxolib.networks.bitcoin, BigInt(10), {
121
+ key: signer,
122
+ vout: i,
123
+ });
124
+ const { redeemScript } = utxolib.bitgo.outputScripts.createOutputScriptP2shP2pk(signer.publicKey);
125
+ assert_1.default.ok(redeemScript);
126
+ utxolib.bitgo.addReplayProtectionUnspentToPsbt(psbt, unspent, redeemScript);
127
+ }
128
+ else {
129
+ const unspent = utxolib.testutil.mockWalletUnspent(utxolib.networks.bitcoin, BigInt(10), {
130
+ keys,
131
+ chain: utxolib.bitgo.getExternalChainCode(t === 'taprootKeyPathSpend' ? 'p2trMusig2' : t),
132
+ vout: i,
133
+ index: i,
134
+ });
135
+ const signerNames = getDefaultSignerNames(t, signers);
136
+ utxolib.bitgo.addWalletUnspentToPsbt(psbt, unspent, keys, signerNames[0], signerNames[1]);
137
+ }
138
+ });
139
+ outputTypes.forEach((t, index) => {
140
+ psbt.addOutput({
141
+ script: txGen_1.createScriptPubKey(keys.triple, t),
142
+ value: BigInt(10),
143
+ });
144
+ });
145
+ if (signatureStatus === 'unsigned') {
146
+ return psbt;
147
+ }
148
+ psbt.setAllInputsMusig2NonceHD(keys['user']);
149
+ psbt.setAllInputsMusig2NonceHD(keys['bitgo']);
150
+ inputTypes.forEach((t, i) => {
151
+ const signerNames = getDefaultSignerNames(t, signers);
152
+ if (t === 'p2shP2pk') {
153
+ if (signatureStatus === 'fullysigned') {
154
+ psbt.signInput(i, keys[signerNames[0]]);
155
+ }
156
+ }
157
+ else {
158
+ psbt.signInputHD(i, keys[signerNames[0]]);
159
+ if (signatureStatus === 'fullysigned') {
160
+ psbt.signInputHD(i, keys[signerNames[1]]);
161
+ }
162
+ }
163
+ });
164
+ if (signatureStatus === 'fullysigned') {
165
+ assert_1.default.ok(psbt.validateSignaturesOfAllInputs());
166
+ }
167
+ return psbt;
168
+ }
169
+ exports.constructPsbt = constructPsbt;
170
+ function getSignedTransaction(keys, signerName, cosignerName, inputTypes, outputTypes) {
171
+ const psbt = constructPsbt(keys, inputTypes, outputTypes, 'fullysigned', { signerName, cosignerName });
172
+ psbt.finalizeAllInputs();
173
+ return psbt.extractTransaction().clone('number');
174
+ }
175
+ exports.getSignedTransaction = getSignedTransaction;
176
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"testutils.js","sourceRoot":"","sources":["../../test/testutils.ts"],"names":[],"mappings":"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","sourcesContent":["import * as unspents from '../src';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport assert from 'assert';\nimport { createScriptPubKey } from './signedTx/txGen';\n\n/**\n * makeEnum('a', 'b') returns `{ a: 'a', b: 'b' }`\n *\n * @param args\n * @return map with string keys and symbol values\n */\nconst makeEnum = (...args: string[]): any => args.reduce((obj, key) => Object.assign(obj, { [key]: key }), {});\n\nexport const UnspentTypeP2shP2pk = 'p2shP2pk';\n\n// p2trMusig2 is assumed to be script path only. taprootKeyPathSpend is for p2trMusig2 key path\nexport const UnspentTypeScript2of3: {\n  p2sh: string;\n  p2shP2wsh: string;\n  p2wsh: string;\n  p2tr: string;\n  p2trMusig2: string;\n  taprootKeyPathSpend: string;\n} = makeEnum('p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2', 'taprootKeyPathSpend');\n\nexport const UnspentTypePubKeyHash: {\n  p2pkh: 'p2pkh';\n  p2wpkh: 'p2wpkh';\n} = makeEnum('p2pkh', 'p2wpkh');\n\nexport type TestUnspentType = string | UnspentTypeOpReturn;\n\nexport class UnspentTypeOpReturn {\n  constructor(public size: number) {}\n\n  public toString(): string {\n    return `opReturn(${this.size})`;\n  }\n}\n\nexport type InputScriptType = utxolib.bitgo.outputScripts.ScriptType | 'taprootKeyPathSpend';\n\nexport function getInputScriptTypes(): InputScriptType[] {\n  return [...utxolib.bitgo.outputScripts.scriptTypes2Of3, 'p2shP2pk', 'taprootKeyPathSpend'];\n}\n\n/**\n * Return the input dimensions based on unspent type\n * @param unspentType - one of UnspentTypeScript2of3\n * @return Dimensions\n */\nexport const getInputDimensionsForUnspentType = (unspentType: TestUnspentType): unspents.Dimensions => {\n  switch (unspentType) {\n    case UnspentTypeScript2of3.p2sh:\n      return unspents.Dimensions.sum({ nP2shInputs: 1 });\n    case UnspentTypeScript2of3.p2shP2wsh:\n      return unspents.Dimensions.sum({ nP2shP2wshInputs: 1 });\n    case UnspentTypeScript2of3.p2wsh:\n      return unspents.Dimensions.sum({ nP2wshInputs: 1 });\n    case UnspentTypeScript2of3.p2tr:\n    case UnspentTypeScript2of3.p2trMusig2:\n      return unspents.Dimensions.sum({ nP2trScriptPathLevel1Inputs: 1 });\n    case UnspentTypeScript2of3.taprootKeyPathSpend:\n      return unspents.Dimensions.sum({ nP2trKeypathInputs: 1 });\n    case UnspentTypeP2shP2pk:\n      return unspents.Dimensions.sum({ nP2shP2pkInputs: 1 });\n  }\n  throw new Error(`no input dimensions for ${unspentType}`);\n};\n\nexport const getOutputDimensionsForUnspentType = (unspentType: TestUnspentType): unspents.Dimensions => {\n  /* The values here are validated in the test 'calculates output dimensions dynamically' */\n  switch (unspentType) {\n    case UnspentTypeScript2of3.p2sh:\n    case UnspentTypeScript2of3.p2shP2wsh:\n    case UnspentTypeP2shP2pk:\n      return unspents.Dimensions.fromOutputScriptLength(23);\n    case UnspentTypeScript2of3.p2wsh:\n      return unspents.Dimensions.fromOutputScriptLength(34);\n    case UnspentTypeScript2of3.p2tr:\n    case UnspentTypeScript2of3.p2trMusig2:\n    case UnspentTypeScript2of3.taprootKeyPathSpend:\n      return unspents.Dimensions.fromOutputScriptLength(34);\n    case UnspentTypePubKeyHash.p2pkh:\n      return unspents.Dimensions.fromOutputScriptLength(25);\n    case UnspentTypePubKeyHash.p2wpkh:\n      return unspents.Dimensions.fromOutputScriptLength(22);\n    default:\n      if (unspentType instanceof UnspentTypeOpReturn) {\n        return unspents.Dimensions.fromOutputScriptLength(1 + unspentType.size);\n      }\n      throw new TypeError(`unknown unspentType ${unspentType}`);\n  }\n};\n\nfunction getDefaultSignerNames(\n  inputType: InputScriptType,\n  signers?: { signerName: utxolib.bitgo.KeyName; cosignerName: utxolib.bitgo.KeyName }\n): utxolib.bitgo.KeyName[] {\n  if (signers) {\n    return [signers.signerName, signers.cosignerName];\n  }\n  if (inputType === 'p2shP2pk') {\n    return ['user'];\n  }\n  if (inputType === 'p2trMusig2') {\n    return ['user', 'backup'];\n  }\n  return ['user', 'bitgo'];\n}\n\nexport function constructPsbt(\n  keys: utxolib.bitgo.RootWalletKeys,\n  inputTypes: InputScriptType[],\n  outputTypes: TestUnspentType[],\n  signatureStatus: 'unsigned' | 'halfsigned' | 'fullysigned',\n  signers?: { signerName: utxolib.bitgo.KeyName; cosignerName: utxolib.bitgo.KeyName }\n): utxolib.bitgo.UtxoPsbt<utxolib.bitgo.UtxoTransaction<bigint>> {\n  const psbt = utxolib.bitgo.createPsbtForNetwork({ network: utxolib.networks.bitcoin });\n\n  inputTypes.forEach((t, i) => {\n    if (t === 'p2shP2pk') {\n      const signer = keys[getDefaultSignerNames(t, signers)[0]];\n      const unspent = utxolib.testutil.mockReplayProtectionUnspent(utxolib.networks.bitcoin, BigInt(10), {\n        key: signer,\n        vout: i,\n      });\n      const { redeemScript } = utxolib.bitgo.outputScripts.createOutputScriptP2shP2pk(signer.publicKey);\n      assert.ok(redeemScript);\n      utxolib.bitgo.addReplayProtectionUnspentToPsbt(psbt, unspent, redeemScript);\n    } else {\n      const unspent = utxolib.testutil.mockWalletUnspent(utxolib.networks.bitcoin, BigInt(10), {\n        keys,\n        chain: utxolib.bitgo.getExternalChainCode(t === 'taprootKeyPathSpend' ? 'p2trMusig2' : t),\n        vout: i,\n        index: i,\n      });\n      const signerNames = getDefaultSignerNames(t, signers);\n      utxolib.bitgo.addWalletUnspentToPsbt(psbt, unspent, keys, signerNames[0], signerNames[1]);\n    }\n  });\n\n  outputTypes.forEach((t, index) => {\n    psbt.addOutput({\n      script: createScriptPubKey(keys.triple, t),\n      value: BigInt(10),\n    });\n  });\n\n  if (signatureStatus === 'unsigned') {\n    return psbt;\n  }\n\n  psbt.setAllInputsMusig2NonceHD(keys['user']);\n  psbt.setAllInputsMusig2NonceHD(keys['bitgo']);\n\n  inputTypes.forEach((t, i) => {\n    const signerNames = getDefaultSignerNames(t, signers);\n    if (t === 'p2shP2pk') {\n      if (signatureStatus === 'fullysigned') {\n        psbt.signInput(i, keys[signerNames[0]]);\n      }\n    } else {\n      psbt.signInputHD(i, keys[signerNames[0]]);\n      if (signatureStatus === 'fullysigned') {\n        psbt.signInputHD(i, keys[signerNames[1]]);\n      }\n    }\n  });\n  if (signatureStatus === 'fullysigned') {\n    assert.ok(psbt.validateSignaturesOfAllInputs());\n  }\n  return psbt;\n}\n\nexport function getSignedTransaction(\n  keys: utxolib.bitgo.RootWalletKeys,\n  signerName: utxolib.bitgo.KeyName,\n  cosignerName: utxolib.bitgo.KeyName,\n  inputTypes: InputScriptType[],\n  outputTypes: TestUnspentType[]\n): utxolib.bitgo.UtxoTransaction {\n  const psbt = constructPsbt(keys, inputTypes, outputTypes, 'fullysigned', { signerName, cosignerName });\n  psbt.finalizeAllInputs();\n  return (psbt.extractTransaction() as utxolib.bitgo.UtxoTransaction<bigint>).clone<number>('number');\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=virtualSizes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"virtualSizes.d.ts","sourceRoot":"","sources":["../../test/virtualSizes.ts"],"names":[],"mappings":""}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const src_1 = require("../src");
4
+ describe('VirtualSizes', function () {
5
+ it('have expected values', function () {
6
+ src_1.VirtualSizes.should.match({
7
+ // check computed values only
8
+ txP2shInputSize: 298,
9
+ txP2shP2wshInputSize: 140,
10
+ txP2wshInputSize: 105,
11
+ txP2trKeypathInputSize: 58,
12
+ txP2trScriptPathLevel1InputSize: 108,
13
+ txP2trScriptPathLevel2InputSize: 116,
14
+ txP2shP2pkInputSize: 151,
15
+ });
16
+ });
17
+ });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlydHVhbFNpemVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdGVzdC92aXJ0dWFsU2l6ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxnQ0FBc0M7QUFFdEMsUUFBUSxDQUFDLGNBQWMsRUFBRTtJQUN2QixFQUFFLENBQUMsc0JBQXNCLEVBQUU7UUFDekIsa0JBQVksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDO1lBQ3hCLDZCQUE2QjtZQUM3QixlQUFlLEVBQUUsR0FBRztZQUNwQixvQkFBb0IsRUFBRSxHQUFHO1lBQ3pCLGdCQUFnQixFQUFFLEdBQUc7WUFDckIsc0JBQXNCLEVBQUUsRUFBRTtZQUMxQiwrQkFBK0IsRUFBRSxHQUFHO1lBQ3BDLCtCQUErQixFQUFFLEdBQUc7WUFDcEMsbUJBQW1CLEVBQUUsR0FBRztTQUN6QixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmlydHVhbFNpemVzIH0gZnJvbSAnLi4vc3JjJztcblxuZGVzY3JpYmUoJ1ZpcnR1YWxTaXplcycsIGZ1bmN0aW9uICgpIHtcbiAgaXQoJ2hhdmUgZXhwZWN0ZWQgdmFsdWVzJywgZnVuY3Rpb24gKCkge1xuICAgIFZpcnR1YWxTaXplcy5zaG91bGQubWF0Y2goe1xuICAgICAgLy8gY2hlY2sgY29tcHV0ZWQgdmFsdWVzIG9ubHlcbiAgICAgIHR4UDJzaElucHV0U2l6ZTogMjk4LFxuICAgICAgdHhQMnNoUDJ3c2hJbnB1dFNpemU6IDE0MCxcbiAgICAgIHR4UDJ3c2hJbnB1dFNpemU6IDEwNSxcbiAgICAgIHR4UDJ0cktleXBhdGhJbnB1dFNpemU6IDU4LFxuICAgICAgdHhQMnRyU2NyaXB0UGF0aExldmVsMUlucHV0U2l6ZTogMTA4LFxuICAgICAgdHhQMnRyU2NyaXB0UGF0aExldmVsMklucHV0U2l6ZTogMTE2LFxuICAgICAgdHhQMnNoUDJwa0lucHV0U2l6ZTogMTUxLFxuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19