@bitgo-beta/utxo-staking 1.1.1-beta.284 → 1.1.1-beta.286
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.
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delegationMessage.d.ts","sourceRoot":"","sources":["../../../src/babylon/delegationMessage.ts"],"names":[],"mappings":"AAMA,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;
|
|
1
|
+
{"version":3,"file":"delegationMessage.d.ts","sourceRoot":"","sources":["../../../src/babylon/delegationMessage.ts"],"names":[],"mappings":"AAMA,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;AAkChE,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,CA+EpB;AACD,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"}
|
|
@@ -57,6 +57,36 @@ const descriptor_1 = require("@bitgo-beta/utxo-core/descriptor");
|
|
|
57
57
|
const stakingManager_1 = require("./stakingManager");
|
|
58
58
|
const stakingParams_1 = require("./stakingParams");
|
|
59
59
|
const network_1 = require("./network");
|
|
60
|
+
/**
|
|
61
|
+
* Decode a hex or base64 encoded string and check if the length is valid.
|
|
62
|
+
* @param v
|
|
63
|
+
* @param encoding
|
|
64
|
+
*/
|
|
65
|
+
function decodeCheck(v, encoding) {
|
|
66
|
+
const result = Buffer.from(v, encoding);
|
|
67
|
+
if (result.toString(encoding).length !== v.length) {
|
|
68
|
+
throw new Error(`Invalid ${encoding} encoding`);
|
|
69
|
+
}
|
|
70
|
+
return result;
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Convert a Buffer or string to a base64 encoded string.
|
|
74
|
+
* @param v
|
|
75
|
+
*/
|
|
76
|
+
function toBase64(v) {
|
|
77
|
+
if (typeof v === 'string') {
|
|
78
|
+
for (const encoding of ['base64', 'hex']) {
|
|
79
|
+
try {
|
|
80
|
+
return toBase64(decodeCheck(v, encoding));
|
|
81
|
+
}
|
|
82
|
+
catch (e) {
|
|
83
|
+
// try next
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
throw new Error(`Invalid base64 or hex encoding: ${v}`);
|
|
87
|
+
}
|
|
88
|
+
return v.toString('base64');
|
|
89
|
+
}
|
|
60
90
|
function getSignedPsbt(psbt, descriptor, signers, { finalize = false }) {
|
|
61
91
|
const wrappedPsbt = (0, descriptor_1.toWrappedPsbt)(psbt.toBuffer());
|
|
62
92
|
const signedInputs = psbt.data.inputs.flatMap((input, i) => {
|
|
@@ -124,13 +154,19 @@ function getBtcProviderForECKey(descriptorBuilder, stakerKey) {
|
|
|
124
154
|
return bip322_js_1.BIP322.encodeWitness(bitcoinjslib.Psbt.fromBuffer(Buffer.from(wrappedPsbt.serialize())));
|
|
125
155
|
}
|
|
126
156
|
return {
|
|
157
|
+
/**
|
|
158
|
+
* @param signingStep
|
|
159
|
+
* @param message
|
|
160
|
+
* @param type
|
|
161
|
+
* @returns Base64 encoded string
|
|
162
|
+
*/
|
|
127
163
|
async signMessage(signingStep, message, type) {
|
|
128
164
|
(0, assert_1.default)(signingStep === 'proof-of-possession');
|
|
129
165
|
switch (type) {
|
|
130
166
|
case 'ecdsa':
|
|
131
|
-
return stakerKey.sign(Buffer.from(message, 'hex'))
|
|
167
|
+
return toBase64(stakerKey.sign(Buffer.from(message, 'hex')));
|
|
132
168
|
case 'bip322-simple':
|
|
133
|
-
return signBip322Simple(message);
|
|
169
|
+
return toBase64(signBip322Simple(message));
|
|
134
170
|
default:
|
|
135
171
|
throw new Error(`unexpected signing step: ${signingStep}`);
|
|
136
172
|
}
|
|
@@ -216,4 +252,4 @@ async function createUnsignedPreStakeRegistrationBabylonTransactionWithBtcProvid
|
|
|
216
252
|
const unsignedDelegationMsg = await createDelegationMessageWithTransaction(manager, staking, stakingInput.stakingAmountSat, transaction, babylonAddress);
|
|
217
253
|
return { unsignedDelegationMsg, stakingTx: transaction };
|
|
218
254
|
}
|
|
219
|
-
//# 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 { BIP322 } from 'bip322-js';\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 { signWithKey, 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  function signBip322Simple(message: string): string {\n    // Get the script public key from the staking descriptor\n    const scriptPubKey = Buffer.from(descriptorBuilder.getStakingDescriptor().scriptPubkey());\n    const toSpendTx = BIP322.buildToSpendTx(message, scriptPubKey);\n\n    // Get the to_spend txid\n    const toSpendTxId = toSpendTx.getId();\n\n    // Create PSBT object for constructing the transaction\n    const toSignPsbt = new bitcoinjslib.Psbt();\n    toSignPsbt.setVersion(2); // nVersion = 0\n    toSignPsbt.setLocktime(0); // nLockTime = 0\n    toSignPsbt.addInput({\n      hash: toSpendTxId,\n      index: 0,\n      sequence: descriptorBuilder.stakingTimeLock,\n      witnessUtxo: {\n        script: scriptPubKey,\n        value: 0,\n      },\n    });\n\n    // Sign the PSBT with the staker key\n    const wrappedPsbt = toWrappedPsbt(toSignPsbt.toBuffer());\n    wrappedPsbt.updateInputWithDescriptor(0, descriptorBuilder.getStakingDescriptor());\n    signWithKey(wrappedPsbt, stakerKey);\n    wrappedPsbt.finalize();\n\n    // Encode the witness data and return\n    return BIP322.encodeWitness(bitcoinjslib.Psbt.fromBuffer(Buffer.from(wrappedPsbt.serialize())));\n  }\n\n  return {\n    async signMessage(\n      signingStep: vendor.SigningStep,\n      message: string,\n      type: 'ecdsa' | 'bip322-simple'\n    ): Promise<string> {\n      assert(signingStep === 'proof-of-possession');\n      switch (type) {\n        case 'ecdsa':\n          return stakerKey.sign(Buffer.from(message, 'hex')).toString('hex');\n        case 'bip322-simple':\n          return signBip322Simple(message);\n        default:\n          throw new Error(`unexpected signing step: ${signingStep}`);\n      }\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}\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"]}
|
|
255
|
+
//# 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 { BIP322 } from 'bip322-js';\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 { signWithKey, 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\n/**\n * Decode a hex or base64 encoded string and check if the length is valid.\n * @param v\n * @param encoding\n */\nfunction decodeCheck(v: string, encoding: 'hex' | 'base64') {\n  const result = Buffer.from(v, encoding);\n  if (result.toString(encoding).length !== v.length) {\n    throw new Error(`Invalid ${encoding} encoding`);\n  }\n  return result;\n}\n\n/**\n * Convert a Buffer or string to a base64 encoded string.\n * @param v\n */\nfunction toBase64(v: Buffer | string) {\n  if (typeof v === 'string') {\n    for (const encoding of ['base64', 'hex'] as const) {\n      try {\n        return toBase64(decodeCheck(v, encoding));\n      } catch (e) {\n        // try next\n      }\n    }\n    throw new Error(`Invalid base64 or hex encoding: ${v}`);\n  }\n\n  return v.toString('base64');\n}\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  function signBip322Simple(message: string): string {\n    // Get the script public key from the staking descriptor\n    const scriptPubKey = Buffer.from(descriptorBuilder.getStakingDescriptor().scriptPubkey());\n    const toSpendTx = BIP322.buildToSpendTx(message, scriptPubKey);\n\n    // Get the to_spend txid\n    const toSpendTxId = toSpendTx.getId();\n\n    // Create PSBT object for constructing the transaction\n    const toSignPsbt = new bitcoinjslib.Psbt();\n    toSignPsbt.setVersion(2); // nVersion = 0\n    toSignPsbt.setLocktime(0); // nLockTime = 0\n    toSignPsbt.addInput({\n      hash: toSpendTxId,\n      index: 0,\n      sequence: descriptorBuilder.stakingTimeLock,\n      witnessUtxo: {\n        script: scriptPubKey,\n        value: 0,\n      },\n    });\n\n    // Sign the PSBT with the staker key\n    const wrappedPsbt = toWrappedPsbt(toSignPsbt.toBuffer());\n    wrappedPsbt.updateInputWithDescriptor(0, descriptorBuilder.getStakingDescriptor());\n    signWithKey(wrappedPsbt, stakerKey);\n    wrappedPsbt.finalize();\n\n    // Encode the witness data and return\n    return BIP322.encodeWitness(bitcoinjslib.Psbt.fromBuffer(Buffer.from(wrappedPsbt.serialize())));\n  }\n\n  return {\n    /**\n     * @param signingStep\n     * @param message\n     * @param type\n     * @returns Base64 encoded string\n     */\n    async signMessage(\n      signingStep: vendor.SigningStep,\n      message: string,\n      type: 'ecdsa' | 'bip322-simple'\n    ): Promise<string> {\n      assert(signingStep === 'proof-of-possession');\n      switch (type) {\n        case 'ecdsa':\n          return toBase64(stakerKey.sign(Buffer.from(message, 'hex')));\n        case 'bip322-simple':\n          return toBase64(signBip322Simple(message));\n        default:\n          throw new Error(`unexpected signing step: ${signingStep}`);\n      }\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}\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"]}
|
|
@@ -1 +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;
|
|
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;AA4EpE,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,CAiBjC"}
|
|
@@ -38,7 +38,58 @@ exports.createStakingManager = createStakingManager;
|
|
|
38
38
|
const bitcoinjslib = __importStar(require("bitcoinjs-lib"));
|
|
39
39
|
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
40
40
|
const vendor = __importStar(require("@bitgo-beta/babylonlabs-io-btc-staking-ts"));
|
|
41
|
+
const pop_1 = require("@babylonlabs-io/babylon-proto-ts/dist/generated/babylon/btcstaking/v1/pop");
|
|
41
42
|
const stakingParams_1 = require("./stakingParams");
|
|
43
|
+
/**
|
|
44
|
+
* Subclass of BabylonBtcStakingManager with the sole purpose of forcing
|
|
45
|
+
* a ECDSA signature.
|
|
46
|
+
*/
|
|
47
|
+
class BitGoStakingManager extends vendor.BabylonBtcStakingManager {
|
|
48
|
+
constructor(network, stakingParams, btcProvider, babylonProvider) {
|
|
49
|
+
super(network, stakingParams, btcProvider, babylonProvider);
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Creates a proof of possession for the staker based on ECDSA signature.
|
|
53
|
+
*
|
|
54
|
+
* This is a parameterized version of the superclass method which infers
|
|
55
|
+
* the signature type from the stakerBtcAddress.
|
|
56
|
+
*
|
|
57
|
+
* @param bech32Address - The staker's bech32 address on the babylon network.
|
|
58
|
+
* @param stakerBtcAddress - The staker's BTC address.
|
|
59
|
+
* @param sigType - The signature type (BIP322 or ECDSA).
|
|
60
|
+
* @returns The proof of possession.
|
|
61
|
+
*/
|
|
62
|
+
async createProofOfPossessionWithSigType(bech32Address, stakerBtcAddress, sigType) {
|
|
63
|
+
const signedBabylonAddress = await this.btcProvider.signMessage(vendor.SigningStep.PROOF_OF_POSSESSION, bech32Address, sigType === pop_1.BTCSigType.BIP322 ? 'bip322-simple' : 'ecdsa');
|
|
64
|
+
let btcSig;
|
|
65
|
+
if (sigType === pop_1.BTCSigType.BIP322) {
|
|
66
|
+
const bip322Sig = pop_1.BIP322Sig.fromPartial({
|
|
67
|
+
address: stakerBtcAddress,
|
|
68
|
+
sig: Buffer.from(signedBabylonAddress, 'base64'),
|
|
69
|
+
});
|
|
70
|
+
// Encode the BIP322 protobuf message to a Uint8Array
|
|
71
|
+
btcSig = pop_1.BIP322Sig.encode(bip322Sig).finish();
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
// Encode the ECDSA signature to a Uint8Array
|
|
75
|
+
btcSig = Buffer.from(signedBabylonAddress, 'base64');
|
|
76
|
+
}
|
|
77
|
+
return {
|
|
78
|
+
btcSigType: sigType,
|
|
79
|
+
btcSig,
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Creates a proof of possession for the staker based on ECDSA signature.
|
|
84
|
+
* @param bech32Address - The staker's bech32 address on the babylon network.
|
|
85
|
+
* @param stakerBtcAddress
|
|
86
|
+
* @returns The proof of possession.
|
|
87
|
+
*/
|
|
88
|
+
async createProofOfPossession(bech32Address, stakerBtcAddress) {
|
|
89
|
+
// force the ECDSA signature type
|
|
90
|
+
return this.createProofOfPossessionWithSigType(bech32Address, stakerBtcAddress, pop_1.BTCSigType.ECDSA);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
42
93
|
exports.mockBabylonProvider = {
|
|
43
94
|
signTransaction() {
|
|
44
95
|
throw new Error('Function not implemented.');
|
|
@@ -60,6 +111,6 @@ function createStakingManager(network, btcProvider, stakingParams, babylonProvid
|
|
|
60
111
|
throw new Error('Unsupported network');
|
|
61
112
|
}
|
|
62
113
|
}
|
|
63
|
-
return new
|
|
114
|
+
return new BitGoStakingManager(network, stakingParams ?? (0, stakingParams_1.getStakingParams)(network), btcProvider, babylonProvider);
|
|
64
115
|
}
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Rha2luZ01hbmFnZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmFieWxvbi9zdGFraW5nTWFuYWdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFvRkEsb0RBc0JDO0FBMUdELDREQUE4QztBQUM5Qyw4REFBZ0Q7QUFDaEQsa0ZBQW9FO0FBQ3BFLG1HQUltRjtBQUVuRixtREFBbUQ7QUFFbkQ7OztHQUdHO0FBQ0gsTUFBTSxtQkFBb0IsU0FBUSxNQUFNLENBQUMsd0JBQXdCO0lBQy9ELFlBQ0UsT0FBNkIsRUFDN0IsYUFBOEMsRUFDOUMsV0FBK0IsRUFDL0IsZUFBdUM7UUFFdkMsS0FBSyxDQUFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsV0FBVyxFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRDs7Ozs7Ozs7OztPQVVHO0lBQ0gsS0FBSyxDQUFDLGtDQUFrQyxDQUN0QyxhQUFxQixFQUNyQixnQkFBd0IsRUFDeEIsT0FBbUI7UUFFbkIsTUFBTSxvQkFBb0IsR0FBRyxNQUFNLElBQUksQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUM3RCxNQUFNLENBQUMsV0FBVyxDQUFDLG1CQUFtQixFQUN0QyxhQUFhLEVBQ2IsT0FBTyxLQUFLLGdCQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FDMUQsQ0FBQztRQUVGLElBQUksTUFBa0IsQ0FBQztRQUN2QixJQUFJLE9BQU8sS0FBSyxnQkFBVSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ2xDLE1BQU0sU0FBUyxHQUFHLGVBQVMsQ0FBQyxXQUFXLENBQUM7Z0JBQ3RDLE9BQU8sRUFBRSxnQkFBZ0I7Z0JBQ3pCLEdBQUcsRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLFFBQVEsQ0FBQzthQUNqRCxDQUFDLENBQUM7WUFDSCxxREFBcUQ7WUFDckQsTUFBTSxHQUFHLGVBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDaEQsQ0FBQzthQUFNLENBQUM7WUFDTiw2Q0FBNkM7WUFDN0MsTUFBTSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsb0JBQW9CLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDdkQsQ0FBQztRQUVELE9BQU87WUFDTCxVQUFVLEVBQUUsT0FBTztZQUNuQixNQUFNO1NBQ1AsQ0FBQztJQUNKLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILEtBQUssQ0FBQyx1QkFBdUIsQ0FBQyxhQUFxQixFQUFFLGdCQUF3QjtRQUMzRSxpQ0FBaUM7UUFDakMsT0FBTyxJQUFJLENBQUMsa0NBQWtDLENBQUMsYUFBYSxFQUFFLGdCQUFnQixFQUFFLGdCQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEcsQ0FBQztDQUNGO0FBRVksUUFBQSxtQkFBbUIsR0FBMkI7SUFDekQsZUFBZTtRQUNiLE1BQU0sSUFBSSxLQUFLLENBQUMsMkJBQTJCLENBQUMsQ0FBQztJQUMvQyxDQUFDO0NBQ0YsQ0FBQztBQUVGLFNBQWdCLG9CQUFvQixDQUNsQyxPQUErQyxFQUMvQyxXQUErQixFQUMvQixhQUErQyxFQUMvQyxlQUFlLEdBQUcsMkJBQW1CO0lBRXJDLElBQUksT0FBTyxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1FBQ3BDLFFBQVEsT0FBTyxFQUFFLENBQUM7WUFDaEIsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLE9BQU87Z0JBQzNCLE9BQU8sR0FBRyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQztnQkFDeEMsTUFBTTtZQUNSLEtBQUssT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUM7WUFDOUIsS0FBSyxPQUFPLENBQUMsUUFBUSxDQUFDLGVBQWU7Z0JBQ25DLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0VBQWdFLENBQUMsQ0FBQztZQUNwRixLQUFLLE9BQU8sQ0FBQyxRQUFRLENBQUMsbUJBQW1CO2dCQUN2QyxPQUFPLEdBQUcsWUFBWSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUM7Z0JBQ3hDLE1BQU07WUFDUjtnQkFDRSxNQUFNLElBQUksS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFDM0MsQ0FBQztJQUNILENBQUM7SUFDRCxPQUFPLElBQUksbUJBQW1CLENBQUMsT0FBTyxFQUFFLGFBQWEsSUFBSSxJQUFBLGdDQUFnQixFQUFDLE9BQU8sQ0FBQyxFQUFFLFdBQVcsRUFBRSxlQUFlLENBQUMsQ0FBQztBQUNwSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgYml0Y29pbmpzbGliIGZyb20gJ2JpdGNvaW5qcy1saWInO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgKiBhcyB2ZW5kb3IgZnJvbSAnQGJpdGdvLWJldGEvYmFieWxvbmxhYnMtaW8tYnRjLXN0YWtpbmctdHMnO1xuaW1wb3J0IHtcbiAgQklQMzIyU2lnLFxuICBCVENTaWdUeXBlLFxuICBQcm9vZk9mUG9zc2Vzc2lvbkJUQyxcbn0gZnJvbSAnQGJhYnlsb25sYWJzLWlvL2JhYnlsb24tcHJvdG8tdHMvZGlzdC9nZW5lcmF0ZWQvYmFieWxvbi9idGNzdGFraW5nL3YxL3BvcCc7XG5cbmltcG9ydCB7IGdldFN0YWtpbmdQYXJhbXMgfSBmcm9tICcuL3N0YWtpbmdQYXJhbXMnO1xuXG4vKipcbiAqIFN1YmNsYXNzIG9mIEJhYnlsb25CdGNTdGFraW5nTWFuYWdlciB3aXRoIHRoZSBzb2xlIHB1cnBvc2Ugb2YgZm9yY2luZ1xuICogYSBFQ0RTQSBzaWduYXR1cmUuXG4gKi9cbmNsYXNzIEJpdEdvU3Rha2luZ01hbmFnZXIgZXh0ZW5kcyB2ZW5kb3IuQmFieWxvbkJ0Y1N0YWtpbmdNYW5hZ2VyIHtcbiAgY29uc3RydWN0b3IoXG4gICAgbmV0d29yazogYml0Y29pbmpzbGliLk5ldHdvcmssXG4gICAgc3Rha2luZ1BhcmFtczogdmVuZG9yLlZlcnNpb25lZFN0YWtpbmdQYXJhbXNbXSxcbiAgICBidGNQcm92aWRlcjogdmVuZG9yLkJ0Y1Byb3ZpZGVyLFxuICAgIGJhYnlsb25Qcm92aWRlcjogdmVuZG9yLkJhYnlsb25Qcm92aWRlclxuICApIHtcbiAgICBzdXBlcihuZXR3b3JrLCBzdGFraW5nUGFyYW1zLCBidGNQcm92aWRlciwgYmFieWxvblByb3ZpZGVyKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgcHJvb2Ygb2YgcG9zc2Vzc2lvbiBmb3IgdGhlIHN0YWtlciBiYXNlZCBvbiBFQ0RTQSBzaWduYXR1cmUuXG4gICAqXG4gICAqIFRoaXMgaXMgYSBwYXJhbWV0ZXJpemVkIHZlcnNpb24gb2YgdGhlIHN1cGVyY2xhc3MgbWV0aG9kIHdoaWNoIGluZmVyc1xuICAgKiB0aGUgc2lnbmF0dXJlIHR5cGUgZnJvbSB0aGUgc3Rha2VyQnRjQWRkcmVzcy5cbiAgICpcbiAgICogQHBhcmFtIGJlY2gzMkFkZHJlc3MgLSBUaGUgc3Rha2VyJ3MgYmVjaDMyIGFkZHJlc3Mgb24gdGhlIGJhYnlsb24gbmV0d29yay5cbiAgICogQHBhcmFtIHN0YWtlckJ0Y0FkZHJlc3MgLSBUaGUgc3Rha2VyJ3MgQlRDIGFkZHJlc3MuXG4gICAqIEBwYXJhbSBzaWdUeXBlIC0gVGhlIHNpZ25hdHVyZSB0eXBlIChCSVAzMjIgb3IgRUNEU0EpLlxuICAgKiBAcmV0dXJucyBUaGUgcHJvb2Ygb2YgcG9zc2Vzc2lvbi5cbiAgICovXG4gIGFzeW5jIGNyZWF0ZVByb29mT2ZQb3NzZXNzaW9uV2l0aFNpZ1R5cGUoXG4gICAgYmVjaDMyQWRkcmVzczogc3RyaW5nLFxuICAgIHN0YWtlckJ0Y0FkZHJlc3M6IHN0cmluZyxcbiAgICBzaWdUeXBlOiBCVENTaWdUeXBlXG4gICk6IFByb21pc2U8UHJvb2ZPZlBvc3Nlc3Npb25CVEM+IHtcbiAgICBjb25zdCBzaWduZWRCYWJ5bG9uQWRkcmVzcyA9IGF3YWl0IHRoaXMuYnRjUHJvdmlkZXIuc2lnbk1lc3NhZ2UoXG4gICAgICB2ZW5kb3IuU2lnbmluZ1N0ZXAuUFJPT0ZfT0ZfUE9TU0VTU0lPTixcbiAgICAgIGJlY2gzMkFkZHJlc3MsXG4gICAgICBzaWdUeXBlID09PSBCVENTaWdUeXBlLkJJUDMyMiA/ICdiaXAzMjItc2ltcGxlJyA6ICdlY2RzYSdcbiAgICApO1xuXG4gICAgbGV0IGJ0Y1NpZzogVWludDhBcnJheTtcbiAgICBpZiAoc2lnVHlwZSA9PT0gQlRDU2lnVHlwZS5CSVAzMjIpIHtcbiAgICAgIGNvbnN0IGJpcDMyMlNpZyA9IEJJUDMyMlNpZy5mcm9tUGFydGlhbCh7XG4gICAgICAgIGFkZHJlc3M6IHN0YWtlckJ0Y0FkZHJlc3MsXG4gICAgICAgIHNpZzogQnVmZmVyLmZyb20oc2lnbmVkQmFieWxvbkFkZHJlc3MsICdiYXNlNjQnKSxcbiAgICAgIH0pO1xuICAgICAgLy8gRW5jb2RlIHRoZSBCSVAzMjIgcHJvdG9idWYgbWVzc2FnZSB0byBhIFVpbnQ4QXJyYXlcbiAgICAgIGJ0Y1NpZyA9IEJJUDMyMlNpZy5lbmNvZGUoYmlwMzIyU2lnKS5maW5pc2goKTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gRW5jb2RlIHRoZSBFQ0RTQSBzaWduYXR1cmUgdG8gYSBVaW50OEFycmF5XG4gICAgICBidGNTaWcgPSBCdWZmZXIuZnJvbShzaWduZWRCYWJ5bG9uQWRkcmVzcywgJ2Jhc2U2NCcpO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBidGNTaWdUeXBlOiBzaWdUeXBlLFxuICAgICAgYnRjU2lnLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIHByb29mIG9mIHBvc3Nlc3Npb24gZm9yIHRoZSBzdGFrZXIgYmFzZWQgb24gRUNEU0Egc2lnbmF0dXJlLlxuICAgKiBAcGFyYW0gYmVjaDMyQWRkcmVzcyAtIFRoZSBzdGFrZXIncyBiZWNoMzIgYWRkcmVzcyBvbiB0aGUgYmFieWxvbiBuZXR3b3JrLlxuICAgKiBAcGFyYW0gc3Rha2VyQnRjQWRkcmVzc1xuICAgKiBAcmV0dXJucyBUaGUgcHJvb2Ygb2YgcG9zc2Vzc2lvbi5cbiAgICovXG4gIGFzeW5jIGNyZWF0ZVByb29mT2ZQb3NzZXNzaW9uKGJlY2gzMkFkZHJlc3M6IHN0cmluZywgc3Rha2VyQnRjQWRkcmVzczogc3RyaW5nKTogUHJvbWlzZTxQcm9vZk9mUG9zc2Vzc2lvbkJUQz4ge1xuICAgIC8vIGZvcmNlIHRoZSBFQ0RTQSBzaWduYXR1cmUgdHlwZVxuICAgIHJldHVybiB0aGlzLmNyZWF0ZVByb29mT2ZQb3NzZXNzaW9uV2l0aFNpZ1R5cGUoYmVjaDMyQWRkcmVzcywgc3Rha2VyQnRjQWRkcmVzcywgQlRDU2lnVHlwZS5FQ0RTQSk7XG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IG1vY2tCYWJ5bG9uUHJvdmlkZXI6IHZlbmRvci5CYWJ5bG9uUHJvdmlkZXIgPSB7XG4gIHNpZ25UcmFuc2FjdGlvbigpOiBQcm9taXNlPFVpbnQ4QXJyYXk+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ0Z1bmN0aW9uIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfSxcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTdGFraW5nTWFuYWdlcihcbiAgbmV0d29yazogYml0Y29pbmpzbGliLk5ldHdvcmsgfCB1dHhvbGliLk5ldHdvcmssXG4gIGJ0Y1Byb3ZpZGVyOiB2ZW5kb3IuQnRjUHJvdmlkZXIsXG4gIHN0YWtpbmdQYXJhbXM/OiB2ZW5kb3IuVmVyc2lvbmVkU3Rha2luZ1BhcmFtc1tdLFxuICBiYWJ5bG9uUHJvdmlkZXIgPSBtb2NrQmFieWxvblByb3ZpZGVyXG4pOiB2ZW5kb3IuQmFieWxvbkJ0Y1N0YWtpbmdNYW5hZ2VyIHtcbiAgaWYgKHV0eG9saWIuaXNWYWxpZE5ldHdvcmsobmV0d29yaykpIHtcbiAgICBzd2l0Y2ggKG5ldHdvcmspIHtcbiAgICAgIGNhc2UgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luOlxuICAgICAgICBuZXR3b3JrID0gYml0Y29pbmpzbGliLm5ldHdvcmtzLmJpdGNvaW47XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSB1dHhvbGliLm5ldHdvcmtzLnRlc3RuZXQ6XG4gICAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuYml0Y29pblRlc3RuZXQ0OlxuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1Vuc3VwcG9ydGVkIGJpdGNvaW4gdGVzdG5ldCBuZXR3b3JrIC0gb25seSBzaWduZXQgaXMgc3VwcG9ydGVkJyk7XG4gICAgICBjYXNlIHV0eG9saWIubmV0d29ya3MuYml0Y29pblB1YmxpY1NpZ25ldDpcbiAgICAgICAgbmV0d29yayA9IGJpdGNvaW5qc2xpYi5uZXR3b3Jrcy50ZXN0bmV0O1xuICAgICAgICBicmVhaztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignVW5zdXBwb3J0ZWQgbmV0d29yaycpO1xuICAgIH1cbiAgfVxuICByZXR1cm4gbmV3IEJpdEdvU3Rha2luZ01hbmFnZXIobmV0d29yaywgc3Rha2luZ1BhcmFtcyA/PyBnZXRTdGFraW5nUGFyYW1zKG5ldHdvcmspLCBidGNQcm92aWRlciwgYmFieWxvblByb3ZpZGVyKTtcbn1cbiJdfQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/utxo-staking",
|
|
3
|
-
"version": "1.1.1-beta.
|
|
3
|
+
"version": "1.1.1-beta.286",
|
|
4
4
|
"description": "BitGo SDK for build UTXO staking transactions",
|
|
5
5
|
"main": "./dist/src/index.js",
|
|
6
6
|
"types": "./dist/src/index.d.ts",
|
|
@@ -43,10 +43,10 @@
|
|
|
43
43
|
},
|
|
44
44
|
"dependencies": {
|
|
45
45
|
"@babylonlabs-io/babylon-proto-ts": "1.0.0",
|
|
46
|
-
"@bitgo-beta/babylonlabs-io-btc-staking-ts": "0.4.0-beta.
|
|
47
|
-
"@bitgo-beta/unspents": "0.13.2-beta.
|
|
48
|
-
"@bitgo-beta/utxo-core": "1.0.0-beta.
|
|
49
|
-
"@bitgo-beta/utxo-lib": "8.0.3-beta.
|
|
46
|
+
"@bitgo-beta/babylonlabs-io-btc-staking-ts": "0.4.0-beta.90",
|
|
47
|
+
"@bitgo-beta/unspents": "0.13.2-beta.845",
|
|
48
|
+
"@bitgo-beta/utxo-core": "1.0.0-beta.156",
|
|
49
|
+
"@bitgo-beta/utxo-lib": "8.0.3-beta.846",
|
|
50
50
|
"@bitgo/wasm-miniscript": "2.0.0-beta.7",
|
|
51
51
|
"bip322-js": "^2.0.0",
|
|
52
52
|
"bitcoinjs-lib": "^6.1.7",
|
|
@@ -57,5 +57,5 @@
|
|
|
57
57
|
"devDependencies": {
|
|
58
58
|
"yargs": "^17.7.2"
|
|
59
59
|
},
|
|
60
|
-
"gitHead": "
|
|
60
|
+
"gitHead": "338716f7e5e55a11028a30007a97f93490670f70"
|
|
61
61
|
}
|