@bitgo-beta/utxo-staking 1.1.0-alpha.6 → 1.1.0-alpha.61
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 +22 -0
- package/dist/src/babylon/delegationMessage.d.ts.map +1 -0
- package/dist/src/babylon/delegationMessage.js +131 -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 +5 -0
- package/dist/src/babylon/index.d.ts.map +1 -0
- package/dist/src/babylon/index.js +21 -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/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 +38 -0
- package/dist/src/babylon/stakingParams.d.ts.map +1 -0
- package/dist/src/babylon/stakingParams.js +145 -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 +15 -8
- package/dist/src/coreDao/transaction.d.ts.map +1 -1
- package/dist/src/coreDao/transaction.js +13 -6
- 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 +19 -7
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -35
|
@@ -0,0 +1,22 @@
|
|
|
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
|
+
export type ValueWithTypeUrl<T> = {
|
|
8
|
+
typeUrl: string;
|
|
9
|
+
value: T;
|
|
10
|
+
};
|
|
11
|
+
export declare function getSignedPsbt(psbt: bitcoinjslib.Psbt, descriptor: Descriptor, signers: utxolib.ECPairInterface[], { finalize }: {
|
|
12
|
+
finalize?: boolean | undefined;
|
|
13
|
+
}): bitcoinjslib.Psbt;
|
|
14
|
+
export declare function getBtcProviderForECKey(descriptorBuilder: BabylonDescriptorBuilder, stakerKey: utxolib.ECPairInterface): vendor.BtcProvider;
|
|
15
|
+
type Result = {
|
|
16
|
+
unsignedDelegationMsg: ValueWithTypeUrl<babylonProtobuf.btcstakingtx.MsgCreateBTCDelegation>;
|
|
17
|
+
stakingTx: bitcoinjslib.Transaction;
|
|
18
|
+
};
|
|
19
|
+
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>;
|
|
20
|
+
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>;
|
|
21
|
+
export {};
|
|
22
|
+
//# 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,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAGpD,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AAIxD,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,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;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,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,CAajB"}
|
|
@@ -0,0 +1,131 @@
|
|
|
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.getBtcProviderForECKey = getBtcProviderForECKey;
|
|
41
|
+
exports.createUnsignedPreStakeRegistrationBabylonTransaction = createUnsignedPreStakeRegistrationBabylonTransaction;
|
|
42
|
+
exports.createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider = createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider;
|
|
43
|
+
const assert_1 = __importDefault(require("assert"));
|
|
44
|
+
const vendor = __importStar(require("@bitgo-beta/babylonlabs-io-btc-staking-ts"));
|
|
45
|
+
const bitcoinjslib = __importStar(require("bitcoinjs-lib"));
|
|
46
|
+
const descriptor_1 = require("@bitgo-beta/utxo-core/descriptor");
|
|
47
|
+
const stakingManager_1 = require("./stakingManager");
|
|
48
|
+
const stakingParams_1 = require("./stakingParams");
|
|
49
|
+
function getSignedPsbt(psbt, descriptor, signers, { finalize = false }) {
|
|
50
|
+
const wrappedPsbt = (0, descriptor_1.toWrappedPsbt)(psbt.toBuffer());
|
|
51
|
+
const signedInputs = psbt.data.inputs.flatMap((input, i) => {
|
|
52
|
+
(0, assert_1.default)(input.witnessUtxo);
|
|
53
|
+
if (Buffer.from(descriptor.scriptPubkey()).equals(input.witnessUtxo.script)) {
|
|
54
|
+
wrappedPsbt.updateInputWithDescriptor(i, descriptor);
|
|
55
|
+
const signResults = signers.map((signer) => {
|
|
56
|
+
(0, assert_1.default)(signer.privateKey);
|
|
57
|
+
return wrappedPsbt.signWithPrv(signer.privateKey);
|
|
58
|
+
});
|
|
59
|
+
return [[i, signResults]];
|
|
60
|
+
}
|
|
61
|
+
return [];
|
|
62
|
+
});
|
|
63
|
+
(0, assert_1.default)(signedInputs.length > 0);
|
|
64
|
+
if (finalize) {
|
|
65
|
+
wrappedPsbt.finalize();
|
|
66
|
+
}
|
|
67
|
+
return bitcoinjslib.Psbt.fromBuffer(Buffer.from(wrappedPsbt.serialize()));
|
|
68
|
+
}
|
|
69
|
+
function getBtcProviderForECKey(descriptorBuilder, stakerKey) {
|
|
70
|
+
function signWithDescriptor(psbt, descriptor, key) {
|
|
71
|
+
psbt = getSignedPsbt(psbt, descriptor, [key], { finalize: false });
|
|
72
|
+
// BUG: we need to blindly finalize here even though we have not fully signed
|
|
73
|
+
psbt.finalizeAllInputs();
|
|
74
|
+
return psbt;
|
|
75
|
+
}
|
|
76
|
+
return {
|
|
77
|
+
async signMessage(signingStep, message, type) {
|
|
78
|
+
(0, assert_1.default)(type === 'ecdsa');
|
|
79
|
+
switch (signingStep) {
|
|
80
|
+
case 'proof-of-possession':
|
|
81
|
+
return stakerKey.sign(Buffer.from(message, 'hex')).toString('hex');
|
|
82
|
+
default:
|
|
83
|
+
throw new Error(`unexpected signing step: ${signingStep}`);
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
async signPsbt(signingStep, psbtHex) {
|
|
87
|
+
const psbt = bitcoinjslib.Psbt.fromHex(psbtHex);
|
|
88
|
+
switch (signingStep) {
|
|
89
|
+
case 'staking-slashing':
|
|
90
|
+
return signWithDescriptor(psbt, descriptorBuilder.getStakingDescriptor(), stakerKey).toHex();
|
|
91
|
+
case 'unbonding-slashing':
|
|
92
|
+
return signWithDescriptor(psbt, descriptorBuilder.getUnbondingDescriptor(), stakerKey).toHex();
|
|
93
|
+
default:
|
|
94
|
+
throw new Error(`unexpected signing step: ${signingStep}`);
|
|
95
|
+
}
|
|
96
|
+
},
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
/*
|
|
100
|
+
* This is mostly lifted from
|
|
101
|
+
* https://github.com/babylonlabs-io/btc-staking-ts/blob/v0.4.0-rc.2/src/staking/manager.ts#L100-L172
|
|
102
|
+
*
|
|
103
|
+
* The difference is that here we are returning an _unsigned_ delegation message.
|
|
104
|
+
*/
|
|
105
|
+
async function createUnsignedPreStakeRegistrationBabylonTransaction(manager, stakingParams, network, stakerBtcInfo, stakingInput, babylonBtcTipHeight, inputUTXOs, feeRateSatB, babylonAddress) {
|
|
106
|
+
if (babylonBtcTipHeight === 0) {
|
|
107
|
+
throw new Error('Babylon BTC tip height cannot be 0');
|
|
108
|
+
}
|
|
109
|
+
if (inputUTXOs.length === 0) {
|
|
110
|
+
throw new Error('No input UTXOs provided');
|
|
111
|
+
}
|
|
112
|
+
if (!vendor.isValidBabylonAddress(babylonAddress)) {
|
|
113
|
+
throw new Error('Invalid Babylon address');
|
|
114
|
+
}
|
|
115
|
+
// Get the Babylon params based on the BTC tip height from Babylon chain
|
|
116
|
+
const params = vendor.getBabylonParamByBtcHeight(babylonBtcTipHeight, stakingParams);
|
|
117
|
+
const staking = new vendor.Staking(network, stakerBtcInfo, params, stakingInput.finalityProviderPkNoCoordHex, stakingInput.stakingTimelock);
|
|
118
|
+
// Create unsigned staking transaction
|
|
119
|
+
const { transaction } = staking.createStakingTransaction(stakingInput.stakingAmountSat, inputUTXOs, feeRateSatB);
|
|
120
|
+
// Create delegation message without including inclusion proof
|
|
121
|
+
const msg = await manager.createBtcDelegationMsg(staking, stakingInput, transaction, babylonAddress, stakerBtcInfo, params);
|
|
122
|
+
return {
|
|
123
|
+
unsignedDelegationMsg: msg,
|
|
124
|
+
stakingTx: transaction,
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
async function createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvider(btcProvider, network, stakerBtcInfo, stakingInput, babylonBtcTipHeight, inputUTXOs, feeRateSatB, babylonAddress, stakingParams = (0, stakingParams_1.getStakingParams)(network)) {
|
|
128
|
+
const manager = (0, stakingManager_1.createStakingManager)(network, btcProvider, stakingParams);
|
|
129
|
+
return await createUnsignedPreStakeRegistrationBabylonTransaction(manager, stakingParams, network, stakerBtcInfo, stakingInput, babylonBtcTipHeight, inputUTXOs, feeRateSatB, babylonAddress);
|
|
130
|
+
}
|
|
131
|
+
//# 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 * as utxolib from '@bitgo-beta/utxo-lib';\nimport { Descriptor } from '@bitgo/wasm-miniscript';\nimport { toWrappedPsbt } from '@bitgo-beta/utxo-core/descriptor';\n\nimport { BabylonDescriptorBuilder } from './descriptor';\nimport { createStakingManager } from './stakingManager';\nimport { getStakingParams } from './stakingParams';\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\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 * 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  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  const manager = createStakingManager(network, btcProvider, stakingParams);\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;AAChC,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
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
|
+
__exportStar(require("./stakingManager"), exports);
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmFieWxvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsc0RBQW9DO0FBQ3BDLCtDQUE2QjtBQUM3QixrREFBZ0M7QUFDaEMsbURBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kZWxlZ2F0aW9uTWVzc2FnZSc7XG5leHBvcnQgKiBmcm9tICcuL2Rlc2NyaXB0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9zdGFraW5nUGFyYW1zJztcbmV4cG9ydCAqIGZyb20gJy4vc3Rha2luZ01hbmFnZXInO1xuIl19
|
|
@@ -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 @@
|
|
|
1
|
+
[]
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
[
|
|
2
|
+
{
|
|
3
|
+
"params": {
|
|
4
|
+
"covenant_pks": [
|
|
5
|
+
"49766ccd9e3cd94343e2040474a77fb37cdfd30530d05f9f1e96ae1e2102c86e",
|
|
6
|
+
"76d1ae01f8fb6bf30108731c884cddcf57ef6eef2d9d9559e130894e0e40c62c",
|
|
7
|
+
"17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4",
|
|
8
|
+
"113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0",
|
|
9
|
+
"79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0",
|
|
10
|
+
"3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c",
|
|
11
|
+
"d21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36",
|
|
12
|
+
"40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df",
|
|
13
|
+
"f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e"
|
|
14
|
+
],
|
|
15
|
+
"covenant_quorum": 6,
|
|
16
|
+
"min_staking_value_sat": "50000",
|
|
17
|
+
"max_staking_value_sat": "5000000",
|
|
18
|
+
"min_staking_time_blocks": 64000,
|
|
19
|
+
"max_staking_time_blocks": 64000,
|
|
20
|
+
"slashing_pk_script": "dqkUAQEBAQEBAQEBAQEBAQEBAQEBAQGIrA==",
|
|
21
|
+
"min_slashing_tx_fee_sat": "1000",
|
|
22
|
+
"slashing_rate": "0.100000000000000000",
|
|
23
|
+
"unbonding_time_blocks": 1008,
|
|
24
|
+
"unbonding_fee_sat": "2000",
|
|
25
|
+
"min_commission_rate": "0.030000000000000000",
|
|
26
|
+
"delegation_creation_base_gas_fee": "1000",
|
|
27
|
+
"allow_list_expiration_height": "26120",
|
|
28
|
+
"btc_activation_height": 197535
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
"params": {
|
|
33
|
+
"covenant_pks": [
|
|
34
|
+
"09585ab55a971a231c945790a0a81df754e5a07263a5c20829931cc24683bbb7",
|
|
35
|
+
"76d1ae01f8fb6bf30108731c884cddcf57ef6eef2d9d9559e130894e0e40c62c",
|
|
36
|
+
"17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4",
|
|
37
|
+
"113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0",
|
|
38
|
+
"79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0",
|
|
39
|
+
"3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c",
|
|
40
|
+
"d21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36",
|
|
41
|
+
"40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df",
|
|
42
|
+
"f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e"
|
|
43
|
+
],
|
|
44
|
+
"covenant_quorum": 6,
|
|
45
|
+
"min_staking_value_sat": "50000",
|
|
46
|
+
"max_staking_value_sat": "5000000",
|
|
47
|
+
"min_staking_time_blocks": 64000,
|
|
48
|
+
"max_staking_time_blocks": 64000,
|
|
49
|
+
"slashing_pk_script": "dqkUAQEBAQEBAQEBAQEBAQEBAQEBAQGIrA==",
|
|
50
|
+
"min_slashing_tx_fee_sat": "1000",
|
|
51
|
+
"slashing_rate": "0.100000000000000000",
|
|
52
|
+
"unbonding_time_blocks": 1008,
|
|
53
|
+
"unbonding_fee_sat": "10000",
|
|
54
|
+
"min_commission_rate": "0.030000000000000000",
|
|
55
|
+
"delegation_creation_base_gas_fee": "1000",
|
|
56
|
+
"allow_list_expiration_height": "26120",
|
|
57
|
+
"btc_activation_height": 198665
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
"params": {
|
|
62
|
+
"covenant_pks": [
|
|
63
|
+
"fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737",
|
|
64
|
+
"0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25",
|
|
65
|
+
"17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4",
|
|
66
|
+
"113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0",
|
|
67
|
+
"79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0",
|
|
68
|
+
"3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c",
|
|
69
|
+
"d21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36",
|
|
70
|
+
"40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df",
|
|
71
|
+
"f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e"
|
|
72
|
+
],
|
|
73
|
+
"covenant_quorum": 6,
|
|
74
|
+
"min_staking_value_sat": "50000",
|
|
75
|
+
"max_staking_value_sat": "5000000",
|
|
76
|
+
"min_staking_time_blocks": 64000,
|
|
77
|
+
"max_staking_time_blocks": 64000,
|
|
78
|
+
"slashing_pk_script": "dqkUAQEBAQEBAQEBAQEBAQEBAQEBAQGIrA==",
|
|
79
|
+
"min_slashing_tx_fee_sat": "1000",
|
|
80
|
+
"slashing_rate": "0.100000000000000000",
|
|
81
|
+
"unbonding_time_blocks": 1008,
|
|
82
|
+
"unbonding_fee_sat": "10000",
|
|
83
|
+
"min_commission_rate": "0.030000000000000000",
|
|
84
|
+
"delegation_creation_base_gas_fee": "1000",
|
|
85
|
+
"allow_list_expiration_height": "26120",
|
|
86
|
+
"btc_activation_height": 200665
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
{
|
|
90
|
+
"params": {
|
|
91
|
+
"covenant_pks": [
|
|
92
|
+
"fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737",
|
|
93
|
+
"0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25",
|
|
94
|
+
"17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4",
|
|
95
|
+
"113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0",
|
|
96
|
+
"79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0",
|
|
97
|
+
"3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c",
|
|
98
|
+
"d21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36",
|
|
99
|
+
"40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df",
|
|
100
|
+
"f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e"
|
|
101
|
+
],
|
|
102
|
+
"covenant_quorum": 6,
|
|
103
|
+
"min_staking_value_sat": "50000",
|
|
104
|
+
"max_staking_value_sat": "50000000",
|
|
105
|
+
"min_staking_time_blocks": 64000,
|
|
106
|
+
"max_staking_time_blocks": 64000,
|
|
107
|
+
"slashing_pk_script": "dqkUAQEBAQEBAQEBAQEBAQEBAQEBAQGIrA==",
|
|
108
|
+
"min_slashing_tx_fee_sat": "1000",
|
|
109
|
+
"slashing_rate": "0.100000000000000000",
|
|
110
|
+
"unbonding_time_blocks": 1008,
|
|
111
|
+
"unbonding_fee_sat": "5000",
|
|
112
|
+
"min_commission_rate": "0.030000000000000000",
|
|
113
|
+
"delegation_creation_base_gas_fee": "1000",
|
|
114
|
+
"allow_list_expiration_height": "26120",
|
|
115
|
+
"btc_activation_height": 215968
|
|
116
|
+
}
|
|
117
|
+
},
|
|
118
|
+
{
|
|
119
|
+
"params": {
|
|
120
|
+
"covenant_pks": [
|
|
121
|
+
"fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737",
|
|
122
|
+
"0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25",
|
|
123
|
+
"17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4",
|
|
124
|
+
"113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0",
|
|
125
|
+
"79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0",
|
|
126
|
+
"3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c",
|
|
127
|
+
"d21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36",
|
|
128
|
+
"40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df",
|
|
129
|
+
"f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e"
|
|
130
|
+
],
|
|
131
|
+
"covenant_quorum": 6,
|
|
132
|
+
"min_staking_value_sat": "50000",
|
|
133
|
+
"max_staking_value_sat": "50000000",
|
|
134
|
+
"min_staking_time_blocks": 64000,
|
|
135
|
+
"max_staking_time_blocks": 64000,
|
|
136
|
+
"slashing_pk_script": "dqkUAQEBAQEBAQEBAQEBAQEBAQEBAQGIrA==",
|
|
137
|
+
"min_slashing_tx_fee_sat": "1000",
|
|
138
|
+
"slashing_rate": "0.100000000000000000",
|
|
139
|
+
"unbonding_time_blocks": 1008,
|
|
140
|
+
"unbonding_fee_sat": "5000",
|
|
141
|
+
"min_commission_rate": "0.030000000000000000",
|
|
142
|
+
"delegation_creation_base_gas_fee": "1000",
|
|
143
|
+
"allow_list_expiration_height": "26120",
|
|
144
|
+
"btc_activation_height": 220637
|
|
145
|
+
}
|
|
146
|
+
},
|
|
147
|
+
{
|
|
148
|
+
"params": {
|
|
149
|
+
"covenant_pks": [
|
|
150
|
+
"fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737",
|
|
151
|
+
"0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25",
|
|
152
|
+
"17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4",
|
|
153
|
+
"113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0",
|
|
154
|
+
"79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0",
|
|
155
|
+
"3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c",
|
|
156
|
+
"d21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36",
|
|
157
|
+
"40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df",
|
|
158
|
+
"f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e"
|
|
159
|
+
],
|
|
160
|
+
"covenant_quorum": 6,
|
|
161
|
+
"min_staking_value_sat": "50000",
|
|
162
|
+
"max_staking_value_sat": "35000000000",
|
|
163
|
+
"min_staking_time_blocks": 10000,
|
|
164
|
+
"max_staking_time_blocks": 64000,
|
|
165
|
+
"slashing_pk_script": "ABRb4SYk0IorQkCV18ByIcM0UNFL8Q==",
|
|
166
|
+
"min_slashing_tx_fee_sat": "5000",
|
|
167
|
+
"slashing_rate": "0.050000000000000000",
|
|
168
|
+
"unbonding_time_blocks": 1008,
|
|
169
|
+
"unbonding_fee_sat": "2000",
|
|
170
|
+
"min_commission_rate": "0.030000000000000000",
|
|
171
|
+
"delegation_creation_base_gas_fee": "1095000",
|
|
172
|
+
"allow_list_expiration_height": "26124",
|
|
173
|
+
"btc_activation_height": 227174
|
|
174
|
+
}
|
|
175
|
+
},
|
|
176
|
+
{
|
|
177
|
+
"params": {
|
|
178
|
+
"covenant_pks": [
|
|
179
|
+
"fa9d882d45f4060bdb8042183828cd87544f1ea997380e586cab77d5fd698737",
|
|
180
|
+
"0aee0509b16db71c999238a4827db945526859b13c95487ab46725357c9a9f25",
|
|
181
|
+
"17921cf156ccb4e73d428f996ed11b245313e37e27c978ac4d2cc21eca4672e4",
|
|
182
|
+
"113c3a32a9d320b72190a04a020a0db3976ef36972673258e9a38a364f3dc3b0",
|
|
183
|
+
"79a71ffd71c503ef2e2f91bccfc8fcda7946f4653cef0d9f3dde20795ef3b9f0",
|
|
184
|
+
"3bb93dfc8b61887d771f3630e9a63e97cbafcfcc78556a474df83a31a0ef899c",
|
|
185
|
+
"d21faf78c6751a0d38e6bd8028b907ff07e9a869a43fc837d6b3f8dff6119a36",
|
|
186
|
+
"40afaf47c4ffa56de86410d8e47baa2bb6f04b604f4ea24323737ddc3fe092df",
|
|
187
|
+
"f5199efae3f28bb82476163a7e458c7ad445d9bffb0682d10d3bdb2cb41f8e8e"
|
|
188
|
+
],
|
|
189
|
+
"covenant_quorum": 6,
|
|
190
|
+
"min_staking_value_sat": "50000",
|
|
191
|
+
"max_staking_value_sat": "35000000000",
|
|
192
|
+
"min_staking_time_blocks": 10000,
|
|
193
|
+
"max_staking_time_blocks": 64000,
|
|
194
|
+
"slashing_pk_script": "ABRb4SYk0IorQkCV18ByIcM0UNFL8Q==",
|
|
195
|
+
"min_slashing_tx_fee_sat": "6000",
|
|
196
|
+
"slashing_rate": "0.050000000000000000",
|
|
197
|
+
"unbonding_time_blocks": 1008,
|
|
198
|
+
"unbonding_fee_sat": "2000",
|
|
199
|
+
"min_commission_rate": "0.030000000000000000",
|
|
200
|
+
"delegation_creation_base_gas_fee": "1095000",
|
|
201
|
+
"allow_list_expiration_height": "26124",
|
|
202
|
+
"btc_activation_height": 235952
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
]
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import * as bitcoinjslib from 'bitcoinjs-lib';
|
|
2
|
+
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
3
|
+
import * as vendor from '@bitgo-beta/babylonlabs-io-btc-staking-ts';
|
|
4
|
+
export declare const mockBabylonProvider: vendor.BabylonProvider;
|
|
5
|
+
export declare function createStakingManager(network: bitcoinjslib.Network | utxolib.Network, btcProvider: vendor.BtcProvider, stakingParams?: vendor.VersionedStakingParams[], babylonProvider?: vendor.BabylonProvider): vendor.BabylonBtcStakingManager;
|
|
6
|
+
//# sourceMappingURL=stakingManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stakingManager.d.ts","sourceRoot":"","sources":["../../../src/babylon/stakingManager.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,YAAY,MAAM,eAAe,CAAC;AAC9C,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,KAAK,MAAM,MAAM,2CAA2C,CAAC;AAIpE,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,eAIxC,CAAC;AAEF,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,YAAY,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,EAC/C,WAAW,EAAE,MAAM,CAAC,WAAW,EAC/B,aAAa,CAAC,EAAE,MAAM,CAAC,sBAAsB,EAAE,EAC/C,eAAe,yBAAsB,GACpC,MAAM,CAAC,wBAAwB,CAsBjC"}
|