@bitgo-beta/utxo-staking 1.1.1-beta.826 → 1.1.1-beta.828
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/dist/cjs/scripts/babylon-sync.d.ts +2 -0
- package/dist/cjs/scripts/babylon-sync.d.ts.map +1 -0
- package/dist/cjs/scripts/babylon-sync.js +126 -0
- package/dist/cjs/src/babylon/delegationMessage.d.ts.map +1 -0
- package/dist/cjs/src/babylon/delegationMessage.js +285 -0
- package/dist/cjs/src/babylon/descriptor.d.ts.map +1 -0
- package/dist/cjs/src/babylon/descriptor.js +97 -0
- package/dist/cjs/src/babylon/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/babylon/index.js +1 -1
- package/dist/cjs/src/babylon/network.d.ts.map +1 -0
- package/dist/{src → cjs/src}/babylon/network.js +1 -1
- package/dist/cjs/src/babylon/parseDescriptor.d.ts.map +1 -0
- package/dist/cjs/src/babylon/parseDescriptor.js +159 -0
- package/dist/cjs/src/babylon/stakingManager.d.ts.map +1 -0
- package/dist/cjs/src/babylon/stakingManager.js +120 -0
- package/dist/cjs/src/babylon/stakingParams.d.ts.map +1 -0
- package/dist/cjs/src/babylon/stakingParams.js +132 -0
- package/dist/cjs/src/babylon/undelegation/UndelegationResponse.d.ts.map +1 -0
- package/dist/{src → cjs/src}/babylon/undelegation/UndelegationResponse.js +1 -1
- package/dist/cjs/src/babylon/undelegation/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/babylon/undelegation/index.js +1 -1
- package/dist/cjs/src/babylon/undelegation/unbonding.d.ts.map +1 -0
- package/dist/cjs/src/babylon/undelegation/unbonding.js +111 -0
- package/dist/cjs/src/coreDao/descriptor.d.ts.map +1 -0
- package/dist/cjs/src/coreDao/descriptor.js +38 -0
- package/dist/cjs/src/coreDao/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/coreDao/index.js +1 -1
- package/dist/cjs/src/coreDao/opReturn.d.ts.map +1 -0
- package/dist/cjs/src/coreDao/opReturn.js +183 -0
- package/dist/cjs/src/coreDao/transaction.d.ts.map +1 -0
- package/dist/cjs/src/coreDao/transaction.js +34 -0
- package/dist/cjs/src/index.d.ts.map +1 -0
- package/dist/{src → cjs/src}/index.js +1 -1
- package/dist/cjs/test/unit/babylon/bug71.d.ts +2 -0
- package/dist/cjs/test/unit/babylon/bug71.d.ts.map +1 -0
- package/dist/cjs/test/unit/babylon/bug71.js +108 -0
- package/dist/cjs/test/unit/babylon/key.utils.d.ts +6 -0
- package/dist/cjs/test/unit/babylon/key.utils.d.ts.map +1 -0
- package/dist/cjs/test/unit/babylon/key.utils.js +68 -0
- package/dist/cjs/test/unit/babylon/transactions.d.ts +2 -0
- package/dist/cjs/test/unit/babylon/transactions.d.ts.map +1 -0
- package/dist/cjs/test/unit/babylon/transactions.js +338 -0
- package/dist/cjs/test/unit/babylon/undelegation.d.ts +2 -0
- package/dist/cjs/test/unit/babylon/undelegation.d.ts.map +1 -0
- package/dist/cjs/test/unit/babylon/undelegation.js +156 -0
- package/dist/cjs/test/unit/babylon/vendor.utils.d.ts +13 -0
- package/dist/cjs/test/unit/babylon/vendor.utils.d.ts.map +1 -0
- package/dist/cjs/test/unit/babylon/vendor.utils.js +78 -0
- package/dist/cjs/test/unit/coreDao/descriptor.d.ts +2 -0
- package/dist/cjs/test/unit/coreDao/descriptor.d.ts.map +1 -0
- package/dist/cjs/test/unit/coreDao/descriptor.js +144 -0
- package/dist/cjs/test/unit/coreDao/opReturn.d.ts +2 -0
- package/dist/cjs/test/unit/coreDao/opReturn.d.ts.map +1 -0
- package/dist/cjs/test/unit/coreDao/opReturn.js +275 -0
- package/dist/cjs/test/unit/coreDao/utils.d.ts +5 -0
- package/dist/cjs/test/unit/coreDao/utils.d.ts.map +1 -0
- package/dist/cjs/test/unit/coreDao/utils.js +54 -0
- package/dist/cjs/test/unit/fixtures.utils.d.ts +9 -0
- package/dist/cjs/test/unit/fixtures.utils.d.ts.map +1 -0
- package/dist/cjs/test/unit/fixtures.utils.js +91 -0
- package/dist/cjs/tsconfig.tsbuildinfo +1 -0
- package/dist/esm/babylon/delegationMessage.d.ts +38 -0
- package/dist/esm/babylon/delegationMessage.js +239 -0
- package/dist/esm/babylon/descriptor.d.ts +48 -0
- package/dist/esm/babylon/descriptor.js +91 -0
- package/dist/esm/babylon/index.d.ts +6 -0
- package/dist/esm/babylon/index.js +11 -0
- package/dist/esm/babylon/network.d.ts +7 -0
- package/dist/esm/babylon/network.js +29 -0
- package/dist/esm/babylon/params.mainnet.json +152 -0
- package/dist/esm/babylon/params.testnet.json +212 -0
- package/dist/esm/babylon/parseDescriptor.d.ts +26 -0
- package/dist/esm/babylon/parseDescriptor.js +155 -0
- package/dist/esm/babylon/stakingManager.d.ts +6 -0
- package/dist/esm/babylon/stakingManager.js +83 -0
- package/dist/esm/babylon/stakingParams.d.ts +40 -0
- package/dist/esm/babylon/stakingParams.js +86 -0
- package/dist/esm/babylon/undelegation/UndelegationResponse.d.ts +24 -0
- package/dist/esm/babylon/undelegation/UndelegationResponse.js +18 -0
- package/dist/esm/babylon/undelegation/index.d.ts +3 -0
- package/dist/esm/babylon/undelegation/index.js +3 -0
- package/dist/esm/babylon/undelegation/unbonding.d.ts +16 -0
- package/dist/esm/babylon/undelegation/unbonding.js +70 -0
- package/dist/esm/coreDao/descriptor.d.ts +18 -0
- package/dist/esm/coreDao/descriptor.js +35 -0
- package/dist/esm/coreDao/index.d.ts +4 -0
- package/dist/esm/coreDao/index.js +4 -0
- package/dist/esm/coreDao/opReturn.d.ts +41 -0
- package/dist/esm/coreDao/opReturn.js +175 -0
- package/dist/esm/coreDao/transaction.d.ts +28 -0
- package/dist/esm/coreDao/transaction.js +30 -0
- package/dist/esm/index.d.ts +3 -0
- package/dist/esm/index.js +3 -0
- package/package.json +26 -10
- package/dist/src/babylon/delegationMessage.js +0 -285
- package/dist/src/babylon/descriptor.js +0 -97
- package/dist/src/babylon/parseDescriptor.js +0 -159
- package/dist/src/babylon/stakingManager.js +0 -120
- package/dist/src/babylon/stakingParams.js +0 -132
- package/dist/src/babylon/undelegation/unbonding.js +0 -111
- package/dist/src/coreDao/descriptor.js +0 -38
- package/dist/src/coreDao/opReturn.js +0 -183
- package/dist/src/coreDao/transaction.js +0 -34
- /package/dist/{src → cjs/src}/babylon/delegationMessage.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/descriptor.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/network.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/params.mainnet.json +0 -0
- /package/dist/{src → cjs/src}/babylon/params.testnet.json +0 -0
- /package/dist/{src → cjs/src}/babylon/parseDescriptor.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/stakingManager.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/stakingParams.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/undelegation/UndelegationResponse.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/undelegation/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/babylon/undelegation/unbonding.d.ts +0 -0
- /package/dist/{src → cjs/src}/coreDao/descriptor.d.ts +0 -0
- /package/dist/{src → cjs/src}/coreDao/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/coreDao/opReturn.d.ts +0 -0
- /package/dist/{src → cjs/src}/coreDao/transaction.d.ts +0 -0
- /package/dist/{src → cjs/src}/index.d.ts +0 -0
- /package/dist/{src → esm}/babylon/delegationMessage.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/descriptor.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/index.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/network.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/parseDescriptor.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/stakingManager.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/stakingParams.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/undelegation/UndelegationResponse.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/undelegation/index.d.ts.map +0 -0
- /package/dist/{src → esm}/babylon/undelegation/unbonding.d.ts.map +0 -0
- /package/dist/{src → esm}/coreDao/descriptor.d.ts.map +0 -0
- /package/dist/{src → esm}/coreDao/index.d.ts.map +0 -0
- /package/dist/{src → esm}/coreDao/opReturn.d.ts.map +0 -0
- /package/dist/{src → esm}/coreDao/transaction.d.ts.map +0 -0
- /package/dist/{src → esm}/index.d.ts.map +0 -0
|
@@ -0,0 +1,156 @@
|
|
|
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
|
+
const assert_1 = __importDefault(require("assert"));
|
|
40
|
+
const fs_1 = require("fs");
|
|
41
|
+
const t = __importStar(require("io-ts"));
|
|
42
|
+
const PathReporter_1 = require("io-ts/lib/PathReporter");
|
|
43
|
+
const Either_1 = require("fp-ts/Either");
|
|
44
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
45
|
+
const wasm_utxo_1 = require("@bitgo/wasm-utxo");
|
|
46
|
+
const babylon_1 = require("../../../src/babylon");
|
|
47
|
+
const undelegation_1 = require("../../../src/babylon/undelegation");
|
|
48
|
+
const parseDescriptor_1 = require("../../../src/babylon/parseDescriptor");
|
|
49
|
+
const fixtures_utils_1 = require("../fixtures.utils");
|
|
50
|
+
const BtcDelegation = t.type({
|
|
51
|
+
unbonding_time: t.number,
|
|
52
|
+
undelegation_response: undelegation_1.UndelegationResponse,
|
|
53
|
+
});
|
|
54
|
+
async function getFixture(txid) {
|
|
55
|
+
// As returned by https://babylon.nodes.guru/api#/Query/BTCDelegation
|
|
56
|
+
const BtcDelegationResponse = t.type({ btc_delegation: BtcDelegation }, 'BtcDelegationResponse');
|
|
57
|
+
const filename = __dirname + `/../../fixtures/babylon/rpc/btc_delegation/testnet.${txid}.json`;
|
|
58
|
+
const data = JSON.parse(await fs_1.promises.readFile(filename, 'utf8'));
|
|
59
|
+
const result = BtcDelegationResponse.decode(data);
|
|
60
|
+
if ((0, Either_1.isLeft)(result)) {
|
|
61
|
+
throw new Error(`Failed to decode fixture data for txid ${txid}: ${PathReporter_1.PathReporter.report(result).join(', ')}`);
|
|
62
|
+
}
|
|
63
|
+
return result.right.btc_delegation;
|
|
64
|
+
}
|
|
65
|
+
function toDescriptor(descriptor) {
|
|
66
|
+
return descriptor instanceof wasm_utxo_1.Descriptor
|
|
67
|
+
? descriptor
|
|
68
|
+
: wasm_utxo_1.Descriptor.fromStringDetectType(typeof descriptor === 'string' ? descriptor : wasm_utxo_1.ast.formatNode(descriptor));
|
|
69
|
+
}
|
|
70
|
+
function runTest(network, txid, descriptor) {
|
|
71
|
+
describe(`Unbonding transaction ${txid}`, function () {
|
|
72
|
+
let fixture;
|
|
73
|
+
let psbt;
|
|
74
|
+
let signatures;
|
|
75
|
+
before('should create a PSBT from the unbonding transaction', async function () {
|
|
76
|
+
fixture = await getFixture(txid);
|
|
77
|
+
const txBuffer = Buffer.from(fixture.undelegation_response.unbonding_tx_hex, 'hex');
|
|
78
|
+
const tx = utxolib.bitgo.createTransactionFromBuffer(txBuffer, network, {
|
|
79
|
+
amountType: 'bigint',
|
|
80
|
+
});
|
|
81
|
+
signatures = fixture.undelegation_response.covenant_unbonding_sig_list.map((sig) => (0, undelegation_1.toPartialSig)(sig));
|
|
82
|
+
psbt = (0, undelegation_1.toUnbondingPsbtWithSignatures)(tx, {
|
|
83
|
+
script: Buffer.from('5120b81e8691ab3c46bddf8ea43f776e4d64abf417a0fa5a4d09976c8aaadabbb6a0', 'hex'),
|
|
84
|
+
value: 100000n,
|
|
85
|
+
}, descriptor, signatures, utxolib.networks.testnet);
|
|
86
|
+
});
|
|
87
|
+
it('should have valid signatures', async function () {
|
|
88
|
+
(0, undelegation_1.assertValidSignatures)(psbt, 0, signatures);
|
|
89
|
+
});
|
|
90
|
+
it('should match the fixture', async function () {
|
|
91
|
+
await (0, fixtures_utils_1.assertTransactionEqualsFixture)('test/fixtures/babylon/unbonding.' + txid.substring(0, 4) + '.psbt.json', psbt);
|
|
92
|
+
});
|
|
93
|
+
it('can spend from unbonding output', async function () {
|
|
94
|
+
const parsed = (0, parseDescriptor_1.parseStakingDescriptor)(descriptor);
|
|
95
|
+
(0, assert_1.default)(parsed);
|
|
96
|
+
const descriptorBuilder = new babylon_1.BabylonDescriptorBuilder(parsed.stakerKey, parsed.finalityProviderKeys, parsed.covenantKeys, parsed.covenantThreshold, parsed.stakingTimeLock, fixture.unbonding_time);
|
|
97
|
+
assert_1.default.deepStrictEqual(descriptorBuilder.getUnbondingMiniscriptNode(), parsed.unbondingMiniscriptNode, 'Unbonding miniscript node does not match expected value');
|
|
98
|
+
(0, assert_1.default)(psbt.txOutputs.length === 1, 'Unbonding transaction should have exactly one output');
|
|
99
|
+
assert_1.default.deepStrictEqual(psbt.txOutputs[0].script, Buffer.from(descriptorBuilder.getUnbondingDescriptor().scriptPubkey()));
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
runTest(utxolib.networks.bitcoinPublicSignet, '5d277e1b29e5589074aea95ac8c8230fd911c2ec3c58774aafdef915619b772c', toDescriptor({
|
|
104
|
+
tr: [
|
|
105
|
+
'50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0',
|
|
106
|
+
[
|
|
107
|
+
{
|
|
108
|
+
and_v: [
|
|
109
|
+
{
|
|
110
|
+
and_v: [
|
|
111
|
+
{ 'v:pk': '1b443f34ddc1bbaef52a8c5162dfa5a84524636ec745292f949470369ee67391' },
|
|
112
|
+
{ 'v:pk': 'd23c2c25e1fcf8fd1c21b9a402c19e2e309e531e45e92fb1e9805b6056b0cc76' },
|
|
113
|
+
],
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
multi_a: [
|
|
117
|
+
6,
|
|
118
|
+
'0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25',
|
|
119
|
+
'113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0',
|
|
120
|
+
'17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4',
|
|
121
|
+
'3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c',
|
|
122
|
+
'40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df',
|
|
123
|
+
'79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0',
|
|
124
|
+
'd21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36',
|
|
125
|
+
'f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e',
|
|
126
|
+
'fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737',
|
|
127
|
+
],
|
|
128
|
+
},
|
|
129
|
+
],
|
|
130
|
+
},
|
|
131
|
+
[
|
|
132
|
+
{
|
|
133
|
+
and_v: [
|
|
134
|
+
{ 'v:pk': '1b443f34ddc1bbaef52a8c5162dfa5a84524636ec745292f949470369ee67391' },
|
|
135
|
+
{
|
|
136
|
+
multi_a: [
|
|
137
|
+
6,
|
|
138
|
+
'0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25',
|
|
139
|
+
'113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0',
|
|
140
|
+
'17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4',
|
|
141
|
+
'3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c',
|
|
142
|
+
'40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df',
|
|
143
|
+
'79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0',
|
|
144
|
+
'd21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36',
|
|
145
|
+
'f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e',
|
|
146
|
+
'fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737',
|
|
147
|
+
],
|
|
148
|
+
},
|
|
149
|
+
],
|
|
150
|
+
},
|
|
151
|
+
{ and_v: [{ 'v:pk': '1b443f34ddc1bbaef52a8c5162dfa5a84524636ec745292f949470369ee67391' }, { older: 10000 }] },
|
|
152
|
+
],
|
|
153
|
+
],
|
|
154
|
+
],
|
|
155
|
+
}));
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"undelegation.js","sourceRoot":"","sources":["../../../../../test/unit/babylon/undelegation.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { promises as fs } from 'fs';\n\nimport * as t from 'io-ts';\nimport { PathReporter } from 'io-ts/lib/PathReporter';\nimport { isLeft } from 'fp-ts/Either';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { ast, Descriptor } from '@bitgo/wasm-utxo';\nimport { PartialSig } from 'bip174/src/lib/interfaces';\n\nimport { BabylonDescriptorBuilder } from '../../../src/babylon';\nimport {\n  toPartialSig,\n  UndelegationResponse,\n  assertValidSignatures,\n  toUnbondingPsbtWithSignatures,\n} from '../../../src/babylon/undelegation';\nimport { parseStakingDescriptor } from '../../../src/babylon/parseDescriptor';\nimport { assertTransactionEqualsFixture } from '../fixtures.utils';\n\nconst BtcDelegation = t.type({\n  unbonding_time: t.number,\n  undelegation_response: UndelegationResponse,\n});\n\ntype BtcDelegation = t.TypeOf<typeof BtcDelegation>;\n\nasync function getFixture(txid: string): Promise<BtcDelegation> {\n  // As returned by https://babylon.nodes.guru/api#/Query/BTCDelegation\n  const BtcDelegationResponse = t.type({ btc_delegation: BtcDelegation }, 'BtcDelegationResponse');\n  const filename = __dirname + `/../../fixtures/babylon/rpc/btc_delegation/testnet.${txid}.json`;\n  const data = JSON.parse(await fs.readFile(filename, 'utf8'));\n  const result = BtcDelegationResponse.decode(data);\n  if (isLeft(result)) {\n    throw new Error(`Failed to decode fixture data for txid ${txid}: ${PathReporter.report(result).join(', ')}`);\n  }\n  return result.right.btc_delegation;\n}\n\ntype DescriptorLike = Descriptor | ast.DescriptorNode | string;\n\nfunction toDescriptor(descriptor: DescriptorLike): Descriptor {\n  return descriptor instanceof Descriptor\n    ? descriptor\n    : Descriptor.fromStringDetectType(typeof descriptor === 'string' ? descriptor : ast.formatNode(descriptor));\n}\n\nfunction runTest(network: utxolib.Network, txid: string, descriptor: Descriptor): void {\n  describe(`Unbonding transaction ${txid}`, function () {\n    let fixture: BtcDelegation;\n    let psbt: utxolib.bitgo.UtxoPsbt;\n    let signatures: PartialSig[];\n\n    before('should create a PSBT from the unbonding transaction', async function () {\n      fixture = await getFixture(txid);\n      const txBuffer = Buffer.from(fixture.undelegation_response.unbonding_tx_hex, 'hex');\n      const tx = utxolib.bitgo.createTransactionFromBuffer(txBuffer, network, {\n        amountType: 'bigint',\n      });\n      signatures = fixture.undelegation_response.covenant_unbonding_sig_list.map((sig) => toPartialSig(sig));\n\n      psbt = toUnbondingPsbtWithSignatures(\n        tx,\n        {\n          script: Buffer.from('5120b81e8691ab3c46bddf8ea43f776e4d64abf417a0fa5a4d09976c8aaadabbb6a0', 'hex'),\n          value: 100_000n,\n        },\n        descriptor,\n        signatures,\n        utxolib.networks.testnet\n      );\n    });\n\n    it('should have valid signatures', async function () {\n      assertValidSignatures(psbt, 0, signatures);\n    });\n\n    it('should match the fixture', async function () {\n      await assertTransactionEqualsFixture(\n        'test/fixtures/babylon/unbonding.' + txid.substring(0, 4) + '.psbt.json',\n        psbt\n      );\n    });\n\n    it('can spend from unbonding output', async function () {\n      const parsed = parseStakingDescriptor(descriptor);\n      assert(parsed);\n\n      const descriptorBuilder = new BabylonDescriptorBuilder(\n        parsed.stakerKey,\n        parsed.finalityProviderKeys,\n        parsed.covenantKeys,\n        parsed.covenantThreshold,\n        parsed.stakingTimeLock,\n        fixture.unbonding_time\n      );\n\n      assert.deepStrictEqual(\n        descriptorBuilder.getUnbondingMiniscriptNode(),\n        parsed.unbondingMiniscriptNode,\n        'Unbonding miniscript node does not match expected value'\n      );\n\n      assert(psbt.txOutputs.length === 1, 'Unbonding transaction should have exactly one output');\n\n      assert.deepStrictEqual(\n        psbt.txOutputs[0].script,\n        Buffer.from(descriptorBuilder.getUnbondingDescriptor().scriptPubkey())\n      );\n    });\n  });\n}\n\nrunTest(\n  utxolib.networks.bitcoinPublicSignet,\n  '5d277e1b29e5589074aea95ac8c8230fd911c2ec3c58774aafdef915619b772c',\n  toDescriptor({\n    tr: [\n      '50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0',\n      [\n        {\n          and_v: [\n            {\n              and_v: [\n                { 'v:pk': '1b443f34ddc1bbaef52a8c5162dfa5a84524636ec745292f949470369ee67391' },\n                { 'v:pk': 'd23c2c25e1fcf8fd1c21b9a402c19e2e309e531e45e92fb1e9805b6056b0cc76' },\n              ],\n            },\n            {\n              multi_a: [\n                6,\n                '0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25',\n                '113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0',\n                '17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4',\n                '3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c',\n                '40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df',\n                '79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0',\n                'd21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36',\n                'f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e',\n                'fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737',\n              ],\n            },\n          ],\n        },\n        [\n          {\n            and_v: [\n              { 'v:pk': '1b443f34ddc1bbaef52a8c5162dfa5a84524636ec745292f949470369ee67391' },\n              {\n                multi_a: [\n                  6,\n                  '0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25',\n                  '113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0',\n                  '17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4',\n                  '3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c',\n                  '40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df',\n                  '79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0',\n                  'd21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36',\n                  'f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e',\n                  'fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737',\n                ],\n              },\n            ],\n          },\n          { and_v: [{ 'v:pk': '1b443f34ddc1bbaef52a8c5162dfa5a84524636ec745292f949470369ee67391' }, { older: 10000 }] },\n        ],\n      ],\n    ],\n  })\n);\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import * as bitcoinjslib from 'bitcoinjs-lib';
|
|
2
|
+
import { ECPairInterface } from '@bitgo-beta/utxo-lib';
|
|
3
|
+
import * as vendor from '@bitgo-beta/babylonlabs-io-btc-staking-ts';
|
|
4
|
+
import * as babylonProtobuf from '@babylonlabs-io/babylon-proto-ts';
|
|
5
|
+
import { BabylonDescriptorBuilder, ValueWithTypeUrl } from '../../../src/babylon';
|
|
6
|
+
type Result = {
|
|
7
|
+
unsignedDelegationMsg: ValueWithTypeUrl<babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation>;
|
|
8
|
+
stakingTx: bitcoinjslib.Transaction;
|
|
9
|
+
};
|
|
10
|
+
export declare function getBitGoUtxoStakingMsgCreateBtcDelegation(network: bitcoinjslib.Network, stakerKey: ECPairInterface, finalityProvider: ECPairInterface, descriptorBuilder: BabylonDescriptorBuilder, stakingParams: vendor.VersionedStakingParams[], changeAddress: string, amount: number, utxo: vendor.UTXO, feeRateSatB: number, blockHeight: number): Promise<Result>;
|
|
11
|
+
export declare function getVendorMsgCreateBtcDelegation(network: bitcoinjslib.Network, stakerKey: ECPairInterface, finalityProvider: ECPairInterface, descriptorBuilder: BabylonDescriptorBuilder, stakingParams: vendor.VersionedStakingParams[], changeAddress: string, amount: number, utxo: vendor.UTXO, feeRateSatB: number, blockHeight: number): Promise<Result>;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=vendor.utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vendor.utils.d.ts","sourceRoot":"","sources":["../../../../../test/unit/babylon/vendor.utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,YAAY,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,MAAM,MAAM,2CAA2C,CAAC;AACpE,OAAO,KAAK,eAAe,MAAM,kCAAkC,CAAC;AAIpE,OAAO,EACL,wBAAwB,EAGxB,gBAAgB,EACjB,MAAM,sBAAsB,CAAC;AAI9B,KAAK,MAAM,GAAG;IACZ,qBAAqB,EAAE,gBAAgB,CAAC,eAAe,CAAC,YAAY,CAAC,sBAAsB,CAAC,CAAC;IAC7F,SAAS,EAAE,YAAY,CAAC,WAAW,CAAC;CACrC,CAAC;AAEF,wBAAsB,yCAAyC,CAC7D,OAAO,EAAE,YAAY,CAAC,OAAO,EAC7B,SAAS,EAAE,eAAe,EAC1B,gBAAgB,EAAE,eAAe,EACjC,iBAAiB,EAAE,wBAAwB,EAC3C,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,EAC9C,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,MAAM,CAAC,CAoBjB;AAED,wBAAsB,+BAA+B,CACnD,OAAO,EAAE,YAAY,CAAC,OAAO,EAC7B,SAAS,EAAE,eAAe,EAC1B,gBAAgB,EAAE,eAAe,EACjC,iBAAiB,EAAE,wBAAwB,EAC3C,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,EAC9C,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,CAAC,IAAI,EACjB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,MAAM,CAAC,CAuCjB"}
|
|
@@ -0,0 +1,78 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.getBitGoUtxoStakingMsgCreateBtcDelegation = getBitGoUtxoStakingMsgCreateBtcDelegation;
|
|
37
|
+
exports.getVendorMsgCreateBtcDelegation = getVendorMsgCreateBtcDelegation;
|
|
38
|
+
const vendor = __importStar(require("@bitgo-beta/babylonlabs-io-btc-staking-ts"));
|
|
39
|
+
const babylonProtobuf = __importStar(require("@babylonlabs-io/babylon-proto-ts"));
|
|
40
|
+
const address_1 = require("bitcoinjs-lib/src/address");
|
|
41
|
+
const babylonlabs_io_btc_staking_ts_1 = require("@bitgo-beta/babylonlabs-io-btc-staking-ts");
|
|
42
|
+
const babylon_1 = require("../../../src/babylon");
|
|
43
|
+
const key_utils_1 = require("./key.utils");
|
|
44
|
+
async function getBitGoUtxoStakingMsgCreateBtcDelegation(network, stakerKey, finalityProvider, descriptorBuilder, stakingParams, changeAddress, amount, utxo, feeRateSatB, blockHeight) {
|
|
45
|
+
return await (0, babylon_1.createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider)((0, babylon_1.getBtcProviderForECKey)(descriptorBuilder, stakerKey), network, {
|
|
46
|
+
address: changeAddress,
|
|
47
|
+
publicKeyNoCoordHex: (0, key_utils_1.getXOnlyPubkey)(stakerKey).toString('hex'),
|
|
48
|
+
}, {
|
|
49
|
+
finalityProviderPksNoCoordHex: [(0, key_utils_1.getXOnlyPubkey)(finalityProvider).toString('hex')],
|
|
50
|
+
stakingAmountSat: amount,
|
|
51
|
+
stakingTimelock: (0, babylonlabs_io_btc_staking_ts_1.getBabylonParamByBtcHeight)(blockHeight, stakingParams).minStakingTimeBlocks,
|
|
52
|
+
}, 800000, [utxo], feeRateSatB, (0, address_1.toBech32)(Buffer.from('test'), 0, 'bbn'), 'delegation:create', stakingParams);
|
|
53
|
+
}
|
|
54
|
+
async function getVendorMsgCreateBtcDelegation(network, stakerKey, finalityProvider, descriptorBuilder, stakingParams, changeAddress, amount, utxo, feeRateSatB, blockHeight) {
|
|
55
|
+
const babylonProvider = {
|
|
56
|
+
async signTransaction(msg) {
|
|
57
|
+
// return unsigned payload
|
|
58
|
+
return babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation.encode(msg.value).finish();
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
const manager = new vendor.BabylonBtcStakingManager(network, stakingParams, (0, babylon_1.getBtcProviderForECKey)(descriptorBuilder, stakerKey), babylonProvider);
|
|
62
|
+
const result = await manager.preStakeRegistrationBabylonTransaction({
|
|
63
|
+
address: changeAddress,
|
|
64
|
+
publicKeyNoCoordHex: (0, key_utils_1.getXOnlyPubkey)(stakerKey).toString('hex'),
|
|
65
|
+
}, {
|
|
66
|
+
finalityProviderPksNoCoordHex: [(0, key_utils_1.getXOnlyPubkey)(finalityProvider).toString('hex')],
|
|
67
|
+
stakingAmountSat: amount,
|
|
68
|
+
stakingTimelock: (0, babylonlabs_io_btc_staking_ts_1.getBabylonParamByBtcHeight)(blockHeight, stakingParams).minStakingTimeBlocks,
|
|
69
|
+
}, blockHeight, [utxo], feeRateSatB, (0, address_1.toBech32)(Buffer.from('test'), 0, 'bbn'));
|
|
70
|
+
return {
|
|
71
|
+
unsignedDelegationMsg: {
|
|
72
|
+
typeUrl: '/babylon.btcstaking.v1.MsgCreateBTCDelegation',
|
|
73
|
+
value: babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation.decode(result.signedBabylonTx),
|
|
74
|
+
},
|
|
75
|
+
stakingTx: result.stakingTx,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVuZG9yLnV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vdGVzdC91bml0L2JhYnlsb24vdmVuZG9yLnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBcUJBLDhGQStCQztBQUVELDBFQWtEQztBQXRHRCxrRkFBb0U7QUFDcEUsa0ZBQW9FO0FBQ3BFLHVEQUFxRDtBQUNyRCw2RkFBdUY7QUFFdkYsa0RBSzhCO0FBRTlCLDJDQUE2QztBQU90QyxLQUFLLFVBQVUseUNBQXlDLENBQzdELE9BQTZCLEVBQzdCLFNBQTBCLEVBQzFCLGdCQUFpQyxFQUNqQyxpQkFBMkMsRUFDM0MsYUFBOEMsRUFDOUMsYUFBcUIsRUFDckIsTUFBYyxFQUNkLElBQWlCLEVBQ2pCLFdBQW1CLEVBQ25CLFdBQW1CO0lBRW5CLE9BQU8sTUFBTSxJQUFBLDZFQUFtRSxFQUM5RSxJQUFBLGdDQUFzQixFQUFDLGlCQUFpQixFQUFFLFNBQVMsQ0FBQyxFQUNwRCxPQUFPLEVBQ1A7UUFDRSxPQUFPLEVBQUUsYUFBYTtRQUN0QixtQkFBbUIsRUFBRSxJQUFBLDBCQUFjLEVBQUMsU0FBUyxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQztLQUMvRCxFQUNEO1FBQ0UsNkJBQTZCLEVBQUUsQ0FBQyxJQUFBLDBCQUFjLEVBQUMsZ0JBQWdCLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDakYsZ0JBQWdCLEVBQUUsTUFBTTtRQUN4QixlQUFlLEVBQUUsSUFBQSwwREFBMEIsRUFBQyxXQUFXLEVBQUUsYUFBYSxDQUFDLENBQUMsb0JBQW9CO0tBQzdGLEVBQ0QsTUFBTyxFQUNQLENBQUMsSUFBSSxDQUFDLEVBQ04sV0FBVyxFQUNYLElBQUEsa0JBQVEsRUFBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxLQUFLLENBQUMsRUFDdkMsbUJBQW1CLEVBQ25CLGFBQWEsQ0FDZCxDQUFDO0FBQ0osQ0FBQztBQUVNLEtBQUssVUFBVSwrQkFBK0IsQ0FDbkQsT0FBNkIsRUFDN0IsU0FBMEIsRUFDMUIsZ0JBQWlDLEVBQ2pDLGlCQUEyQyxFQUMzQyxhQUE4QyxFQUM5QyxhQUFxQixFQUNyQixNQUFjLEVBQ2QsSUFBaUIsRUFDakIsV0FBbUIsRUFDbkIsV0FBbUI7SUFFbkIsTUFBTSxlQUFlLEdBQTJCO1FBQzlDLEtBQUssQ0FBQyxlQUFlLENBQUMsR0FBRztZQUN2QiwwQkFBMEI7WUFDMUIsT0FBTyxlQUFlLENBQUMsWUFBWSxDQUFDLHNCQUFzQixDQUFDLE1BQU0sQ0FDL0QsR0FBRyxDQUFDLEtBQTRELENBQ2pFLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDYixDQUFDO0tBQ0YsQ0FBQztJQUNGLE1BQU0sT0FBTyxHQUFHLElBQUksTUFBTSxDQUFDLHdCQUF3QixDQUNqRCxPQUFPLEVBQ1AsYUFBYSxFQUNiLElBQUEsZ0NBQXNCLEVBQUMsaUJBQWlCLEVBQUUsU0FBUyxDQUFDLEVBQ3BELGVBQWUsQ0FDaEIsQ0FBQztJQUVGLE1BQU0sTUFBTSxHQUFHLE1BQU0sT0FBTyxDQUFDLHNDQUFzQyxDQUNqRTtRQUNFLE9BQU8sRUFBRSxhQUFhO1FBQ3RCLG1CQUFtQixFQUFFLElBQUEsMEJBQWMsRUFBQyxTQUFTLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDO0tBQy9ELEVBQ0Q7UUFDRSw2QkFBNkIsRUFBRSxDQUFDLElBQUEsMEJBQWMsRUFBQyxnQkFBZ0IsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNqRixnQkFBZ0IsRUFBRSxNQUFNO1FBQ3hCLGVBQWUsRUFBRSxJQUFBLDBEQUEwQixFQUFDLFdBQVcsRUFBRSxhQUFhLENBQUMsQ0FBQyxvQkFBb0I7S0FDN0YsRUFDRCxXQUFXLEVBQ1gsQ0FBQyxJQUFJLENBQUMsRUFDTixXQUFXLEVBQ1gsSUFBQSxrQkFBUSxFQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUN4QyxDQUFDO0lBRUYsT0FBTztRQUNMLHFCQUFxQixFQUFFO1lBQ3JCLE9BQU8sRUFBRSwrQ0FBK0M7WUFDeEQsS0FBSyxFQUFFLGVBQWUsQ0FBQyxZQUFZLENBQUMsc0JBQXNCLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUM7U0FDMUY7UUFDRCxTQUFTLEVBQUUsTUFBTSxDQUFDLFNBQVM7S0FDNUIsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBiaXRjb2luanNsaWIgZnJvbSAnYml0Y29pbmpzLWxpYic7XG5pbXBvcnQgeyBFQ1BhaXJJbnRlcmZhY2UgfSBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgKiBhcyB2ZW5kb3IgZnJvbSAnQGJpdGdvLWJldGEvYmFieWxvbmxhYnMtaW8tYnRjLXN0YWtpbmctdHMnO1xuaW1wb3J0ICogYXMgYmFieWxvblByb3RvYnVmIGZyb20gJ0BiYWJ5bG9ubGFicy1pby9iYWJ5bG9uLXByb3RvLXRzJztcbmltcG9ydCB7IHRvQmVjaDMyIH0gZnJvbSAnYml0Y29pbmpzLWxpYi9zcmMvYWRkcmVzcyc7XG5pbXBvcnQgeyBnZXRCYWJ5bG9uUGFyYW1CeUJ0Y0hlaWdodCB9IGZyb20gJ0BiaXRnby1iZXRhL2JhYnlsb25sYWJzLWlvLWJ0Yy1zdGFraW5nLXRzJztcblxuaW1wb3J0IHtcbiAgQmFieWxvbkRlc2NyaXB0b3JCdWlsZGVyLFxuICBjcmVhdGVVbnNpZ25lZFByZVN0YWtlUmVnaXN0cmF0aW9uQmFieWxvblRyYW5zYWN0aW9uV2l0aEJ0Y1Byb3ZpZGVyLFxuICBnZXRCdGNQcm92aWRlckZvckVDS2V5LFxuICBWYWx1ZVdpdGhUeXBlVXJsLFxufSBmcm9tICcuLi8uLi8uLi9zcmMvYmFieWxvbic7XG5cbmltcG9ydCB7IGdldFhPbmx5UHVia2V5IH0gZnJvbSAnLi9rZXkudXRpbHMnO1xuXG50eXBlIFJlc3VsdCA9IHtcbiAgdW5zaWduZWREZWxlZ2F0aW9uTXNnOiBWYWx1ZVdpdGhUeXBlVXJsPGJhYnlsb25Qcm90b2J1Zi5idGNzdGFraW5ndHguTXNnQ3JlYXRlQlRDRGVsZWdhdGlvbj47XG4gIHN0YWtpbmdUeDogYml0Y29pbmpzbGliLlRyYW5zYWN0aW9uO1xufTtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldEJpdEdvVXR4b1N0YWtpbmdNc2dDcmVhdGVCdGNEZWxlZ2F0aW9uKFxuICBuZXR3b3JrOiBiaXRjb2luanNsaWIuTmV0d29yayxcbiAgc3Rha2VyS2V5OiBFQ1BhaXJJbnRlcmZhY2UsXG4gIGZpbmFsaXR5UHJvdmlkZXI6IEVDUGFpckludGVyZmFjZSxcbiAgZGVzY3JpcHRvckJ1aWxkZXI6IEJhYnlsb25EZXNjcmlwdG9yQnVpbGRlcixcbiAgc3Rha2luZ1BhcmFtczogdmVuZG9yLlZlcnNpb25lZFN0YWtpbmdQYXJhbXNbXSxcbiAgY2hhbmdlQWRkcmVzczogc3RyaW5nLFxuICBhbW91bnQ6IG51bWJlcixcbiAgdXR4bzogdmVuZG9yLlVUWE8sXG4gIGZlZVJhdGVTYXRCOiBudW1iZXIsXG4gIGJsb2NrSGVpZ2h0OiBudW1iZXJcbik6IFByb21pc2U8UmVzdWx0PiB7XG4gIHJldHVybiBhd2FpdCBjcmVhdGVVbnNpZ25lZFByZVN0YWtlUmVnaXN0cmF0aW9uQmFieWxvblRyYW5zYWN0aW9uV2l0aEJ0Y1Byb3ZpZGVyKFxuICAgIGdldEJ0Y1Byb3ZpZGVyRm9yRUNLZXkoZGVzY3JpcHRvckJ1aWxkZXIsIHN0YWtlcktleSksXG4gICAgbmV0d29yayxcbiAgICB7XG4gICAgICBhZGRyZXNzOiBjaGFuZ2VBZGRyZXNzLFxuICAgICAgcHVibGljS2V5Tm9Db29yZEhleDogZ2V0WE9ubHlQdWJrZXkoc3Rha2VyS2V5KS50b1N0cmluZygnaGV4JyksXG4gICAgfSxcbiAgICB7XG4gICAgICBmaW5hbGl0eVByb3ZpZGVyUGtzTm9Db29yZEhleDogW2dldFhPbmx5UHVia2V5KGZpbmFsaXR5UHJvdmlkZXIpLnRvU3RyaW5nKCdoZXgnKV0sXG4gICAgICBzdGFraW5nQW1vdW50U2F0OiBhbW91bnQsXG4gICAgICBzdGFraW5nVGltZWxvY2s6IGdldEJhYnlsb25QYXJhbUJ5QnRjSGVpZ2h0KGJsb2NrSGVpZ2h0LCBzdGFraW5nUGFyYW1zKS5taW5TdGFraW5nVGltZUJsb2NrcyxcbiAgICB9LFxuICAgIDgwMF8wMDAsXG4gICAgW3V0eG9dLFxuICAgIGZlZVJhdGVTYXRCLFxuICAgIHRvQmVjaDMyKEJ1ZmZlci5mcm9tKCd0ZXN0JyksIDAsICdiYm4nKSxcbiAgICAnZGVsZWdhdGlvbjpjcmVhdGUnLFxuICAgIHN0YWtpbmdQYXJhbXNcbiAgKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldFZlbmRvck1zZ0NyZWF0ZUJ0Y0RlbGVnYXRpb24oXG4gIG5ldHdvcms6IGJpdGNvaW5qc2xpYi5OZXR3b3JrLFxuICBzdGFrZXJLZXk6IEVDUGFpckludGVyZmFjZSxcbiAgZmluYWxpdHlQcm92aWRlcjogRUNQYWlySW50ZXJmYWNlLFxuICBkZXNjcmlwdG9yQnVpbGRlcjogQmFieWxvbkRlc2NyaXB0b3JCdWlsZGVyLFxuICBzdGFraW5nUGFyYW1zOiB2ZW5kb3IuVmVyc2lvbmVkU3Rha2luZ1BhcmFtc1tdLFxuICBjaGFuZ2VBZGRyZXNzOiBzdHJpbmcsXG4gIGFtb3VudDogbnVtYmVyLFxuICB1dHhvOiB2ZW5kb3IuVVRYTyxcbiAgZmVlUmF0ZVNhdEI6IG51bWJlcixcbiAgYmxvY2tIZWlnaHQ6IG51bWJlclxuKTogUHJvbWlzZTxSZXN1bHQ+IHtcbiAgY29uc3QgYmFieWxvblByb3ZpZGVyOiB2ZW5kb3IuQmFieWxvblByb3ZpZGVyID0ge1xuICAgIGFzeW5jIHNpZ25UcmFuc2FjdGlvbihtc2cpIHtcbiAgICAgIC8vIHJldHVybiB1bnNpZ25lZCBwYXlsb2FkXG4gICAgICByZXR1cm4gYmFieWxvblByb3RvYnVmLmJ0Y3N0YWtpbmd0eC5Nc2dDcmVhdGVCVENEZWxlZ2F0aW9uLmVuY29kZShcbiAgICAgICAgbXNnLnZhbHVlIGFzIGJhYnlsb25Qcm90b2J1Zi5idGNzdGFraW5ndHguTXNnQ3JlYXRlQlRDRGVsZWdhdGlvblxuICAgICAgKS5maW5pc2goKTtcbiAgICB9LFxuICB9O1xuICBjb25zdCBtYW5hZ2VyID0gbmV3IHZlbmRvci5CYWJ5bG9uQnRjU3Rha2luZ01hbmFnZXIoXG4gICAgbmV0d29yayxcbiAgICBzdGFraW5nUGFyYW1zLFxuICAgIGdldEJ0Y1Byb3ZpZGVyRm9yRUNLZXkoZGVzY3JpcHRvckJ1aWxkZXIsIHN0YWtlcktleSksXG4gICAgYmFieWxvblByb3ZpZGVyXG4gICk7XG5cbiAgY29uc3QgcmVzdWx0ID0gYXdhaXQgbWFuYWdlci5wcmVTdGFrZVJlZ2lzdHJhdGlvbkJhYnlsb25UcmFuc2FjdGlvbihcbiAgICB7XG4gICAgICBhZGRyZXNzOiBjaGFuZ2VBZGRyZXNzLFxuICAgICAgcHVibGljS2V5Tm9Db29yZEhleDogZ2V0WE9ubHlQdWJrZXkoc3Rha2VyS2V5KS50b1N0cmluZygnaGV4JyksXG4gICAgfSxcbiAgICB7XG4gICAgICBmaW5hbGl0eVByb3ZpZGVyUGtzTm9Db29yZEhleDogW2dldFhPbmx5UHVia2V5KGZpbmFsaXR5UHJvdmlkZXIpLnRvU3RyaW5nKCdoZXgnKV0sXG4gICAgICBzdGFraW5nQW1vdW50U2F0OiBhbW91bnQsXG4gICAgICBzdGFraW5nVGltZWxvY2s6IGdldEJhYnlsb25QYXJhbUJ5QnRjSGVpZ2h0KGJsb2NrSGVpZ2h0LCBzdGFraW5nUGFyYW1zKS5taW5TdGFraW5nVGltZUJsb2NrcyxcbiAgICB9LFxuICAgIGJsb2NrSGVpZ2h0LFxuICAgIFt1dHhvXSxcbiAgICBmZWVSYXRlU2F0QixcbiAgICB0b0JlY2gzMihCdWZmZXIuZnJvbSgndGVzdCcpLCAwLCAnYmJuJylcbiAgKTtcblxuICByZXR1cm4ge1xuICAgIHVuc2lnbmVkRGVsZWdhdGlvbk1zZzoge1xuICAgICAgdHlwZVVybDogJy9iYWJ5bG9uLmJ0Y3N0YWtpbmcudjEuTXNnQ3JlYXRlQlRDRGVsZWdhdGlvbicsXG4gICAgICB2YWx1ZTogYmFieWxvblByb3RvYnVmLmJ0Y3N0YWtpbmd0eC5Nc2dDcmVhdGVCVENEZWxlZ2F0aW9uLmRlY29kZShyZXN1bHQuc2lnbmVkQmFieWxvblR4KSxcbiAgICB9LFxuICAgIHN0YWtpbmdUeDogcmVzdWx0LnN0YWtpbmdUeCxcbiAgfTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"descriptor.d.ts","sourceRoot":"","sources":["../../../../../test/unit/coreDao/descriptor.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,144 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const assert = __importStar(require("assert"));
|
|
37
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
38
|
+
const wasm_utxo_1 = require("@bitgo/wasm-utxo");
|
|
39
|
+
const testutil_1 = require("@bitgo-beta/utxo-core/testutil");
|
|
40
|
+
const coreDao_1 = require("../../../src/coreDao");
|
|
41
|
+
const utils_1 = require("./utils");
|
|
42
|
+
describe('descriptor', function () {
|
|
43
|
+
const baseFixturePath = 'test/fixtures/coreDao/descriptor/';
|
|
44
|
+
const rootWalletKeys = utxolib.testutil.getDefaultWalletKeys();
|
|
45
|
+
const key1 = rootWalletKeys.triple[0];
|
|
46
|
+
const key2 = rootWalletKeys.triple[1];
|
|
47
|
+
const key3 = rootWalletKeys.triple[2];
|
|
48
|
+
const validLocktime = 2048;
|
|
49
|
+
it('should fail if m is longer than the number of keys or not at least 1', function () {
|
|
50
|
+
assert.throws(() => {
|
|
51
|
+
(0, coreDao_1.createMultiSigDescriptor)('sh', validLocktime, 3, [key1, key2], false);
|
|
52
|
+
});
|
|
53
|
+
assert.throws(() => {
|
|
54
|
+
(0, coreDao_1.createMultiSigDescriptor)('sh', validLocktime, 0, [key1, key2], false);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
it('should fail if locktime is invalid', function () {
|
|
58
|
+
assert.throws(() => {
|
|
59
|
+
(0, coreDao_1.createMultiSigDescriptor)('sh', 0, 2, [key1, key2], false);
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
async function runTestForParams(scriptType, m, keys) {
|
|
63
|
+
const fixturePath = baseFixturePath + `${scriptType}-${m}of${keys.length}`;
|
|
64
|
+
describe(`should create a ${m} of ${keys.length} multi-sig ${scriptType} descriptor`, function () {
|
|
65
|
+
it('has expected descriptor string', async function () {
|
|
66
|
+
const descriptorString = (0, coreDao_1.createMultiSigDescriptor)(scriptType, validLocktime, m, keys, false);
|
|
67
|
+
assert.strictEqual(descriptorString, await (0, testutil_1.getFixture)(fixturePath + `-string.txt`, descriptorString), descriptorString);
|
|
68
|
+
});
|
|
69
|
+
it('has expected AST', async function () {
|
|
70
|
+
const descriptor = wasm_utxo_1.Descriptor.fromString((0, coreDao_1.createMultiSigDescriptor)(scriptType, validLocktime, m, keys, false), 'derivable');
|
|
71
|
+
assert.deepStrictEqual(descriptor.node(), await (0, testutil_1.getFixture)(fixturePath + '-ast.json', descriptor.node()));
|
|
72
|
+
});
|
|
73
|
+
it('has expected asm', async function () {
|
|
74
|
+
const descriptor = wasm_utxo_1.Descriptor.fromString((0, coreDao_1.createMultiSigDescriptor)(scriptType, validLocktime, m, keys, false), 'derivable');
|
|
75
|
+
const asmString = descriptor.atDerivationIndex(0).toAsmString();
|
|
76
|
+
assert.strictEqual(asmString, await (0, testutil_1.getFixture)(fixturePath + '-asm.txt', asmString), asmString);
|
|
77
|
+
});
|
|
78
|
+
it('can be signed', async function () {
|
|
79
|
+
// Derive the script from the descriptor
|
|
80
|
+
const descriptor = wasm_utxo_1.Descriptor.fromString((0, coreDao_1.createMultiSigDescriptor)(scriptType, validLocktime, m, keys, false), 'derivable');
|
|
81
|
+
const descriptorAt0 = descriptor.atDerivationIndex(0);
|
|
82
|
+
const script = Buffer.from(descriptorAt0.scriptPubkey());
|
|
83
|
+
// Make the prevTx
|
|
84
|
+
const prevPsbt = utxolib.testutil.constructPsbt([{ scriptType: 'p2wsh', value: BigInt(1.1e8) }], [{ script: script.toString('hex'), value: BigInt(1e8) }], utxolib.networks.bitcoin, rootWalletKeys, 'fullsigned');
|
|
85
|
+
const prevTx = prevPsbt.finalizeAllInputs().extractTransaction();
|
|
86
|
+
// Create the PSBT and sign
|
|
87
|
+
const psbt = Object.assign(new utxolib.Psbt({ network: utxolib.networks.bitcoin }), {
|
|
88
|
+
locktime: validLocktime,
|
|
89
|
+
});
|
|
90
|
+
psbt.addInput({
|
|
91
|
+
hash: prevTx.getId(),
|
|
92
|
+
index: 0,
|
|
93
|
+
sequence: 0xfffffffe,
|
|
94
|
+
});
|
|
95
|
+
if (scriptType === 'sh-wsh') {
|
|
96
|
+
psbt.updateInput(0, { witnessUtxo: { script, value: BigInt(1e8) } });
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
psbt.updateInput(0, { nonWitnessUtxo: prevTx.toBuffer() });
|
|
100
|
+
}
|
|
101
|
+
psbt.addOutput({ script, value: BigInt(0.9e8) });
|
|
102
|
+
(0, utils_1.updateInputWithDescriptor)(psbt, 0, descriptorAt0);
|
|
103
|
+
keys.forEach((signer, i) => {
|
|
104
|
+
if (i >= m) {
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
psbt.signAllInputsHD(signer);
|
|
108
|
+
});
|
|
109
|
+
// Get the fully signed transaction and check
|
|
110
|
+
const signedTx = (0, utils_1.finalizePsbt)(psbt).extractTransaction().toBuffer();
|
|
111
|
+
assert.strictEqual(signedTx.toString('hex'), await (0, testutil_1.getFixture)(fixturePath + '-tx.txt', signedTx.toString('hex')));
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
runTestForParams('sh', 2, [key1, key2]);
|
|
116
|
+
runTestForParams('sh-wsh', 2, [key1, key2]);
|
|
117
|
+
runTestForParams('sh', 3, [key1, key2, key3]);
|
|
118
|
+
runTestForParams('wsh', 3, [key1, key2, key3]);
|
|
119
|
+
it('should recreate the script used in testnet staking transaction', function () {
|
|
120
|
+
// Source: https://mempool.space/testnet/address/2MxTi2EhHKgdJFKRTBttVGGxir9ZzjmKCXw
|
|
121
|
+
// 2 of 2 multisig
|
|
122
|
+
const timelock = 'fce4cb66';
|
|
123
|
+
const pubkey1 = '03ecb6d4b7f5d56962e547fc52dd588359f5729c0ba856d6978b84723895a16691';
|
|
124
|
+
const pubkey2 = '024aaea25d82b1db2be030a05b641d6302e48ed652b1ca9cb08a67267fcbb56747';
|
|
125
|
+
const redeemScriptASM = [
|
|
126
|
+
'OP_PUSHBYTES_4',
|
|
127
|
+
timelock,
|
|
128
|
+
'OP_CLTV',
|
|
129
|
+
'OP_DROP',
|
|
130
|
+
'OP_PUSHNUM_2',
|
|
131
|
+
'OP_PUSHBYTES_33',
|
|
132
|
+
pubkey1,
|
|
133
|
+
'OP_PUSHBYTES_33',
|
|
134
|
+
pubkey2,
|
|
135
|
+
'OP_PUSHNUM_2',
|
|
136
|
+
'OP_CHECKMULTISIG',
|
|
137
|
+
].join(' ');
|
|
138
|
+
const decodedTimelock = (0, coreDao_1.decodeTimelock)(Buffer.from(timelock, 'hex'));
|
|
139
|
+
const descriptor = (0, coreDao_1.createMultiSigDescriptor)('sh', decodedTimelock, 2, [Buffer.from(pubkey1, 'hex'), Buffer.from(pubkey2, 'hex')], false);
|
|
140
|
+
const descriptorASM = wasm_utxo_1.Descriptor.fromString(descriptor, 'definite').toAsmString();
|
|
141
|
+
assert.deepStrictEqual(redeemScriptASM, descriptorASM);
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"descriptor.js","sourceRoot":"","sources":["../../../../../test/unit/coreDao/descriptor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\n\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { Descriptor } from '@bitgo/wasm-utxo';\nimport { getFixture } from '@bitgo-beta/utxo-core/testutil';\n\nimport { createMultiSigDescriptor, decodeTimelock } from '../../../src/coreDao';\n\nimport { finalizePsbt, updateInputWithDescriptor } from './utils';\n\ndescribe('descriptor', function () {\n  const baseFixturePath = 'test/fixtures/coreDao/descriptor/';\n  const rootWalletKeys = utxolib.testutil.getDefaultWalletKeys();\n  const key1 = rootWalletKeys.triple[0];\n  const key2 = rootWalletKeys.triple[1];\n  const key3 = rootWalletKeys.triple[2];\n  const validLocktime = 2048;\n\n  it('should fail if m is longer than the number of keys or not at least 1', function () {\n    assert.throws(() => {\n      createMultiSigDescriptor('sh', validLocktime, 3, [key1, key2], false);\n    });\n\n    assert.throws(() => {\n      createMultiSigDescriptor('sh', validLocktime, 0, [key1, key2], false);\n    });\n  });\n\n  it('should fail if locktime is invalid', function () {\n    assert.throws(() => {\n      createMultiSigDescriptor('sh', 0, 2, [key1, key2], false);\n    });\n  });\n\n  async function runTestForParams(scriptType: 'sh' | 'sh-wsh' | 'wsh', m: number, keys: utxolib.BIP32Interface[]) {\n    const fixturePath = baseFixturePath + `${scriptType}-${m}of${keys.length}`;\n    describe(`should create a ${m} of ${keys.length} multi-sig ${scriptType} descriptor`, function () {\n      it('has expected descriptor string', async function () {\n        const descriptorString = createMultiSigDescriptor(scriptType, validLocktime, m, keys, false);\n        assert.strictEqual(\n          descriptorString,\n          await getFixture(fixturePath + `-string.txt`, descriptorString),\n          descriptorString\n        );\n      });\n\n      it('has expected AST', async function () {\n        const descriptor = Descriptor.fromString(\n          createMultiSigDescriptor(scriptType, validLocktime, m, keys, false),\n          'derivable'\n        );\n\n        assert.deepStrictEqual(descriptor.node(), await getFixture(fixturePath + '-ast.json', descriptor.node()));\n      });\n\n      it('has expected asm', async function () {\n        const descriptor = Descriptor.fromString(\n          createMultiSigDescriptor(scriptType, validLocktime, m, keys, false),\n          'derivable'\n        );\n        const asmString = descriptor.atDerivationIndex(0).toAsmString();\n        assert.strictEqual(asmString, await getFixture(fixturePath + '-asm.txt', asmString), asmString);\n      });\n\n      it('can be signed', async function () {\n        // Derive the script from the descriptor\n        const descriptor = Descriptor.fromString(\n          createMultiSigDescriptor(scriptType, validLocktime, m, keys, false),\n          'derivable'\n        );\n        const descriptorAt0 = descriptor.atDerivationIndex(0);\n        const script = Buffer.from(descriptorAt0.scriptPubkey());\n\n        // Make the prevTx\n        const prevPsbt = utxolib.testutil.constructPsbt(\n          [{ scriptType: 'p2wsh', value: BigInt(1.1e8) }],\n          [{ script: script.toString('hex'), value: BigInt(1e8) }],\n          utxolib.networks.bitcoin,\n          rootWalletKeys,\n          'fullsigned'\n        );\n        const prevTx = prevPsbt.finalizeAllInputs().extractTransaction();\n\n        // Create the PSBT and sign\n        const psbt = Object.assign(new utxolib.Psbt({ network: utxolib.networks.bitcoin }), {\n          locktime: validLocktime,\n        });\n        psbt.addInput({\n          hash: prevTx.getId(),\n          index: 0,\n          sequence: 0xfffffffe,\n        });\n        if (scriptType === 'sh-wsh') {\n          psbt.updateInput(0, { witnessUtxo: { script, value: BigInt(1e8) } });\n        } else {\n          psbt.updateInput(0, { nonWitnessUtxo: prevTx.toBuffer() });\n        }\n        psbt.addOutput({ script, value: BigInt(0.9e8) });\n        updateInputWithDescriptor(psbt, 0, descriptorAt0);\n        keys.forEach((signer, i) => {\n          if (i >= m) {\n            return;\n          }\n          psbt.signAllInputsHD(signer);\n        });\n\n        // Get the fully signed transaction and check\n        const signedTx = finalizePsbt(psbt).extractTransaction().toBuffer();\n        assert.strictEqual(\n          signedTx.toString('hex'),\n          await getFixture(fixturePath + '-tx.txt', signedTx.toString('hex'))\n        );\n      });\n    });\n  }\n\n  runTestForParams('sh', 2, [key1, key2]);\n  runTestForParams('sh-wsh', 2, [key1, key2]);\n  runTestForParams('sh', 3, [key1, key2, key3]);\n  runTestForParams('wsh', 3, [key1, key2, key3]);\n\n  it('should recreate the script used in testnet staking transaction', function () {\n    // Source: https://mempool.space/testnet/address/2MxTi2EhHKgdJFKRTBttVGGxir9ZzjmKCXw\n    // 2 of 2 multisig\n    const timelock = 'fce4cb66';\n    const pubkey1 = '03ecb6d4b7f5d56962e547fc52dd588359f5729c0ba856d6978b84723895a16691';\n    const pubkey2 = '024aaea25d82b1db2be030a05b641d6302e48ed652b1ca9cb08a67267fcbb56747';\n    const redeemScriptASM = [\n      'OP_PUSHBYTES_4',\n      timelock,\n      'OP_CLTV',\n      'OP_DROP',\n      'OP_PUSHNUM_2',\n      'OP_PUSHBYTES_33',\n      pubkey1,\n      'OP_PUSHBYTES_33',\n      pubkey2,\n      'OP_PUSHNUM_2',\n      'OP_CHECKMULTISIG',\n    ].join(' ');\n\n    const decodedTimelock = decodeTimelock(Buffer.from(timelock, 'hex'));\n    const descriptor = createMultiSigDescriptor(\n      'sh',\n      decodedTimelock,\n      2,\n      [Buffer.from(pubkey1, 'hex'), Buffer.from(pubkey2, 'hex')],\n      false\n    );\n    const descriptorASM = Descriptor.fromString(descriptor, 'definite').toAsmString();\n    assert.deepStrictEqual(redeemScriptASM, descriptorASM);\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"opReturn.d.ts","sourceRoot":"","sources":["../../../../../test/unit/coreDao/opReturn.ts"],"names":[],"mappings":""}
|