@bitgo-beta/unspents 0.13.2-beta.9 → 0.13.2-beta.900
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.
- package/.mocharc.js +1 -1
- package/CHANGELOG.md +541 -0
- package/bin/generate_tables.ts +94 -0
- package/dist/bin/generate_tables.d.ts +2 -0
- package/dist/bin/generate_tables.d.ts.map +1 -0
- package/dist/bin/generate_tables.js +107 -0
- package/dist/{codes.d.ts → src/codes.d.ts} +11 -10
- package/dist/src/codes.d.ts.map +1 -0
- package/dist/src/codes.js +182 -0
- package/dist/{dimensions.d.ts → src/dimensions.d.ts} +10 -11
- package/dist/src/dimensions.d.ts.map +1 -0
- package/dist/src/dimensions.js +500 -0
- package/dist/{index.d.ts → src/index.d.ts} +1 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +44 -0
- package/dist/{inputWeights.d.ts → src/inputWeights.d.ts} +4 -3
- package/dist/src/inputWeights.d.ts.map +1 -0
- package/dist/src/inputWeights.js +97 -0
- package/dist/{scriptSizes.d.ts → src/scriptSizes.d.ts} +1 -0
- package/dist/src/scriptSizes.d.ts.map +1 -0
- package/dist/src/scriptSizes.js +50 -0
- package/dist/{types.d.ts → src/types.d.ts} +1 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +39 -0
- package/dist/{virtualSizes.d.ts → src/virtualSizes.d.ts} +13 -12
- package/dist/src/virtualSizes.d.ts.map +1 -0
- package/dist/src/virtualSizes.js +114 -0
- package/dist/src/zcash.d.ts +9 -0
- package/dist/src/zcash.d.ts.map +1 -0
- package/dist/src/zcash.js +22 -0
- package/dist/test/chain.d.ts +2 -0
- package/dist/test/chain.d.ts.map +1 -0
- package/dist/test/chain.js +92 -0
- package/dist/test/dimensions.d.ts +2 -0
- package/dist/test/dimensions.d.ts.map +1 -0
- package/dist/test/dimensions.js +235 -0
- package/dist/test/signedTx/inputWeights.d.ts +2 -0
- package/dist/test/signedTx/inputWeights.d.ts.map +1 -0
- package/dist/test/signedTx/inputWeights.js +127 -0
- package/dist/test/signedTx/txCombinations.d.ts +3 -0
- package/dist/test/signedTx/txCombinations.d.ts.map +1 -0
- package/dist/test/signedTx/txCombinations.js +130 -0
- package/dist/test/signedTx/txGen.d.ts +74 -0
- package/dist/test/signedTx/txGen.d.ts.map +1 -0
- package/dist/test/signedTx/txGen.js +233 -0
- package/dist/test/testutils.d.ts +36 -0
- package/dist/test/testutils.d.ts.map +1 -0
- package/dist/test/testutils.js +190 -0
- package/dist/test/virtualSizes.d.ts +2 -0
- package/dist/test/virtualSizes.d.ts.map +1 -0
- package/dist/test/virtualSizes.js +18 -0
- package/dist/test/zcash.d.ts +2 -0
- package/dist/test/zcash.d.ts.map +1 -0
- package/dist/test/zcash.js +60 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/docs/input-costs.md +14 -0
- package/package.json +7 -7
- package/dist/codes.js +0 -168
- package/dist/dimensions.js +0 -490
- package/dist/index.js +0 -30
- package/dist/inputWeights.js +0 -97
- package/dist/scriptSizes.js +0 -51
- package/dist/types.js +0 -25
- package/dist/virtualSizes.js +0 -114
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
2
|
+
import { BIP32Interface } from '@bitgo-beta/utxo-lib';
|
|
3
|
+
import 'lodash.combinations';
|
|
4
|
+
import { Dimensions } from '../../src';
|
|
5
|
+
import { InputScriptType, TestUnspentType } from '../testutils';
|
|
6
|
+
interface IUnspent {
|
|
7
|
+
scriptPubKey: Buffer;
|
|
8
|
+
redeemScript?: Buffer;
|
|
9
|
+
witnessScript?: Buffer;
|
|
10
|
+
value: number;
|
|
11
|
+
inputType: utxolib.bitgo.outputScripts.ScriptType;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
*
|
|
15
|
+
* @param keys - Pubkeys to use for generating the address.
|
|
16
|
+
* If unspentType is one of UnspentTypePubKeyHash is used, the first key will be used.
|
|
17
|
+
* @param unspentType {String} - one of UnspentTypeScript2of3 or UnspentTypePubKeyHash
|
|
18
|
+
* @return {String} address
|
|
19
|
+
*/
|
|
20
|
+
export declare const createScriptPubKey: (keys: BIP32Interface[], unspentType: TestUnspentType) => Buffer;
|
|
21
|
+
declare class TxCombo {
|
|
22
|
+
walletKeys: BIP32Interface[];
|
|
23
|
+
inputTypes: string[];
|
|
24
|
+
outputTypes: TestUnspentType[];
|
|
25
|
+
expectedDims: Readonly<Dimensions>;
|
|
26
|
+
signKeys?: BIP32Interface[] | undefined;
|
|
27
|
+
inputValue: number;
|
|
28
|
+
unspents: IUnspent[];
|
|
29
|
+
inputTx: any;
|
|
30
|
+
constructor(walletKeys: BIP32Interface[], inputTypes: string[], outputTypes: TestUnspentType[], expectedDims?: Readonly<Dimensions>, signKeys?: BIP32Interface[] | undefined, inputValue?: number);
|
|
31
|
+
getBuilderWithUnsignedTx(): utxolib.bitgo.UtxoTransactionBuilder;
|
|
32
|
+
getUnsignedTx(): utxolib.bitgo.UtxoTransaction;
|
|
33
|
+
getSignedTx(): utxolib.Transaction;
|
|
34
|
+
}
|
|
35
|
+
declare const runCombinations: ({ inputTypes, maxNInputs, outputTypes, maxNOutputs, }: {
|
|
36
|
+
inputTypes: InputScriptType[];
|
|
37
|
+
maxNInputs: number;
|
|
38
|
+
outputTypes: TestUnspentType[];
|
|
39
|
+
maxNOutputs: number;
|
|
40
|
+
}, callback: (inputCombo: InputScriptType[], outputCombo: TestUnspentType[]) => void) => void;
|
|
41
|
+
declare class Histogram {
|
|
42
|
+
map: Map<number, number>;
|
|
43
|
+
total: number;
|
|
44
|
+
constructor(map?: Map<number, number>);
|
|
45
|
+
add(size: number): void;
|
|
46
|
+
asSortedArray(): number[][];
|
|
47
|
+
asFullSortedArray(): number[][];
|
|
48
|
+
getPercentile(p: number): number;
|
|
49
|
+
toString(): string;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
*
|
|
53
|
+
* Calls `callback` with a variety of signed txs, based on input parameters
|
|
54
|
+
* Callback arguments are
|
|
55
|
+
* inputType, inputCount, outputType, txs
|
|
56
|
+
* where `txs` implements `forEach()`
|
|
57
|
+
*
|
|
58
|
+
* @param inputTypes - input types to test
|
|
59
|
+
* @param nInputKeyTriplets - number of different input key triples to cycle through
|
|
60
|
+
* @param outputTypes - output types to test
|
|
61
|
+
* @param nOutputKeyTriplets - number of different output key triplets to cycle through
|
|
62
|
+
* @param callback
|
|
63
|
+
*/
|
|
64
|
+
declare const runSignedTransactions: ({ inputTypes, nInputKeyTriplets, outputTypes, nOutputKeyTriplets, }: {
|
|
65
|
+
inputTypes: Array<{
|
|
66
|
+
inputType: string;
|
|
67
|
+
count: number;
|
|
68
|
+
}>;
|
|
69
|
+
nInputKeyTriplets: number;
|
|
70
|
+
outputTypes: TestUnspentType[];
|
|
71
|
+
nOutputKeyTriplets: number;
|
|
72
|
+
}, callback: (inputType: string, inputCount: number, outputType: TestUnspentType, txs: any) => void) => void;
|
|
73
|
+
export { TxCombo, Histogram, runCombinations, runSignedTransactions };
|
|
74
|
+
//# 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,EAAE,cAAc,EAAE;IAC3B,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,EAAE,cAAc,EAAE,YAAA,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,0DAMhB;IACD,UAAU,EAAE,eAAe,EAAE,CAAC;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,eAAe,EAAE,CAAC;IAC/B,WAAW,EAAE,MAAM,CAAC;CACrB,YACS,CAAC,UAAU,EAAE,eAAe,EAAE,EAAE,WAAW,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,wEAMtB;IACD,UAAU,EAAE,KAAK,CAAC;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACxD,iBAAiB,EAAE,MAAM,CAAC;IAC1B,WAAW,EAAE,eAAe,EAAE,CAAC;IAC/B,kBAAkB,EAAE,MAAM,CAAC;CAC5B,YACS,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,GAAG,EAAE,GAAG,KAAK,IAAI,KAC/F,IAyCF,CAAC;AAEF,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,qBAAqB,EAAE,CAAC"}
|
|
@@ -0,0 +1,233 @@
|
|
|
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
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
+
var ownKeys = function(o) {
|
|
21
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
+
var ar = [];
|
|
23
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
+
return ar;
|
|
25
|
+
};
|
|
26
|
+
return ownKeys(o);
|
|
27
|
+
};
|
|
28
|
+
return function (mod) {
|
|
29
|
+
if (mod && mod.__esModule) return mod;
|
|
30
|
+
var result = {};
|
|
31
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
+
__setModuleDefault(result, mod);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
})();
|
|
36
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
37
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
38
|
+
};
|
|
39
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
40
|
+
exports.runSignedTransactions = exports.runCombinations = exports.Histogram = exports.TxCombo = exports.createScriptPubKey = void 0;
|
|
41
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
42
|
+
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
43
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
44
|
+
require("lodash.combinations");
|
|
45
|
+
const src_1 = require("../../src");
|
|
46
|
+
const testutils_1 = require("../testutils");
|
|
47
|
+
function createUnspent(pubkeys, inputType, value) {
|
|
48
|
+
let spendableScript;
|
|
49
|
+
const scriptType = inputType === 'taprootKeyPathSpend' ? 'p2trMusig2' : inputType;
|
|
50
|
+
if (scriptType === testutils_1.UnspentTypeP2shP2pk) {
|
|
51
|
+
spendableScript = utxolib.bitgo.outputScripts.createOutputScriptP2shP2pk(pubkeys[0]);
|
|
52
|
+
}
|
|
53
|
+
else if (utxolib.bitgo.outputScripts.isScriptType2Of3(scriptType)) {
|
|
54
|
+
spendableScript = utxolib.bitgo.outputScripts.createOutputScript2of3(pubkeys, scriptType);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
throw new Error(`unexpected inputType ${scriptType}`);
|
|
58
|
+
}
|
|
59
|
+
return {
|
|
60
|
+
...spendableScript,
|
|
61
|
+
value,
|
|
62
|
+
inputType: scriptType,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
*
|
|
67
|
+
* @param keys - Pubkeys to use for generating the address.
|
|
68
|
+
* If unspentType is one of UnspentTypePubKeyHash is used, the first key will be used.
|
|
69
|
+
* @param unspentType {String} - one of UnspentTypeScript2of3 or UnspentTypePubKeyHash
|
|
70
|
+
* @return {String} address
|
|
71
|
+
*/
|
|
72
|
+
const createScriptPubKey = (keys, unspentType) => {
|
|
73
|
+
const pubkeys = keys.map((key) => key.publicKey);
|
|
74
|
+
if (typeof unspentType === 'string' && unspentType in testutils_1.UnspentTypeScript2of3) {
|
|
75
|
+
return createUnspent(pubkeys, unspentType, 0).scriptPubKey;
|
|
76
|
+
}
|
|
77
|
+
const pkHash = utxolib.crypto.hash160(pubkeys[0]);
|
|
78
|
+
switch (unspentType) {
|
|
79
|
+
case testutils_1.UnspentTypePubKeyHash.p2pkh:
|
|
80
|
+
return utxolib.payments.p2pkh({ hash: pkHash }).output;
|
|
81
|
+
case testutils_1.UnspentTypePubKeyHash.p2wpkh:
|
|
82
|
+
return utxolib.payments.p2wpkh({ hash: pkHash }).output;
|
|
83
|
+
}
|
|
84
|
+
if (unspentType instanceof testutils_1.UnspentTypeOpReturn) {
|
|
85
|
+
const payload = Buffer.alloc(unspentType.size).fill(pubkeys[0]);
|
|
86
|
+
return utxolib.script.compile([0x6a, payload]);
|
|
87
|
+
}
|
|
88
|
+
throw new Error(`unsupported output type ${unspentType}`);
|
|
89
|
+
};
|
|
90
|
+
exports.createScriptPubKey = createScriptPubKey;
|
|
91
|
+
const createInputTx = (unspents, inputValue) => {
|
|
92
|
+
const txInputBuilder = new utxolib.bitgo.UtxoTransactionBuilder(utxolib.networks.bitcoin);
|
|
93
|
+
txInputBuilder.addInput(Array(32).fill('01').join(''), 0);
|
|
94
|
+
unspents.forEach(({ scriptPubKey }) => txInputBuilder.addOutput(scriptPubKey, inputValue));
|
|
95
|
+
return txInputBuilder.buildIncomplete();
|
|
96
|
+
};
|
|
97
|
+
function signInput(txBuilder, index, walletKeys, unspent, signKeys = unspent.inputType === 'p2shP2pk' ? [walletKeys[0]] : [walletKeys[0], walletKeys[2]]) {
|
|
98
|
+
signKeys.forEach((keyPair) => {
|
|
99
|
+
if (unspent.inputType === 'p2shP2pk') {
|
|
100
|
+
utxolib.bitgo.signInputP2shP2pk(txBuilder, index, keyPair);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
if (signKeys.length !== 2) {
|
|
104
|
+
throw new Error(`invalid signKeys length`);
|
|
105
|
+
}
|
|
106
|
+
const cosigner = keyPair === signKeys[0] ? signKeys[1] : signKeys[0];
|
|
107
|
+
utxolib.bitgo.signInput2Of3(txBuilder, index, unspent.inputType, walletKeys.map((k) => k.publicKey), keyPair, cosigner.publicKey, unspent.value);
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
class TxCombo {
|
|
112
|
+
constructor(walletKeys, inputTypes, outputTypes, expectedDims = src_1.Dimensions.ZERO, signKeys, inputValue = 10) {
|
|
113
|
+
this.walletKeys = walletKeys;
|
|
114
|
+
this.inputTypes = inputTypes;
|
|
115
|
+
this.outputTypes = outputTypes;
|
|
116
|
+
this.expectedDims = expectedDims;
|
|
117
|
+
this.signKeys = signKeys;
|
|
118
|
+
this.inputValue = inputValue;
|
|
119
|
+
this.unspents = inputTypes.map((inputType) => createUnspent(walletKeys.map((key) => key.publicKey), inputType, this.inputValue));
|
|
120
|
+
this.inputTx = createInputTx(this.unspents, inputValue);
|
|
121
|
+
}
|
|
122
|
+
getBuilderWithUnsignedTx() {
|
|
123
|
+
const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);
|
|
124
|
+
this.inputTx.outs.forEach(({}, i) => txBuilder.addInput(this.inputTx, i));
|
|
125
|
+
this.outputTypes.forEach((unspentType) => txBuilder.addOutput((0, exports.createScriptPubKey)(this.walletKeys, unspentType), this.inputValue));
|
|
126
|
+
return txBuilder;
|
|
127
|
+
}
|
|
128
|
+
getUnsignedTx() {
|
|
129
|
+
return this.getBuilderWithUnsignedTx().buildIncomplete();
|
|
130
|
+
}
|
|
131
|
+
getSignedTx() {
|
|
132
|
+
const txBuilder = this.getBuilderWithUnsignedTx();
|
|
133
|
+
this.unspents.forEach((unspent, i) => {
|
|
134
|
+
signInput(txBuilder, i, this.walletKeys, unspent, this.signKeys);
|
|
135
|
+
});
|
|
136
|
+
return txBuilder.build();
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
exports.TxCombo = TxCombo;
|
|
140
|
+
const runCombinations = ({ inputTypes, maxNInputs, outputTypes, maxNOutputs, }, callback) => {
|
|
141
|
+
// Create combinations of different input and output types. Length between 1 and 3.
|
|
142
|
+
const inputCombinations = lodash_1.default.flatten(
|
|
143
|
+
// @ts-ignore
|
|
144
|
+
[...Array(maxNInputs)].map((__, i) => lodash_1.default.combinations(inputTypes, i + 1)));
|
|
145
|
+
const outputCombinations = lodash_1.default.flatten(
|
|
146
|
+
// @ts-ignore
|
|
147
|
+
[...Array(maxNOutputs)].map((__, i) => lodash_1.default.combinations(outputTypes, i + 1)));
|
|
148
|
+
inputCombinations.forEach((inputTypeCombo) => outputCombinations.forEach((outputTypeCombo) => {
|
|
149
|
+
callback(inputTypeCombo, outputTypeCombo);
|
|
150
|
+
}));
|
|
151
|
+
};
|
|
152
|
+
exports.runCombinations = runCombinations;
|
|
153
|
+
class Histogram {
|
|
154
|
+
constructor(map = new Map()) {
|
|
155
|
+
this.map = map;
|
|
156
|
+
this.total = 0;
|
|
157
|
+
}
|
|
158
|
+
add(size) {
|
|
159
|
+
this.map.set(size, (this.map.get(size) || 0) + 1);
|
|
160
|
+
this.total++;
|
|
161
|
+
}
|
|
162
|
+
asSortedArray() {
|
|
163
|
+
return [...this.map.entries()].sort(([a], [b]) => a - b);
|
|
164
|
+
}
|
|
165
|
+
asFullSortedArray() {
|
|
166
|
+
return lodash_1.default.range(this.getPercentile(0), this.getPercentile(1)).map((v) => [v, this.map.get(v) || 0]);
|
|
167
|
+
}
|
|
168
|
+
getPercentile(p) {
|
|
169
|
+
if (0 > p || p > 1) {
|
|
170
|
+
throw new Error(`p must be between 0 and 1`);
|
|
171
|
+
}
|
|
172
|
+
let sum = 0;
|
|
173
|
+
for (const [k, v] of this.asSortedArray()) {
|
|
174
|
+
sum += v;
|
|
175
|
+
if (sum / this.total >= p) {
|
|
176
|
+
return k;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
throw new Error('could not find percentile');
|
|
180
|
+
}
|
|
181
|
+
toString() {
|
|
182
|
+
const keys = [...this.map.keys()].sort((a, b) => a - b);
|
|
183
|
+
return `[${keys.map((k) => `[${k}, ${this.map.get(k)}]`).join(' ')}]`;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
exports.Histogram = Histogram;
|
|
187
|
+
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)));
|
|
188
|
+
/**
|
|
189
|
+
*
|
|
190
|
+
* Calls `callback` with a variety of signed txs, based on input parameters
|
|
191
|
+
* Callback arguments are
|
|
192
|
+
* inputType, inputCount, outputType, txs
|
|
193
|
+
* where `txs` implements `forEach()`
|
|
194
|
+
*
|
|
195
|
+
* @param inputTypes - input types to test
|
|
196
|
+
* @param nInputKeyTriplets - number of different input key triples to cycle through
|
|
197
|
+
* @param outputTypes - output types to test
|
|
198
|
+
* @param nOutputKeyTriplets - number of different output key triplets to cycle through
|
|
199
|
+
* @param callback
|
|
200
|
+
*/
|
|
201
|
+
const runSignedTransactions = ({ inputTypes, nInputKeyTriplets, outputTypes, nOutputKeyTriplets, }, callback) => {
|
|
202
|
+
const inputKeyTriplets = getKeyTriplets('test/input/', nInputKeyTriplets);
|
|
203
|
+
const outputKeyTriplets = getKeyTriplets('test/output/', nOutputKeyTriplets);
|
|
204
|
+
const outputValue = 1e8;
|
|
205
|
+
inputTypes.forEach(({ inputType, count: inputCount }) => {
|
|
206
|
+
const inputTxs = inputKeyTriplets.map((inputKeys) => {
|
|
207
|
+
const unspents = [...Array(inputCount)].map(() => createUnspent(inputKeys.map((key) => key.publicKey), inputType, outputValue));
|
|
208
|
+
const inputTx = createInputTx(unspents, outputValue);
|
|
209
|
+
return { inputKeys, unspents, inputTx };
|
|
210
|
+
});
|
|
211
|
+
outputTypes.forEach((outputType) => {
|
|
212
|
+
const outputs = outputKeyTriplets.map((outputKeys) => (0, exports.createScriptPubKey)(outputKeys, outputType));
|
|
213
|
+
const txs = {
|
|
214
|
+
forEach(cb) {
|
|
215
|
+
inputTxs.forEach(({ inputKeys, unspents, inputTx }) => {
|
|
216
|
+
outputs.forEach((scriptPubKey) => {
|
|
217
|
+
const txBuilder = utxolib.bitgo.createTransactionBuilderForNetwork(utxolib.networks.bitcoin);
|
|
218
|
+
inputTx.outs.forEach((v, i) => txBuilder.addInput(inputTx, i));
|
|
219
|
+
txBuilder.addOutput(scriptPubKey, outputValue);
|
|
220
|
+
unspents.forEach((unspent, i) => {
|
|
221
|
+
signInput(txBuilder, i, inputKeys, unspent);
|
|
222
|
+
});
|
|
223
|
+
cb(txBuilder.build());
|
|
224
|
+
});
|
|
225
|
+
});
|
|
226
|
+
},
|
|
227
|
+
};
|
|
228
|
+
callback(inputType, inputCount, outputType, txs);
|
|
229
|
+
});
|
|
230
|
+
});
|
|
231
|
+
};
|
|
232
|
+
exports.runSignedTransactions = runSignedTransactions;
|
|
233
|
+
//# 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 type TestUnspentType = string | UnspentTypeOpReturn;
|
|
17
|
+
export declare class UnspentTypeOpReturn {
|
|
18
|
+
size: number;
|
|
19
|
+
constructor(size: number);
|
|
20
|
+
toString(): string;
|
|
21
|
+
}
|
|
22
|
+
export 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,MAAM,MAAM,eAAe,GAAG,MAAM,GAAG,mBAAmB,CAAC;AAE3D,qBAAa,mBAAmB;IACX,IAAI,EAAE,MAAM;gBAAZ,IAAI,EAAE,MAAM;IAExB,QAAQ,IAAI,MAAM;CAG1B;AAED,MAAM,MAAM,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,QAAQ,CAAC,UAiBxF,CAAC;AAEF,eAAO,MAAM,iCAAiC,gBAAiB,eAAe,KAAG,QAAQ,CAAC,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,190 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.getOutputDimensionsForUnspentType = exports.getInputDimensionsForUnspentType = exports.UnspentTypeOpReturn = exports.UnspentTypePubKeyHash = exports.UnspentTypeScript2of3 = exports.UnspentTypeP2shP2pk = void 0;
|
|
40
|
+
exports.getInputScriptTypes = getInputScriptTypes;
|
|
41
|
+
exports.constructPsbt = constructPsbt;
|
|
42
|
+
exports.getSignedTransaction = getSignedTransaction;
|
|
43
|
+
const unspents = __importStar(require("../src"));
|
|
44
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
45
|
+
const assert_1 = __importDefault(require("assert"));
|
|
46
|
+
const txGen_1 = require("./signedTx/txGen");
|
|
47
|
+
/**
|
|
48
|
+
* makeEnum('a', 'b') returns `{ a: 'a', b: 'b' }`
|
|
49
|
+
*
|
|
50
|
+
* @param args
|
|
51
|
+
* @return map with string keys and symbol values
|
|
52
|
+
*/
|
|
53
|
+
const makeEnum = (...args) => args.reduce((obj, key) => Object.assign(obj, { [key]: key }), {});
|
|
54
|
+
exports.UnspentTypeP2shP2pk = 'p2shP2pk';
|
|
55
|
+
// p2trMusig2 is assumed to be script path only. taprootKeyPathSpend is for p2trMusig2 key path
|
|
56
|
+
exports.UnspentTypeScript2of3 = makeEnum('p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2', 'taprootKeyPathSpend');
|
|
57
|
+
exports.UnspentTypePubKeyHash = makeEnum('p2pkh', 'p2wpkh');
|
|
58
|
+
class UnspentTypeOpReturn {
|
|
59
|
+
constructor(size) {
|
|
60
|
+
this.size = size;
|
|
61
|
+
}
|
|
62
|
+
toString() {
|
|
63
|
+
return `opReturn(${this.size})`;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.UnspentTypeOpReturn = UnspentTypeOpReturn;
|
|
67
|
+
function getInputScriptTypes() {
|
|
68
|
+
return [...utxolib.bitgo.outputScripts.scriptTypes2Of3, 'p2shP2pk', 'taprootKeyPathSpend'];
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Return the input dimensions based on unspent type
|
|
72
|
+
* @param unspentType - one of UnspentTypeScript2of3
|
|
73
|
+
* @return Dimensions
|
|
74
|
+
*/
|
|
75
|
+
const getInputDimensionsForUnspentType = (unspentType) => {
|
|
76
|
+
switch (unspentType) {
|
|
77
|
+
case exports.UnspentTypeScript2of3.p2sh:
|
|
78
|
+
return unspents.Dimensions.sum({ nP2shInputs: 1 });
|
|
79
|
+
case exports.UnspentTypeScript2of3.p2shP2wsh:
|
|
80
|
+
return unspents.Dimensions.sum({ nP2shP2wshInputs: 1 });
|
|
81
|
+
case exports.UnspentTypeScript2of3.p2wsh:
|
|
82
|
+
return unspents.Dimensions.sum({ nP2wshInputs: 1 });
|
|
83
|
+
case exports.UnspentTypeScript2of3.p2tr:
|
|
84
|
+
case exports.UnspentTypeScript2of3.p2trMusig2:
|
|
85
|
+
return unspents.Dimensions.sum({ nP2trScriptPathLevel1Inputs: 1 });
|
|
86
|
+
case exports.UnspentTypeScript2of3.taprootKeyPathSpend:
|
|
87
|
+
return unspents.Dimensions.sum({ nP2trKeypathInputs: 1 });
|
|
88
|
+
case exports.UnspentTypeP2shP2pk:
|
|
89
|
+
return unspents.Dimensions.sum({ nP2shP2pkInputs: 1 });
|
|
90
|
+
}
|
|
91
|
+
throw new Error(`no input dimensions for ${unspentType}`);
|
|
92
|
+
};
|
|
93
|
+
exports.getInputDimensionsForUnspentType = getInputDimensionsForUnspentType;
|
|
94
|
+
const getOutputDimensionsForUnspentType = (unspentType) => {
|
|
95
|
+
/* The values here are validated in the test 'calculates output dimensions dynamically' */
|
|
96
|
+
switch (unspentType) {
|
|
97
|
+
case exports.UnspentTypeScript2of3.p2sh:
|
|
98
|
+
case exports.UnspentTypeScript2of3.p2shP2wsh:
|
|
99
|
+
case exports.UnspentTypeP2shP2pk:
|
|
100
|
+
return unspents.Dimensions.fromOutputScriptLength(23);
|
|
101
|
+
case exports.UnspentTypeScript2of3.p2wsh:
|
|
102
|
+
return unspents.Dimensions.fromOutputScriptLength(34);
|
|
103
|
+
case exports.UnspentTypeScript2of3.p2tr:
|
|
104
|
+
case exports.UnspentTypeScript2of3.p2trMusig2:
|
|
105
|
+
case exports.UnspentTypeScript2of3.taprootKeyPathSpend:
|
|
106
|
+
return unspents.Dimensions.fromOutputScriptLength(34);
|
|
107
|
+
case exports.UnspentTypePubKeyHash.p2pkh:
|
|
108
|
+
return unspents.Dimensions.fromOutputScriptLength(25);
|
|
109
|
+
case exports.UnspentTypePubKeyHash.p2wpkh:
|
|
110
|
+
return unspents.Dimensions.fromOutputScriptLength(22);
|
|
111
|
+
default:
|
|
112
|
+
if (unspentType instanceof UnspentTypeOpReturn) {
|
|
113
|
+
return unspents.Dimensions.fromOutputScriptLength(1 + unspentType.size);
|
|
114
|
+
}
|
|
115
|
+
throw new TypeError(`unknown unspentType ${unspentType}`);
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
exports.getOutputDimensionsForUnspentType = getOutputDimensionsForUnspentType;
|
|
119
|
+
function getDefaultSignerNames(inputType, signers) {
|
|
120
|
+
if (signers) {
|
|
121
|
+
return [signers.signerName, signers.cosignerName];
|
|
122
|
+
}
|
|
123
|
+
if (inputType === 'p2shP2pk') {
|
|
124
|
+
return ['user'];
|
|
125
|
+
}
|
|
126
|
+
if (inputType === 'p2trMusig2') {
|
|
127
|
+
return ['user', 'backup'];
|
|
128
|
+
}
|
|
129
|
+
return ['user', 'bitgo'];
|
|
130
|
+
}
|
|
131
|
+
function constructPsbt(keys, inputTypes, outputTypes, signatureStatus, signers) {
|
|
132
|
+
const psbt = utxolib.bitgo.createPsbtForNetwork({ network: utxolib.networks.bitcoin });
|
|
133
|
+
inputTypes.forEach((t, i) => {
|
|
134
|
+
if (t === 'p2shP2pk') {
|
|
135
|
+
const signer = keys[getDefaultSignerNames(t, signers)[0]];
|
|
136
|
+
const unspent = utxolib.testutil.mockReplayProtectionUnspent(utxolib.networks.bitcoin, BigInt(10), {
|
|
137
|
+
key: signer,
|
|
138
|
+
vout: i,
|
|
139
|
+
});
|
|
140
|
+
const { redeemScript } = utxolib.bitgo.outputScripts.createOutputScriptP2shP2pk(signer.publicKey);
|
|
141
|
+
assert_1.default.ok(redeemScript);
|
|
142
|
+
utxolib.bitgo.addReplayProtectionUnspentToPsbt(psbt, unspent, redeemScript);
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
const unspent = utxolib.testutil.mockWalletUnspent(utxolib.networks.bitcoin, BigInt(10), {
|
|
146
|
+
keys,
|
|
147
|
+
chain: utxolib.bitgo.getExternalChainCode(t === 'taprootKeyPathSpend' ? 'p2trMusig2' : t),
|
|
148
|
+
vout: i,
|
|
149
|
+
index: i,
|
|
150
|
+
});
|
|
151
|
+
const signerNames = getDefaultSignerNames(t, signers);
|
|
152
|
+
utxolib.bitgo.addWalletUnspentToPsbt(psbt, unspent, keys, signerNames[0], signerNames[1]);
|
|
153
|
+
}
|
|
154
|
+
});
|
|
155
|
+
outputTypes.forEach((t, index) => {
|
|
156
|
+
psbt.addOutput({
|
|
157
|
+
script: (0, txGen_1.createScriptPubKey)(keys.triple, t),
|
|
158
|
+
value: BigInt(10),
|
|
159
|
+
});
|
|
160
|
+
});
|
|
161
|
+
if (signatureStatus === 'unsigned') {
|
|
162
|
+
return psbt;
|
|
163
|
+
}
|
|
164
|
+
psbt.setAllInputsMusig2NonceHD(keys['user']);
|
|
165
|
+
psbt.setAllInputsMusig2NonceHD(keys['bitgo']);
|
|
166
|
+
inputTypes.forEach((t, i) => {
|
|
167
|
+
const signerNames = getDefaultSignerNames(t, signers);
|
|
168
|
+
if (t === 'p2shP2pk') {
|
|
169
|
+
if (signatureStatus === 'fullysigned') {
|
|
170
|
+
psbt.signInput(i, keys[signerNames[0]]);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
psbt.signInputHD(i, keys[signerNames[0]]);
|
|
175
|
+
if (signatureStatus === 'fullysigned') {
|
|
176
|
+
psbt.signInputHD(i, keys[signerNames[1]]);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
});
|
|
180
|
+
if (signatureStatus === 'fullysigned') {
|
|
181
|
+
assert_1.default.ok(psbt.validateSignaturesOfAllInputs());
|
|
182
|
+
}
|
|
183
|
+
return psbt;
|
|
184
|
+
}
|
|
185
|
+
function getSignedTransaction(keys, signerName, cosignerName, inputTypes, outputTypes) {
|
|
186
|
+
const psbt = constructPsbt(keys, inputTypes, outputTypes, 'fullysigned', { signerName, cosignerName });
|
|
187
|
+
psbt.finalizeAllInputs();
|
|
188
|
+
return psbt.extractTransaction().clone('number');
|
|
189
|
+
}
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"testutils.js","sourceRoot":"","sources":["../../test/testutils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0CA,kDAEC;AAmED,sCA8DC;AAED,oDAUC;AAzLD,iDAAmC;AACnC,8DAAgD;AAChD,oDAA4B;AAC5B,4CAAsD;AAEtD;;;;;GAKG;AACH,MAAM,QAAQ,GAAG,CAAC,GAAG,IAAc,EAAO,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;AAElG,QAAA,mBAAmB,GAAG,UAAU,CAAC;AAE9C,+FAA+F;AAClF,QAAA,qBAAqB,GAO9B,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,qBAAqB,CAAC,CAAC;AAE3E,QAAA,qBAAqB,GAG9B,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;AAIhC,MAAa,mBAAmB;IAC9B,YAAmB,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;IAAG,CAAC;IAE5B,QAAQ;QACb,OAAO,YAAY,IAAI,CAAC,IAAI,GAAG,CAAC;IAClC,CAAC;CACF;AAND,kDAMC;AAID,SAAgB,mBAAmB;IACjC,OAAO,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,eAAe,EAAE,UAAU,EAAE,qBAAqB,CAAC,CAAC;AAC7F,CAAC;AAED;;;;GAIG;AACI,MAAM,gCAAgC,GAAG,CAAC,WAA4B,EAAuB,EAAE;IACpG,QAAQ,WAAW,EAAE,CAAC;QACpB,KAAK,6BAAqB,CAAC,IAAI;YAC7B,OAAO,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC;QACrD,KAAK,6BAAqB,CAAC,SAAS;YAClC,OAAO,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,gBAAgB,EAAE,CAAC,EAAE,CAAC,CAAC;QAC1D,KAAK,6BAAqB,CAAC,KAAK;YAC9B,OAAO,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC;QACtD,KAAK,6BAAqB,CAAC,IAAI,CAAC;QAChC,KAAK,6BAAqB,CAAC,UAAU;YACnC,OAAO,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,2BAA2B,EAAE,CAAC,EAAE,CAAC,CAAC;QACrE,KAAK,6BAAqB,CAAC,mBAAmB;YAC5C,OAAO,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,kBAAkB,EAAE,CAAC,EAAE,CAAC,CAAC;QAC5D,KAAK,2BAAmB;YACtB,OAAO,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,eAAe,EAAE,CAAC,EAAE,CAAC,CAAC;IAC3D,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,2BAA2B,WAAW,EAAE,CAAC,CAAC;AAC5D,CAAC,CAAC;AAjBW,QAAA,gCAAgC,oCAiB3C;AAEK,MAAM,iCAAiC,GAAG,CAAC,WAA4B,EAAuB,EAAE;IACrG,0FAA0F;IAC1F,QAAQ,WAAW,EAAE,CAAC;QACpB,KAAK,6BAAqB,CAAC,IAAI,CAAC;QAChC,KAAK,6BAAqB,CAAC,SAAS,CAAC;QACrC,KAAK,2BAAmB;YACtB,OAAO,QAAQ,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QACxD,KAAK,6BAAqB,CAAC,KAAK;YAC9B,OAAO,QAAQ,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QACxD,KAAK,6BAAqB,CAAC,IAAI,CAAC;QAChC,KAAK,6BAAqB,CAAC,UAAU,CAAC;QACtC,KAAK,6BAAqB,CAAC,mBAAmB;YAC5C,OAAO,QAAQ,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QACxD,KAAK,6BAAqB,CAAC,KAAK;YAC9B,OAAO,QAAQ,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QACxD,KAAK,6BAAqB,CAAC,MAAM;YAC/B,OAAO,QAAQ,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QACxD;YACE,IAAI,WAAW,YAAY,mBAAmB,EAAE,CAAC;gBAC/C,OAAO,QAAQ,CAAC,UAAU,CAAC,sBAAsB,CAAC,CAAC,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;YAC1E,CAAC;YACD,MAAM,IAAI,SAAS,CAAC,uBAAuB,WAAW,EAAE,CAAC,CAAC;IAC9D,CAAC;AACH,CAAC,CAAC;AAvBW,QAAA,iCAAiC,qCAuB5C;AAEF,SAAS,qBAAqB,CAC5B,SAA0B,EAC1B,OAAoF;IAEpF,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC;IACpD,CAAC;IACD,IAAI,SAAS,KAAK,UAAU,EAAE,CAAC;QAC7B,OAAO,CAAC,MAAM,CAAC,CAAC;IAClB,CAAC;IACD,IAAI,SAAS,KAAK,YAAY,EAAE,CAAC;QAC/B,OAAO,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IAC5B,CAAC;IACD,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAC3B,CAAC;AAED,SAAgB,aAAa,CAC3B,IAAkC,EAClC,UAA6B,EAC7B,WAA8B,EAC9B,eAA0D,EAC1D,OAAoF;IAEpF,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,oBAAoB,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;IAEvF,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QAC1B,IAAI,CAAC,KAAK,UAAU,EAAE,CAAC;YACrB,MAAM,MAAM,GAAG,IAAI,CAAC,qBAAqB,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1D,MAAM,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC,2BAA2B,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE;gBACjG,GAAG,EAAE,MAAM;gBACX,IAAI,EAAE,CAAC;aACR,CAAC,CAAC;YACH,MAAM,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,0BAA0B,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YAClG,gBAAM,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;YACxB,OAAO,CAAC,KAAK,CAAC,gCAAgC,CAAC,IAAI,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;QAC9E,CAAC;aAAM,CAAC;YACN,MAAM,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE;gBACvF,IAAI;gBACJ,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC,KAAK,qBAAqB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;gBACzF,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,CAAC;aACT,CAAC,CAAC;YACH,MAAM,WAAW,GAAG,qBAAqB,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;YACtD,OAAO,CAAC,KAAK,CAAC,sBAAsB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5F,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;QAC/B,IAAI,CAAC,SAAS,CAAC;YACb,MAAM,EAAE,IAAA,0BAAkB,EAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;YAC1C,KAAK,EAAE,MAAM,CAAC,EAAE,CAAC;SAClB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,eAAe,KAAK,UAAU,EAAE,CAAC;QACnC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAC7C,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;IAE9C,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QAC1B,MAAM,WAAW,GAAG,qBAAqB,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QACtD,IAAI,CAAC,KAAK,UAAU,EAAE,CAAC;YACrB,IAAI,eAAe,KAAK,aAAa,EAAE,CAAC;gBACtC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1C,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1C,IAAI,eAAe,KAAK,aAAa,EAAE,CAAC;gBACtC,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5C,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IACH,IAAI,eAAe,KAAK,aAAa,EAAE,CAAC;QACtC,gBAAM,CAAC,EAAE,CAAC,IAAI,CAAC,6BAA6B,EAAE,CAAC,CAAC;IAClD,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,oBAAoB,CAClC,IAAkC,EAClC,UAAiC,EACjC,YAAmC,EACnC,UAA6B,EAC7B,WAA8B;IAE9B,MAAM,IAAI,GAAG,aAAa,CAAC,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,aAAa,EAAE,EAAE,UAAU,EAAE,YAAY,EAAE,CAAC,CAAC;IACvG,IAAI,CAAC,iBAAiB,EAAE,CAAC;IACzB,OAAQ,IAAI,CAAC,kBAAkB,EAA4C,CAAC,KAAK,CAAS,QAAQ,CAAC,CAAC;AACtG,CAAC","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 @@
|
|
|
1
|
+
{"version":3,"file":"virtualSizes.d.ts","sourceRoot":"","sources":["../../test/virtualSizes.ts"],"names":[],"mappings":""}
|