@babylonlabs-io/ts-sdk 0.25.0 → 0.26.0
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/{buildAndBroadcastRefund-D7NCbgtv.js → buildAndBroadcastRefund-Ce5jAu-C.js} +146 -145
- package/dist/buildAndBroadcastRefund-Ce5jAu-C.js.map +1 -0
- package/dist/buildAndBroadcastRefund-IQ_2SCic.cjs +2 -0
- package/dist/buildAndBroadcastRefund-IQ_2SCic.cjs.map +1 -0
- package/dist/{errors-B3TOmE31.cjs → errors-B3DbZYLe.cjs} +2 -2
- package/dist/{errors-B3TOmE31.cjs.map → errors-B3DbZYLe.cjs.map} +1 -1
- package/dist/{errors-rJcuN2m_.js → errors-Ul7fTCjl.js} +4 -4
- package/dist/{errors-rJcuN2m_.js.map → errors-Ul7fTCjl.js.map} +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +4 -4
- package/dist/{psbtInputFields-r1ss6WLU.js → psbtInputFields-1dXR4hLk.js} +2 -2
- package/dist/{psbtInputFields-r1ss6WLU.js.map → psbtInputFields-1dXR4hLk.js.map} +1 -1
- package/dist/{psbtInputFields-05ZrwRzf.cjs → psbtInputFields-tnAR8tG5.cjs} +2 -2
- package/dist/{psbtInputFields-05ZrwRzf.cjs.map → psbtInputFields-tnAR8tG5.cjs.map} +1 -1
- package/dist/shared/index.cjs.map +1 -1
- package/dist/shared/index.js.map +1 -1
- package/dist/shared/wallets/interfaces/BitcoinWallet.d.ts +17 -1
- package/dist/shared/wallets/interfaces/BitcoinWallet.d.ts.map +1 -1
- package/dist/{signing-DeWVBl7m.js → signing-BZigafm0.js} +2 -2
- package/dist/{signing-DeWVBl7m.js.map → signing-BZigafm0.js.map} +1 -1
- package/dist/{signing-cl-lowxV.cjs → signing-DHSXjhLM.cjs} +2 -2
- package/dist/{signing-cl-lowxV.cjs.map → signing-DHSXjhLM.cjs.map} +1 -1
- package/dist/tbv/core/index.cjs +1 -1
- package/dist/tbv/core/index.js +4 -4
- package/dist/tbv/core/services/index.cjs +1 -1
- package/dist/tbv/core/services/index.js +2 -2
- package/dist/tbv/core/utils/index.cjs +1 -1
- package/dist/tbv/core/utils/index.js +2 -2
- package/dist/tbv/core/utils/signing.d.ts +1 -1
- package/dist/tbv/index.cjs +1 -1
- package/dist/tbv/index.js +4 -4
- package/package.json +1 -1
- package/dist/buildAndBroadcastRefund-BDGGbGeK.cjs +0 -2
- package/dist/buildAndBroadcastRefund-BDGGbGeK.cjs.map +0 -1
- package/dist/buildAndBroadcastRefund-D7NCbgtv.js.map +0 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var l=(e=>(e[e.PENDING=0]="PENDING",e[e.VERIFIED=1]="VERIFIED",e[e.ACTIVE=2]="ACTIVE",e[e.REDEEMED=3]="REDEEMED",e[e.LIQUIDATED=4]="LIQUIDATED",e[e.INVALID=5]="INVALID",e[e.DEPOSITOR_WITHDRAWN=6]="DEPOSITOR_WITHDRAWN",e[e.EXPIRED=7]="EXPIRED",e))(l||{}),
|
|
2
|
-
//# sourceMappingURL=signing-
|
|
1
|
+
"use strict";var l=(e=>(e[e.PENDING=0]="PENDING",e[e.VERIFIED=1]="VERIFIED",e[e.ACTIVE=2]="ACTIVE",e[e.REDEEMED=3]="REDEEMED",e[e.LIQUIDATED=4]="LIQUIDATED",e[e.INVALID=5]="INVALID",e[e.DEPOSITOR_WITHDRAWN=6]="DEPOSITOR_WITHDRAWN",e[e.EXPIRED=7]="EXPIRED",e))(l||{}),E=(e=>(e.SUBMIT_WOTS_KEY="SUBMIT_WOTS_KEY",e.SIGN_PAYOUT_TRANSACTIONS="SIGN_PAYOUT_TRANSACTIONS",e.SIGN_AND_BROADCAST_TO_BITCOIN="SIGN_AND_BROADCAST_TO_BITCOIN",e.ACTIVATE_VAULT="ACTIVATE_VAULT",e.REFUND_HTLC="REFUND_HTLC",e))(E||{});function N(e,i={}){const{transactionsReady:A,needsWotsKey:T,pendingIngestion:I,canRefund:r,hasProviderTerminalFailure:_}=i;return e===0?_?{contractStatus:e,availableActions:[]}:T?{contractStatus:e,availableActions:["SUBMIT_WOTS_KEY"]}:I===!0&&!A?{contractStatus:e,availableActions:["SIGN_AND_BROADCAST_TO_BITCOIN"]}:I===void 0&&!A?{contractStatus:e,availableActions:[]}:A?{contractStatus:e,availableActions:["SIGN_PAYOUT_TRANSACTIONS"]}:{contractStatus:e,availableActions:[]}:e===1?{contractStatus:e,availableActions:["ACTIVATE_VAULT"]}:e===2?{contractStatus:e,availableActions:[]}:e===3?{contractStatus:e,availableActions:[]}:e===4?{contractStatus:e,availableActions:[]}:e===7?{contractStatus:e,availableActions:r?["REFUND_HTLC"]:[]}:e===5?{contractStatus:e,availableActions:[]}:e===6?{contractStatus:e,availableActions:[]}:{contractStatus:e,availableActions:[]}}function D(e,i){return e.availableActions.includes(i)}function n(e,i){if(!Number.isInteger(i)||i<1)throw new Error(`inputCount must be a positive integer, got ${i}`);return{autoFinalized:!1,signInputs:Array.from({length:i},(A,T)=>({index:T,publicKey:e,useTweakedSigner:!1}))}}exports.ContractStatus=l;exports.PeginAction=E;exports.canPerformAction=D;exports.createTaprootScriptPathSignOptions=n;exports.getPeginProtocolState=N;
|
|
2
|
+
//# sourceMappingURL=signing-DHSXjhLM.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signing-
|
|
1
|
+
{"version":3,"file":"signing-DHSXjhLM.cjs","sources":["../src/tbv/core/services/deposit/peginState.ts","../src/tbv/core/utils/signing.ts"],"sourcesContent":["// ============================================================================\n// State Definitions\n// ============================================================================\n\n/**\n * Vault status — combines on-chain contract status (0-4) with indexer-derived\n * statuses (5-7). The contract enum (BTCVaultRegistry.sol BTCVaultStatus) only\n * has: Pending(0), Verified(1), Active(2), Redeemed(3), Expired(4).\n * The indexer maps these and adds extra statuses for UI display.\n *\n * IMPORTANT: With the new contract architecture:\n * - Core vault status (BTCVaultRegistry) does NOT change when used by applications\n * - Vaults remain at ACTIVE status even when used in DeFi positions\n * - Application usage status is tracked separately by each integration controller\n */\nexport enum ContractStatus {\n /** Status 0: Request submitted, waiting for ACKs */\n PENDING = 0,\n /** Status 1: All ACKs collected, ready for secret activation */\n VERIFIED = 1,\n /** Status 2: HTLC secret revealed, vault is active and usable (stays here even when used by apps) */\n ACTIVE = 2,\n /** Status 3: Vault has been redeemed, BTC is claimable */\n REDEEMED = 3,\n /** Status 4 (indexer-only): Vault was liquidated (collateral seized due to unpaid debt) */\n LIQUIDATED = 4,\n /** Status 5 (indexer-only): Vault is invalid — BTC UTXOs were spent in a different transaction */\n INVALID = 5,\n /** Status 6 (indexer-only): Depositor has withdrawn their BTC (redemption complete) */\n DEPOSITOR_WITHDRAWN = 6,\n /** Status 7 (indexer-only): Vault expired due to AckTimeout or ActivationTimeout */\n EXPIRED = 7,\n}\n\n/** Reason why a vault expired */\nexport type ExpirationReason =\n | \"ack_timeout\"\n | \"proof_timeout\"\n | \"activation_timeout\";\n\n// ============================================================================\n// Protocol State Model\n// ============================================================================\n\n/**\n * Available actions user can take\n */\nexport enum PeginAction {\n /** Submit WOTS key (re-enter mnemonic) */\n SUBMIT_WOTS_KEY = \"SUBMIT_WOTS_KEY\",\n /** Sign payout transactions */\n SIGN_PAYOUT_TRANSACTIONS = \"SIGN_PAYOUT_TRANSACTIONS\",\n /** Sign and broadcast peg-in transaction to Bitcoin */\n SIGN_AND_BROADCAST_TO_BITCOIN = \"SIGN_AND_BROADCAST_TO_BITCOIN\",\n /** Reveal HTLC secret on Ethereum to activate vault */\n ACTIVATE_VAULT = \"ACTIVATE_VAULT\",\n /** Sign and broadcast HTLC refund transaction for an expired vault */\n REFUND_HTLC = \"REFUND_HTLC\",\n}\n\n/**\n * Protocol-level peg-in state (framework-agnostic)\n */\nexport interface PeginProtocolState {\n /** Smart contract status (source of truth for on-chain state) */\n contractStatus: ContractStatus;\n /** Available user actions (empty array when no action is available) */\n availableActions: PeginAction[];\n}\n\n/**\n * Options for getPeginProtocolState function.\n *\n * All fields represent protocol-level state from the vault provider or\n * on-chain contracts. Client-side tracking (localStorage, polling state)\n * is NOT included — consumers handle that in their own layer.\n */\nexport interface GetPeginProtocolStateOptions {\n /** Whether claim/payout transactions are ready from VP */\n transactionsReady?: boolean;\n /** Whether the vault provider is waiting for the depositor's WOTS public key */\n needsWotsKey?: boolean;\n /** Whether the vault provider hasn't ingested this peg-in yet */\n pendingIngestion?: boolean;\n /** Whether the depositor can refund the HTLC (Pre-PegIn tx available) */\n canRefund?: boolean;\n /** Whether the vault provider reported a terminal failure */\n hasProviderTerminalFailure?: boolean;\n}\n\n// ============================================================================\n// State Machine Logic\n// ============================================================================\n\n/**\n * Determine the current protocol state and available actions based on contract\n * status and vault provider state. Framework-agnostic: returns only\n * protocol-level data with no display labels, messages, or UI concerns.\n *\n * Client-side tracking overrides (e.g. suppressing actions after the user\n * has already acted but on-chain state hasn't caught up) are the caller's\n * responsibility.\n *\n * @param contractStatus - On-chain contract status (source of truth)\n * @param options - Vault provider state\n * @returns Protocol state with available actions\n */\nexport function getPeginProtocolState(\n contractStatus: ContractStatus,\n options: GetPeginProtocolStateOptions = {},\n): PeginProtocolState {\n const {\n transactionsReady,\n needsWotsKey,\n pendingIngestion,\n canRefund,\n hasProviderTerminalFailure,\n } = options;\n\n if (contractStatus === ContractStatus.PENDING) {\n if (hasProviderTerminalFailure) {\n return { contractStatus, availableActions: [] };\n }\n\n if (needsWotsKey) {\n return {\n contractStatus,\n availableActions: [PeginAction.SUBMIT_WOTS_KEY],\n };\n }\n\n if (pendingIngestion === true && !transactionsReady) {\n return {\n contractStatus,\n availableActions: [PeginAction.SIGN_AND_BROADCAST_TO_BITCOIN],\n };\n }\n\n if (pendingIngestion === undefined && !transactionsReady) {\n return { contractStatus, availableActions: [] };\n }\n\n if (!transactionsReady) {\n return { contractStatus, availableActions: [] };\n }\n\n return {\n contractStatus,\n availableActions: [PeginAction.SIGN_PAYOUT_TRANSACTIONS],\n };\n }\n\n if (contractStatus === ContractStatus.VERIFIED) {\n return {\n contractStatus,\n availableActions: [PeginAction.ACTIVATE_VAULT],\n };\n }\n\n if (contractStatus === ContractStatus.ACTIVE) {\n return { contractStatus, availableActions: [] };\n }\n\n if (contractStatus === ContractStatus.REDEEMED) {\n return { contractStatus, availableActions: [] };\n }\n\n if (contractStatus === ContractStatus.LIQUIDATED) {\n return { contractStatus, availableActions: [] };\n }\n\n if (contractStatus === ContractStatus.EXPIRED) {\n return {\n contractStatus,\n availableActions: canRefund ? [PeginAction.REFUND_HTLC] : [],\n };\n }\n\n if (contractStatus === ContractStatus.INVALID) {\n return { contractStatus, availableActions: [] };\n }\n\n if (contractStatus === ContractStatus.DEPOSITOR_WITHDRAWN) {\n return { contractStatus, availableActions: [] };\n }\n\n return { contractStatus, availableActions: [] };\n}\n\n/**\n * Check if a specific action is available in the current state\n */\nexport function canPerformAction(\n state: PeginProtocolState,\n action: PeginAction,\n): boolean {\n return state.availableActions.includes(action);\n}\n","import type { SignPsbtOptions } from \"../../../shared/wallets/interfaces\";\n\n/**\n * Create SignPsbtOptions for Taproot script-path PSBT signing.\n *\n * All vault protocol signing operations are Taproot script-path spends that\n * require `useTweakedSigner: false` (untweaked key) and `autoFinalized: false`\n * (to preserve tapScriptSig for Schnorr signature extraction).\n *\n * @param publicKey - Signer's BTC public key (hex). Accepts both compressed\n * (66-char) and x-only (64-char) formats — the wallet connector handles both.\n * @param inputCount - Number of inputs to sign. Generates entries\n * for indices 0 through inputCount-1.\n */\nexport function createTaprootScriptPathSignOptions(\n publicKey: string,\n inputCount: number,\n): SignPsbtOptions {\n if (!Number.isInteger(inputCount) || inputCount < 1) {\n throw new Error(`inputCount must be a positive integer, got ${inputCount}`);\n }\n\n return {\n autoFinalized: false,\n signInputs: Array.from({ length: inputCount }, (_, i) => ({\n index: i,\n publicKey,\n useTweakedSigner: false,\n })),\n };\n}\n"],"names":["ContractStatus","PeginAction","getPeginProtocolState","contractStatus","options","transactionsReady","needsWotsKey","pendingIngestion","canRefund","hasProviderTerminalFailure","canPerformAction","state","action","createTaprootScriptPathSignOptions","publicKey","inputCount","_","i"],"mappings":"aAeO,IAAKA,GAAAA,IAEVA,EAAAA,EAAA,QAAU,CAAA,EAAV,UAEAA,EAAAA,EAAA,SAAW,CAAA,EAAX,WAEAA,EAAAA,EAAA,OAAS,CAAA,EAAT,SAEAA,EAAAA,EAAA,SAAW,CAAA,EAAX,WAEAA,EAAAA,EAAA,WAAa,CAAA,EAAb,aAEAA,EAAAA,EAAA,QAAU,CAAA,EAAV,UAEAA,EAAAA,EAAA,oBAAsB,CAAA,EAAtB,sBAEAA,EAAAA,EAAA,QAAU,CAAA,EAAV,UAhBUA,IAAAA,GAAA,CAAA,CAAA,EAgCAC,GAAAA,IAEVA,EAAA,gBAAkB,kBAElBA,EAAA,yBAA2B,2BAE3BA,EAAA,8BAAgC,gCAEhCA,EAAA,eAAiB,iBAEjBA,EAAA,YAAc,cAVJA,IAAAA,GAAA,CAAA,CAAA,EA4DL,SAASC,EACdC,EACAC,EAAwC,GACpB,CACpB,KAAM,CACJ,kBAAAC,EACA,aAAAC,EACA,iBAAAC,EACA,UAAAC,EACA,2BAAAC,CAAA,EACEL,EAEJ,OAAID,IAAmB,EACjBM,EACK,CAAE,eAAAN,EAAgB,iBAAkB,EAAC,EAG1CG,EACK,CACL,eAAAH,EACA,iBAAkB,CAAC,iBAAA,CAA2B,EAI9CI,IAAqB,IAAQ,CAACF,EACzB,CACL,eAAAF,EACA,iBAAkB,CAAC,+BAAA,CAAyC,EAI5DI,IAAqB,QAAa,CAACF,EAC9B,CAAE,eAAAF,EAAgB,iBAAkB,EAAC,EAGzCE,EAIE,CACL,eAAAF,EACA,iBAAkB,CAAC,0BAAA,CAAoC,EALhD,CAAE,eAAAA,EAAgB,iBAAkB,EAAC,EAS5CA,IAAmB,EACd,CACL,eAAAA,EACA,iBAAkB,CAAC,gBAAA,CAA0B,EAI7CA,IAAmB,EACd,CAAE,eAAAA,EAAgB,iBAAkB,EAAC,EAG1CA,IAAmB,EACd,CAAE,eAAAA,EAAgB,iBAAkB,EAAC,EAG1CA,IAAmB,EACd,CAAE,eAAAA,EAAgB,iBAAkB,EAAC,EAG1CA,IAAmB,EACd,CACL,eAAAA,EACA,iBAAkBK,EAAY,CAAC,eAA2B,CAAA,CAAC,EAI3DL,IAAmB,EACd,CAAE,eAAAA,EAAgB,iBAAkB,EAAC,EAG1CA,IAAmB,EACd,CAAE,eAAAA,EAAgB,iBAAkB,EAAC,EAGvC,CAAE,eAAAA,EAAgB,iBAAkB,EAAC,CAC9C,CAKO,SAASO,EACdC,EACAC,EACS,CACT,OAAOD,EAAM,iBAAiB,SAASC,CAAM,CAC/C,CCvLO,SAASC,EACdC,EACAC,EACiB,CACjB,GAAI,CAAC,OAAO,UAAUA,CAAU,GAAKA,EAAa,EAChD,MAAM,IAAI,MAAM,8CAA8CA,CAAU,EAAE,EAG5E,MAAO,CACL,cAAe,GACf,WAAY,MAAM,KAAK,CAAE,OAAQA,GAAc,CAACC,EAAGC,KAAO,CACxD,MAAOA,EACP,UAAAH,EACA,iBAAkB,EAAA,EAClB,CAAA,CAEN"}
|
package/dist/tbv/core/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("../../challengeAssert-X7V3Ik_Q.cjs"),c=require("@babylonlabs-io/babylon-tbv-rust-wasm"),P=require("../../payout-RFIh7GLN.cjs"),o=require("../../bitcoin-CNnPFU6Y.cjs"),l=require("../../signing-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("../../challengeAssert-X7V3Ik_Q.cjs"),c=require("@babylonlabs-io/babylon-tbv-rust-wasm"),P=require("../../payout-RFIh7GLN.cjs"),o=require("../../bitcoin-CNnPFU6Y.cjs"),l=require("../../signing-DHSXjhLM.cjs"),u=require("../../validation-u8W7Lp2x.cjs"),e=require("../../buildAndBroadcastRefund-IQ_2SCic.cjs"),r=require("../../fundPeginTransaction-DxNOeyNI.cjs"),i=require("../../psbtInputFields-tnAR8tG5.cjs"),a=require("../../errors-B3DbZYLe.cjs"),t=require("../../index-BAECy2oz.cjs"),s=require("../../types-B-p4dhEH.cjs");exports.buildChallengeAssertPsbt=n.buildChallengeAssertPsbt;exports.buildDepositorPayoutPsbt=n.buildDepositorPayoutPsbt;exports.buildNoPayoutPsbt=n.buildNoPayoutPsbt;exports.buildPeginInputPsbt=n.buildPeginInputPsbt;exports.buildPeginTxFromFundedPrePegin=n.buildPeginTxFromFundedPrePegin;exports.buildPrePeginPsbt=n.buildPrePeginPsbt;exports.computeNumLocalChallengers=n.computeNumLocalChallengers;exports.extractPeginInputSignature=n.extractPeginInputSignature;exports.finalizePeginInputPsbt=n.finalizePeginInputPsbt;Object.defineProperty(exports,"computeMinClaimValue",{enumerable:!0,get:()=>c.computeMinClaimValue});Object.defineProperty(exports,"deriveVaultId",{enumerable:!0,get:()=>c.deriveVaultId});exports.buildPayoutPsbt=P.buildPayoutPsbt;exports.buildRefundPsbt=P.buildRefundPsbt;exports.createPayoutScript=P.createPayoutScript;exports.extractPayoutSignature=P.extractPayoutSignature;exports.deriveNativeSegwitAddress=o.deriveNativeSegwitAddress;exports.deriveTaprootAddress=o.deriveTaprootAddress;exports.ensureHexPrefix=o.ensureHexPrefix;exports.formatSatoshisToBtc=o.formatSatoshisToBtc;exports.getNetwork=o.getNetwork;exports.hexToUint8Array=o.hexToUint8Array;exports.isAddressFromPublicKey=o.isAddressFromPublicKey;exports.isValidHex=o.isValidHex;exports.processPublicKeyToXOnly=o.processPublicKeyToXOnly;exports.stripHexPrefix=o.stripHexPrefix;exports.toXOnly=o.toXOnly;exports.uint8ArrayToHex=o.uint8ArrayToHex;exports.validateWalletPubkey=o.validateWalletPubkey;exports.ContractStatus=l.ContractStatus;exports.PeginAction=l.PeginAction;exports.canPerformAction=l.canPerformAction;exports.createTaprootScriptPathSignOptions=l.createTaprootScriptPathSignOptions;exports.getPeginProtocolState=l.getPeginProtocolState;exports.BITCOIN_ADDRESS_RE=u.BITCOIN_ADDRESS_RE;exports.HEX_RE=u.HEX_RE;exports.KNOWN_SCRIPT_PREFIXES=u.KNOWN_SCRIPT_PREFIXES;exports.MAX_REASONABLE_FEE_SATS=u.MAX_REASONABLE_FEE_SATS;exports.TXID_RE=u.TXID_RE;exports.BIP68NotMatureError=e.BIP68NotMatureError;exports.ClaimerPegoutStatusValue=e.ClaimerPegoutStatusValue;exports.PayoutManager=e.PayoutManager;exports.activateVault=e.activateVault;exports.buildAndBroadcastRefund=e.buildAndBroadcastRefund;exports.computeHashlock=e.computeHashlock;exports.isDepositAmountValid=e.isDepositAmountValid;exports.isPegoutTerminalStatus=e.isPegoutTerminalStatus;exports.isRecognizedPegoutStatus=e.isRecognizedPegoutStatus;exports.pollAndSignPayouts=e.pollAndSignPayouts;exports.signDepositorGraph=e.signDepositorGraph;exports.submitWotsPublicKey=e.submitWotsPublicKey;exports.validateDepositAmount=e.validateDepositAmount;exports.validateMultiVaultDepositInputs=e.validateMultiVaultDepositInputs;exports.validateProviderSelection=e.validateProviderSelection;exports.validateRemainingCapacity=e.validateRemainingCapacity;exports.validateSecretAgainstHashlock=e.validateSecretAgainstHashlock;exports.validateVaultAmounts=e.validateVaultAmounts;exports.validateVaultProviderPubkey=e.validateVaultProviderPubkey;exports.waitForPeginStatus=e.waitForPeginStatus;exports.BTC_DUST_SAT=r.BTC_DUST_SAT;exports.DUST_THRESHOLD=r.DUST_THRESHOLD;exports.FEE_SAFETY_MARGIN=r.FEE_SAFETY_MARGIN;exports.LOW_RATE_ESTIMATION_ACCURACY_BUFFER=r.LOW_RATE_ESTIMATION_ACCURACY_BUFFER;exports.MAX_NON_LEGACY_OUTPUT_SIZE=r.MAX_NON_LEGACY_OUTPUT_SIZE;exports.P2TR_INPUT_SIZE=r.P2TR_INPUT_SIZE;exports.PEGIN_FIXED_OUTPUTS=r.PEGIN_FIXED_OUTPUTS;exports.SPLIT_TX_FEE_SAFETY_MULTIPLIER=r.SPLIT_TX_FEE_SAFETY_MULTIPLIER;exports.TX_BUFFER_SIZE_OVERHEAD=r.TX_BUFFER_SIZE_OVERHEAD;exports.WALLET_RELAY_FEE_RATE_THRESHOLD=r.WALLET_RELAY_FEE_RATE_THRESHOLD;exports.fundPeginTransaction=r.fundPeginTransaction;exports.parseUnfundedWasmTransaction=r.parseUnfundedWasmTransaction;exports.peginOutputCount=r.peginOutputCount;exports.rateBasedTxBufferFee=r.rateBasedTxBufferFee;exports.BitcoinScriptType=i.BitcoinScriptType;exports.UtxoNotAvailableError=i.UtxoNotAvailableError;exports.assertUtxosAvailable=i.assertUtxosAvailable;exports.calculateBtcTxHash=i.calculateBtcTxHash;exports.collectReservedUtxoRefs=i.collectReservedUtxoRefs;exports.extractInputsFromTransaction=i.extractInputsFromTransaction;exports.getDustThreshold=i.getDustThreshold;exports.getPsbtInputFields=i.getPsbtInputFields;exports.getScriptType=i.getScriptType;exports.selectUtxosForDeposit=i.selectUtxosForDeposit;exports.selectUtxosForPegin=i.selectUtxosForPegin;exports.shouldAddChangeOutput=i.shouldAddChangeOutput;exports.validateUtxosAvailable=i.validateUtxosAvailable;exports.CONTRACT_ERRORS=a.CONTRACT_ERRORS;exports.PeginManager=a.PeginManager;exports.computeWotsBlockPublicKeysHash=a.computeWotsBlockPublicKeysHash;exports.computeWotsPkHash=a.computeWotsPkHash;exports.deriveWotsBlockPublicKeys=a.deriveWotsBlockPublicKeys;exports.deriveWotsKeypair=a.deriveWotsKeypair;exports.deriveWotsPkHash=a.deriveWotsPkHash;exports.extractErrorData=a.extractErrorData;exports.getContractErrorMessage=a.getContractErrorMessage;exports.handleContractError=a.handleContractError;exports.isKnownContractError=a.isKnownContractError;exports.isWotsMismatchError=a.isWotsMismatchError;exports.keypairToPublicKey=a.keypairToPublicKey;exports.mnemonicToWotsSeed=a.mnemonicToWotsSeed;exports.ApplicationRegistryABI=t.ApplicationRegistryABI;exports.MEMPOOL_API_URLS=t.MEMPOOL_API_URLS;exports.ProtocolParamsABI=t.ProtocolParamsABI;exports.VaultProviderRpcClient=t.VaultProviderRpcClient;exports.ViemProtocolParamsReader=t.ViemProtocolParamsReader;exports.ViemUniversalChallengerReader=t.ViemUniversalChallengerReader;exports.ViemVaultKeeperReader=t.ViemVaultKeeperReader;exports.ViemVaultRegistryReader=t.ViemVaultRegistryReader;exports.VpResponseValidationError=t.VpResponseValidationError;exports.getAddressTxs=t.getAddressTxs;exports.getAddressUtxos=t.getAddressUtxos;exports.getMempoolApiUrl=t.getMempoolApiUrl;exports.getNetworkFees=t.getNetworkFees;exports.getTxHex=t.getTxHex;exports.getTxInfo=t.getTxInfo;exports.getUtxoInfo=t.getUtxoInfo;exports.pushTx=t.pushTx;exports.resolveProtocolAddresses=t.resolveProtocolAddresses;exports.validateRequestDepositorClaimerArtifactsResponse=t.validateRequestDepositorClaimerArtifactsResponse;exports.BTCVaultRegistryABI=s.BTCVaultRegistryABI;exports.DaemonStatus=s.DaemonStatus;exports.JSON_RPC_ERROR_CODES=s.JSON_RPC_ERROR_CODES;exports.JsonRpcClient=s.JsonRpcClient;exports.JsonRpcError=s.JsonRpcError;exports.POST_WOTS_STATUSES=s.POST_WOTS_STATUSES;exports.PRE_DEPOSITOR_SIGNATURES_STATES=s.PRE_DEPOSITOR_SIGNATURES_STATES;exports.RpcErrorCode=s.RpcErrorCode;exports.VP_TERMINAL_STATUSES=s.VP_TERMINAL_STATUSES;exports.VP_TRANSIENT_STATUSES=s.VP_TRANSIENT_STATUSES;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/tbv/core/index.js
CHANGED
|
@@ -2,12 +2,12 @@ import { i as e, g as t, h as o, d as r, a as i, b as l, c as n, e as u, f as P
|
|
|
2
2
|
import { computeMinClaimValue as c, deriveVaultId as T } from "@babylonlabs-io/babylon-tbv-rust-wasm";
|
|
3
3
|
import { a as S, b as E, c as A, e as g } from "../../payout-DzGsAnhf.js";
|
|
4
4
|
import { d as _, a as m, e as b, f as x, g as I, h as f, i as v, b as C, p as U, s as y, t as O, u as h, v as V } from "../../bitcoin-nOOgeRyl.js";
|
|
5
|
-
import { C as D, P as F, a as N, c as M, g as H } from "../../signing-
|
|
5
|
+
import { C as D, P as F, a as N, c as M, g as H } from "../../signing-BZigafm0.js";
|
|
6
6
|
import { B as W, H as k, K, M as X, T as w } from "../../validation-CxqROCno.js";
|
|
7
|
-
import { B as Y, C as J, P as j, a as Z, m as z, h as q, i as Q, l as $, k as aa, p as sa, b as ea, s as ta, v as oa, g as ra, d as ia, c as la, j as na, e as ua, f as Pa, w as da } from "../../buildAndBroadcastRefund-
|
|
7
|
+
import { B as Y, C as J, P as j, a as Z, m as z, h as q, i as Q, l as $, k as aa, p as sa, b as ea, s as ta, v as oa, g as ra, d as ia, c as la, j as na, e as ua, f as Pa, w as da } from "../../buildAndBroadcastRefund-Ce5jAu-C.js";
|
|
8
8
|
import { B as Ta, D as pa, F as Sa, L as Ea, M as Aa, P as ga, a as Ra, S as _a, T as ma, W as ba, f as xa, b as Ia, p as fa, r as va } from "../../fundPeginTransaction-BLYXxLBv.js";
|
|
9
|
-
import { B as Ua, U as ya, a as Oa, f as ha, c as Va, e as Ba, g as Da, i as Fa, h as Na, s as Ma, b as Ha, d as La, v as Wa } from "../../psbtInputFields-
|
|
10
|
-
import { C as Ka, P as Xa, b as wa, c as Ga, a as Ya, d as Ja, f as ja, e as Za, g as za, h as qa, i as Qa, j as $a, k as as, m as ss } from "../../errors-
|
|
9
|
+
import { B as Ua, U as ya, a as Oa, f as ha, c as Va, e as Ba, g as Da, i as Fa, h as Na, s as Ma, b as Ha, d as La, v as Wa } from "../../psbtInputFields-1dXR4hLk.js";
|
|
10
|
+
import { C as Ka, P as Xa, b as wa, c as Ga, a as Ya, d as Ja, f as ja, e as Za, g as za, h as qa, i as Qa, j as $a, k as as, m as ss } from "../../errors-Ul7fTCjl.js";
|
|
11
11
|
import { A as ts, M as os, P as rs, V as is, i as ls, j as ns, k as us, l as Ps, h as ds, g as cs, a as Ts, b as ps, c as Ss, d as Es, e as As, f as gs, p as Rs, r as _s, v as ms } from "../../index-DLtpqdlu.js";
|
|
12
12
|
import { B as xs, D as Is, b as fs, J as vs, a as Cs, d as Us, P as ys, R as Os, c as hs, V as Vs } from "../../types-DWjaqVfP.js";
|
|
13
13
|
export {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("../../../buildAndBroadcastRefund-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("../../../buildAndBroadcastRefund-IQ_2SCic.cjs"),a=require("../../../signing-DHSXjhLM.cjs");exports.BIP68NotMatureError=t.BIP68NotMatureError;exports.ClaimerPegoutStatusValue=t.ClaimerPegoutStatusValue;exports.activateVault=t.activateVault;exports.buildAndBroadcastRefund=t.buildAndBroadcastRefund;exports.computeHashlock=t.computeHashlock;exports.isDepositAmountValid=t.isDepositAmountValid;exports.isPegoutTerminalStatus=t.isPegoutTerminalStatus;exports.isRecognizedPegoutStatus=t.isRecognizedPegoutStatus;exports.pollAndSignPayouts=t.pollAndSignPayouts;exports.signDepositorGraph=t.signDepositorGraph;exports.submitWotsPublicKey=t.submitWotsPublicKey;exports.validateDepositAmount=t.validateDepositAmount;exports.validateMultiVaultDepositInputs=t.validateMultiVaultDepositInputs;exports.validateProviderSelection=t.validateProviderSelection;exports.validateRemainingCapacity=t.validateRemainingCapacity;exports.validateSecretAgainstHashlock=t.validateSecretAgainstHashlock;exports.validateVaultAmounts=t.validateVaultAmounts;exports.validateVaultProviderPubkey=t.validateVaultProviderPubkey;exports.waitForPeginStatus=t.waitForPeginStatus;exports.ContractStatus=a.ContractStatus;exports.PeginAction=a.PeginAction;exports.canPerformAction=a.canPerformAction;exports.getPeginProtocolState=a.getPeginProtocolState;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { B as s, C as e, a as i, m as o, h as u, i as l, l as r, k as n, p as d, b as c, s as P, v as g, g as m, d as p, c as v, j as S, e as A, f as V, w as b } from "../../../buildAndBroadcastRefund-
|
|
2
|
-
import { C, P as h, a as k, g as y } from "../../../signing-
|
|
1
|
+
import { B as s, C as e, a as i, m as o, h as u, i as l, l as r, k as n, p as d, b as c, s as P, v as g, g as m, d as p, c as v, j as S, e as A, f as V, w as b } from "../../../buildAndBroadcastRefund-Ce5jAu-C.js";
|
|
2
|
+
import { C, P as h, a as k, g as y } from "../../../signing-BZigafm0.js";
|
|
3
3
|
export {
|
|
4
4
|
s as BIP68NotMatureError,
|
|
5
5
|
e as ClaimerPegoutStatusValue,
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const T=require("../../../signing-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const T=require("../../../signing-DHSXjhLM.cjs"),E=require("../../../validation-u8W7Lp2x.cjs"),t=require("../../../fundPeginTransaction-DxNOeyNI.cjs"),e=require("../../../psbtInputFields-tnAR8tG5.cjs"),_=require("../../../bitcoin-CNnPFU6Y.cjs");exports.createTaprootScriptPathSignOptions=T.createTaprootScriptPathSignOptions;exports.BITCOIN_ADDRESS_RE=E.BITCOIN_ADDRESS_RE;exports.HEX_RE=E.HEX_RE;exports.KNOWN_SCRIPT_PREFIXES=E.KNOWN_SCRIPT_PREFIXES;exports.MAX_REASONABLE_FEE_SATS=E.MAX_REASONABLE_FEE_SATS;exports.TXID_RE=E.TXID_RE;exports.BTC_DUST_SAT=t.BTC_DUST_SAT;exports.DUST_THRESHOLD=t.DUST_THRESHOLD;exports.FEE_SAFETY_MARGIN=t.FEE_SAFETY_MARGIN;exports.LOW_RATE_ESTIMATION_ACCURACY_BUFFER=t.LOW_RATE_ESTIMATION_ACCURACY_BUFFER;exports.MAX_NON_LEGACY_OUTPUT_SIZE=t.MAX_NON_LEGACY_OUTPUT_SIZE;exports.P2TR_INPUT_SIZE=t.P2TR_INPUT_SIZE;exports.PEGIN_FIXED_OUTPUTS=t.PEGIN_FIXED_OUTPUTS;exports.SPLIT_TX_FEE_SAFETY_MULTIPLIER=t.SPLIT_TX_FEE_SAFETY_MULTIPLIER;exports.TX_BUFFER_SIZE_OVERHEAD=t.TX_BUFFER_SIZE_OVERHEAD;exports.WALLET_RELAY_FEE_RATE_THRESHOLD=t.WALLET_RELAY_FEE_RATE_THRESHOLD;exports.fundPeginTransaction=t.fundPeginTransaction;exports.parseUnfundedWasmTransaction=t.parseUnfundedWasmTransaction;exports.peginOutputCount=t.peginOutputCount;exports.rateBasedTxBufferFee=t.rateBasedTxBufferFee;exports.BitcoinScriptType=e.BitcoinScriptType;exports.UtxoNotAvailableError=e.UtxoNotAvailableError;exports.assertUtxosAvailable=e.assertUtxosAvailable;exports.calculateBtcTxHash=e.calculateBtcTxHash;exports.collectReservedUtxoRefs=e.collectReservedUtxoRefs;exports.extractInputsFromTransaction=e.extractInputsFromTransaction;exports.getDustThreshold=e.getDustThreshold;exports.getPsbtInputFields=e.getPsbtInputFields;exports.getScriptType=e.getScriptType;exports.selectUtxosForDeposit=e.selectUtxosForDeposit;exports.selectUtxosForPegin=e.selectUtxosForPegin;exports.shouldAddChangeOutput=e.shouldAddChangeOutput;exports.validateUtxosAvailable=e.validateUtxosAvailable;exports.getNetwork=_.getNetwork;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { c as t } from "../../../signing-
|
|
1
|
+
import { c as t } from "../../../signing-BZigafm0.js";
|
|
2
2
|
import { B as E, H as T, K as _, M as o, T as r } from "../../../validation-CxqROCno.js";
|
|
3
3
|
import { B as A, D as R, F as i, L as p, M as n, P as I, a as U, S as c, T as F, W as l, f as x, b as O, p as P, r as u } from "../../../fundPeginTransaction-BLYXxLBv.js";
|
|
4
|
-
import { B as f, U as B, a as D, f as L, c as N, e as g, g as C, i as H, h as X, s as h, b as m, d as M, v as b } from "../../../psbtInputFields-
|
|
4
|
+
import { B as f, U as B, a as D, f as L, c as N, e as g, g as C, i as H, h as X, s as h, b as m, d as M, v as b } from "../../../psbtInputFields-1dXR4hLk.js";
|
|
5
5
|
import { g as W } from "../../../bitcoin-nOOgeRyl.js";
|
|
6
6
|
export {
|
|
7
7
|
E as BITCOIN_ADDRESS_RE,
|
|
@@ -3,7 +3,7 @@ import { SignPsbtOptions } from '../../../shared/wallets/interfaces';
|
|
|
3
3
|
* Create SignPsbtOptions for Taproot script-path PSBT signing.
|
|
4
4
|
*
|
|
5
5
|
* All vault protocol signing operations are Taproot script-path spends that
|
|
6
|
-
* require `
|
|
6
|
+
* require `useTweakedSigner: false` (untweaked key) and `autoFinalized: false`
|
|
7
7
|
* (to preserve tapScriptSig for Schnorr signature extraction).
|
|
8
8
|
*
|
|
9
9
|
* @param publicKey - Signer's BTC public key (hex). Accepts both compressed
|
package/dist/tbv/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("../challengeAssert-X7V3Ik_Q.cjs"),c=require("@babylonlabs-io/babylon-tbv-rust-wasm"),P=require("../payout-RFIh7GLN.cjs"),o=require("../bitcoin-CNnPFU6Y.cjs"),l=require("../signing-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("../challengeAssert-X7V3Ik_Q.cjs"),c=require("@babylonlabs-io/babylon-tbv-rust-wasm"),P=require("../payout-RFIh7GLN.cjs"),o=require("../bitcoin-CNnPFU6Y.cjs"),l=require("../signing-DHSXjhLM.cjs"),u=require("../validation-u8W7Lp2x.cjs"),e=require("../buildAndBroadcastRefund-IQ_2SCic.cjs"),r=require("../fundPeginTransaction-DxNOeyNI.cjs"),i=require("../psbtInputFields-tnAR8tG5.cjs"),a=require("../errors-B3DbZYLe.cjs"),t=require("../index-BAECy2oz.cjs"),s=require("../types-B-p4dhEH.cjs");exports.buildChallengeAssertPsbt=n.buildChallengeAssertPsbt;exports.buildDepositorPayoutPsbt=n.buildDepositorPayoutPsbt;exports.buildNoPayoutPsbt=n.buildNoPayoutPsbt;exports.buildPeginInputPsbt=n.buildPeginInputPsbt;exports.buildPeginTxFromFundedPrePegin=n.buildPeginTxFromFundedPrePegin;exports.buildPrePeginPsbt=n.buildPrePeginPsbt;exports.computeNumLocalChallengers=n.computeNumLocalChallengers;exports.extractPeginInputSignature=n.extractPeginInputSignature;exports.finalizePeginInputPsbt=n.finalizePeginInputPsbt;Object.defineProperty(exports,"computeMinClaimValue",{enumerable:!0,get:()=>c.computeMinClaimValue});Object.defineProperty(exports,"deriveVaultId",{enumerable:!0,get:()=>c.deriveVaultId});exports.buildPayoutPsbt=P.buildPayoutPsbt;exports.buildRefundPsbt=P.buildRefundPsbt;exports.createPayoutScript=P.createPayoutScript;exports.extractPayoutSignature=P.extractPayoutSignature;exports.deriveNativeSegwitAddress=o.deriveNativeSegwitAddress;exports.deriveTaprootAddress=o.deriveTaprootAddress;exports.ensureHexPrefix=o.ensureHexPrefix;exports.formatSatoshisToBtc=o.formatSatoshisToBtc;exports.getNetwork=o.getNetwork;exports.hexToUint8Array=o.hexToUint8Array;exports.isAddressFromPublicKey=o.isAddressFromPublicKey;exports.isValidHex=o.isValidHex;exports.processPublicKeyToXOnly=o.processPublicKeyToXOnly;exports.stripHexPrefix=o.stripHexPrefix;exports.toXOnly=o.toXOnly;exports.uint8ArrayToHex=o.uint8ArrayToHex;exports.validateWalletPubkey=o.validateWalletPubkey;exports.ContractStatus=l.ContractStatus;exports.PeginAction=l.PeginAction;exports.canPerformAction=l.canPerformAction;exports.createTaprootScriptPathSignOptions=l.createTaprootScriptPathSignOptions;exports.getPeginProtocolState=l.getPeginProtocolState;exports.BITCOIN_ADDRESS_RE=u.BITCOIN_ADDRESS_RE;exports.HEX_RE=u.HEX_RE;exports.KNOWN_SCRIPT_PREFIXES=u.KNOWN_SCRIPT_PREFIXES;exports.MAX_REASONABLE_FEE_SATS=u.MAX_REASONABLE_FEE_SATS;exports.TXID_RE=u.TXID_RE;exports.BIP68NotMatureError=e.BIP68NotMatureError;exports.ClaimerPegoutStatusValue=e.ClaimerPegoutStatusValue;exports.PayoutManager=e.PayoutManager;exports.activateVault=e.activateVault;exports.buildAndBroadcastRefund=e.buildAndBroadcastRefund;exports.computeHashlock=e.computeHashlock;exports.isDepositAmountValid=e.isDepositAmountValid;exports.isPegoutTerminalStatus=e.isPegoutTerminalStatus;exports.isRecognizedPegoutStatus=e.isRecognizedPegoutStatus;exports.pollAndSignPayouts=e.pollAndSignPayouts;exports.signDepositorGraph=e.signDepositorGraph;exports.submitWotsPublicKey=e.submitWotsPublicKey;exports.validateDepositAmount=e.validateDepositAmount;exports.validateMultiVaultDepositInputs=e.validateMultiVaultDepositInputs;exports.validateProviderSelection=e.validateProviderSelection;exports.validateRemainingCapacity=e.validateRemainingCapacity;exports.validateSecretAgainstHashlock=e.validateSecretAgainstHashlock;exports.validateVaultAmounts=e.validateVaultAmounts;exports.validateVaultProviderPubkey=e.validateVaultProviderPubkey;exports.waitForPeginStatus=e.waitForPeginStatus;exports.BTC_DUST_SAT=r.BTC_DUST_SAT;exports.DUST_THRESHOLD=r.DUST_THRESHOLD;exports.FEE_SAFETY_MARGIN=r.FEE_SAFETY_MARGIN;exports.LOW_RATE_ESTIMATION_ACCURACY_BUFFER=r.LOW_RATE_ESTIMATION_ACCURACY_BUFFER;exports.MAX_NON_LEGACY_OUTPUT_SIZE=r.MAX_NON_LEGACY_OUTPUT_SIZE;exports.P2TR_INPUT_SIZE=r.P2TR_INPUT_SIZE;exports.PEGIN_FIXED_OUTPUTS=r.PEGIN_FIXED_OUTPUTS;exports.SPLIT_TX_FEE_SAFETY_MULTIPLIER=r.SPLIT_TX_FEE_SAFETY_MULTIPLIER;exports.TX_BUFFER_SIZE_OVERHEAD=r.TX_BUFFER_SIZE_OVERHEAD;exports.WALLET_RELAY_FEE_RATE_THRESHOLD=r.WALLET_RELAY_FEE_RATE_THRESHOLD;exports.fundPeginTransaction=r.fundPeginTransaction;exports.parseUnfundedWasmTransaction=r.parseUnfundedWasmTransaction;exports.peginOutputCount=r.peginOutputCount;exports.rateBasedTxBufferFee=r.rateBasedTxBufferFee;exports.BitcoinScriptType=i.BitcoinScriptType;exports.UtxoNotAvailableError=i.UtxoNotAvailableError;exports.assertUtxosAvailable=i.assertUtxosAvailable;exports.calculateBtcTxHash=i.calculateBtcTxHash;exports.collectReservedUtxoRefs=i.collectReservedUtxoRefs;exports.extractInputsFromTransaction=i.extractInputsFromTransaction;exports.getDustThreshold=i.getDustThreshold;exports.getPsbtInputFields=i.getPsbtInputFields;exports.getScriptType=i.getScriptType;exports.selectUtxosForDeposit=i.selectUtxosForDeposit;exports.selectUtxosForPegin=i.selectUtxosForPegin;exports.shouldAddChangeOutput=i.shouldAddChangeOutput;exports.validateUtxosAvailable=i.validateUtxosAvailable;exports.CONTRACT_ERRORS=a.CONTRACT_ERRORS;exports.PeginManager=a.PeginManager;exports.computeWotsBlockPublicKeysHash=a.computeWotsBlockPublicKeysHash;exports.computeWotsPkHash=a.computeWotsPkHash;exports.deriveWotsBlockPublicKeys=a.deriveWotsBlockPublicKeys;exports.deriveWotsKeypair=a.deriveWotsKeypair;exports.deriveWotsPkHash=a.deriveWotsPkHash;exports.extractErrorData=a.extractErrorData;exports.getContractErrorMessage=a.getContractErrorMessage;exports.handleContractError=a.handleContractError;exports.isKnownContractError=a.isKnownContractError;exports.isWotsMismatchError=a.isWotsMismatchError;exports.keypairToPublicKey=a.keypairToPublicKey;exports.mnemonicToWotsSeed=a.mnemonicToWotsSeed;exports.ApplicationRegistryABI=t.ApplicationRegistryABI;exports.MEMPOOL_API_URLS=t.MEMPOOL_API_URLS;exports.ProtocolParamsABI=t.ProtocolParamsABI;exports.VaultProviderRpcClient=t.VaultProviderRpcClient;exports.ViemProtocolParamsReader=t.ViemProtocolParamsReader;exports.ViemUniversalChallengerReader=t.ViemUniversalChallengerReader;exports.ViemVaultKeeperReader=t.ViemVaultKeeperReader;exports.ViemVaultRegistryReader=t.ViemVaultRegistryReader;exports.VpResponseValidationError=t.VpResponseValidationError;exports.getAddressTxs=t.getAddressTxs;exports.getAddressUtxos=t.getAddressUtxos;exports.getMempoolApiUrl=t.getMempoolApiUrl;exports.getNetworkFees=t.getNetworkFees;exports.getTxHex=t.getTxHex;exports.getTxInfo=t.getTxInfo;exports.getUtxoInfo=t.getUtxoInfo;exports.pushTx=t.pushTx;exports.resolveProtocolAddresses=t.resolveProtocolAddresses;exports.validateRequestDepositorClaimerArtifactsResponse=t.validateRequestDepositorClaimerArtifactsResponse;exports.BTCVaultRegistryABI=s.BTCVaultRegistryABI;exports.DaemonStatus=s.DaemonStatus;exports.JSON_RPC_ERROR_CODES=s.JSON_RPC_ERROR_CODES;exports.JsonRpcClient=s.JsonRpcClient;exports.JsonRpcError=s.JsonRpcError;exports.POST_WOTS_STATUSES=s.POST_WOTS_STATUSES;exports.PRE_DEPOSITOR_SIGNATURES_STATES=s.PRE_DEPOSITOR_SIGNATURES_STATES;exports.RpcErrorCode=s.RpcErrorCode;exports.VP_TERMINAL_STATUSES=s.VP_TERMINAL_STATUSES;exports.VP_TRANSIENT_STATUSES=s.VP_TRANSIENT_STATUSES;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/tbv/index.js
CHANGED
|
@@ -2,12 +2,12 @@ import { i as e, g as t, h as o, d as r, a as i, b as l, c as n, e as u, f as P
|
|
|
2
2
|
import { computeMinClaimValue as c, deriveVaultId as T } from "@babylonlabs-io/babylon-tbv-rust-wasm";
|
|
3
3
|
import { a as S, b as E, c as A, e as g } from "../payout-DzGsAnhf.js";
|
|
4
4
|
import { d as _, a as m, e as b, f as x, g as I, h as f, i as v, b as C, p as U, s as y, t as O, u as h, v as V } from "../bitcoin-nOOgeRyl.js";
|
|
5
|
-
import { C as D, P as F, a as N, c as M, g as H } from "../signing-
|
|
5
|
+
import { C as D, P as F, a as N, c as M, g as H } from "../signing-BZigafm0.js";
|
|
6
6
|
import { B as W, H as k, K, M as X, T as w } from "../validation-CxqROCno.js";
|
|
7
|
-
import { B as Y, C as J, P as j, a as Z, m as z, h as q, i as Q, l as $, k as aa, p as sa, b as ea, s as ta, v as oa, g as ra, d as ia, c as la, j as na, e as ua, f as Pa, w as da } from "../buildAndBroadcastRefund-
|
|
7
|
+
import { B as Y, C as J, P as j, a as Z, m as z, h as q, i as Q, l as $, k as aa, p as sa, b as ea, s as ta, v as oa, g as ra, d as ia, c as la, j as na, e as ua, f as Pa, w as da } from "../buildAndBroadcastRefund-Ce5jAu-C.js";
|
|
8
8
|
import { B as Ta, D as pa, F as Sa, L as Ea, M as Aa, P as ga, a as Ra, S as _a, T as ma, W as ba, f as xa, b as Ia, p as fa, r as va } from "../fundPeginTransaction-BLYXxLBv.js";
|
|
9
|
-
import { B as Ua, U as ya, a as Oa, f as ha, c as Va, e as Ba, g as Da, i as Fa, h as Na, s as Ma, b as Ha, d as La, v as Wa } from "../psbtInputFields-
|
|
10
|
-
import { C as Ka, P as Xa, b as wa, c as Ga, a as Ya, d as Ja, f as ja, e as Za, g as za, h as qa, i as Qa, j as $a, k as as, m as ss } from "../errors-
|
|
9
|
+
import { B as Ua, U as ya, a as Oa, f as ha, c as Va, e as Ba, g as Da, i as Fa, h as Na, s as Ma, b as Ha, d as La, v as Wa } from "../psbtInputFields-1dXR4hLk.js";
|
|
10
|
+
import { C as Ka, P as Xa, b as wa, c as Ga, a as Ya, d as Ja, f as ja, e as Za, g as za, h as qa, i as Qa, j as $a, k as as, m as ss } from "../errors-Ul7fTCjl.js";
|
|
11
11
|
import { A as ts, M as os, P as rs, V as is, i as ls, j as ns, k as us, l as Ps, h as ds, g as cs, a as Ts, b as ps, c as Ss, d as Es, e as As, f as gs, p as Rs, r as _s, v as ms } from "../index-DLtpqdlu.js";
|
|
12
12
|
import { B as xs, D as Is, b as fs, J as vs, a as Cs, d as Us, P as ys, R as Os, c as hs, V as Vs } from "../types-DWjaqVfP.js";
|
|
13
13
|
export {
|
package/package.json
CHANGED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";var Ct=Object.defineProperty;var Lt=(t,e,r)=>e in t?Ct(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r;var f=(t,e,r)=>Lt(t,typeof e!="symbol"?e+"":e,r);const m=require("./types-B-p4dhEH.cjs"),d=require("./bitcoin-CNnPFU6Y.cjs"),N=require("bitcoinjs-lib"),bt=require("buffer"),W=require("./signing-cl-lowxV.cjs");require("@babylonlabs-io/babylon-tbv-rust-wasm");const $=require("./payout-RFIh7GLN.cjs");function $t(t){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const r in t)if(r!=="default"){const n=Object.getOwnPropertyDescriptor(t,r);Object.defineProperty(e,r,n.get?n:{enumerable:!0,get:()=>t[r]})}}return e.default=t,Object.freeze(e)}const Ot=$t(N);class xt{constructor(e){f(this,"config");this.config=e}async signPayoutTransaction(e){this.validatePayoutOutputs(e.payoutTxHex,e.registeredPayoutScriptPubKey);const r=await this.config.btcWallet.getPublicKeyHex(),{depositorPubkey:n}=d.validateWalletPubkey(r,e.depositorBtcPubkey),o=await $.buildPayoutPsbt({payoutTxHex:e.payoutTxHex,peginTxHex:e.peginTxHex,assertTxHex:e.assertTxHex,depositorBtcPubkey:n,vaultProviderBtcPubkey:e.vaultProviderBtcPubkey,vaultKeeperBtcPubkeys:e.vaultKeeperBtcPubkeys,universalChallengerBtcPubkeys:e.universalChallengerBtcPubkeys,timelockPegin:e.timelockPegin,network:this.config.network}),c=await this.config.btcWallet.signPsbt(o.psbtHex,W.createTaprootScriptPathSignOptions(r,1));return{signature:$.extractPayoutSignature(c,n),depositorBtcPubkey:n}}getNetwork(){return this.config.network}supportsBatchSigning(){return typeof this.config.btcWallet.signPsbts=="function"}async signPayoutTransactionsBatch(e){if(!this.supportsBatchSigning())throw new Error("Wallet does not support batch signing (signPsbts method not available)");const r=await this.config.btcWallet.getPublicKeyHex(),n=[],o=[],c=[];for(const s of e){this.validatePayoutOutputs(s.payoutTxHex,s.registeredPayoutScriptPubKey);const{depositorPubkey:u}=d.validateWalletPubkey(r,s.depositorBtcPubkey);c.push(u);const h=await $.buildPayoutPsbt({payoutTxHex:s.payoutTxHex,peginTxHex:s.peginTxHex,assertTxHex:s.assertTxHex,depositorBtcPubkey:u,vaultProviderBtcPubkey:s.vaultProviderBtcPubkey,vaultKeeperBtcPubkeys:s.vaultKeeperBtcPubkeys,universalChallengerBtcPubkeys:s.universalChallengerBtcPubkeys,timelockPegin:s.timelockPegin,network:this.config.network});n.push(h.psbtHex),o.push(W.createTaprootScriptPathSignOptions(r,1))}const a=await this.config.btcWallet.signPsbts(n,o);if(a.length!==e.length)throw new Error(`Expected ${e.length} signed PSBTs but received ${a.length}`);const i=[];for(let s=0;s<e.length;s++){const u=c[s],h=$.extractPayoutSignature(a[s],u);i.push({payoutSignature:h,depositorBtcPubkey:u})}return i}validatePayoutOutputs(e,r){if(!d.isValidHex(r))throw new Error("Invalid registeredPayoutScriptPubKey: not valid hex");const n=bt.Buffer.from(d.stripHexPrefix(r),"hex"),o=N.Transaction.fromHex(d.stripHexPrefix(e));if(o.outs.length===0)throw new Error("Payout transaction has no outputs");if(!o.outs.reduce((a,i)=>i.value>a.value?i:a).script.equals(n))throw new Error("Payout transaction does not pay to the registered depositor payout address")}}function Rt(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function Z(t,e=""){if(!Number.isSafeInteger(t)||t<0){const r=e&&`"${e}" `;throw new Error(`${r}expected integer >= 0, got ${t}`)}}function z(t,e,r=""){const n=Rt(t),o=t==null?void 0:t.length,c=e!==void 0;if(!n||c&&o!==e){const a=r&&`"${r}" `,i=c?` of length ${e}`:"",s=n?`length=${o}`:`type=${typeof t}`;throw new Error(a+"expected Uint8Array"+i+", got "+s)}return t}function Dt(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash must wrapped by utils.createHasher");Z(t.outputLen),Z(t.blockLen)}function tt(t,e=!0){if(t.destroyed)throw new Error("Hash instance has been destroyed");if(e&&t.finished)throw new Error("Hash#digest() has already been called")}function pt(t,e){z(t,void 0,"digestInto() output");const r=e.outputLen;if(t.length<r)throw new Error('"digestInto() output" expected to be of length >='+r)}function Nt(t){return new Uint32Array(t.buffer,t.byteOffset,Math.floor(t.byteLength/4))}function D(...t){for(let e=0;e<t.length;e++)t[e].fill(0)}function G(t){return new DataView(t.buffer,t.byteOffset,t.byteLength)}function S(t,e){return t<<32-e|t>>>e}function Ut(t,e){return t<<e|t>>>32-e>>>0}const Vt=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Kt(t){return t<<24&4278190080|t<<8&16711680|t>>>8&65280|t>>>24&255}function Ft(t){for(let e=0;e<t.length;e++)t[e]=Kt(t[e]);return t}const Mt=Vt?t=>t:Ft;function Gt(t){if(typeof t!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(t))}function Wt(t,e=""){return typeof t=="string"?Gt(t):z(t,void 0,e)}function zt(t,e){if(e!==void 0&&{}.toString.call(e)!=="[object Object]")throw new Error("options must be object or undefined");return Object.assign(t,e)}function rt(t,e={}){const r=(o,c)=>t(c).update(o).digest(),n=t(void 0);return r.outputLen=n.outputLen,r.blockLen=n.blockLen,r.create=o=>t(o),Object.assign(r,e),Object.freeze(r)}const gt=t=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,t])});function Xt(t,e,r){return t&e^~t&r}function jt(t,e,r){return t&e^t&r^e&r}class nt{constructor(e,r,n,o){f(this,"blockLen");f(this,"outputLen");f(this,"padOffset");f(this,"isLE");f(this,"buffer");f(this,"view");f(this,"finished",!1);f(this,"length",0);f(this,"pos",0);f(this,"destroyed",!1);this.blockLen=e,this.outputLen=r,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(e),this.view=G(this.buffer)}update(e){tt(this),z(e);const{view:r,buffer:n,blockLen:o}=this,c=e.length;for(let a=0;a<c;){const i=Math.min(o-this.pos,c-a);if(i===o){const s=G(e);for(;o<=c-a;a+=o)this.process(s,a);continue}n.set(e.subarray(a,a+i),this.pos),this.pos+=i,a+=i,this.pos===o&&(this.process(r,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){tt(this),pt(e,this),this.finished=!0;const{buffer:r,view:n,blockLen:o,isLE:c}=this;let{pos:a}=this;r[a++]=128,D(this.buffer.subarray(a)),this.padOffset>o-a&&(this.process(n,0),a=0);for(let l=a;l<o;l++)r[l]=0;n.setBigUint64(o-8,BigInt(this.length*8),c),this.process(n,0);const i=G(e),s=this.outputLen;if(s%4)throw new Error("_sha2: outputLen must be aligned to 32bit");const u=s/4,h=this.get();if(u>h.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)i.setUint32(4*l,h[l],c)}digest(){const{buffer:e,outputLen:r}=this;this.digestInto(e);const n=e.slice(0,r);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:r,buffer:n,length:o,finished:c,destroyed:a,pos:i}=this;return e.destroyed=a,e.finished=c,e.length=o,e.pos=i,o%r&&e.buffer.set(n),e}clone(){return this._cloneInto()}}const B=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),w=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]),K=BigInt(2**32-1),at=BigInt(32);function qt(t,e=!1){return e?{h:Number(t&K),l:Number(t>>at&K)}:{h:Number(t>>at&K)|0,l:Number(t&K)|0}}function yt(t,e=!1){const r=t.length;let n=new Uint32Array(r),o=new Uint32Array(r);for(let c=0;c<r;c++){const{h:a,l:i}=qt(t[c],e);[n[c],o[c]]=[a,i]}return[n,o]}const ct=(t,e,r)=>t>>>r,ut=(t,e,r)=>t<<32-r|e>>>r,O=(t,e,r)=>t>>>r|e<<32-r,R=(t,e,r)=>t<<32-r|e>>>r,F=(t,e,r)=>t<<64-r|e>>>r-32,M=(t,e,r)=>t>>>r-32|e<<64-r,Yt=(t,e,r)=>t<<r|e>>>32-r,Qt=(t,e,r)=>e<<r|t>>>32-r,Jt=(t,e,r)=>e<<r-32|t>>>64-r,Zt=(t,e,r)=>t<<r-32|e>>>64-r;function v(t,e,r,n){const o=(e>>>0)+(n>>>0);return{h:t+r+(o/2**32|0)|0,l:o|0}}const te=(t,e,r)=>(t>>>0)+(e>>>0)+(r>>>0),ee=(t,e,r,n)=>e+r+n+(t/2**32|0)|0,re=(t,e,r,n)=>(t>>>0)+(e>>>0)+(r>>>0)+(n>>>0),ne=(t,e,r,n,o)=>e+r+n+o+(t/2**32|0)|0,oe=(t,e,r,n,o)=>(t>>>0)+(e>>>0)+(r>>>0)+(n>>>0)+(o>>>0),se=(t,e,r,n,o,c)=>e+r+n+o+c+(t/2**32|0)|0,ie=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),_=new Uint32Array(64);class ae extends nt{constructor(e){super(64,e,8,!1)}get(){const{A:e,B:r,C:n,D:o,E:c,F:a,G:i,H:s}=this;return[e,r,n,o,c,a,i,s]}set(e,r,n,o,c,a,i,s){this.A=e|0,this.B=r|0,this.C=n|0,this.D=o|0,this.E=c|0,this.F=a|0,this.G=i|0,this.H=s|0}process(e,r){for(let l=0;l<16;l++,r+=4)_[l]=e.getUint32(r,!1);for(let l=16;l<64;l++){const b=_[l-15],p=_[l-2],P=S(b,7)^S(b,18)^b>>>3,g=S(p,17)^S(p,19)^p>>>10;_[l]=g+_[l-7]+P+_[l-16]|0}let{A:n,B:o,C:c,D:a,E:i,F:s,G:u,H:h}=this;for(let l=0;l<64;l++){const b=S(i,6)^S(i,11)^S(i,25),p=h+b+Xt(i,s,u)+ie[l]+_[l]|0,g=(S(n,2)^S(n,13)^S(n,22))+jt(n,o,c)|0;h=u,u=s,s=i,i=a+p|0,a=c,c=o,o=n,n=p+g|0}n=n+this.A|0,o=o+this.B|0,c=c+this.C|0,a=a+this.D|0,i=i+this.E|0,s=s+this.F|0,u=u+this.G|0,h=h+this.H|0,this.set(n,o,c,a,i,s,u,h)}roundClean(){D(_)}destroy(){this.set(0,0,0,0,0,0,0,0),D(this.buffer)}}class ce extends ae{constructor(){super(32);f(this,"A",B[0]|0);f(this,"B",B[1]|0);f(this,"C",B[2]|0);f(this,"D",B[3]|0);f(this,"E",B[4]|0);f(this,"F",B[5]|0);f(this,"G",B[6]|0);f(this,"H",B[7]|0)}}const Pt=yt(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(t=>BigInt(t))),ue=Pt[0],le=Pt[1],I=new Uint32Array(80),C=new Uint32Array(80);class fe extends nt{constructor(e){super(128,e,16,!1)}get(){const{Ah:e,Al:r,Bh:n,Bl:o,Ch:c,Cl:a,Dh:i,Dl:s,Eh:u,El:h,Fh:l,Fl:b,Gh:p,Gl:P,Hh:g,Hl:y}=this;return[e,r,n,o,c,a,i,s,u,h,l,b,p,P,g,y]}set(e,r,n,o,c,a,i,s,u,h,l,b,p,P,g,y){this.Ah=e|0,this.Al=r|0,this.Bh=n|0,this.Bl=o|0,this.Ch=c|0,this.Cl=a|0,this.Dh=i|0,this.Dl=s|0,this.Eh=u|0,this.El=h|0,this.Fh=l|0,this.Fl=b|0,this.Gh=p|0,this.Gl=P|0,this.Hh=g|0,this.Hl=y|0}process(e,r){for(let x=0;x<16;x++,r+=4)I[x]=e.getUint32(r),C[x]=e.getUint32(r+=4);for(let x=16;x<80;x++){const H=I[x-15]|0,k=C[x-15]|0,X=O(H,k,1)^O(H,k,8)^ct(H,k,7),j=R(H,k,1)^R(H,k,8)^ut(H,k,7),T=I[x-2]|0,E=C[x-2]|0,U=O(T,E,19)^F(T,E,61)^ct(T,E,6),q=R(T,E,19)^M(T,E,61)^ut(T,E,6),V=re(j,q,C[x-7],C[x-16]),Y=ne(V,X,U,I[x-7],I[x-16]);I[x]=Y|0,C[x]=V|0}let{Ah:n,Al:o,Bh:c,Bl:a,Ch:i,Cl:s,Dh:u,Dl:h,Eh:l,El:b,Fh:p,Fl:P,Gh:g,Gl:y,Hh:A,Hl:L}=this;for(let x=0;x<80;x++){const H=O(l,b,14)^O(l,b,18)^F(l,b,41),k=R(l,b,14)^R(l,b,18)^M(l,b,41),X=l&p^~l&g,j=b&P^~b&y,T=oe(L,k,j,le[x],C[x]),E=se(T,A,H,X,ue[x],I[x]),U=T|0,q=O(n,o,28)^F(n,o,34)^F(n,o,39),V=R(n,o,28)^M(n,o,34)^M(n,o,39),Y=n&c^n&i^c&i,It=o&a^o&s^a&s;A=g|0,L=y|0,g=p|0,y=P|0,p=l|0,P=b|0,{h:l,l:b}=v(u|0,h|0,E|0,U|0),u=i|0,h=s|0,i=c|0,s=a|0,c=n|0,a=o|0;const it=te(U,V,It);n=ee(it,E,q,Y),o=it|0}({h:n,l:o}=v(this.Ah|0,this.Al|0,n|0,o|0)),{h:c,l:a}=v(this.Bh|0,this.Bl|0,c|0,a|0),{h:i,l:s}=v(this.Ch|0,this.Cl|0,i|0,s|0),{h:u,l:h}=v(this.Dh|0,this.Dl|0,u|0,h|0),{h:l,l:b}=v(this.Eh|0,this.El|0,l|0,b|0),{h:p,l:P}=v(this.Fh|0,this.Fl|0,p|0,P|0),{h:g,l:y}=v(this.Gh|0,this.Gl|0,g|0,y|0),{h:A,l:L}=v(this.Hh|0,this.Hl|0,A|0,L|0),this.set(n,o,c,a,i,s,u,h,l,b,p,P,g,y,A,L)}roundClean(){D(I,C)}destroy(){D(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}}class he extends fe{constructor(){super(64);f(this,"Ah",w[0]|0);f(this,"Al",w[1]|0);f(this,"Bh",w[2]|0);f(this,"Bl",w[3]|0);f(this,"Ch",w[4]|0);f(this,"Cl",w[5]|0);f(this,"Dh",w[6]|0);f(this,"Dl",w[7]|0);f(this,"Eh",w[8]|0);f(this,"El",w[9]|0);f(this,"Fh",w[10]|0);f(this,"Fl",w[11]|0);f(this,"Gh",w[12]|0);f(this,"Gl",w[13]|0);f(this,"Hh",w[14]|0);f(this,"Hl",w[15]|0)}}const wt=rt(()=>new ce,gt(1)),de=rt(()=>new he,gt(3)),lt=66;function mt(t){if(!t.startsWith("0x")&&!t.startsWith("0X"))throw new Error("Expected 0x-prefixed hex string");const e=t.slice(2);if(e.length%2!==0)throw new Error(`Hex string has odd length: ${e.length}`);if(!/^[0-9a-fA-F]*$/.test(e))throw new Error("Hex string contains non-hex characters");const r=new Uint8Array(e.length/2);for(let n=0;n<r.length;n++)r[n]=parseInt(e.slice(n*2,n*2+2),16);return r}function be(t){return`0x${Array.from(t).map(e=>e.toString(16).padStart(2,"0")).join("")}`}function et(t,e){if(t.length!==lt)throw new Error(`${e} must be exactly 32 bytes (${lt} hex chars with 0x prefix), got ${t.length}`)}function St(t){et(t,"Secret");const e=mt(t),r=wt(e);return be(r)}function Tt(t,e){return et(t,"Secret"),et(e,"Hashlock"),mt(e),St(t).toLowerCase()===e.toLowerCase()}const xe=/^0x[0-9a-fA-F]{64}$/,pe=/^0x[0-9a-fA-F]{40}$/,ge=/^0x([0-9a-fA-F]{2})*$/;function Q(t,e){if(t.length!==66)throw new Error(`${e} must be 32 bytes (66 hex chars with 0x prefix), got length ${t.length}`);if(!xe.test(t))throw new Error(`${e} must contain only hex characters after the 0x prefix`)}function ye(t,e){if(!pe.test(t))throw new Error(`${e} must be a 20-byte 0x-prefixed hex address (42 chars)`)}function Pe(t,e){if(!ge.test(t))throw new Error(`${e} must be a 0x-prefixed hex string with an even number of hex chars`)}async function we(t){const{btcVaultRegistryAddress:e,vaultId:r,hashlock:n,activationMetadata:o,writeContract:c,signal:a}=t;a==null||a.throwIfAborted(),ye(e,"btcVaultRegistryAddress"),Q(r,"vaultId");const i=d.ensureHexPrefix(t.secret);if(Q(i,"secret"),n!==void 0&&(Q(n,"hashlock"),!Tt(i,n)))throw new Error("Invalid secret: SHA256(secret) does not match the provided hashlock");return Pe(o,"activationMetadata"),c({address:e,abi:m.BTCVaultRegistryABI,functionName:"activateVaultWithSecret",args:[r,i,o]})}const me=1e4;async function ot(t){const{statusReader:e,peginTxid:r,targetStatuses:n,timeoutMs:o,pollIntervalMs:c=me,signal:a}=t,i=Date.now();for(;;){if(a!=null&&a.aborted)throw new Error(`Polling aborted for pegin ${r.slice(0,8)}… (target: ${[...n].join(", ")})`);if(Date.now()-i>=o)throw new Error(`Polling timeout after ${o}ms for pegin ${r.slice(0,8)}… (target: ${[...n].join(", ")})`);try{const u=(await e.getPeginStatus({pegin_txid:r},a)).status;if(n.has(u))return u;if(m.VP_TERMINAL_STATUSES.has(u)&&!n.has(u))throw new Error(`Pegin ${r.slice(0,8)}… reached terminal status "${u}" while waiting for ${[...n].join(", ")}`)}catch(s){if(!(s instanceof m.JsonRpcError&&s.code===m.RpcErrorCode.NOT_FOUND||s instanceof Error&&s.message.includes("PegIn not found")))throw s}await new Promise((s,u)=>{const h=()=>{clearTimeout(l),u(new Error(`Polling aborted for pegin ${r.slice(0,8)}… (target: ${[...n].join(", ")})`))},l=setTimeout(()=>{a==null||a.removeEventListener("abort",h),s()},c);a==null||a.addEventListener("abort",h,{once:!0})})}}const Se=300*1e3,Te=new Set([m.DaemonStatus.PENDING_DEPOSITOR_WOTS_PK,...m.POST_WOTS_STATUSES]);async function Ee(t){const{statusReader:e,wotsSubmitter:r,peginTxid:n,depositorPk:o,wotsPublicKeys:c,timeoutMs:a=Se,signal:i}=t;i==null||i.throwIfAborted();const s=await ot({statusReader:e,peginTxid:n,targetStatuses:Te,timeoutMs:a,signal:i});m.POST_WOTS_STATUSES.has(s)||(i==null||i.throwIfAborted(),await r.submitDepositorWotsKey({pegin_txid:n,depositor_pk:o,wots_public_keys:c},i))}const ve=1;function Ae(t,e,r){const n=N.Psbt.fromBase64(t),o=n.data.getTransaction().toString("hex").toLowerCase(),c=d.stripHexPrefix(e).toLowerCase();if(o!==c)throw new Error(`PSBT integrity check failed for ${r}: unsigned transaction does not match tx_hex`);return n}function He(t){const e=N.Psbt.fromHex(t.toHex());for(const r of e.data.inputs)delete r.tapBip32Derivation,delete r.tapMerkleRoot;return e}function ft(t,e,r){if(!t)throw new Error(`Missing ${r} PSBT`);const n=Ae(t,e,r);return He(n).toHex()}function ke(t,e){const r=[],n=[],o=[],c=W.createTaprootScriptPathSignOptions(e,ve),a=ft(t.payout_psbt,t.payout_tx.tx_hex,"depositor payout");r.push(a),n.push(c);for(const i of t.challenger_presign_data){const s=d.stripHexPrefix(i.challenger_pubkey),u=r.length,h=ft(i.nopayout_psbt,i.nopayout_tx.tx_hex,`nopayout (challenger ${s})`);r.push(h),n.push(c),o.push({challengerPubkey:s,noPayoutIdx:u})}return{psbtHexes:r,signOptions:n,challengerEntries:o}}function Be(t,e,r){const n=$.extractPayoutSignature(t[0],r),o={};for(const c of e)o[c.challengerPubkey]={nopayout_signature:$.extractPayoutSignature(t[c.noPayoutIdx],r)};return{payout_signatures:{payout_signature:n},per_challenger:o}}async function _e(t,e,r){if(typeof t.signPsbts=="function")return t.signPsbts(e,r);const n=[];for(let o=0;o<e.length;o++)n.push(await t.signPsbt(e[o],r==null?void 0:r[o]));return n}async function Et(t){const{depositorGraph:e,depositorBtcPubkey:r,btcWallet:n}=t,o=d.stripHexPrefix(r),c=await n.getPublicKeyHex(),{psbtHexes:a,signOptions:i,challengerEntries:s}=ke(e,c),u=await _e(n,a,i);if(u.length!==a.length)throw new Error(`Wallet returned ${u.length} signed PSBTs, expected ${a.length}`);return Be(u,s,o)}const Ie=1200*1e3,vt=new Set([m.DaemonStatus.PENDING_ACKS,m.DaemonStatus.PENDING_ACTIVATION,m.DaemonStatus.ACTIVATED]),Ce=new Set([m.DaemonStatus.PENDING_DEPOSITOR_SIGNATURES,...vt]);function Le(t){return t.map(e=>({claimerPubkeyXOnly:d.processPublicKeyToXOnly(e.claimer_pubkey),payoutTxHex:e.payout_tx.tx_hex,assertTxHex:e.assert_tx.tx_hex}))}function $e(t){const{output:e}=Ot.payments.p2tr({internalPubkey:bt.Buffer.from(t,"hex")});if(!e)throw new Error("Failed to derive BIP-86 P2TR scriptPubKey");return e.toString("hex")}function Oe(t,e){const r=d.stripHexPrefix(t).toLowerCase(),n=d.stripHexPrefix(e.vaultProviderBtcPubkey).toLowerCase(),o=d.stripHexPrefix(e.depositorBtcPubkey).toLowerCase();if(r===n||r===o)return e.registeredPayoutScriptPubKey;if(!e.vaultKeeperBtcPubkeys.some(i=>d.stripHexPrefix(i).toLowerCase()===r))throw new Error(`Unknown claimer pubkey ${r}: not VP, depositor, or a registered vault keeper`);return`0x${$e(r)}`}function ht(t,e){return{payoutTxHex:t.payoutTxHex,peginTxHex:e.peginTxHex,assertTxHex:t.assertTxHex,vaultProviderBtcPubkey:e.vaultProviderBtcPubkey,vaultKeeperBtcPubkeys:e.vaultKeeperBtcPubkeys,universalChallengerBtcPubkeys:e.universalChallengerBtcPubkeys,depositorBtcPubkey:e.depositorBtcPubkey,timelockPegin:e.timelockPegin,registeredPayoutScriptPubKey:Oe(t.claimerPubkeyXOnly,e)}}async function Re(t,e,r,n){const o=new xt({network:e.network,btcWallet:t}),c=r.length;n==null||n(0,c);let a;if(o.supportsBatchSigning())a=(await o.signPayoutTransactionsBatch(r.map(u=>ht(u,e)))).map(u=>u.payoutSignature);else{a=[];for(let s=0;s<r.length;s++){n==null||n(s,c);const u=await o.signPayoutTransaction(ht(r[s],e));a.push(u.signature)}}const i={};for(let s=0;s<r.length;s++)i[r[s].claimerPubkeyXOnly]={payout_signature:a[s]};return n==null||n(c,c),i}async function De(t){const{statusReader:e,presignClient:r,btcWallet:n,peginTxid:o,depositorPk:c,signingContext:a,timeoutMs:i=Ie,signal:s,onProgress:u}=t,h=await ot({statusReader:e,peginTxid:o,targetStatuses:Ce,timeoutMs:i,signal:s});if(vt.has(h))return;s==null||s.throwIfAborted();const l=await r.requestDepositorPresignTransactions({pegin_txid:o,depositor_pk:c},s);s==null||s.throwIfAborted();const b=d.processPublicKeyToXOnly(c),p=l.txs.filter(L=>d.processPublicKeyToXOnly(L.claimer_pubkey)!==b),P=Le(p),g=await Re(n,a,P,u);s==null||s.throwIfAborted();const y=await Et({depositorGraph:l.depositor_graph,depositorBtcPubkey:c,btcWallet:n});s==null||s.throwIfAborted();const A={...g};A[d.stripHexPrefix(c)]=y.payout_signatures,await r.submitDepositorPresignatures({pegin_txid:o,depositor_pk:c,signatures:A,depositor_claimer_presignatures:y},s)}function Ne(t){return/^[0-9a-fA-F]{64}$/.test(t)}function Ue(t){const{amountSats:e,minDeposit:r,maxDeposit:n,btcBalance:o,estimatedFeeSats:c,depositorClaimValue:a}=t;return!(e<=0n||e<r||n&&n>0n&&e>n||c==null||a==null||e+c+a>o)}function Ve(t,e,r){return t<=0n?{valid:!1,error:"Deposit amount must be greater than zero"}:t<e?{valid:!1,error:`Minimum deposit is ${d.formatSatoshisToBtc(e)} BTC`}:r&&r>0n&&t>r?{valid:!1,error:`Maximum deposit is ${d.formatSatoshisToBtc(r)} BTC`}:{valid:!0}}function Ke(t){const{amount:e,effectiveRemaining:r}=t;return r===null?{valid:!0}:r===0n?{valid:!1,error:"Supply cap reached — deposits temporarily paused"}:e>r?{valid:!1,error:`Vault size exceeds remaining capacity (${d.formatSatoshisToBtc(r)} BTC)`}:{valid:!0}}function Fe(t,e){if(!t||t.length===0)return{valid:!1,error:"At least one vault provider must be selected"};const r=e.map(o=>o.toLowerCase());return t.filter(o=>!r.includes(o.toLowerCase())).length>0?{valid:!1,error:"Invalid vault provider selected"}:{valid:!0}}function At(t,e,r){if(!t||t.length===0)return{valid:!1,error:"At least one vault amount required"};for(let n=0;n<t.length;n++){const o=t[n];if(o<=0n)return{valid:!1,error:`Vault ${n+1} amount must be positive`};if(e&&o<e)return{valid:!1,error:`Vault ${n+1} amount ${d.formatSatoshisToBtc(o)} BTC is below minimum deposit ${d.formatSatoshisToBtc(e)} BTC`};if(r&&o>r)return{valid:!1,error:`Vault ${n+1} amount ${d.formatSatoshisToBtc(o)} BTC exceeds maximum deposit ${d.formatSatoshisToBtc(r)} BTC`}}return{valid:!0}}function Ht(t){const e=d.stripHexPrefix(t);return Ne(e)?{valid:!0}:{valid:!1,error:"Invalid pubkey format: must be 64 hex characters (32-byte x-only public key, no 0x prefix)"}}function Me(t){if(!t||t.length===0)throw new Error("No vault keepers available. The system requires at least one vault keeper to create a deposit.")}function Ge(t){if(!t||t.length===0)throw new Error("No universal challengers available. The system requires at least one universal challenger to create a deposit.")}function We(t){if(t.length===0)throw new Error("No spendable UTXOs available")}function ze(t){const{vaultAmounts:e,confirmedUTXOs:r,vaultProviderBtcPubkey:n,vaultKeeperBtcPubkeys:o,universalChallengerBtcPubkeys:c,minDeposit:a,maxDeposit:i,htlcSecretHexesLength:s,depositorSecretHashesLength:u}=t,h=e.length;if(s!==h)throw new Error(`htlcSecretHexes length (${s}) must match vaultAmounts length (${h})`);if(u!==h)throw new Error(`depositorSecretHashes length (${u}) must match vaultAmounts length (${h})`);const l=At(e,a,i);if(!l.valid)throw new Error(l.error);const b=Ht(n);if(!b.valid)throw new Error(b.error);Me(o),Ge(c),We(r)}var st=(t=>(t.CLAIM_EVENT_RECEIVED="ClaimEventReceived",t.CLAIM_BROADCAST="ClaimBroadcast",t.ASSERT_BROADCAST="AssertBroadcast",t.CHALLENGE_ASSERT_OBSERVED="ChallengeAssertObserved",t.WRONGLY_CHALLENGED_BROADCAST="WronglyChallengedBroadcast",t.PAYOUT_BROADCAST="PayoutBroadcast",t.FAILED="Failed",t))(st||{});const Xe=new Set(["PayoutBroadcast","Failed"]);function je(t){return Object.values(st).includes(t)}function qe(t){return!!t&&Xe.has(t)}class kt extends Error{constructor(r,n){super(`Refund not yet mature (BIP68 not final): ${n.message}`);f(this,"vaultId");f(this,"cause");this.name="BIP68NotMatureError",this.vaultId=r,this.cause=n}}const Ye=/^0x[0-9a-fA-F]{64}$/,Qe=/^(?:0x)?(?:[0-9a-fA-F]{2})+$/,Bt=/^(?:0x)?(?:[0-9a-fA-F]{64}|[0-9a-fA-F]{66})$/,Je=160,Ze=1,dt=65535,tr=/non-BIP68-final/i;function _t(t,e){if(t.length!==66)throw new Error(`${e} must be 32 bytes (66 hex chars with 0x prefix), got length ${t.length}`);if(!Ye.test(t))throw new Error(`${e} must contain only hex characters after the 0x prefix`)}function J(t,e){if(!Number.isInteger(t)||t<0)throw new Error(`${e} must be a non-negative integer, got ${t}`)}function er(t){if(_t(t.hashlock,"hashlock"),!Number.isInteger(t.htlcVout)||t.htlcVout<0||t.htlcVout>dt)throw new Error(`htlcVout must be an integer 0-${dt}, got ${t.htlcVout}`);if(J(t.offchainParamsVersion,"offchainParamsVersion"),J(t.appVaultKeepersVersion,"appVaultKeepersVersion"),J(t.universalChallengersVersion,"universalChallengersVersion"),typeof t.unsignedPrePeginTxHex!="string"||t.unsignedPrePeginTxHex.length===0)throw new Error("unsignedPrePeginTxHex must be a non-empty hex string");if(!Qe.test(t.unsignedPrePeginTxHex))throw new Error("unsignedPrePeginTxHex must be a hex byte string (optional 0x prefix, even length)");if(!t.depositorBtcPubkey||!Bt.test(t.depositorBtcPubkey))throw new Error("depositorBtcPubkey must be 32 or 33 bytes of hex (optional 0x prefix)");if(typeof t.amount!="bigint"||t.amount<=0n)throw new Error(`amount must be a positive bigint, got ${t.amount}`)}function rr(t){if(!t.vaultProviderPubkey||!Bt.test(t.vaultProviderPubkey))throw new Error("vaultProviderPubkey must be 32 or 33 bytes of hex");if(t.vaultKeeperPubkeys.length===0)throw new Error("vaultKeeperPubkeys must be non-empty");if(t.universalChallengerPubkeys.length===0)throw new Error("universalChallengerPubkeys must be non-empty");if(!Number.isInteger(t.timelockRefund)||t.timelockRefund<=0)throw new Error(`timelockRefund must be a positive integer, got ${t.timelockRefund}`);if(typeof t.feeRate!="bigint"||t.feeRate<=0n)throw new Error(`protocol feeRate must be a positive bigint, got ${t.feeRate}`);if(!Number.isInteger(t.numLocalChallengers)||t.numLocalChallengers<0)throw new Error("numLocalChallengers must be a non-negative integer");if(!Number.isInteger(t.councilQuorum)||!Number.isInteger(t.councilSize)||t.councilQuorum<=0||t.councilSize<=0||t.councilQuorum>t.councilSize)throw new Error(`councilQuorum (${t.councilQuorum}) must be in [1, councilSize=${t.councilSize}]`)}function nr(t){const e=N.Psbt.fromHex(t);try{e.finalizeAllInputs()}catch(r){const n=r instanceof Error?r.message:String(r);if(!n.includes("already finalized"))throw new Error(`Failed to finalize refund PSBT: ${n}`)}return e.extractTransaction().toHex()}async function or(t){const{vaultId:e,readVault:r,readPrePeginContext:n,feeRate:o,signPsbt:c,broadcastTx:a,signal:i}=t;i==null||i.throwIfAborted(),_t(e,"vaultId");const s=await r();er(s),i==null||i.throwIfAborted();const u=await n(s);if(rr(u),i==null||i.throwIfAborted(),!Number.isFinite(o)||o<=0)throw new Error(`feeRate must be a positive number, got ${o}`);const h=BigInt(Math.ceil(o*Je));i==null||i.throwIfAborted();const l=d.processPublicKeyToXOnly(s.depositorBtcPubkey),{psbtHex:b}=await $.buildRefundPsbt({prePeginParams:{depositorPubkey:l,vaultProviderPubkey:d.stripHexPrefix(u.vaultProviderPubkey),vaultKeeperPubkeys:u.vaultKeeperPubkeys.map(d.stripHexPrefix),universalChallengerPubkeys:u.universalChallengerPubkeys.map(d.stripHexPrefix),hashlocks:[d.stripHexPrefix(s.hashlock)],timelockRefund:u.timelockRefund,pegInAmounts:[s.amount],feeRate:u.feeRate,numLocalChallengers:u.numLocalChallengers,councilQuorum:u.councilQuorum,councilSize:u.councilSize,network:u.network},fundedPrePeginTxHex:d.stripHexPrefix(s.unsignedPrePeginTxHex),htlcVout:s.htlcVout,refundFee:h,hashlock:d.stripHexPrefix(s.hashlock)});i==null||i.throwIfAborted();const p=W.createTaprootScriptPathSignOptions(s.depositorBtcPubkey,Ze),P=await c(b,p),g=nr(P);i==null||i.throwIfAborted();try{return await a(g)}catch(y){throw y instanceof Error&&tr.test(y.message)?new kt(e,y):y}}exports.BIP68NotMatureError=kt;exports.ClaimerPegoutStatusValue=st;exports.HashMD=nt;exports.PayoutManager=xt;exports.abytes=z;exports.activateVault=we;exports.aexists=tt;exports.ahash=Dt;exports.anumber=Z;exports.aoutput=pt;exports.buildAndBroadcastRefund=or;exports.checkOpts=zt;exports.clean=D;exports.computeHashlock=St;exports.createHasher=rt;exports.createView=G;exports.isDepositAmountValid=Ue;exports.isPegoutTerminalStatus=qe;exports.isRecognizedPegoutStatus=je;exports.kdfInputToBytes=Wt;exports.pollAndSignPayouts=De;exports.rotl=Ut;exports.rotlBH=Jt;exports.rotlBL=Zt;exports.rotlSH=Yt;exports.rotlSL=Qt;exports.sha256=wt;exports.sha512=de;exports.signDepositorGraph=Et;exports.split=yt;exports.submitWotsPublicKey=Ee;exports.swap32IfBE=Mt;exports.u32=Nt;exports.validateDepositAmount=Ve;exports.validateMultiVaultDepositInputs=ze;exports.validateProviderSelection=Fe;exports.validateRemainingCapacity=Ke;exports.validateSecretAgainstHashlock=Tt;exports.validateVaultAmounts=At;exports.validateVaultProviderPubkey=Ht;exports.waitForPeginStatus=ot;
|
|
2
|
-
//# sourceMappingURL=buildAndBroadcastRefund-BDGGbGeK.cjs.map
|