@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.
Files changed (39) hide show
  1. package/dist/src/babylon/delegationMessage.d.ts +22 -0
  2. package/dist/src/babylon/delegationMessage.d.ts.map +1 -0
  3. package/dist/src/babylon/delegationMessage.js +131 -0
  4. package/dist/src/babylon/descriptor.d.ts +28 -0
  5. package/dist/src/babylon/descriptor.d.ts.map +1 -0
  6. package/dist/src/babylon/descriptor.js +92 -0
  7. package/dist/src/babylon/index.d.ts +5 -0
  8. package/dist/src/babylon/index.d.ts.map +1 -0
  9. package/dist/src/babylon/index.js +21 -0
  10. package/dist/src/babylon/keyUtils.d.ts +3 -0
  11. package/dist/src/babylon/keyUtils.d.ts.map +1 -0
  12. package/dist/src/babylon/keyUtils.js +7 -0
  13. package/dist/src/babylon/params.mainnet.json +1 -0
  14. package/dist/src/babylon/params.testnet.json +205 -0
  15. package/dist/src/babylon/stakingManager.d.ts +6 -0
  16. package/dist/src/babylon/stakingManager.d.ts.map +1 -0
  17. package/dist/src/babylon/stakingManager.js +65 -0
  18. package/dist/src/babylon/stakingParams.d.ts +38 -0
  19. package/dist/src/babylon/stakingParams.d.ts.map +1 -0
  20. package/dist/src/babylon/stakingParams.js +145 -0
  21. package/dist/src/coreDao/descriptor.d.ts +4 -4
  22. package/dist/src/coreDao/descriptor.d.ts.map +1 -1
  23. package/dist/src/coreDao/descriptor.js +12 -5
  24. package/dist/src/coreDao/opReturn.d.ts +5 -5
  25. package/dist/src/coreDao/opReturn.d.ts.map +1 -1
  26. package/dist/src/coreDao/opReturn.js +19 -11
  27. package/dist/src/coreDao/transaction.d.ts +15 -8
  28. package/dist/src/coreDao/transaction.d.ts.map +1 -1
  29. package/dist/src/coreDao/transaction.js +13 -6
  30. package/dist/src/index.d.ts +1 -0
  31. package/dist/src/index.d.ts.map +1 -1
  32. package/dist/src/index.js +26 -3
  33. package/dist/src/transaction.d.ts +0 -2
  34. package/dist/src/transaction.d.ts.map +1 -1
  35. package/dist/src/transaction.js +36 -4
  36. package/package.json +19 -7
  37. package/.eslintignore +0 -5
  38. package/.mocharc.yml +0 -8
  39. 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,5 @@
1
+ export * from './delegationMessage';
2
+ export * from './descriptor';
3
+ export * from './stakingParams';
4
+ export * from './stakingManager';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -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,3 @@
1
+ import { ECPairInterface } from '@bitgo-beta/utxo-lib';
2
+ export declare function getXOnlyPubkey(key: ECPairInterface): Buffer;
3
+ //# sourceMappingURL=keyUtils.d.ts.map
@@ -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"}