@bitgo-beta/utxo-staking 1.1.1-beta.28 → 1.1.1-beta.281
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/src/babylon/delegationMessage.d.ts +38 -0
- package/dist/src/babylon/delegationMessage.d.ts.map +1 -0
- package/dist/src/babylon/delegationMessage.js +189 -0
- package/dist/src/babylon/descriptor.d.ts +29 -0
- package/dist/src/babylon/descriptor.d.ts.map +1 -0
- package/dist/src/babylon/descriptor.js +78 -0
- package/dist/src/babylon/index.d.ts +5 -0
- package/dist/src/babylon/index.d.ts.map +1 -0
- package/dist/src/babylon/index.js +48 -0
- package/dist/src/babylon/network.d.ts +7 -0
- package/dist/src/babylon/network.d.ts.map +1 -0
- package/dist/src/babylon/network.js +66 -0
- package/dist/src/babylon/params.mainnet.json +1 -0
- package/dist/src/babylon/params.testnet.json +205 -0
- package/dist/src/babylon/stakingManager.d.ts +6 -0
- package/dist/src/babylon/stakingManager.d.ts.map +1 -0
- package/dist/src/babylon/stakingManager.js +65 -0
- package/dist/src/babylon/stakingParams.d.ts +39 -0
- package/dist/src/babylon/stakingParams.d.ts.map +1 -0
- package/dist/src/babylon/stakingParams.js +131 -0
- package/dist/src/coreDao/descriptor.d.ts +4 -2
- package/dist/src/coreDao/descriptor.d.ts.map +1 -1
- package/dist/src/coreDao/descriptor.js +11 -3
- package/dist/src/coreDao/opReturn.d.ts +2 -0
- package/dist/src/coreDao/opReturn.d.ts.map +1 -1
- package/dist/src/coreDao/opReturn.js +14 -6
- package/dist/src/coreDao/transaction.d.ts +15 -6
- package/dist/src/coreDao/transaction.d.ts.map +1 -1
- package/dist/src/coreDao/transaction.js +12 -4
- 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.map +1 -1
- package/dist/src/transaction.js +37 -2
- package/package.json +19 -7
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -39
|
@@ -0,0 +1,38 @@
|
|
|
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 * as utxolib from '@bitgo-beta/utxo-lib';
|
|
5
|
+
import { Descriptor } from '@bitgo/wasm-miniscript';
|
|
6
|
+
import { BabylonDescriptorBuilder } from './descriptor';
|
|
7
|
+
import { BabylonNetworkLike } from './network';
|
|
8
|
+
export type ValueWithTypeUrl<T> = {
|
|
9
|
+
typeUrl: string;
|
|
10
|
+
value: T;
|
|
11
|
+
};
|
|
12
|
+
export declare function getSignedPsbt(psbt: bitcoinjslib.Psbt, descriptor: Descriptor, signers: utxolib.ECPairInterface[], { finalize }: {
|
|
13
|
+
finalize?: boolean | undefined;
|
|
14
|
+
}): bitcoinjslib.Psbt;
|
|
15
|
+
/**
|
|
16
|
+
* Utility method to work around a bug in btc-staking-ts
|
|
17
|
+
* https://github.com/babylonlabs-io/btc-staking-ts/issues/71
|
|
18
|
+
* @param buffer
|
|
19
|
+
* @param network
|
|
20
|
+
*/
|
|
21
|
+
export declare function forceFinalizePsbt(buffer: Buffer, network: BabylonNetworkLike): bitcoinjslib.Psbt;
|
|
22
|
+
export declare function getBtcProviderForECKey(descriptorBuilder: BabylonDescriptorBuilder, stakerKey: utxolib.ECPairInterface): vendor.BtcProvider;
|
|
23
|
+
type Result = {
|
|
24
|
+
unsignedDelegationMsg: ValueWithTypeUrl<babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation>;
|
|
25
|
+
stakingTx: bitcoinjslib.Transaction;
|
|
26
|
+
};
|
|
27
|
+
/**
|
|
28
|
+
* @param stakingKey - this is the single-sig key that is used for co-signing the staking output
|
|
29
|
+
* @param changeAddress - this is unrelated to the staking key and is used for the change output
|
|
30
|
+
*/
|
|
31
|
+
export declare function toStakerInfo(stakingKey: utxolib.ECPairInterface | Buffer | string, changeAddress: string): vendor.StakerInfo;
|
|
32
|
+
export declare function createStaking(network: BabylonNetworkLike, blockHeight: number, stakerBtcInfo: vendor.StakerInfo, stakingInput: vendor.StakingInputs, versionedParams?: vendor.VersionedStakingParams[]): vendor.Staking;
|
|
33
|
+
type TransactionLike = bitcoinjslib.Psbt | bitcoinjslib.Transaction | utxolib.Transaction | utxolib.bitgo.UtxoTransaction<bigint | number> | utxolib.Psbt | utxolib.bitgo.UtxoPsbt;
|
|
34
|
+
export declare function toStakingTransaction(tx: TransactionLike): bitcoinjslib.Transaction;
|
|
35
|
+
export declare function createDelegationMessageWithTransaction(manager: vendor.BabylonBtcStakingManager, staking: vendor.Staking, stakingAmountSat: number, transaction: TransactionLike, babylonAddress: string): Promise<ValueWithTypeUrl<babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation>>;
|
|
36
|
+
export declare function createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider(btcProvider: vendor.BtcProvider, network: bitcoinjslib.Network, stakerBtcInfo: vendor.StakerInfo, stakingInput: vendor.StakingInputs, babylonBtcTipHeight: number, inputUTXOs: vendor.UTXO[], feeRateSatB: number, babylonAddress: string, stakingParams?: vendor.VersionedStakingParams[]): Promise<Result>;
|
|
37
|
+
export {};
|
|
38
|
+
//# sourceMappingURL=delegationMessage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delegationMessage.d.ts","sourceRoot":"","sources":["../../../src/babylon/delegationMessage.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,MAAM,MAAM,2CAA2C,CAAC;AACpE,OAAO,KAAK,eAAe,MAAM,kCAAkC,CAAC;AACpE,OAAO,KAAK,YAAY,MAAM,eAAe,CAAC;AAC9C,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAIpD,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AAGxD,OAAO,EAAE,kBAAkB,EAAsB,MAAM,WAAW,CAAC;AAEnE,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,OAAO,CAAC,eAAe,EAAE,EAClC,EAAE,QAAgB,EAAE;;CAAA,GACnB,YAAY,CAAC,IAAI,CAmBnB;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,kBAAkB,GAAG,YAAY,CAAC,IAAI,CAKhG;AAED,wBAAgB,sBAAsB,CACpC,iBAAiB,EAAE,wBAAwB,EAC3C,SAAS,EAAE,OAAO,CAAC,eAAe,GACjC,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;AAEF;;;GAGG;AACH,wBAAgB,YAAY,CAC1B,UAAU,EAAE,OAAO,CAAC,eAAe,GAAG,MAAM,GAAG,MAAM,EACrD,aAAa,EAAE,MAAM,GACpB,MAAM,CAAC,UAAU,CAWnB;AAED,wBAAgB,aAAa,CAC3B,OAAO,EAAE,kBAAkB,EAC3B,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,MAAM,CAAC,UAAU,EAChC,YAAY,EAAE,MAAM,CAAC,aAAa,EAClC,eAAe,GAAE,MAAM,CAAC,sBAAsB,EAA8B,GAC3E,MAAM,CAAC,OAAO,CAehB;AAED,KAAK,eAAe,GAChB,YAAY,CAAC,IAAI,GACjB,YAAY,CAAC,WAAW,GACxB,OAAO,CAAC,WAAW,GACnB,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,MAAM,CAAC,GAC9C,OAAO,CAAC,IAAI,GACZ,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC;AAe3B,wBAAgB,oBAAoB,CAAC,EAAE,EAAE,eAAe,GAAG,YAAY,CAAC,WAAW,CAKlF;AAQD,wBAAsB,sCAAsC,CAC1D,OAAO,EAAE,MAAM,CAAC,wBAAwB,EACxC,OAAO,EAAE,MAAM,CAAC,OAAO,EACvB,gBAAgB,EAAE,MAAM,EACxB,WAAW,EAAE,eAAe,EAC5B,cAAc,EAAE,MAAM,GACrB,OAAO,CAAC,gBAAgB,CAAC,eAAe,CAAC,YAAY,CAAC,sBAAsB,CAAC,CAAC,CAiBhF;AAED,wBAAsB,mEAAmE,CACvF,WAAW,EAAE,MAAM,CAAC,WAAW,EAC/B,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,EACtB,aAAa,GAAE,MAAM,CAAC,sBAAsB,EAA8B,GACzE,OAAO,CAAC,MAAM,CAAC,CAgBjB"}
|
|
@@ -0,0 +1,189 @@
|
|
|
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.getSignedPsbt = getSignedPsbt;
|
|
40
|
+
exports.forceFinalizePsbt = forceFinalizePsbt;
|
|
41
|
+
exports.getBtcProviderForECKey = getBtcProviderForECKey;
|
|
42
|
+
exports.toStakerInfo = toStakerInfo;
|
|
43
|
+
exports.createStaking = createStaking;
|
|
44
|
+
exports.toStakingTransaction = toStakingTransaction;
|
|
45
|
+
exports.createDelegationMessageWithTransaction = createDelegationMessageWithTransaction;
|
|
46
|
+
exports.createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider = createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider;
|
|
47
|
+
/**
|
|
48
|
+
* https://github.com/babylonlabs-io/babylon/blob/v1.99.0-snapshot.250211/x/btcstaking/types/validate_parsed_message.go
|
|
49
|
+
*/
|
|
50
|
+
const assert_1 = __importDefault(require("assert"));
|
|
51
|
+
const vendor = __importStar(require("@bitgo-beta/babylonlabs-io-btc-staking-ts"));
|
|
52
|
+
const bitcoinjslib = __importStar(require("bitcoinjs-lib"));
|
|
53
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
54
|
+
const utxo_core_1 = require("@bitgo-beta/utxo-core");
|
|
55
|
+
const descriptor_1 = require("@bitgo-beta/utxo-core/descriptor");
|
|
56
|
+
const stakingManager_1 = require("./stakingManager");
|
|
57
|
+
const stakingParams_1 = require("./stakingParams");
|
|
58
|
+
const network_1 = require("./network");
|
|
59
|
+
function getSignedPsbt(psbt, descriptor, signers, { finalize = false }) {
|
|
60
|
+
const wrappedPsbt = (0, descriptor_1.toWrappedPsbt)(psbt.toBuffer());
|
|
61
|
+
const signedInputs = psbt.data.inputs.flatMap((input, i) => {
|
|
62
|
+
(0, assert_1.default)(input.witnessUtxo);
|
|
63
|
+
if (Buffer.from(descriptor.scriptPubkey()).equals(input.witnessUtxo.script)) {
|
|
64
|
+
wrappedPsbt.updateInputWithDescriptor(i, descriptor);
|
|
65
|
+
const signResults = signers.map((signer) => {
|
|
66
|
+
(0, assert_1.default)(signer.privateKey);
|
|
67
|
+
return wrappedPsbt.signWithPrv(signer.privateKey);
|
|
68
|
+
});
|
|
69
|
+
return [[i, signResults]];
|
|
70
|
+
}
|
|
71
|
+
return [];
|
|
72
|
+
});
|
|
73
|
+
(0, assert_1.default)(signedInputs.length > 0);
|
|
74
|
+
if (finalize) {
|
|
75
|
+
wrappedPsbt.finalize();
|
|
76
|
+
}
|
|
77
|
+
return bitcoinjslib.Psbt.fromBuffer(Buffer.from(wrappedPsbt.serialize()));
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Utility method to work around a bug in btc-staking-ts
|
|
81
|
+
* https://github.com/babylonlabs-io/btc-staking-ts/issues/71
|
|
82
|
+
* @param buffer
|
|
83
|
+
* @param network
|
|
84
|
+
*/
|
|
85
|
+
function forceFinalizePsbt(buffer, network) {
|
|
86
|
+
const psbt = bitcoinjslib.Psbt.fromBuffer(buffer, { network: (0, network_1.toBitcoinJsNetwork)(network) });
|
|
87
|
+
// this only works with certain bitcoinjslib versions
|
|
88
|
+
psbt.finalizeAllInputs();
|
|
89
|
+
return psbt;
|
|
90
|
+
}
|
|
91
|
+
function getBtcProviderForECKey(descriptorBuilder, stakerKey) {
|
|
92
|
+
function signWithDescriptor(psbt, descriptor, key) {
|
|
93
|
+
psbt = getSignedPsbt(psbt, descriptor, [key], { finalize: false });
|
|
94
|
+
// BUG: we need to blindly finalize here even though we have not fully signed
|
|
95
|
+
psbt.finalizeAllInputs();
|
|
96
|
+
return psbt;
|
|
97
|
+
}
|
|
98
|
+
return {
|
|
99
|
+
async signMessage(signingStep, message, type) {
|
|
100
|
+
(0, assert_1.default)(type === 'ecdsa');
|
|
101
|
+
switch (signingStep) {
|
|
102
|
+
case 'proof-of-possession':
|
|
103
|
+
return stakerKey.sign(Buffer.from(message, 'hex')).toString('hex');
|
|
104
|
+
default:
|
|
105
|
+
throw new Error(`unexpected signing step: ${signingStep}`);
|
|
106
|
+
}
|
|
107
|
+
},
|
|
108
|
+
async signPsbt(signingStep, psbtHex) {
|
|
109
|
+
const psbt = bitcoinjslib.Psbt.fromHex(psbtHex);
|
|
110
|
+
switch (signingStep) {
|
|
111
|
+
case 'staking-slashing':
|
|
112
|
+
return signWithDescriptor(psbt, descriptorBuilder.getStakingDescriptor(), stakerKey).toHex();
|
|
113
|
+
case 'unbonding-slashing':
|
|
114
|
+
return signWithDescriptor(psbt, descriptorBuilder.getUnbondingDescriptor(), stakerKey).toHex();
|
|
115
|
+
default:
|
|
116
|
+
throw new Error(`unexpected signing step: ${signingStep}`);
|
|
117
|
+
}
|
|
118
|
+
},
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* @param stakingKey - this is the single-sig key that is used for co-signing the staking output
|
|
123
|
+
* @param changeAddress - this is unrelated to the staking key and is used for the change output
|
|
124
|
+
*/
|
|
125
|
+
function toStakerInfo(stakingKey, changeAddress) {
|
|
126
|
+
if (typeof stakingKey === 'object' && 'publicKey' in stakingKey) {
|
|
127
|
+
stakingKey = stakingKey.publicKey;
|
|
128
|
+
}
|
|
129
|
+
if (typeof stakingKey === 'string') {
|
|
130
|
+
stakingKey = Buffer.from(stakingKey, 'hex');
|
|
131
|
+
}
|
|
132
|
+
return {
|
|
133
|
+
publicKeyNoCoordHex: (0, utxo_core_1.toXOnlyPublicKey)(stakingKey).toString('hex'),
|
|
134
|
+
address: changeAddress,
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
function createStaking(network, blockHeight, stakerBtcInfo, stakingInput, versionedParams = (0, stakingParams_1.getStakingParams)(network)) {
|
|
138
|
+
if (blockHeight === 0) {
|
|
139
|
+
throw new Error('Babylon BTC tip height cannot be 0');
|
|
140
|
+
}
|
|
141
|
+
// Get the Babylon params based on the BTC tip height from Babylon chain
|
|
142
|
+
const params = vendor.getBabylonParamByBtcHeight(blockHeight, versionedParams);
|
|
143
|
+
return new vendor.Staking((0, network_1.toBitcoinJsNetwork)(network), stakerBtcInfo, params, stakingInput.finalityProviderPkNoCoordHex, stakingInput.stakingTimelock);
|
|
144
|
+
}
|
|
145
|
+
function toStakingTransactionFromPsbt(psbt) {
|
|
146
|
+
if (!(psbt instanceof utxolib.bitgo.UtxoPsbt)) {
|
|
147
|
+
psbt = utxolib.bitgo.createPsbtFromBuffer(psbt.toBuffer(), utxolib.networks.bitcoin);
|
|
148
|
+
}
|
|
149
|
+
if (psbt instanceof utxolib.bitgo.UtxoPsbt) {
|
|
150
|
+
// only utxolib.bitgo.UtxoPsbt has the getUnsignedTx method
|
|
151
|
+
return bitcoinjslib.Transaction.fromHex(psbt.getUnsignedTx().toHex());
|
|
152
|
+
}
|
|
153
|
+
throw new Error('illegal state');
|
|
154
|
+
}
|
|
155
|
+
function toStakingTransaction(tx) {
|
|
156
|
+
if (tx instanceof bitcoinjslib.Psbt || tx instanceof utxolib.Psbt) {
|
|
157
|
+
return toStakingTransactionFromPsbt(tx);
|
|
158
|
+
}
|
|
159
|
+
return bitcoinjslib.Transaction.fromHex(tx.toHex());
|
|
160
|
+
}
|
|
161
|
+
/*
|
|
162
|
+
* This is mostly lifted from
|
|
163
|
+
* https://github.com/babylonlabs-io/btc-staking-ts/blob/v0.4.0-rc.2/src/staking/manager.ts#L100-L172
|
|
164
|
+
*
|
|
165
|
+
* The difference is that here we are returning an _unsigned_ delegation message.
|
|
166
|
+
*/
|
|
167
|
+
async function createDelegationMessageWithTransaction(manager, staking, stakingAmountSat, transaction, babylonAddress) {
|
|
168
|
+
if (!vendor.isValidBabylonAddress(babylonAddress)) {
|
|
169
|
+
throw new Error('Invalid Babylon address');
|
|
170
|
+
}
|
|
171
|
+
// Create delegation message without including inclusion proof
|
|
172
|
+
return manager.createBtcDelegationMsg(staking, {
|
|
173
|
+
stakingTimelock: staking.stakingTimelock,
|
|
174
|
+
finalityProviderPkNoCoordHex: staking.finalityProviderPkNoCoordHex,
|
|
175
|
+
stakingAmountSat,
|
|
176
|
+
}, toStakingTransaction(transaction), babylonAddress, staking.stakerInfo, staking.params);
|
|
177
|
+
}
|
|
178
|
+
async function createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider(btcProvider, network, stakerBtcInfo, stakingInput, babylonBtcTipHeight, inputUTXOs, feeRateSatB, babylonAddress, stakingParams = (0, stakingParams_1.getStakingParams)(network)) {
|
|
179
|
+
if (inputUTXOs.length === 0) {
|
|
180
|
+
throw new Error('No input UTXOs provided');
|
|
181
|
+
}
|
|
182
|
+
const manager = (0, stakingManager_1.createStakingManager)(network, btcProvider, stakingParams);
|
|
183
|
+
const staking = createStaking(network, babylonBtcTipHeight, stakerBtcInfo, stakingInput, stakingParams);
|
|
184
|
+
// Create unsigned staking transaction
|
|
185
|
+
const { transaction } = staking.createStakingTransaction(stakingInput.stakingAmountSat, inputUTXOs, feeRateSatB);
|
|
186
|
+
const unsignedDelegationMsg = await createDelegationMessageWithTransaction(manager, staking, stakingInput.stakingAmountSat, transaction, babylonAddress);
|
|
187
|
+
return { unsignedDelegationMsg, stakingTx: transaction };
|
|
188
|
+
}
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delegationMessage.js","sourceRoot":"","sources":["../../../src/babylon/delegationMessage.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * https://github.com/babylonlabs-io/babylon/blob/v1.99.0-snapshot.250211/x/btcstaking/types/validate_parsed_message.go\n */\nimport 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 * as utxolib from '@bitgo-beta/utxo-lib';\nimport { Descriptor } from '@bitgo/wasm-miniscript';\nimport { toXOnlyPublicKey } from '@bitgo-beta/utxo-core';\nimport { toWrappedPsbt } from '@bitgo-beta/utxo-core/descriptor';\n\nimport { BabylonDescriptorBuilder } from './descriptor';\nimport { createStakingManager } from './stakingManager';\nimport { getStakingParams } from './stakingParams';\nimport { BabylonNetworkLike, toBitcoinJsNetwork } from './network';\n\nexport type ValueWithTypeUrl<T> = { typeUrl: string; value: T };\n\nexport function getSignedPsbt(\n  psbt: bitcoinjslib.Psbt,\n  descriptor: Descriptor,\n  signers: utxolib.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\n/**\n * Utility method to work around a bug in btc-staking-ts\n * https://github.com/babylonlabs-io/btc-staking-ts/issues/71\n * @param buffer\n * @param network\n */\nexport function forceFinalizePsbt(buffer: Buffer, network: BabylonNetworkLike): bitcoinjslib.Psbt {\n  const psbt = bitcoinjslib.Psbt.fromBuffer(buffer, { network: toBitcoinJsNetwork(network) });\n  // this only works with certain bitcoinjslib versions\n  psbt.finalizeAllInputs();\n  return psbt;\n}\n\nexport function getBtcProviderForECKey(\n  descriptorBuilder: BabylonDescriptorBuilder,\n  stakerKey: utxolib.ECPairInterface\n): vendor.BtcProvider {\n  function signWithDescriptor(\n    psbt: bitcoinjslib.Psbt,\n    descriptor: Descriptor,\n    key: utxolib.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 * @param stakingKey - this is the single-sig key that is used for co-signing the staking output\n * @param changeAddress - this is unrelated to the staking key and is used for the change output\n */\nexport function toStakerInfo(\n  stakingKey: utxolib.ECPairInterface | Buffer | string,\n  changeAddress: string\n): vendor.StakerInfo {\n  if (typeof stakingKey === 'object' && 'publicKey' in stakingKey) {\n    stakingKey = stakingKey.publicKey;\n  }\n  if (typeof stakingKey === 'string') {\n    stakingKey = Buffer.from(stakingKey, 'hex');\n  }\n  return {\n    publicKeyNoCoordHex: toXOnlyPublicKey(stakingKey).toString('hex'),\n    address: changeAddress,\n  };\n}\n\nexport function createStaking(\n  network: BabylonNetworkLike,\n  blockHeight: number,\n  stakerBtcInfo: vendor.StakerInfo,\n  stakingInput: vendor.StakingInputs,\n  versionedParams: vendor.VersionedStakingParams[] = getStakingParams(network)\n): vendor.Staking {\n  if (blockHeight === 0) {\n    throw new Error('Babylon BTC tip height cannot be 0');\n  }\n\n  // Get the Babylon params based on the BTC tip height from Babylon chain\n  const params = vendor.getBabylonParamByBtcHeight(blockHeight, versionedParams);\n\n  return new vendor.Staking(\n    toBitcoinJsNetwork(network),\n    stakerBtcInfo,\n    params,\n    stakingInput.finalityProviderPkNoCoordHex,\n    stakingInput.stakingTimelock\n  );\n}\n\ntype TransactionLike =\n  | bitcoinjslib.Psbt\n  | bitcoinjslib.Transaction\n  | utxolib.Transaction\n  | utxolib.bitgo.UtxoTransaction<bigint | number>\n  | utxolib.Psbt\n  | utxolib.bitgo.UtxoPsbt;\n\nfunction toStakingTransactionFromPsbt(\n  psbt: bitcoinjslib.Psbt | utxolib.Psbt | utxolib.bitgo.UtxoPsbt\n): bitcoinjslib.Transaction {\n  if (!(psbt instanceof utxolib.bitgo.UtxoPsbt)) {\n    psbt = utxolib.bitgo.createPsbtFromBuffer(psbt.toBuffer(), utxolib.networks.bitcoin);\n  }\n  if (psbt instanceof utxolib.bitgo.UtxoPsbt) {\n    // only utxolib.bitgo.UtxoPsbt has the getUnsignedTx method\n    return bitcoinjslib.Transaction.fromHex(psbt.getUnsignedTx().toHex());\n  }\n  throw new Error('illegal state');\n}\n\nexport function toStakingTransaction(tx: TransactionLike): bitcoinjslib.Transaction {\n  if (tx instanceof bitcoinjslib.Psbt || tx instanceof utxolib.Psbt) {\n    return toStakingTransactionFromPsbt(tx);\n  }\n  return bitcoinjslib.Transaction.fromHex(tx.toHex());\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 createDelegationMessageWithTransaction(\n  manager: vendor.BabylonBtcStakingManager,\n  staking: vendor.Staking,\n  stakingAmountSat: number,\n  transaction: TransactionLike,\n  babylonAddress: string\n): Promise<ValueWithTypeUrl<babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation>> {\n  if (!vendor.isValidBabylonAddress(babylonAddress)) {\n    throw new Error('Invalid Babylon address');\n  }\n  // Create delegation message without including inclusion proof\n  return manager.createBtcDelegationMsg(\n    staking,\n    {\n      stakingTimelock: staking.stakingTimelock,\n      finalityProviderPkNoCoordHex: staking.finalityProviderPkNoCoordHex,\n      stakingAmountSat,\n    },\n    toStakingTransaction(transaction),\n    babylonAddress,\n    staking.stakerInfo,\n    staking.params\n  );\n}\n\nexport async function createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider(\n  btcProvider: vendor.BtcProvider,\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  stakingParams: vendor.VersionedStakingParams[] = getStakingParams(network)\n): Promise<Result> {\n  if (inputUTXOs.length === 0) {\n    throw new Error('No input UTXOs provided');\n  }\n  const manager = createStakingManager(network, btcProvider, stakingParams);\n  const staking = createStaking(network, babylonBtcTipHeight, stakerBtcInfo, stakingInput, stakingParams);\n  // Create unsigned staking transaction\n  const { transaction } = staking.createStakingTransaction(stakingInput.stakingAmountSat, inputUTXOs, feeRateSatB);\n  const unsignedDelegationMsg = await createDelegationMessageWithTransaction(\n    manager,\n    staking,\n    stakingInput.stakingAmountSat,\n    transaction,\n    babylonAddress\n  );\n  return { unsignedDelegationMsg, stakingTx: transaction };\n}\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
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
|
+
* https://github.com/babylonlabs-io/babylon/blob/v1.99.0-snapshot.250211/btcstaking/staking.go
|
|
5
|
+
*/
|
|
6
|
+
import { Descriptor, ast } from '@bitgo/wasm-miniscript';
|
|
7
|
+
import { StakingParams } from '@bitgo-beta/babylonlabs-io-btc-staking-ts';
|
|
8
|
+
export declare function getUnspendableKey(): string;
|
|
9
|
+
export declare class BabylonDescriptorBuilder {
|
|
10
|
+
stakerKey: Buffer;
|
|
11
|
+
finalityProviderKeys: Buffer[];
|
|
12
|
+
covenantKeys: Buffer[];
|
|
13
|
+
covenantThreshold: number;
|
|
14
|
+
stakingTimeLock: number;
|
|
15
|
+
unbondingTimeLock: number;
|
|
16
|
+
constructor(stakerKey: Buffer, finalityProviderKeys: Buffer[], covenantKeys: Buffer[], covenantThreshold: number, stakingTimeLock: number, unbondingTimeLock: number);
|
|
17
|
+
static fromParams(params: {
|
|
18
|
+
stakerKey: Buffer;
|
|
19
|
+
finalityProviderKeys: Buffer[];
|
|
20
|
+
} & StakingParams): BabylonDescriptorBuilder;
|
|
21
|
+
getTimelockMiniscript(): ast.MiniscriptNode;
|
|
22
|
+
getUnbondingMiniscript(): ast.MiniscriptNode;
|
|
23
|
+
getSlashingMiniscript(): ast.MiniscriptNode;
|
|
24
|
+
getUnbondingTimelockMiniscript(): ast.MiniscriptNode;
|
|
25
|
+
getStakingDescriptor(): Descriptor;
|
|
26
|
+
getSlashingDescriptor(): Descriptor;
|
|
27
|
+
getUnbondingDescriptor(): Descriptor;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=descriptor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"descriptor.d.ts","sourceRoot":"","sources":["../../../src/babylon/descriptor.ts"],"names":[],"mappings":"AAAA;;;;GAIG;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;IAW3B,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,78 @@
|
|
|
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
|
+
* https://github.com/babylonlabs-io/babylon/blob/v1.99.0-snapshot.250211/btcstaking/staking.go
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.BabylonDescriptorBuilder = void 0;
|
|
9
|
+
exports.getUnspendableKey = getUnspendableKey;
|
|
10
|
+
const wasm_miniscript_1 = require("@bitgo/wasm-miniscript");
|
|
11
|
+
function getUnspendableKey() {
|
|
12
|
+
// https://github.com/babylonlabs-io/btc-staking-ts/blob/v0.4.0-rc.2/src/constants/internalPubkey.ts
|
|
13
|
+
return '50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0';
|
|
14
|
+
}
|
|
15
|
+
// Helper functions for creating miniscript nodes
|
|
16
|
+
function pk(b) {
|
|
17
|
+
return { 'v:pk': b.toString('hex') };
|
|
18
|
+
}
|
|
19
|
+
function sortedKeys(keys) {
|
|
20
|
+
return [...keys].sort((a, b) => a.compare(b));
|
|
21
|
+
}
|
|
22
|
+
function multiArgs(threshold, keys) {
|
|
23
|
+
return [threshold, ...sortedKeys(keys).map((k) => k.toString('hex'))];
|
|
24
|
+
}
|
|
25
|
+
function taprootScriptOnlyFromAst(n) {
|
|
26
|
+
return wasm_miniscript_1.Descriptor.fromString(wasm_miniscript_1.ast.formatNode({ tr: [getUnspendableKey(), n] }), 'definite');
|
|
27
|
+
}
|
|
28
|
+
class BabylonDescriptorBuilder {
|
|
29
|
+
constructor(stakerKey, finalityProviderKeys, covenantKeys, covenantThreshold, stakingTimeLock, unbondingTimeLock) {
|
|
30
|
+
this.stakerKey = stakerKey;
|
|
31
|
+
this.finalityProviderKeys = finalityProviderKeys;
|
|
32
|
+
this.covenantKeys = covenantKeys;
|
|
33
|
+
this.covenantThreshold = covenantThreshold;
|
|
34
|
+
this.stakingTimeLock = stakingTimeLock;
|
|
35
|
+
this.unbondingTimeLock = unbondingTimeLock;
|
|
36
|
+
}
|
|
37
|
+
static fromParams(params) {
|
|
38
|
+
return new BabylonDescriptorBuilder(params.stakerKey, params.finalityProviderKeys, params.covenantNoCoordPks.map((k) => Buffer.from(k, 'hex')), params.covenantQuorum, params.minStakingTimeBlocks, params.unbondingTime);
|
|
39
|
+
}
|
|
40
|
+
getTimelockMiniscript() {
|
|
41
|
+
return { and_v: [pk(this.stakerKey), { older: this.stakingTimeLock }] };
|
|
42
|
+
}
|
|
43
|
+
getUnbondingMiniscript() {
|
|
44
|
+
return { and_v: [pk(this.stakerKey), { multi_a: multiArgs(this.covenantThreshold, this.covenantKeys) }] };
|
|
45
|
+
}
|
|
46
|
+
getSlashingMiniscript() {
|
|
47
|
+
return {
|
|
48
|
+
and_v: [
|
|
49
|
+
{
|
|
50
|
+
and_v: [
|
|
51
|
+
pk(this.stakerKey),
|
|
52
|
+
this.finalityProviderKeys.length === 1
|
|
53
|
+
? { 'v:pk': this.finalityProviderKeys[0].toString('hex') }
|
|
54
|
+
: { 'v:multi_a': multiArgs(1, this.finalityProviderKeys) },
|
|
55
|
+
],
|
|
56
|
+
},
|
|
57
|
+
{ multi_a: multiArgs(this.covenantThreshold, this.covenantKeys) },
|
|
58
|
+
],
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
getUnbondingTimelockMiniscript() {
|
|
62
|
+
return { and_v: [pk(this.stakerKey), { older: this.unbondingTimeLock }] };
|
|
63
|
+
}
|
|
64
|
+
getStakingDescriptor() {
|
|
65
|
+
return taprootScriptOnlyFromAst([
|
|
66
|
+
this.getSlashingMiniscript(),
|
|
67
|
+
[this.getUnbondingMiniscript(), this.getTimelockMiniscript()],
|
|
68
|
+
]);
|
|
69
|
+
}
|
|
70
|
+
getSlashingDescriptor() {
|
|
71
|
+
return taprootScriptOnlyFromAst(this.getUnbondingTimelockMiniscript());
|
|
72
|
+
}
|
|
73
|
+
getUnbondingDescriptor() {
|
|
74
|
+
return taprootScriptOnlyFromAst([this.getSlashingMiniscript(), this.getUnbondingTimelockMiniscript()]);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
exports.BabylonDescriptorBuilder = BabylonDescriptorBuilder;
|
|
78
|
+
//# 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 * https://github.com/babylonlabs-io/babylon/blob/v1.99.0-snapshot.250211/btcstaking/staking.go\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    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":"AAOA,cAAc,qBAAqB,CAAC;AACpC,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
36
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
const babylonlabs_io_btc_staking_ts_1 = require("@bitgo-beta/babylonlabs-io-btc-staking-ts");
|
|
40
|
+
const bitcoinjslib = __importStar(require("bitcoinjs-lib"));
|
|
41
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
42
|
+
(0, babylonlabs_io_btc_staking_ts_1.initBTCCurve)();
|
|
43
|
+
bitcoinjslib.initEccLib(utxolib.ecc);
|
|
44
|
+
__exportStar(require("./delegationMessage"), exports);
|
|
45
|
+
__exportStar(require("./descriptor"), exports);
|
|
46
|
+
__exportStar(require("./stakingParams"), exports);
|
|
47
|
+
__exportStar(require("./stakingManager"), exports);
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmFieWxvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZGQUF5RTtBQUN6RSw0REFBOEM7QUFDOUMsOERBQWdEO0FBRWhELElBQUEsNENBQVksR0FBRSxDQUFDO0FBQ2YsWUFBWSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7QUFFckMsc0RBQW9DO0FBQ3BDLCtDQUE2QjtBQUM3QixrREFBZ0M7QUFDaEMsbURBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5pdEJUQ0N1cnZlIH0gZnJvbSAnQGJpdGdvLWJldGEvYmFieWxvbmxhYnMtaW8tYnRjLXN0YWtpbmctdHMnO1xuaW1wb3J0ICogYXMgYml0Y29pbmpzbGliIGZyb20gJ2JpdGNvaW5qcy1saWInO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5cbmluaXRCVENDdXJ2ZSgpO1xuYml0Y29pbmpzbGliLmluaXRFY2NMaWIodXR4b2xpYi5lY2MpO1xuXG5leHBvcnQgKiBmcm9tICcuL2RlbGVnYXRpb25NZXNzYWdlJztcbmV4cG9ydCAqIGZyb20gJy4vZGVzY3JpcHRvcic7XG5leHBvcnQgKiBmcm9tICcuL3N0YWtpbmdQYXJhbXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdGFraW5nTWFuYWdlcic7XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as bitcoinjslib from 'bitcoinjs-lib';
|
|
2
|
+
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
3
|
+
export type BabylonNetwork = 'mainnet' | 'testnet';
|
|
4
|
+
export type BabylonNetworkLike = bitcoinjslib.Network | utxolib.Network | BabylonNetwork;
|
|
5
|
+
export declare function toBabylonNetwork(n: BabylonNetworkLike): BabylonNetwork;
|
|
6
|
+
export declare function toBitcoinJsNetwork(n: BabylonNetworkLike): bitcoinjslib.Network;
|
|
7
|
+
//# sourceMappingURL=network.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"network.d.ts","sourceRoot":"","sources":["../../../src/babylon/network.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,YAAY,MAAM,eAAe,CAAC;AAC9C,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,MAAM,MAAM,cAAc,GAAG,SAAS,GAAG,SAAS,CAAC;AAEnD,MAAM,MAAM,kBAAkB,GAAG,YAAY,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,GAAG,cAAc,CAAC;AAEzF,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,kBAAkB,GAAG,cAAc,CAetE;AAED,wBAAgB,kBAAkB,CAAC,CAAC,EAAE,kBAAkB,GAAG,YAAY,CAAC,OAAO,CAS9E"}
|
|
@@ -0,0 +1,66 @@
|
|
|
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.toBabylonNetwork = toBabylonNetwork;
|
|
37
|
+
exports.toBitcoinJsNetwork = toBitcoinJsNetwork;
|
|
38
|
+
const bitcoinjslib = __importStar(require("bitcoinjs-lib"));
|
|
39
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
40
|
+
function toBabylonNetwork(n) {
|
|
41
|
+
switch (n) {
|
|
42
|
+
case bitcoinjslib.networks.bitcoin:
|
|
43
|
+
case utxolib.networks.bitcoin:
|
|
44
|
+
return 'mainnet';
|
|
45
|
+
case bitcoinjslib.networks.testnet:
|
|
46
|
+
case utxolib.networks.testnet:
|
|
47
|
+
case utxolib.networks.bitcoinPublicSignet:
|
|
48
|
+
return 'testnet';
|
|
49
|
+
case 'mainnet':
|
|
50
|
+
case 'testnet':
|
|
51
|
+
return n;
|
|
52
|
+
default:
|
|
53
|
+
throw new Error('Unsupported network');
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
function toBitcoinJsNetwork(n) {
|
|
57
|
+
switch (toBabylonNetwork(n)) {
|
|
58
|
+
case 'mainnet':
|
|
59
|
+
return bitcoinjslib.networks.bitcoin;
|
|
60
|
+
case 'testnet':
|
|
61
|
+
return bitcoinjslib.networks.testnet;
|
|
62
|
+
default:
|
|
63
|
+
throw new Error('Unsupported network');
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV0d29yay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iYWJ5bG9uL25ldHdvcmsudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFPQSw0Q0FlQztBQUVELGdEQVNDO0FBakNELDREQUE4QztBQUM5Qyw4REFBZ0Q7QUFNaEQsU0FBZ0IsZ0JBQWdCLENBQUMsQ0FBcUI7SUFDcEQsUUFBUSxDQUFDLEVBQUUsQ0FBQztRQUNWLEtBQUssWUFBWSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUM7UUFDbkMsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLE9BQU87WUFDM0IsT0FBTyxTQUFTLENBQUM7UUFDbkIsS0FBSyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQztRQUNuQyxLQUFLLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDO1FBQzlCLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxtQkFBbUI7WUFDdkMsT0FBTyxTQUFTLENBQUM7UUFDbkIsS0FBSyxTQUFTLENBQUM7UUFDZixLQUFLLFNBQVM7WUFDWixPQUFPLENBQUMsQ0FBQztRQUNYO1lBQ0UsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0lBQzNDLENBQUM7QUFDSCxDQUFDO0FBRUQsU0FBZ0Isa0JBQWtCLENBQUMsQ0FBcUI7SUFDdEQsUUFBUSxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzVCLEtBQUssU0FBUztZQUNaLE9BQU8sWUFBWSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUM7UUFDdkMsS0FBSyxTQUFTO1lBQ1osT0FBTyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQztRQUN2QztZQUNFLE1BQU0sSUFBSSxLQUFLLENBQUMscUJBQXFCLENBQUMsQ0FBQztJQUMzQyxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGJpdGNvaW5qc2xpYiBmcm9tICdiaXRjb2luanMtbGliJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5leHBvcnQgdHlwZSBCYWJ5bG9uTmV0d29yayA9ICdtYWlubmV0JyB8ICd0ZXN0bmV0JztcblxuZXhwb3J0IHR5cGUgQmFieWxvbk5ldHdvcmtMaWtlID0gYml0Y29pbmpzbGliLk5ldHdvcmsgfCB1dHhvbGliLk5ldHdvcmsgfCBCYWJ5bG9uTmV0d29yaztcblxuZXhwb3J0IGZ1bmN0aW9uIHRvQmFieWxvbk5ldHdvcmsobjogQmFieWxvbk5ldHdvcmtMaWtlKTogQmFieWxvbk5ldHdvcmsge1xuICBzd2l0Y2ggKG4pIHtcbiAgICBjYXNlIGJpdGNvaW5qc2xpYi5uZXR3b3Jrcy5iaXRjb2luOlxuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luOlxuICAgICAgcmV0dXJuICdtYWlubmV0JztcbiAgICBjYXNlIGJpdGNvaW5qc2xpYi5uZXR3b3Jrcy50ZXN0bmV0OlxuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy50ZXN0bmV0OlxuICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luUHVibGljU2lnbmV0OlxuICAgICAgcmV0dXJuICd0ZXN0bmV0JztcbiAgICBjYXNlICdtYWlubmV0JzpcbiAgICBjYXNlICd0ZXN0bmV0JzpcbiAgICAgIHJldHVybiBuO1xuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ1Vuc3VwcG9ydGVkIG5ldHdvcmsnKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gdG9CaXRjb2luSnNOZXR3b3JrKG46IEJhYnlsb25OZXR3b3JrTGlrZSk6IGJpdGNvaW5qc2xpYi5OZXR3b3JrIHtcbiAgc3dpdGNoICh0b0JhYnlsb25OZXR3b3JrKG4pKSB7XG4gICAgY2FzZSAnbWFpbm5ldCc6XG4gICAgICByZXR1cm4gYml0Y29pbmpzbGliLm5ldHdvcmtzLmJpdGNvaW47XG4gICAgY2FzZSAndGVzdG5ldCc6XG4gICAgICByZXR1cm4gYml0Y29pbmpzbGliLm5ldHdvcmtzLnRlc3RuZXQ7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBFcnJvcignVW5zdXBwb3J0ZWQgbmV0d29yaycpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
[]
|