@bitgo-beta/utxo-staking 1.1.1-beta.2 → 1.1.1-beta.200
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/.eslintignore +1 -1
- package/.eslintrc.js +7 -0
- package/CHANGELOG.md +93 -0
- package/dist/src/babylon/delegationMessage.d.ts +23 -0
- package/dist/src/babylon/delegationMessage.d.ts.map +1 -0
- package/dist/src/babylon/delegationMessage.js +135 -0
- package/dist/src/babylon/descriptor.d.ts +28 -0
- package/dist/src/babylon/descriptor.d.ts.map +1 -0
- package/dist/src/babylon/descriptor.js +92 -0
- package/dist/src/babylon/index.d.ts +4 -0
- package/dist/src/babylon/index.d.ts.map +1 -0
- package/dist/src/babylon/index.js +20 -0
- package/dist/src/babylon/keyUtils.d.ts +3 -0
- package/dist/src/babylon/keyUtils.d.ts.map +1 -0
- package/dist/src/babylon/keyUtils.js +7 -0
- package/dist/src/babylon/stakingParams.d.ts +31 -0
- package/dist/src/babylon/stakingParams.d.ts.map +1 -0
- package/dist/src/babylon/stakingParams.js +98 -0
- package/dist/src/coreDao/descriptor.d.ts +4 -4
- package/dist/src/coreDao/descriptor.d.ts.map +1 -1
- package/dist/src/coreDao/descriptor.js +12 -5
- package/dist/src/coreDao/opReturn.d.ts +5 -5
- package/dist/src/coreDao/opReturn.d.ts.map +1 -1
- package/dist/src/coreDao/opReturn.js +19 -11
- package/dist/src/coreDao/transaction.d.ts +17 -9
- package/dist/src/coreDao/transaction.d.ts.map +1 -1
- package/dist/src/coreDao/transaction.js +17 -9
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +26 -3
- package/dist/src/transaction.d.ts +0 -2
- package/dist/src/transaction.d.ts.map +1 -1
- package/dist/src/transaction.js +36 -4
- package/package.json +10 -7
- package/.mocharc.yml +0 -8
package/.eslintignore
CHANGED
package/.eslintrc.js
ADDED
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,99 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [1.9.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.8.0...@bitgo/utxo-staking@1.9.0) (2025-03-06)
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
- **utxo-staking:** add normalize helper for test fixtures ([b2266d8](https://github.com/BitGo/BitGoJS/commit/b2266d8264b7579ebd505cb7c723389439f65849))
|
|
11
|
+
|
|
12
|
+
# [1.8.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.6.0...@bitgo/utxo-staking@1.8.0) (2025-03-04)
|
|
13
|
+
|
|
14
|
+
### Bug Fixes
|
|
15
|
+
|
|
16
|
+
- **utxo-staking:** avoid mutating input array in sortedKeys ([17f6e5d](https://github.com/BitGo/BitGoJS/commit/17f6e5de5f16d0356075816ba3f204b8612ce641))
|
|
17
|
+
|
|
18
|
+
### Features
|
|
19
|
+
|
|
20
|
+
- **utxo-core:** simplify module exports ([ea7cd0f](https://github.com/BitGo/BitGoJS/commit/ea7cd0f90977894c25fc0734386b9e8d27465fd5))
|
|
21
|
+
- **utxo-staking:** add single key finality provider script generation ([0fe5393](https://github.com/BitGo/BitGoJS/commit/0fe539359f01c204d34cfe86f208cdc2697bcb7d))
|
|
22
|
+
- **utxo-staking:** exclude test fixtures from prettier formatting ([7cf7bdc](https://github.com/BitGo/BitGoJS/commit/7cf7bdcc57bc5ee09be387abcf5ae119889f44db))
|
|
23
|
+
- **utxo-staking:** update CoreDAO output type to use utxo-core Output ([30902d6](https://github.com/BitGo/BitGoJS/commit/30902d6e152581651806a86aa3d1b2f56a1a9830))
|
|
24
|
+
|
|
25
|
+
# [1.7.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.6.0...@bitgo/utxo-staking@1.7.0) (2025-02-26)
|
|
26
|
+
|
|
27
|
+
### Bug Fixes
|
|
28
|
+
|
|
29
|
+
- **utxo-staking:** avoid mutating input array in sortedKeys ([17f6e5d](https://github.com/BitGo/BitGoJS/commit/17f6e5de5f16d0356075816ba3f204b8612ce641))
|
|
30
|
+
|
|
31
|
+
### Features
|
|
32
|
+
|
|
33
|
+
- **utxo-staking:** add single key finality provider script generation ([0fe5393](https://github.com/BitGo/BitGoJS/commit/0fe539359f01c204d34cfe86f208cdc2697bcb7d))
|
|
34
|
+
- **utxo-staking:** exclude test fixtures from prettier formatting ([7cf7bdc](https://github.com/BitGo/BitGoJS/commit/7cf7bdcc57bc5ee09be387abcf5ae119889f44db))
|
|
35
|
+
|
|
36
|
+
## [1.6.1](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.6.0...@bitgo/utxo-staking@1.6.1) (2025-02-20)
|
|
37
|
+
|
|
38
|
+
**Note:** Version bump only for package @bitgo/utxo-staking
|
|
39
|
+
|
|
40
|
+
# [1.6.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.5.0...@bitgo/utxo-staking@1.6.0) (2025-02-19)
|
|
41
|
+
|
|
42
|
+
### Features
|
|
43
|
+
|
|
44
|
+
- **utxo-staking:** add testnet params and descriptor builder for Babylon ([b0764bb](https://github.com/BitGo/BitGoJS/commit/b0764bb644ad2313ac19ddd4210f340fbf9b60f1))
|
|
45
|
+
- **utxo-staking:** add vendored btc-staking-ts 0.4.0-rc.2 ([607fd3e](https://github.com/BitGo/BitGoJS/commit/607fd3eaea6508668ae42dbe9c5d2444d12ec245))
|
|
46
|
+
- **utxo-staking:** enable import ordering rule ([0f8b127](https://github.com/BitGo/BitGoJS/commit/0f8b1273a6e5683610a7131de828d6e21a5a4bc4))
|
|
47
|
+
- **utxo-staking:** export babylon staking module ([4e86a2c](https://github.com/BitGo/BitGoJS/commit/4e86a2c06fe68a5592aa937399a0e5aa6648e24e))
|
|
48
|
+
- **utxo-staking:** migrate test utils to utxo-core ([4395971](https://github.com/BitGo/BitGoJS/commit/4395971fcc21afaf55727f6badb26335c91cde19))
|
|
49
|
+
- **utxo-staking:** simplify mocha config and test scripts ([44b3d7c](https://github.com/BitGo/BitGoJS/commit/44b3d7c0ae0cc1d0c4b49f5fcbeabc21cfb7effa))
|
|
50
|
+
- **utxo-staking:** use miniscript AST for descriptor creation ([bc0fb09](https://github.com/BitGo/BitGoJS/commit/bc0fb096ce29dae1e6cde984f3d54f9a292d4996))
|
|
51
|
+
- **utxo-staking:** use TapTreeNode type for Babylon descriptor ([79f9c5c](https://github.com/BitGo/BitGoJS/commit/79f9c5c8e8650b494ec1afa2fa215328d3d1facb))
|
|
52
|
+
|
|
53
|
+
# [1.5.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.3.5...@bitgo/utxo-staking@1.5.0) (2024-12-17)
|
|
54
|
+
|
|
55
|
+
### Features
|
|
56
|
+
|
|
57
|
+
- **utxo-staking:** add support for wsh script type ([c3632a4](https://github.com/BitGo/BitGoJS/commit/c3632a456a92953ee52340c79740bcd9e6f66215))
|
|
58
|
+
|
|
59
|
+
# [1.4.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.3.5...@bitgo/utxo-staking@1.4.0) (2024-12-17)
|
|
60
|
+
|
|
61
|
+
### Features
|
|
62
|
+
|
|
63
|
+
- **utxo-staking:** add support for wsh script type ([c3632a4](https://github.com/BitGo/BitGoJS/commit/c3632a456a92953ee52340c79740bcd9e6f66215))
|
|
64
|
+
|
|
65
|
+
## [1.3.5](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.3.4...@bitgo/utxo-staking@1.3.5) (2024-12-12)
|
|
66
|
+
|
|
67
|
+
**Note:** Version bump only for package @bitgo/utxo-staking
|
|
68
|
+
|
|
69
|
+
## [1.3.4](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.3.3...@bitgo/utxo-staking@1.3.4) (2024-12-11)
|
|
70
|
+
|
|
71
|
+
**Note:** Version bump only for package @bitgo/utxo-staking
|
|
72
|
+
|
|
73
|
+
## [1.3.3](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.3.2...@bitgo/utxo-staking@1.3.3) (2024-12-03)
|
|
74
|
+
|
|
75
|
+
**Note:** Version bump only for package @bitgo/utxo-staking
|
|
76
|
+
|
|
77
|
+
## [1.3.2](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.3.1...@bitgo/utxo-staking@1.3.2) (2024-11-26)
|
|
78
|
+
|
|
79
|
+
**Note:** Version bump only for package @bitgo/utxo-staking
|
|
80
|
+
|
|
81
|
+
## [1.3.1](https://github.com/BitGo/BitGoJS/compare/@bitgo/utxo-staking@1.3.0...@bitgo/utxo-staking@1.3.1) (2024-11-21)
|
|
82
|
+
|
|
83
|
+
**Note:** Version bump only for package @bitgo/utxo-staking
|
|
84
|
+
|
|
85
|
+
# 1.3.0 (2024-11-19)
|
|
86
|
+
|
|
87
|
+
### Features
|
|
88
|
+
|
|
89
|
+
- **utxo-staking:** build staking transaction ([73b33bc](https://github.com/BitGo/BitGoJS/commit/73b33bc93e46934fe5e6002c52c0b1443a3d0d8d))
|
|
90
|
+
- **utxo-staking:** create coredao staking outputs ([6b5ca4b](https://github.com/BitGo/BitGoJS/commit/6b5ca4b7c726fb6a4380526391416f6db356e0b7))
|
|
91
|
+
|
|
92
|
+
# 1.2.0 (2024-11-14)
|
|
93
|
+
|
|
94
|
+
### Features
|
|
95
|
+
|
|
96
|
+
- **utxo-staking:** build staking transaction ([73b33bc](https://github.com/BitGo/BitGoJS/commit/73b33bc93e46934fe5e6002c52c0b1443a3d0d8d))
|
|
97
|
+
- **utxo-staking:** create coredao staking outputs ([6b5ca4b](https://github.com/BitGo/BitGoJS/commit/6b5ca4b7c726fb6a4380526391416f6db356e0b7))
|
|
98
|
+
|
|
6
99
|
# 1.1.0 (2024-11-01)
|
|
7
100
|
|
|
8
101
|
### Bug Fixes
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import * as vendor from '@bitgo-beta/babylonlabs-io-btc-staking-ts';
|
|
2
|
+
import * as babylonProtobuf from '@babylonlabs-io/babylon-proto-ts';
|
|
3
|
+
import * as bitcoinjslib from 'bitcoinjs-lib';
|
|
4
|
+
import { ECPairInterface } from '@bitgo-beta/utxo-lib';
|
|
5
|
+
import { Descriptor } from '@bitgo/wasm-miniscript';
|
|
6
|
+
import { BabylonDescriptorBuilder } from './descriptor';
|
|
7
|
+
export declare const mockBabylonProvider: vendor.BabylonProvider;
|
|
8
|
+
export type ValueWithTypeUrl<T> = {
|
|
9
|
+
typeUrl: string;
|
|
10
|
+
value: T;
|
|
11
|
+
};
|
|
12
|
+
export declare function getSignedPsbt(psbt: bitcoinjslib.Psbt, descriptor: Descriptor, signers: ECPairInterface[], { finalize }: {
|
|
13
|
+
finalize?: boolean | undefined;
|
|
14
|
+
}): bitcoinjslib.Psbt;
|
|
15
|
+
export declare function getBtcProviderForECKey(descriptorBuilder: BabylonDescriptorBuilder, stakerKey: ECPairInterface): vendor.BtcProvider;
|
|
16
|
+
type Result = {
|
|
17
|
+
unsignedDelegationMsg: ValueWithTypeUrl<babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation>;
|
|
18
|
+
stakingTx: bitcoinjslib.Transaction;
|
|
19
|
+
};
|
|
20
|
+
export declare function createUnsignedPreStakeRegistrationBabylonTransaction(manager: vendor.BabylonBtcStakingManager, stakingParams: vendor.VersionedStakingParams[], network: bitcoinjslib.Network, stakerBtcInfo: vendor.StakerInfo, stakingInput: vendor.StakingInputs, babylonBtcTipHeight: number, inputUTXOs: vendor.UTXO[], feeRateSatB: number, babylonAddress: string): Promise<Result>;
|
|
21
|
+
export declare function createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider(btcProvider: vendor.BtcProvider, stakingParams: vendor.VersionedStakingParams, network: bitcoinjslib.Network, stakerBtcInfo: vendor.StakerInfo, stakingInput: vendor.StakingInputs, babylonBtcTipHeight: number, inputUTXOs: vendor.UTXO[], feeRateSatB: number, babylonAddress: string): Promise<Result>;
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=delegationMessage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegationMessage.d.ts","sourceRoot":"","sources":["../../../src/babylon/delegationMessage.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,MAAM,2CAA2C,CAAC;AACpE,OAAO,KAAK,eAAe,MAAM,kCAAkC,CAAC;AACpE,OAAO,KAAK,YAAY,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAGpD,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AAExD,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,eAIxC,CAAC;AAEF,MAAM,MAAM,gBAAgB,CAAC,CAAC,IAAI;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,CAAC,CAAA;CAAE,CAAC;AAEhE,wBAAgB,aAAa,CAC3B,IAAI,EAAE,YAAY,CAAC,IAAI,EACvB,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,eAAe,EAAE,EAC1B,EAAE,QAAgB,EAAE;;CAAA,GACnB,YAAY,CAAC,IAAI,CAmBnB;AAED,wBAAgB,sBAAsB,CACpC,iBAAiB,EAAE,wBAAwB,EAC3C,SAAS,EAAE,eAAe,GACzB,MAAM,CAAC,WAAW,CAkCpB;AAED,KAAK,MAAM,GAAG;IACZ,qBAAqB,EAAE,gBAAgB,CAAC,eAAe,CAAC,YAAY,CAAC,sBAAsB,CAAC,CAAC;IAC7F,SAAS,EAAE,YAAY,CAAC,WAAW,CAAC;CACrC,CAAC;AAQF,wBAAsB,oDAAoD,CACxE,OAAO,EAAE,MAAM,CAAC,wBAAwB,EACxC,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAAE,EAC9C,OAAO,EAAE,YAAY,CAAC,OAAO,EAC7B,aAAa,EAAE,MAAM,CAAC,UAAU,EAChC,YAAY,EAAE,MAAM,CAAC,aAAa,EAClC,mBAAmB,EAAE,MAAM,EAC3B,UAAU,EAAE,MAAM,CAAC,IAAI,EAAE,EACzB,WAAW,EAAE,MAAM,EACnB,cAAc,EAAE,MAAM,GACrB,OAAO,CAAC,MAAM,CAAC,CAsCjB;AAED,wBAAsB,mEAAmE,CACvF,WAAW,EAAE,MAAM,CAAC,WAAW,EAC/B,aAAa,EAAE,MAAM,CAAC,sBAAsB,EAC5C,OAAO,EAAE,YAAY,CAAC,OAAO,EAC7B,aAAa,EAAE,MAAM,CAAC,UAAU,EAChC,YAAY,EAAE,MAAM,CAAC,aAAa,EAClC,mBAAmB,EAAE,MAAM,EAC3B,UAAU,EAAE,MAAM,CAAC,IAAI,EAAE,EACzB,WAAW,EAAE,MAAM,EACnB,cAAc,EAAE,MAAM,GACrB,OAAO,CAAC,MAAM,CAAC,CAajB"}
|
|
@@ -0,0 +1,135 @@
|
|
|
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.mockBabylonProvider = void 0;
|
|
40
|
+
exports.getSignedPsbt = getSignedPsbt;
|
|
41
|
+
exports.getBtcProviderForECKey = getBtcProviderForECKey;
|
|
42
|
+
exports.createUnsignedPreStakeRegistrationBabylonTransaction = createUnsignedPreStakeRegistrationBabylonTransaction;
|
|
43
|
+
exports.createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider = createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider;
|
|
44
|
+
const assert_1 = __importDefault(require("assert"));
|
|
45
|
+
const vendor = __importStar(require("@bitgo-beta/babylonlabs-io-btc-staking-ts"));
|
|
46
|
+
const bitcoinjslib = __importStar(require("bitcoinjs-lib"));
|
|
47
|
+
const descriptor_1 = require("@bitgo-beta/utxo-core/descriptor");
|
|
48
|
+
exports.mockBabylonProvider = {
|
|
49
|
+
signTransaction() {
|
|
50
|
+
throw new Error('Function not implemented.');
|
|
51
|
+
},
|
|
52
|
+
};
|
|
53
|
+
function getSignedPsbt(psbt, descriptor, signers, { finalize = false }) {
|
|
54
|
+
const wrappedPsbt = (0, descriptor_1.toWrappedPsbt)(psbt.toBuffer());
|
|
55
|
+
const signedInputs = psbt.data.inputs.flatMap((input, i) => {
|
|
56
|
+
(0, assert_1.default)(input.witnessUtxo);
|
|
57
|
+
if (Buffer.from(descriptor.scriptPubkey()).equals(input.witnessUtxo.script)) {
|
|
58
|
+
wrappedPsbt.updateInputWithDescriptor(i, descriptor);
|
|
59
|
+
const signResults = signers.map((signer) => {
|
|
60
|
+
(0, assert_1.default)(signer.privateKey);
|
|
61
|
+
return wrappedPsbt.signWithPrv(signer.privateKey);
|
|
62
|
+
});
|
|
63
|
+
return [[i, signResults]];
|
|
64
|
+
}
|
|
65
|
+
return [];
|
|
66
|
+
});
|
|
67
|
+
(0, assert_1.default)(signedInputs.length > 0);
|
|
68
|
+
if (finalize) {
|
|
69
|
+
wrappedPsbt.finalize();
|
|
70
|
+
}
|
|
71
|
+
return bitcoinjslib.Psbt.fromBuffer(Buffer.from(wrappedPsbt.serialize()));
|
|
72
|
+
}
|
|
73
|
+
function getBtcProviderForECKey(descriptorBuilder, stakerKey) {
|
|
74
|
+
function signWithDescriptor(psbt, descriptor, key) {
|
|
75
|
+
psbt = getSignedPsbt(psbt, descriptor, [key], { finalize: false });
|
|
76
|
+
// BUG: we need to blindly finalize here even though we have not fully signed
|
|
77
|
+
psbt.finalizeAllInputs();
|
|
78
|
+
return psbt;
|
|
79
|
+
}
|
|
80
|
+
return {
|
|
81
|
+
async signMessage(signingStep, message, type) {
|
|
82
|
+
(0, assert_1.default)(type === 'ecdsa');
|
|
83
|
+
switch (signingStep) {
|
|
84
|
+
case 'proof-of-possession':
|
|
85
|
+
return stakerKey.sign(Buffer.from(message, 'hex')).toString('hex');
|
|
86
|
+
default:
|
|
87
|
+
throw new Error(`unexpected signing step: ${signingStep}`);
|
|
88
|
+
}
|
|
89
|
+
},
|
|
90
|
+
async signPsbt(signingStep, psbtHex) {
|
|
91
|
+
const psbt = bitcoinjslib.Psbt.fromHex(psbtHex);
|
|
92
|
+
switch (signingStep) {
|
|
93
|
+
case 'staking-slashing':
|
|
94
|
+
return signWithDescriptor(psbt, descriptorBuilder.getStakingDescriptor(), stakerKey).toHex();
|
|
95
|
+
case 'unbonding-slashing':
|
|
96
|
+
return signWithDescriptor(psbt, descriptorBuilder.getUnbondingDescriptor(), stakerKey).toHex();
|
|
97
|
+
default:
|
|
98
|
+
throw new Error(`unexpected signing step: ${signingStep}`);
|
|
99
|
+
}
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
/*
|
|
104
|
+
* This is mostly lifted from
|
|
105
|
+
* https://github.com/babylonlabs-io/btc-staking-ts/blob/v0.4.0-rc.2/src/staking/manager.ts#L100-L172
|
|
106
|
+
*
|
|
107
|
+
* The difference is that here we are returning an _unsigned_ delegation message.
|
|
108
|
+
*/
|
|
109
|
+
async function createUnsignedPreStakeRegistrationBabylonTransaction(manager, stakingParams, network, stakerBtcInfo, stakingInput, babylonBtcTipHeight, inputUTXOs, feeRateSatB, babylonAddress) {
|
|
110
|
+
if (babylonBtcTipHeight === 0) {
|
|
111
|
+
throw new Error('Babylon BTC tip height cannot be 0');
|
|
112
|
+
}
|
|
113
|
+
if (inputUTXOs.length === 0) {
|
|
114
|
+
throw new Error('No input UTXOs provided');
|
|
115
|
+
}
|
|
116
|
+
if (!vendor.isValidBabylonAddress(babylonAddress)) {
|
|
117
|
+
throw new Error('Invalid Babylon address');
|
|
118
|
+
}
|
|
119
|
+
// Get the Babylon params based on the BTC tip height from Babylon chain
|
|
120
|
+
const params = vendor.getBabylonParamByBtcHeight(babylonBtcTipHeight, stakingParams);
|
|
121
|
+
const staking = new vendor.Staking(network, stakerBtcInfo, params, stakingInput.finalityProviderPkNoCoordHex, stakingInput.stakingTimelock);
|
|
122
|
+
// Create unsigned staking transaction
|
|
123
|
+
const { transaction } = staking.createStakingTransaction(stakingInput.stakingAmountSat, inputUTXOs, feeRateSatB);
|
|
124
|
+
// Create delegation message without including inclusion proof
|
|
125
|
+
const msg = await manager.createBtcDelegationMsg(staking, stakingInput, transaction, babylonAddress, stakerBtcInfo, params);
|
|
126
|
+
return {
|
|
127
|
+
unsignedDelegationMsg: msg,
|
|
128
|
+
stakingTx: transaction,
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
async function createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider(btcProvider, stakingParams, network, stakerBtcInfo, stakingInput, babylonBtcTipHeight, inputUTXOs, feeRateSatB, babylonAddress) {
|
|
132
|
+
const manager = new vendor.BabylonBtcStakingManager(network, [stakingParams], btcProvider, exports.mockBabylonProvider);
|
|
133
|
+
return await createUnsignedPreStakeRegistrationBabylonTransaction(manager, [stakingParams], network, stakerBtcInfo, stakingInput, babylonBtcTipHeight, inputUTXOs, feeRateSatB, babylonAddress);
|
|
134
|
+
}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delegationMessage.js","sourceRoot":"","sources":["../../../src/babylon/delegationMessage.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\n\nimport * as vendor from '@bitgo-beta/babylonlabs-io-btc-staking-ts';\nimport * as babylonProtobuf from '@babylonlabs-io/babylon-proto-ts';\nimport * as bitcoinjslib from 'bitcoinjs-lib';\nimport { ECPairInterface } from '@bitgo-beta/utxo-lib';\nimport { Descriptor } from '@bitgo/wasm-miniscript';\nimport { toWrappedPsbt } from '@bitgo-beta/utxo-core/descriptor';\n\nimport { BabylonDescriptorBuilder } from './descriptor';\n\nexport const mockBabylonProvider: vendor.BabylonProvider = {\n  signTransaction(): Promise<Uint8Array> {\n    throw new Error('Function not implemented.');\n  },\n};\n\nexport type ValueWithTypeUrl<T> = { typeUrl: string; value: T };\n\nexport function getSignedPsbt(\n  psbt: bitcoinjslib.Psbt,\n  descriptor: Descriptor,\n  signers: ECPairInterface[],\n  { finalize = false }\n): bitcoinjslib.Psbt {\n  const wrappedPsbt = toWrappedPsbt(psbt.toBuffer());\n  const signedInputs = psbt.data.inputs.flatMap((input, i) => {\n    assert(input.witnessUtxo);\n    if (Buffer.from(descriptor.scriptPubkey()).equals(input.witnessUtxo.script)) {\n      wrappedPsbt.updateInputWithDescriptor(i, descriptor);\n      const signResults = signers.map((signer) => {\n        assert(signer.privateKey);\n        return wrappedPsbt.signWithPrv(signer.privateKey);\n      });\n      return [[i, signResults]];\n    }\n    return [];\n  });\n  assert(signedInputs.length > 0);\n  if (finalize) {\n    wrappedPsbt.finalize();\n  }\n  return bitcoinjslib.Psbt.fromBuffer(Buffer.from(wrappedPsbt.serialize()));\n}\n\nexport function getBtcProviderForECKey(\n  descriptorBuilder: BabylonDescriptorBuilder,\n  stakerKey: ECPairInterface\n): vendor.BtcProvider {\n  function signWithDescriptor(\n    psbt: bitcoinjslib.Psbt,\n    descriptor: Descriptor,\n    key: ECPairInterface\n  ): bitcoinjslib.Psbt {\n    psbt = getSignedPsbt(psbt, descriptor, [key], { finalize: false });\n    // BUG: we need to blindly finalize here even though we have not fully signed\n    psbt.finalizeAllInputs();\n    return psbt;\n  }\n\n  return {\n    async signMessage(signingStep: vendor.SigningStep, message: string, type: 'ecdsa'): Promise<string> {\n      assert(type === 'ecdsa');\n      switch (signingStep) {\n        case 'proof-of-possession':\n          return stakerKey.sign(Buffer.from(message, 'hex')).toString('hex');\n        default:\n          throw new Error(`unexpected signing step: ${signingStep}`);\n      }\n    },\n    async signPsbt(signingStep: vendor.SigningStep, psbtHex: string): Promise<string> {\n      const psbt = bitcoinjslib.Psbt.fromHex(psbtHex);\n      switch (signingStep) {\n        case 'staking-slashing':\n          return signWithDescriptor(psbt, descriptorBuilder.getStakingDescriptor(), stakerKey).toHex();\n        case 'unbonding-slashing':\n          return signWithDescriptor(psbt, descriptorBuilder.getUnbondingDescriptor(), stakerKey).toHex();\n        default:\n          throw new Error(`unexpected signing step: ${signingStep}`);\n      }\n    },\n  };\n}\n\ntype Result = {\n  unsignedDelegationMsg: ValueWithTypeUrl<babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation>;\n  stakingTx: bitcoinjslib.Transaction;\n};\n\n/*\n * This is mostly lifted from\n * https://github.com/babylonlabs-io/btc-staking-ts/blob/v0.4.0-rc.2/src/staking/manager.ts#L100-L172\n *\n * The difference is that here we are returning an _unsigned_ delegation message.\n */\nexport async function createUnsignedPreStakeRegistrationBabylonTransaction(\n  manager: vendor.BabylonBtcStakingManager,\n  stakingParams: vendor.VersionedStakingParams[],\n  network: bitcoinjslib.Network,\n  stakerBtcInfo: vendor.StakerInfo,\n  stakingInput: vendor.StakingInputs,\n  babylonBtcTipHeight: number,\n  inputUTXOs: vendor.UTXO[],\n  feeRateSatB: number,\n  babylonAddress: string\n): Promise<Result> {\n  if (babylonBtcTipHeight === 0) {\n    throw new Error('Babylon BTC tip height cannot be 0');\n  }\n  if (inputUTXOs.length === 0) {\n    throw new Error('No input UTXOs provided');\n  }\n  if (!vendor.isValidBabylonAddress(babylonAddress)) {\n    throw new Error('Invalid Babylon address');\n  }\n\n  // Get the Babylon params based on the BTC tip height from Babylon chain\n  const params = vendor.getBabylonParamByBtcHeight(babylonBtcTipHeight, stakingParams);\n\n  const staking = new vendor.Staking(\n    network,\n    stakerBtcInfo,\n    params,\n    stakingInput.finalityProviderPkNoCoordHex,\n    stakingInput.stakingTimelock\n  );\n\n  // Create unsigned staking transaction\n  const { transaction } = staking.createStakingTransaction(stakingInput.stakingAmountSat, inputUTXOs, feeRateSatB);\n\n  // Create delegation message without including inclusion proof\n  const msg = await manager.createBtcDelegationMsg(\n    staking,\n    stakingInput,\n    transaction,\n    babylonAddress,\n    stakerBtcInfo,\n    params\n  );\n  return {\n    unsignedDelegationMsg: msg,\n    stakingTx: transaction,\n  };\n}\n\nexport async function createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider(\n  btcProvider: vendor.BtcProvider,\n  stakingParams: vendor.VersionedStakingParams,\n  network: bitcoinjslib.Network,\n  stakerBtcInfo: vendor.StakerInfo,\n  stakingInput: vendor.StakingInputs,\n  babylonBtcTipHeight: number,\n  inputUTXOs: vendor.UTXO[],\n  feeRateSatB: number,\n  babylonAddress: string\n): Promise<Result> {\n  const manager = new vendor.BabylonBtcStakingManager(network, [stakingParams], btcProvider, mockBabylonProvider);\n  return await createUnsignedPreStakeRegistrationBabylonTransaction(\n    manager,\n    [stakingParams],\n    network,\n    stakerBtcInfo,\n    stakingInput,\n    babylonBtcTipHeight,\n    inputUTXOs,\n    feeRateSatB,\n    babylonAddress\n  );\n}\n"]}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* https://github.com/babylonlabs-io/babylon/tree/main/docs
|
|
3
|
+
* https://github.com/babylonlabs-io/babylon/blob/main/docs/staking-script.md
|
|
4
|
+
*/
|
|
5
|
+
import { Descriptor, ast } from '@bitgo/wasm-miniscript';
|
|
6
|
+
import { StakingParams } from '@bitgo-beta/babylonlabs-io-btc-staking-ts';
|
|
7
|
+
export declare function getUnspendableKey(): string;
|
|
8
|
+
export declare class BabylonDescriptorBuilder {
|
|
9
|
+
stakerKey: Buffer;
|
|
10
|
+
finalityProviderKeys: Buffer[];
|
|
11
|
+
covenantKeys: Buffer[];
|
|
12
|
+
covenantThreshold: number;
|
|
13
|
+
stakingTimeLock: number;
|
|
14
|
+
unbondingTimeLock: number;
|
|
15
|
+
constructor(stakerKey: Buffer, finalityProviderKeys: Buffer[], covenantKeys: Buffer[], covenantThreshold: number, stakingTimeLock: number, unbondingTimeLock: number);
|
|
16
|
+
static fromParams(params: {
|
|
17
|
+
stakerKey: Buffer;
|
|
18
|
+
finalityProviderKeys: Buffer[];
|
|
19
|
+
} & StakingParams): BabylonDescriptorBuilder;
|
|
20
|
+
getTimelockMiniscript(): ast.MiniscriptNode;
|
|
21
|
+
getUnbondingMiniscript(): ast.MiniscriptNode;
|
|
22
|
+
getSlashingMiniscript(): ast.MiniscriptNode;
|
|
23
|
+
getUnbondingTimelockMiniscript(): ast.MiniscriptNode;
|
|
24
|
+
getStakingDescriptor(): Descriptor;
|
|
25
|
+
getSlashingDescriptor(): Descriptor;
|
|
26
|
+
getUnbondingDescriptor(): Descriptor;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=descriptor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"descriptor.d.ts","sourceRoot":"","sources":["../../../src/babylon/descriptor.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,2CAA2C,CAAC;AAE1E,wBAAgB,iBAAiB,IAAI,MAAM,CAG1C;AAmBD,qBAAa,wBAAwB;IAE1B,SAAS,EAAE,MAAM;IACjB,oBAAoB,EAAE,MAAM,EAAE;IAC9B,YAAY,EAAE,MAAM,EAAE;IACtB,iBAAiB,EAAE,MAAM;IACzB,eAAe,EAAE,MAAM;IACvB,iBAAiB,EAAE,MAAM;gBALzB,SAAS,EAAE,MAAM,EACjB,oBAAoB,EAAE,MAAM,EAAE,EAC9B,YAAY,EAAE,MAAM,EAAE,EACtB,iBAAiB,EAAE,MAAM,EACzB,eAAe,EAAE,MAAM,EACvB,iBAAiB,EAAE,MAAM;IAGlC,MAAM,CAAC,UAAU,CACf,MAAM,EAAE;QACN,SAAS,EAAE,MAAM,CAAC;QAClB,oBAAoB,EAAE,MAAM,EAAE,CAAC;KAChC,GAAG,aAAa,GAChB,wBAAwB;IA0B3B,qBAAqB,IAAI,GAAG,CAAC,cAAc;IAI3C,sBAAsB,IAAI,GAAG,CAAC,cAAc;IAI5C,qBAAqB,IAAI,GAAG,CAAC,cAAc;IAgB3C,8BAA8B,IAAI,GAAG,CAAC,cAAc;IAIpD,oBAAoB,IAAI,UAAU;IAOlC,qBAAqB,IAAI,UAAU;IAInC,sBAAsB,IAAI,UAAU;CAGrC"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* https://github.com/babylonlabs-io/babylon/tree/main/docs
|
|
4
|
+
* https://github.com/babylonlabs-io/babylon/blob/main/docs/staking-script.md
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.BabylonDescriptorBuilder = void 0;
|
|
8
|
+
exports.getUnspendableKey = getUnspendableKey;
|
|
9
|
+
const wasm_miniscript_1 = require("@bitgo/wasm-miniscript");
|
|
10
|
+
function getUnspendableKey() {
|
|
11
|
+
// https://github.com/babylonlabs-io/btc-staking-ts/blob/v0.4.0-rc.2/src/constants/internalPubkey.ts
|
|
12
|
+
return '50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0';
|
|
13
|
+
}
|
|
14
|
+
// Helper functions for creating miniscript nodes
|
|
15
|
+
function pk(b) {
|
|
16
|
+
return { 'v:pk': b.toString('hex') };
|
|
17
|
+
}
|
|
18
|
+
function sortedKeys(keys) {
|
|
19
|
+
return [...keys].sort((a, b) => a.compare(b));
|
|
20
|
+
}
|
|
21
|
+
function multiArgs(threshold, keys) {
|
|
22
|
+
return [threshold, ...sortedKeys(keys).map((k) => k.toString('hex'))];
|
|
23
|
+
}
|
|
24
|
+
function taprootScriptOnlyFromAst(n) {
|
|
25
|
+
return wasm_miniscript_1.Descriptor.fromString(wasm_miniscript_1.ast.formatNode({ tr: [getUnspendableKey(), n] }), 'definite');
|
|
26
|
+
}
|
|
27
|
+
class BabylonDescriptorBuilder {
|
|
28
|
+
constructor(stakerKey, finalityProviderKeys, covenantKeys, covenantThreshold, stakingTimeLock, unbondingTimeLock) {
|
|
29
|
+
this.stakerKey = stakerKey;
|
|
30
|
+
this.finalityProviderKeys = finalityProviderKeys;
|
|
31
|
+
this.covenantKeys = covenantKeys;
|
|
32
|
+
this.covenantThreshold = covenantThreshold;
|
|
33
|
+
this.stakingTimeLock = stakingTimeLock;
|
|
34
|
+
this.unbondingTimeLock = unbondingTimeLock;
|
|
35
|
+
}
|
|
36
|
+
static fromParams(params) {
|
|
37
|
+
/*
|
|
38
|
+
|
|
39
|
+
const stakerKey = getECKey('staker');
|
|
40
|
+
const covenantThreshold = stakingParams.covenantQuorum;
|
|
41
|
+
const stakingTimelock = stakingParams.minStakingTimeBlocks;
|
|
42
|
+
const unbondingTimelock = stakingParams.unbondingTime;
|
|
43
|
+
const vendorBuilder = new vendor.StakingScriptData(
|
|
44
|
+
getXOnlyPubkey(stakerKey),
|
|
45
|
+
finalityProviderKeys.map(getXOnlyPubkey),
|
|
46
|
+
covenantKeys.map(getXOnlyPubkey),
|
|
47
|
+
covenantThreshold,
|
|
48
|
+
stakingTimelock,
|
|
49
|
+
unbondingTimelock
|
|
50
|
+
);
|
|
51
|
+
*/
|
|
52
|
+
return new BabylonDescriptorBuilder(params.stakerKey, params.finalityProviderKeys, params.covenantNoCoordPks.map((k) => Buffer.from(k, 'hex')), params.covenantQuorum, params.minStakingTimeBlocks, params.unbondingTime);
|
|
53
|
+
}
|
|
54
|
+
getTimelockMiniscript() {
|
|
55
|
+
return { and_v: [pk(this.stakerKey), { older: this.stakingTimeLock }] };
|
|
56
|
+
}
|
|
57
|
+
getUnbondingMiniscript() {
|
|
58
|
+
return { and_v: [pk(this.stakerKey), { multi_a: multiArgs(this.covenantThreshold, this.covenantKeys) }] };
|
|
59
|
+
}
|
|
60
|
+
getSlashingMiniscript() {
|
|
61
|
+
return {
|
|
62
|
+
and_v: [
|
|
63
|
+
{
|
|
64
|
+
and_v: [
|
|
65
|
+
pk(this.stakerKey),
|
|
66
|
+
this.finalityProviderKeys.length === 1
|
|
67
|
+
? { 'v:pk': this.finalityProviderKeys[0].toString('hex') }
|
|
68
|
+
: { 'v:multi_a': multiArgs(1, this.finalityProviderKeys) },
|
|
69
|
+
],
|
|
70
|
+
},
|
|
71
|
+
{ multi_a: multiArgs(this.covenantThreshold, this.covenantKeys) },
|
|
72
|
+
],
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
getUnbondingTimelockMiniscript() {
|
|
76
|
+
return { and_v: [pk(this.stakerKey), { older: this.unbondingTimeLock }] };
|
|
77
|
+
}
|
|
78
|
+
getStakingDescriptor() {
|
|
79
|
+
return taprootScriptOnlyFromAst([
|
|
80
|
+
this.getSlashingMiniscript(),
|
|
81
|
+
[this.getUnbondingMiniscript(), this.getTimelockMiniscript()],
|
|
82
|
+
]);
|
|
83
|
+
}
|
|
84
|
+
getSlashingDescriptor() {
|
|
85
|
+
return taprootScriptOnlyFromAst(this.getUnbondingTimelockMiniscript());
|
|
86
|
+
}
|
|
87
|
+
getUnbondingDescriptor() {
|
|
88
|
+
return taprootScriptOnlyFromAst([this.getSlashingMiniscript(), this.getUnbondingTimelockMiniscript()]);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
exports.BabylonDescriptorBuilder = BabylonDescriptorBuilder;
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"descriptor.js","sourceRoot":"","sources":["../../../src/babylon/descriptor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * https://github.com/babylonlabs-io/babylon/tree/main/docs\n * https://github.com/babylonlabs-io/babylon/blob/main/docs/staking-script.md\n */\n\nimport { Descriptor, ast } from '@bitgo/wasm-miniscript';\nimport { StakingParams } from '@bitgo-beta/babylonlabs-io-btc-staking-ts';\n\nexport function getUnspendableKey(): string {\n  // https://github.com/babylonlabs-io/btc-staking-ts/blob/v0.4.0-rc.2/src/constants/internalPubkey.ts\n  return '50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0';\n}\n\n// Helper functions for creating miniscript nodes\nfunction pk(b: Buffer): ast.MiniscriptNode {\n  return { 'v:pk': b.toString('hex') };\n}\n\nfunction sortedKeys(keys: Buffer[]): Buffer[] {\n  return [...keys].sort((a, b) => a.compare(b));\n}\n\nfunction multiArgs(threshold: number, keys: Buffer[]): [number, ...string[]] {\n  return [threshold, ...sortedKeys(keys).map((k) => k.toString('hex'))];\n}\n\nfunction taprootScriptOnlyFromAst(n: ast.TapTreeNode): Descriptor {\n  return Descriptor.fromString(ast.formatNode({ tr: [getUnspendableKey(), n] }), 'definite');\n}\n\nexport class BabylonDescriptorBuilder {\n  constructor(\n    public stakerKey: Buffer,\n    public finalityProviderKeys: Buffer[],\n    public covenantKeys: Buffer[],\n    public covenantThreshold: number,\n    public stakingTimeLock: number,\n    public unbondingTimeLock: number\n  ) {}\n\n  static fromParams(\n    params: {\n      stakerKey: Buffer;\n      finalityProviderKeys: Buffer[];\n    } & StakingParams\n  ): BabylonDescriptorBuilder {\n    /*\n\n  const stakerKey = getECKey('staker');\n  const covenantThreshold = stakingParams.covenantQuorum;\n  const stakingTimelock = stakingParams.minStakingTimeBlocks;\n  const unbondingTimelock = stakingParams.unbondingTime;\n  const vendorBuilder = new vendor.StakingScriptData(\n    getXOnlyPubkey(stakerKey),\n    finalityProviderKeys.map(getXOnlyPubkey),\n    covenantKeys.map(getXOnlyPubkey),\n    covenantThreshold,\n    stakingTimelock,\n    unbondingTimelock\n  );\n     */\n    return new BabylonDescriptorBuilder(\n      params.stakerKey,\n      params.finalityProviderKeys,\n      params.covenantNoCoordPks.map((k) => Buffer.from(k, 'hex')),\n      params.covenantQuorum,\n      params.minStakingTimeBlocks,\n      params.unbondingTime\n    );\n  }\n\n  getTimelockMiniscript(): ast.MiniscriptNode {\n    return { and_v: [pk(this.stakerKey), { older: this.stakingTimeLock }] };\n  }\n\n  getUnbondingMiniscript(): ast.MiniscriptNode {\n    return { and_v: [pk(this.stakerKey), { multi_a: multiArgs(this.covenantThreshold, this.covenantKeys) }] };\n  }\n\n  getSlashingMiniscript(): ast.MiniscriptNode {\n    return {\n      and_v: [\n        {\n          and_v: [\n            pk(this.stakerKey),\n            this.finalityProviderKeys.length === 1\n              ? { 'v:pk': this.finalityProviderKeys[0].toString('hex') }\n              : { 'v:multi_a': multiArgs(1, this.finalityProviderKeys) },\n          ],\n        },\n        { multi_a: multiArgs(this.covenantThreshold, this.covenantKeys) },\n      ],\n    };\n  }\n\n  getUnbondingTimelockMiniscript(): ast.MiniscriptNode {\n    return { and_v: [pk(this.stakerKey), { older: this.unbondingTimeLock }] };\n  }\n\n  getStakingDescriptor(): Descriptor {\n    return taprootScriptOnlyFromAst([\n      this.getSlashingMiniscript(),\n      [this.getUnbondingMiniscript(), this.getTimelockMiniscript()],\n    ]);\n  }\n\n  getSlashingDescriptor(): Descriptor {\n    return taprootScriptOnlyFromAst(this.getUnbondingTimelockMiniscript());\n  }\n\n  getUnbondingDescriptor(): Descriptor {\n    return taprootScriptOnlyFromAst([this.getSlashingMiniscript(), this.getUnbondingTimelockMiniscript()]);\n  }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/babylon/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC;AACpC,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./delegationMessage"), exports);
|
|
18
|
+
__exportStar(require("./descriptor"), exports);
|
|
19
|
+
__exportStar(require("./stakingParams"), exports);
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmFieWxvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsc0RBQW9DO0FBQ3BDLCtDQUE2QjtBQUM3QixrREFBZ0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2RlbGVnYXRpb25NZXNzYWdlJztcbmV4cG9ydCAqIGZyb20gJy4vZGVzY3JpcHRvcic7XG5leHBvcnQgKiBmcm9tICcuL3N0YWtpbmdQYXJhbXMnO1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keyUtils.d.ts","sourceRoot":"","sources":["../../../src/babylon/keyUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEvD,wBAAgB,cAAc,CAAC,GAAG,EAAE,eAAe,GAAG,MAAM,CAE3D"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getXOnlyPubkey = getXOnlyPubkey;
|
|
4
|
+
function getXOnlyPubkey(key) {
|
|
5
|
+
return key.publicKey.subarray(1);
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5VXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmFieWxvbi9rZXlVdGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUVBLHdDQUVDO0FBRkQsU0FBZ0IsY0FBYyxDQUFDLEdBQW9CO0lBQ2pELE9BQU8sR0FBRyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDbkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVDUGFpckludGVyZmFjZSB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFhPbmx5UHVia2V5KGtleTogRUNQYWlySW50ZXJmYWNlKTogQnVmZmVyIHtcbiAgcmV0dXJuIGtleS5wdWJsaWNLZXkuc3ViYXJyYXkoMSk7XG59XG4iXX0=
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { BIP32Interface, ECPairInterface } from '@bitgo-beta/utxo-lib';
|
|
2
|
+
import { StakerInfo, StakingInputs, VersionedStakingParams } from '@bitgo-beta/babylonlabs-io-btc-staking-ts';
|
|
3
|
+
import { BabylonDescriptorBuilder } from './descriptor';
|
|
4
|
+
export type JsonParams = {
|
|
5
|
+
version: number;
|
|
6
|
+
covenant_pks: string[];
|
|
7
|
+
covenant_quorum: number;
|
|
8
|
+
min_staking_value_sat: number;
|
|
9
|
+
max_staking_value_sat: number;
|
|
10
|
+
min_staking_time_blocks: number;
|
|
11
|
+
max_staking_time_blocks: number;
|
|
12
|
+
slashing_pk_script: string;
|
|
13
|
+
min_slashing_tx_fee_sat: number;
|
|
14
|
+
slashing_rate: string;
|
|
15
|
+
unbonding_time_blocks: number;
|
|
16
|
+
unbonding_fee_sat: number;
|
|
17
|
+
min_commission_rate: string;
|
|
18
|
+
delegation_creation_base_gas_fee: number;
|
|
19
|
+
allow_list_expiration_height: number;
|
|
20
|
+
btc_activation_height: number;
|
|
21
|
+
};
|
|
22
|
+
export declare const testnetStakingParams: JsonParams;
|
|
23
|
+
export declare const mainnetStakingParams: JsonParams;
|
|
24
|
+
export declare function toVersionedParams(p: JsonParams): VersionedStakingParams;
|
|
25
|
+
export declare const testnetFinalityProvider0: Buffer<ArrayBuffer>;
|
|
26
|
+
export declare function getDescriptorBuilderForParams(userKey: BIP32Interface | ECPairInterface | Buffer, finalityProviderKeys: Buffer[], params: Pick<VersionedStakingParams, 'covenantNoCoordPks' | 'covenantQuorum' | 'minStakingTimeBlocks' | 'unbondingTime'>): BabylonDescriptorBuilder;
|
|
27
|
+
export declare function getDescriptorProviderForStakingParams(stakerBtcInfo: StakerInfo, stakingInput: StakingInputs, stakingParams: VersionedStakingParams): BabylonDescriptorBuilder;
|
|
28
|
+
export declare function getTestnetDescriptorBuilder(userKey: BIP32Interface | ECPairInterface | Buffer, { finalityProviderKeys, }?: {
|
|
29
|
+
finalityProviderKeys?: Buffer[];
|
|
30
|
+
}): BabylonDescriptorBuilder;
|
|
31
|
+
//# sourceMappingURL=stakingParams.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stakingParams.d.ts","sourceRoot":"","sources":["../../../src/babylon/stakingParams.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,2CAA2C,CAAC;AAE9G,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AAExD,MAAM,MAAM,UAAU,GAAG;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,eAAe,EAAE,MAAM,CAAC;IACxB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,qBAAqB,EAAE,MAAM,CAAC;IAC9B,uBAAuB,EAAE,MAAM,CAAC;IAChC,uBAAuB,EAAE,MAAM,CAAC;IAChC,kBAAkB,EAAE,MAAM,CAAC;IAC3B,uBAAuB,EAAE,MAAM,CAAC;IAChC,aAAa,EAAE,MAAM,CAAC;IACtB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,gCAAgC,EAAE,MAAM,CAAC;IACzC,4BAA4B,EAAE,MAAM,CAAC;IACrC,qBAAqB,EAAE,MAAM,CAAC;CAC/B,CAAC;AAGF,eAAO,MAAM,oBAAoB,EAAE,UA2BlC,CAAC;AAGF,eAAO,MAAM,oBAAoB,EAAE,UAuBlC,CAAC;AAEF,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,UAAU,GAAG,sBAAsB,CAkBvE;AAGD,eAAO,MAAM,wBAAwB,qBAGpC,CAAC;AAEF,wBAAgB,6BAA6B,CAC3C,OAAO,EAAE,cAAc,GAAG,eAAe,GAAG,MAAM,EAClD,oBAAoB,EAAE,MAAM,EAAE,EAC9B,MAAM,EAAE,IAAI,CACV,sBAAsB,EACtB,oBAAoB,GAAG,gBAAgB,GAAG,sBAAsB,GAAG,eAAe,CACnF,GACA,wBAAwB,CAY1B;AAED,wBAAgB,qCAAqC,CACnD,aAAa,EAAE,UAAU,EACzB,YAAY,EAAE,aAAa,EAC3B,aAAa,EAAE,sBAAsB,GACpC,wBAAwB,CAI1B;AAED,wBAAgB,2BAA2B,CACzC,OAAO,EAAE,cAAc,GAAG,eAAe,GAAG,MAAM,EAClD,EACE,oBAAiD,GAClD,GAAE;IACD,oBAAoB,CAAC,EAAE,MAAM,EAAE,CAAC;CAC5B,GACL,wBAAwB,CAE1B"}
|