@btc-vision/transaction 1.8.0-beta.3 → 1.8.0-beta.4
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/browser/_version.d.ts +1 -0
- package/browser/_version.d.ts.map +1 -0
- package/browser/abi/ABICoder.d.ts +1 -1
- package/browser/abi/ABICoder.d.ts.map +1 -0
- package/browser/branded/Branded.d.ts +4 -0
- package/browser/branded/Branded.d.ts.map +1 -0
- package/browser/btc-vision-bitcoin.js +11999 -2647
- package/browser/buffer/BinaryReader.d.ts +120 -1
- package/browser/buffer/BinaryReader.d.ts.map +1 -0
- package/browser/buffer/BinaryWriter.d.ts +51 -1
- package/browser/buffer/BinaryWriter.d.ts.map +1 -0
- package/browser/bytecode/Compressor.d.ts +12 -0
- package/browser/bytecode/Compressor.d.ts.map +1 -0
- package/browser/chain/ChainData.d.ts +2 -2
- package/browser/chain/ChainData.d.ts.map +1 -0
- package/browser/consensus/Consensus.d.ts +11 -3
- package/browser/consensus/Consensus.d.ts.map +1 -0
- package/browser/consensus/ConsensusConfig.d.ts +1 -0
- package/browser/consensus/ConsensusConfig.d.ts.map +1 -0
- package/browser/consensus/IConsensusConfig.d.ts +1 -0
- package/browser/consensus/IConsensusConfig.d.ts.map +1 -0
- package/browser/consensus/metadata/RoswellConsensus.d.ts +1 -0
- package/browser/consensus/metadata/RoswellConsensus.d.ts.map +1 -0
- package/browser/crypto/crypto.d.ts +1 -0
- package/browser/crypto/crypto.d.ts.map +1 -0
- package/browser/deterministic/AddressMap.d.ts +6 -1
- package/browser/deterministic/AddressMap.d.ts.map +1 -0
- package/browser/deterministic/AddressSet.d.ts +3 -1
- package/browser/deterministic/AddressSet.d.ts.map +1 -0
- package/browser/deterministic/CustomMap.d.ts +3 -1
- package/browser/deterministic/CustomMap.d.ts.map +1 -0
- package/browser/deterministic/DeterministicMap.d.ts +3 -1
- package/browser/deterministic/DeterministicMap.d.ts.map +1 -0
- package/browser/deterministic/DeterministicSet.d.ts +3 -1
- package/browser/deterministic/DeterministicSet.d.ts.map +1 -0
- package/browser/deterministic/ExtendedAddressMap.d.ts +7 -1
- package/browser/deterministic/ExtendedAddressMap.d.ts.map +1 -0
- package/browser/deterministic/FastMap.d.ts +7 -1
- package/browser/deterministic/FastMap.d.ts.map +1 -0
- package/browser/ecc/backend.d.ts +13 -0
- package/browser/ecc/backend.d.ts.map +1 -0
- package/browser/epoch/ChallengeSolution.d.ts +33 -1
- package/browser/epoch/ChallengeSolution.d.ts.map +1 -0
- package/browser/epoch/interfaces/IChallengeSolution.d.ts +14 -13
- package/browser/epoch/interfaces/IChallengeSolution.d.ts.map +1 -0
- package/browser/epoch/validator/EpochValidator.d.ts +37 -7
- package/browser/epoch/validator/EpochValidator.d.ts.map +1 -0
- package/browser/event/NetEvent.d.ts +1 -0
- package/browser/event/NetEvent.d.ts.map +1 -0
- package/browser/generators/AddressGenerator.d.ts +4 -3
- package/browser/generators/AddressGenerator.d.ts.map +1 -0
- package/browser/generators/Features.d.ts +1 -0
- package/browser/generators/Features.d.ts.map +1 -0
- package/browser/generators/Generator.d.ts +46 -10
- package/browser/generators/Generator.d.ts.map +1 -0
- package/browser/generators/MLDSAData.d.ts +1 -0
- package/browser/generators/MLDSAData.d.ts.map +1 -0
- package/browser/generators/builders/CalldataGenerator.d.ts +25 -4
- package/browser/generators/builders/CalldataGenerator.d.ts.map +1 -0
- package/browser/generators/builders/CustomGenerator.d.ts +13 -3
- package/browser/generators/builders/CustomGenerator.d.ts.map +1 -0
- package/browser/generators/builders/DeploymentGenerator.d.ts +15 -4
- package/browser/generators/builders/DeploymentGenerator.d.ts.map +1 -0
- package/browser/generators/builders/HashCommitmentGenerator.d.ts +164 -12
- package/browser/generators/builders/HashCommitmentGenerator.d.ts.map +1 -0
- package/browser/generators/builders/LegacyCalldataGenerator.d.ts +26 -4
- package/browser/generators/builders/LegacyCalldataGenerator.d.ts.map +1 -0
- package/browser/generators/builders/MultiSignGenerator.d.ts +6 -1
- package/browser/generators/builders/MultiSignGenerator.d.ts.map +1 -0
- package/browser/generators/builders/P2WDAGenerator.d.ts +42 -4
- package/browser/generators/builders/P2WDAGenerator.d.ts.map +1 -0
- package/browser/index.d.ts +1 -0
- package/browser/index.d.ts.map +1 -0
- package/browser/index.js +3583 -3184
- package/browser/keypair/Address.d.ts +283 -13
- package/browser/keypair/Address.d.ts.map +1 -0
- package/browser/keypair/AddressVerificator.d.ts +7 -6
- package/browser/keypair/AddressVerificator.d.ts.map +1 -0
- package/browser/keypair/EcKeyPair.d.ts +183 -21
- package/browser/keypair/EcKeyPair.d.ts.map +1 -0
- package/browser/keypair/MessageSigner.d.ts +17 -16
- package/browser/keypair/MessageSigner.d.ts.map +1 -0
- package/browser/keypair/Secp256k1PointDeriver.d.ts +55 -0
- package/browser/keypair/Secp256k1PointDeriver.d.ts.map +1 -0
- package/browser/keypair/Wallet.d.ts +27 -13
- package/browser/keypair/Wallet.d.ts.map +1 -0
- package/browser/keypair/interfaces/IWallet.d.ts +19 -0
- package/browser/keypair/interfaces/IWallet.d.ts.map +1 -0
- package/browser/metadata/ContractBaseMetadata.d.ts +10 -2
- package/browser/metadata/ContractBaseMetadata.d.ts.map +1 -0
- package/browser/mnemonic/BIPStandard.d.ts +59 -0
- package/browser/mnemonic/BIPStandard.d.ts.map +1 -0
- package/browser/mnemonic/Mnemonic.d.ts +15 -3
- package/browser/mnemonic/Mnemonic.d.ts.map +1 -0
- package/browser/mnemonic/MnemonicStrength.d.ts +6 -0
- package/browser/mnemonic/MnemonicStrength.d.ts.map +1 -0
- package/browser/network/ChainId.d.ts +1 -0
- package/browser/network/ChainId.d.ts.map +1 -0
- package/browser/noble-curves.js +844 -2746
- package/browser/noble-hashes.js +1338 -2067
- package/browser/opnet.d.ts +22 -1
- package/browser/opnet.d.ts.map +1 -0
- package/browser/p2wda/P2WDADetector.d.ts +36 -9
- package/browser/p2wda/P2WDADetector.d.ts.map +1 -0
- package/browser/polyfill/disposable.d.ts +16 -0
- package/browser/polyfill/disposable.d.ts.map +1 -0
- package/browser/signer/AddressRotation.d.ts +36 -0
- package/browser/signer/AddressRotation.d.ts.map +1 -0
- package/browser/signer/IRotationSigner.d.ts +27 -3
- package/browser/signer/IRotationSigner.d.ts.map +1 -0
- package/browser/signer/ParallelSignerAdapter.d.ts +14 -0
- package/browser/signer/ParallelSignerAdapter.d.ts.map +1 -0
- package/browser/signer/SignerUtils.d.ts +11 -4
- package/browser/signer/SignerUtils.d.ts.map +1 -0
- package/browser/signer/TweakedSigner.d.ts +28 -4
- package/browser/signer/TweakedSigner.d.ts.map +1 -0
- package/browser/transaction/ContractAddress.d.ts +2 -2
- package/browser/transaction/ContractAddress.d.ts.map +1 -0
- package/browser/transaction/TransactionFactory.d.ts +140 -2
- package/browser/transaction/TransactionFactory.d.ts.map +1 -0
- package/browser/transaction/browser/BrowserSignerBase.d.ts +12 -6
- package/browser/transaction/browser/BrowserSignerBase.d.ts.map +1 -0
- package/browser/transaction/browser/WalletNetworks.d.ts +1 -0
- package/browser/transaction/browser/WalletNetworks.d.ts.map +1 -0
- package/browser/transaction/browser/Web3Provider.d.ts +27 -0
- package/browser/transaction/browser/Web3Provider.d.ts.map +1 -0
- package/browser/transaction/browser/extensions/UnisatSigner.d.ts +9 -7
- package/browser/transaction/browser/extensions/UnisatSigner.d.ts.map +1 -0
- package/browser/transaction/browser/extensions/XverseSigner.d.ts +9 -7
- package/browser/transaction/browser/extensions/XverseSigner.d.ts.map +1 -0
- package/browser/transaction/browser/types/OPWallet.d.ts +10 -0
- package/browser/transaction/browser/types/OPWallet.d.ts.map +1 -0
- package/browser/transaction/browser/types/Unisat.d.ts +1 -0
- package/browser/transaction/browser/types/Unisat.d.ts.map +1 -0
- package/browser/transaction/browser/types/Xverse.d.ts +1 -0
- package/browser/transaction/browser/types/Xverse.d.ts.map +1 -0
- package/browser/transaction/builders/CancelTransaction.d.ts +29 -4
- package/browser/transaction/builders/CancelTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/ChallengeSolutionTransaction.d.ts +1 -0
- package/browser/transaction/builders/ChallengeSolutionTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/ConsolidatedInteractionTransaction.d.ts +137 -10
- package/browser/transaction/builders/ConsolidatedInteractionTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/CustomScriptTransaction.d.ts +106 -6
- package/browser/transaction/builders/CustomScriptTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/DeploymentTransaction.d.ts +116 -5
- package/browser/transaction/builders/DeploymentTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/FundingTransaction.d.ts +4 -3
- package/browser/transaction/builders/FundingTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/InteractionTransaction.d.ts +12 -3
- package/browser/transaction/builders/InteractionTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/InteractionTransactionP2WDA.d.ts +56 -5
- package/browser/transaction/builders/InteractionTransactionP2WDA.d.ts.map +1 -0
- package/browser/transaction/builders/MultiSignTransaction.d.ts +125 -16
- package/browser/transaction/builders/MultiSignTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/SharedInteractionTransaction.d.ts +103 -15
- package/browser/transaction/builders/SharedInteractionTransaction.d.ts.map +1 -0
- package/browser/transaction/builders/TransactionBuilder.d.ts +243 -14
- package/browser/transaction/builders/TransactionBuilder.d.ts.map +1 -0
- package/browser/transaction/enums/TransactionType.d.ts +1 -0
- package/browser/transaction/enums/TransactionType.d.ts.map +1 -0
- package/browser/transaction/interfaces/ICancelTransactionParameters.d.ts +2 -1
- package/browser/transaction/interfaces/ICancelTransactionParameters.d.ts.map +1 -0
- package/browser/transaction/interfaces/IConsolidatedTransactionParameters.d.ts +46 -3
- package/browser/transaction/interfaces/IConsolidatedTransactionParameters.d.ts.map +1 -0
- package/browser/transaction/interfaces/ICustomTransactionParameters.d.ts +6 -4
- package/browser/transaction/interfaces/ICustomTransactionParameters.d.ts.map +1 -0
- package/browser/transaction/interfaces/ITransactionParameters.d.ts +22 -10
- package/browser/transaction/interfaces/ITransactionParameters.d.ts.map +1 -0
- package/browser/transaction/interfaces/ITransactionResponses.d.ts +1 -0
- package/browser/transaction/interfaces/ITransactionResponses.d.ts.map +1 -0
- package/browser/transaction/interfaces/ITweakedTransactionData.d.ts +18 -5
- package/browser/transaction/interfaces/ITweakedTransactionData.d.ts.map +1 -0
- package/browser/transaction/interfaces/IWeb3ProviderTypes.d.ts +26 -0
- package/browser/transaction/interfaces/IWeb3ProviderTypes.d.ts.map +1 -0
- package/browser/transaction/interfaces/Tap.d.ts +4 -3
- package/browser/transaction/interfaces/Tap.d.ts.map +1 -0
- package/browser/transaction/mineable/IP2WSHAddress.d.ts +2 -1
- package/browser/transaction/mineable/IP2WSHAddress.d.ts.map +1 -0
- package/browser/transaction/mineable/TimelockGenerator.d.ts +12 -3
- package/browser/transaction/mineable/TimelockGenerator.d.ts.map +1 -0
- package/browser/transaction/offline/OfflineTransactionManager.d.ts +190 -9
- package/browser/transaction/offline/OfflineTransactionManager.d.ts.map +1 -0
- package/browser/transaction/offline/TransactionReconstructor.d.ts +53 -3
- package/browser/transaction/offline/TransactionReconstructor.d.ts.map +1 -0
- package/browser/transaction/offline/TransactionSerializer.d.ts +53 -2
- package/browser/transaction/offline/TransactionSerializer.d.ts.map +1 -0
- package/browser/transaction/offline/TransactionStateCapture.d.ts +64 -5
- package/browser/transaction/offline/TransactionStateCapture.d.ts.map +1 -0
- package/browser/transaction/offline/interfaces/ISerializableState.d.ts +71 -0
- package/browser/transaction/offline/interfaces/ISerializableState.d.ts.map +1 -0
- package/browser/transaction/offline/interfaces/ITypeSpecificData.d.ts +76 -0
- package/browser/transaction/offline/interfaces/ITypeSpecificData.d.ts.map +1 -0
- package/browser/transaction/psbt/PSBTTypes.d.ts +1 -0
- package/browser/transaction/psbt/PSBTTypes.d.ts.map +1 -0
- package/browser/transaction/shared/P2TR_MS.d.ts +11 -2
- package/browser/transaction/shared/P2TR_MS.d.ts.map +1 -0
- package/browser/transaction/shared/TweakedTransaction.d.ts +275 -33
- package/browser/transaction/shared/TweakedTransaction.d.ts.map +1 -0
- package/browser/transaction/utils/WitnessUtils.d.ts +7 -1
- package/browser/transaction/utils/WitnessUtils.d.ts.map +1 -0
- package/browser/utils/BitcoinUtils.d.ts +19 -0
- package/browser/utils/BitcoinUtils.d.ts.map +1 -0
- package/browser/utils/BufferHelper.d.ts +1 -0
- package/browser/utils/BufferHelper.d.ts.map +1 -0
- package/browser/utils/StringToBuffer.d.ts +1 -0
- package/browser/utils/StringToBuffer.d.ts.map +1 -0
- package/browser/utils/lengths.d.ts +1 -0
- package/browser/utils/lengths.d.ts.map +1 -0
- package/browser/utils/types.d.ts +1 -0
- package/browser/utils/types.d.ts.map +1 -0
- package/browser/utxo/OPNetLimitedProvider.d.ts +37 -1
- package/browser/utxo/OPNetLimitedProvider.d.ts.map +1 -0
- package/browser/utxo/interfaces/BroadcastResponse.d.ts +1 -0
- package/browser/utxo/interfaces/BroadcastResponse.d.ts.map +1 -0
- package/browser/utxo/interfaces/IUTXO.d.ts +11 -5
- package/browser/utxo/interfaces/IUTXO.d.ts.map +1 -0
- package/browser/vendors.js +14351 -10031
- package/browser/verification/TapscriptVerificator.d.ts +10 -8
- package/browser/verification/TapscriptVerificator.d.ts.map +1 -0
- package/build/_version.d.ts +1 -0
- package/build/_version.d.ts.map +1 -0
- package/build/_version.js +1 -0
- package/build/_version.js.map +1 -0
- package/build/abi/ABICoder.d.ts +1 -1
- package/build/abi/ABICoder.d.ts.map +1 -0
- package/build/abi/ABICoder.js +9 -10
- package/build/abi/ABICoder.js.map +1 -0
- package/build/branded/Branded.d.ts +4 -0
- package/build/branded/Branded.d.ts.map +1 -0
- package/build/branded/Branded.js +2 -0
- package/build/branded/Branded.js.map +1 -0
- package/build/buffer/BinaryReader.d.ts +121 -2
- package/build/buffer/BinaryReader.d.ts.map +1 -0
- package/build/buffer/BinaryReader.js +129 -5
- package/build/buffer/BinaryReader.js.map +1 -0
- package/build/buffer/BinaryWriter.d.ts +52 -2
- package/build/buffer/BinaryWriter.d.ts.map +1 -0
- package/build/buffer/BinaryWriter.js +62 -2
- package/build/buffer/BinaryWriter.js.map +1 -0
- package/build/bytecode/Compressor.d.ts +12 -0
- package/build/bytecode/Compressor.d.ts.map +1 -0
- package/build/bytecode/Compressor.js +17 -5
- package/build/bytecode/Compressor.js.map +1 -0
- package/build/chain/ChainData.d.ts +2 -2
- package/build/chain/ChainData.d.ts.map +1 -0
- package/build/chain/ChainData.js +35 -17
- package/build/chain/ChainData.js.map +1 -0
- package/build/consensus/Consensus.d.ts +11 -3
- package/build/consensus/Consensus.d.ts.map +1 -0
- package/build/consensus/Consensus.js +8 -0
- package/build/consensus/Consensus.js.map +1 -0
- package/build/consensus/ConsensusConfig.d.ts +2 -1
- package/build/consensus/ConsensusConfig.d.ts.map +1 -0
- package/build/consensus/ConsensusConfig.js +1 -0
- package/build/consensus/ConsensusConfig.js.map +1 -0
- package/build/consensus/IConsensusConfig.d.ts +1 -0
- package/build/consensus/IConsensusConfig.d.ts.map +1 -0
- package/build/consensus/IConsensusConfig.js +2 -1
- package/build/consensus/IConsensusConfig.js.map +1 -0
- package/build/consensus/metadata/RoswellConsensus.d.ts +2 -1
- package/build/consensus/metadata/RoswellConsensus.d.ts.map +1 -0
- package/build/consensus/metadata/RoswellConsensus.js +2 -0
- package/build/consensus/metadata/RoswellConsensus.js.map +1 -0
- package/build/crypto/crypto.d.ts +1 -0
- package/build/crypto/crypto.d.ts.map +1 -0
- package/build/crypto/crypto.js +1 -0
- package/build/crypto/crypto.js.map +1 -0
- package/build/deterministic/AddressMap.d.ts +6 -1
- package/build/deterministic/AddressMap.d.ts.map +1 -0
- package/build/deterministic/AddressMap.js +8 -0
- package/build/deterministic/AddressMap.js.map +1 -0
- package/build/deterministic/AddressSet.d.ts +3 -1
- package/build/deterministic/AddressSet.d.ts.map +1 -0
- package/build/deterministic/AddressSet.js +7 -0
- package/build/deterministic/AddressSet.js.map +1 -0
- package/build/deterministic/CustomMap.d.ts +3 -1
- package/build/deterministic/CustomMap.d.ts.map +1 -0
- package/build/deterministic/CustomMap.js +65 -47
- package/build/deterministic/CustomMap.js.map +1 -0
- package/build/deterministic/DeterministicMap.d.ts +4 -2
- package/build/deterministic/DeterministicMap.d.ts.map +1 -0
- package/build/deterministic/DeterministicMap.js +24 -27
- package/build/deterministic/DeterministicMap.js.map +1 -0
- package/build/deterministic/DeterministicSet.d.ts +3 -1
- package/build/deterministic/DeterministicSet.d.ts.map +1 -0
- package/build/deterministic/DeterministicSet.js +6 -0
- package/build/deterministic/DeterministicSet.js.map +1 -0
- package/build/deterministic/ExtendedAddressMap.d.ts +7 -1
- package/build/deterministic/ExtendedAddressMap.d.ts.map +1 -0
- package/build/deterministic/ExtendedAddressMap.js +18 -2
- package/build/deterministic/ExtendedAddressMap.js.map +1 -0
- package/build/deterministic/FastMap.d.ts +7 -1
- package/build/deterministic/FastMap.d.ts.map +1 -0
- package/build/deterministic/FastMap.js +7 -2
- package/build/deterministic/FastMap.js.map +1 -0
- package/build/ecc/backend.d.ts +13 -0
- package/build/ecc/backend.d.ts.map +1 -0
- package/build/ecc/backend.js +15 -0
- package/build/ecc/backend.js.map +1 -0
- package/build/epoch/ChallengeSolution.d.ts +34 -2
- package/build/epoch/ChallengeSolution.d.ts.map +1 -0
- package/build/epoch/ChallengeSolution.js +52 -0
- package/build/epoch/ChallengeSolution.js.map +1 -0
- package/build/epoch/interfaces/IChallengeSolution.d.ts +14 -13
- package/build/epoch/interfaces/IChallengeSolution.d.ts.map +1 -0
- package/build/epoch/interfaces/IChallengeSolution.js +2 -1
- package/build/epoch/interfaces/IChallengeSolution.js.map +1 -0
- package/build/epoch/validator/EpochValidator.d.ts +38 -8
- package/build/epoch/validator/EpochValidator.d.ts.map +1 -0
- package/build/epoch/validator/EpochValidator.js +45 -19
- package/build/epoch/validator/EpochValidator.js.map +1 -0
- package/build/event/NetEvent.d.ts +1 -0
- package/build/event/NetEvent.d.ts.map +1 -0
- package/build/event/NetEvent.js +3 -0
- package/build/event/NetEvent.js.map +1 -0
- package/build/generators/AddressGenerator.d.ts +4 -3
- package/build/generators/AddressGenerator.d.ts.map +1 -0
- package/build/generators/AddressGenerator.js +10 -3
- package/build/generators/AddressGenerator.js.map +1 -0
- package/build/generators/Features.d.ts +4 -3
- package/build/generators/Features.d.ts.map +1 -0
- package/build/generators/Features.js +1 -0
- package/build/generators/Features.js.map +1 -0
- package/build/generators/Generator.d.ts +47 -11
- package/build/generators/Generator.d.ts.map +1 -0
- package/build/generators/Generator.js +48 -12
- package/build/generators/Generator.js.map +1 -0
- package/build/generators/MLDSAData.d.ts +1 -0
- package/build/generators/MLDSAData.d.ts.map +1 -0
- package/build/generators/MLDSAData.js +1 -0
- package/build/generators/MLDSAData.js.map +1 -0
- package/build/generators/builders/CalldataGenerator.d.ts +27 -6
- package/build/generators/builders/CalldataGenerator.d.ts.map +1 -0
- package/build/generators/builders/CalldataGenerator.js +33 -4
- package/build/generators/builders/CalldataGenerator.js.map +1 -0
- package/build/generators/builders/CustomGenerator.d.ts +13 -3
- package/build/generators/builders/CustomGenerator.d.ts.map +1 -0
- package/build/generators/builders/CustomGenerator.js +11 -0
- package/build/generators/builders/CustomGenerator.js.map +1 -0
- package/build/generators/builders/DeploymentGenerator.d.ts +17 -6
- package/build/generators/builders/DeploymentGenerator.d.ts.map +1 -0
- package/build/generators/builders/DeploymentGenerator.js +18 -2
- package/build/generators/builders/DeploymentGenerator.js.map +1 -0
- package/build/generators/builders/HashCommitmentGenerator.d.ts +166 -14
- package/build/generators/builders/HashCommitmentGenerator.d.ts.map +1 -0
- package/build/generators/builders/HashCommitmentGenerator.js +193 -27
- package/build/generators/builders/HashCommitmentGenerator.js.map +1 -0
- package/build/generators/builders/LegacyCalldataGenerator.d.ts +27 -5
- package/build/generators/builders/LegacyCalldataGenerator.d.ts.map +1 -0
- package/build/generators/builders/LegacyCalldataGenerator.js +35 -5
- package/build/generators/builders/LegacyCalldataGenerator.js.map +1 -0
- package/build/generators/builders/MultiSignGenerator.d.ts +6 -1
- package/build/generators/builders/MultiSignGenerator.d.ts.map +1 -0
- package/build/generators/builders/MultiSignGenerator.js +20 -10
- package/build/generators/builders/MultiSignGenerator.js.map +1 -0
- package/build/generators/builders/P2WDAGenerator.d.ts +44 -6
- package/build/generators/builders/P2WDAGenerator.d.ts.map +1 -0
- package/build/generators/builders/P2WDAGenerator.js +41 -2
- package/build/generators/builders/P2WDAGenerator.js.map +1 -0
- package/build/index.d.ts +1 -0
- package/build/index.d.ts.map +1 -0
- package/build/index.js +1 -0
- package/build/index.js.map +1 -0
- package/build/keypair/Address.d.ts +284 -14
- package/build/keypair/Address.d.ts.map +1 -0
- package/build/keypair/Address.js +446 -128
- package/build/keypair/Address.js.map +1 -0
- package/build/keypair/AddressVerificator.d.ts +7 -6
- package/build/keypair/AddressVerificator.d.ts.map +1 -0
- package/build/keypair/AddressVerificator.js +6 -5
- package/build/keypair/AddressVerificator.js.map +1 -0
- package/build/keypair/EcKeyPair.d.ts +185 -23
- package/build/keypair/EcKeyPair.d.ts.map +1 -0
- package/build/keypair/EcKeyPair.js +219 -50
- package/build/keypair/EcKeyPair.js.map +1 -0
- package/build/keypair/MessageSigner.d.ts +18 -17
- package/build/keypair/MessageSigner.d.ts.map +1 -0
- package/build/keypair/MessageSigner.js +34 -25
- package/build/keypair/MessageSigner.js.map +1 -0
- package/build/keypair/Secp256k1PointDeriver.d.ts +55 -0
- package/build/keypair/Secp256k1PointDeriver.d.ts.map +1 -0
- package/build/keypair/Secp256k1PointDeriver.js +66 -0
- package/build/keypair/Secp256k1PointDeriver.js.map +1 -0
- package/build/keypair/Wallet.d.ts +29 -15
- package/build/keypair/Wallet.d.ts.map +1 -0
- package/build/keypair/Wallet.js +48 -14
- package/build/keypair/Wallet.js.map +1 -0
- package/build/keypair/interfaces/IWallet.d.ts +19 -0
- package/build/keypair/interfaces/IWallet.d.ts.map +1 -0
- package/build/keypair/interfaces/IWallet.js +1 -0
- package/build/keypair/interfaces/IWallet.js.map +1 -0
- package/build/metadata/ContractBaseMetadata.d.ts +10 -2
- package/build/metadata/ContractBaseMetadata.d.ts.map +1 -0
- package/build/metadata/ContractBaseMetadata.js +10 -1
- package/build/metadata/ContractBaseMetadata.js.map +1 -0
- package/build/mnemonic/BIPStandard.d.ts +59 -0
- package/build/mnemonic/BIPStandard.d.ts.map +1 -0
- package/build/mnemonic/BIPStandard.js +59 -0
- package/build/mnemonic/BIPStandard.js.map +1 -0
- package/build/mnemonic/Mnemonic.d.ts +16 -4
- package/build/mnemonic/Mnemonic.d.ts.map +1 -0
- package/build/mnemonic/Mnemonic.js +36 -8
- package/build/mnemonic/Mnemonic.js.map +1 -0
- package/build/mnemonic/MnemonicStrength.d.ts +6 -0
- package/build/mnemonic/MnemonicStrength.d.ts.map +1 -0
- package/build/mnemonic/MnemonicStrength.js +6 -0
- package/build/mnemonic/MnemonicStrength.js.map +1 -0
- package/build/network/ChainId.d.ts +1 -0
- package/build/network/ChainId.d.ts.map +1 -0
- package/build/network/ChainId.js +1 -0
- package/build/network/ChainId.js.map +1 -0
- package/build/opnet.d.ts +26 -3
- package/build/opnet.d.ts.map +1 -0
- package/build/opnet.js +23 -0
- package/build/opnet.js.map +1 -0
- package/build/p2wda/P2WDADetector.d.ts +38 -11
- package/build/p2wda/P2WDADetector.d.ts.map +1 -0
- package/build/p2wda/P2WDADetector.js +43 -10
- package/build/p2wda/P2WDADetector.js.map +1 -0
- package/build/polyfill/disposable.d.ts +16 -0
- package/build/polyfill/disposable.d.ts.map +1 -0
- package/build/polyfill/disposable.js +23 -0
- package/build/polyfill/disposable.js.map +1 -0
- package/build/signer/AddressRotation.d.ts +37 -1
- package/build/signer/AddressRotation.d.ts.map +1 -0
- package/build/signer/AddressRotation.js +16 -0
- package/build/signer/AddressRotation.js.map +1 -0
- package/build/signer/IRotationSigner.d.ts +27 -3
- package/build/signer/IRotationSigner.d.ts.map +1 -0
- package/build/signer/IRotationSigner.js +2 -1
- package/build/signer/IRotationSigner.js.map +1 -0
- package/build/signer/ParallelSignerAdapter.d.ts +14 -0
- package/build/signer/ParallelSignerAdapter.d.ts.map +1 -0
- package/build/signer/ParallelSignerAdapter.js +51 -0
- package/build/signer/ParallelSignerAdapter.js.map +1 -0
- package/build/signer/SignerUtils.d.ts +11 -4
- package/build/signer/SignerUtils.d.ts.map +1 -0
- package/build/signer/SignerUtils.js +16 -0
- package/build/signer/SignerUtils.js.map +1 -0
- package/build/signer/TweakedSigner.d.ts +28 -4
- package/build/signer/TweakedSigner.d.ts.map +1 -0
- package/build/signer/TweakedSigner.js +24 -6
- package/build/signer/TweakedSigner.js.map +1 -0
- package/build/transaction/ContractAddress.d.ts +2 -2
- package/build/transaction/ContractAddress.d.ts.map +1 -0
- package/build/transaction/ContractAddress.js +4 -8
- package/build/transaction/ContractAddress.js.map +1 -0
- package/build/transaction/TransactionFactory.d.ts +147 -9
- package/build/transaction/TransactionFactory.d.ts.map +1 -0
- package/build/transaction/TransactionFactory.js +145 -26
- package/build/transaction/TransactionFactory.js.map +1 -0
- package/build/transaction/browser/BrowserSignerBase.d.ts +12 -6
- package/build/transaction/browser/BrowserSignerBase.d.ts.map +1 -0
- package/build/transaction/browser/BrowserSignerBase.js +7 -0
- package/build/transaction/browser/BrowserSignerBase.js.map +1 -0
- package/build/transaction/browser/WalletNetworks.d.ts +1 -0
- package/build/transaction/browser/WalletNetworks.d.ts.map +1 -0
- package/build/transaction/browser/WalletNetworks.js +1 -0
- package/build/transaction/browser/WalletNetworks.js.map +1 -0
- package/build/transaction/browser/Web3Provider.d.ts +30 -3
- package/build/transaction/browser/Web3Provider.d.ts.map +1 -0
- package/build/transaction/browser/Web3Provider.js +1 -0
- package/build/transaction/browser/Web3Provider.js.map +1 -0
- package/build/transaction/browser/extensions/UnisatSigner.d.ts +11 -9
- package/build/transaction/browser/extensions/UnisatSigner.d.ts.map +1 -0
- package/build/transaction/browser/extensions/UnisatSigner.js +27 -17
- package/build/transaction/browser/extensions/UnisatSigner.js.map +1 -0
- package/build/transaction/browser/extensions/XverseSigner.d.ts +10 -8
- package/build/transaction/browser/extensions/XverseSigner.d.ts.map +1 -0
- package/build/transaction/browser/extensions/XverseSigner.js +25 -15
- package/build/transaction/browser/extensions/XverseSigner.js.map +1 -0
- package/build/transaction/browser/types/OPWallet.d.ts +12 -2
- package/build/transaction/browser/types/OPWallet.d.ts.map +1 -0
- package/build/transaction/browser/types/OPWallet.js +4 -0
- package/build/transaction/browser/types/OPWallet.js.map +1 -0
- package/build/transaction/browser/types/Unisat.d.ts +2 -1
- package/build/transaction/browser/types/Unisat.d.ts.map +1 -0
- package/build/transaction/browser/types/Unisat.js +2 -0
- package/build/transaction/browser/types/Unisat.js.map +1 -0
- package/build/transaction/browser/types/Xverse.d.ts +1 -0
- package/build/transaction/browser/types/Xverse.d.ts.map +1 -0
- package/build/transaction/browser/types/Xverse.js +1 -0
- package/build/transaction/browser/types/Xverse.js.map +1 -0
- package/build/transaction/builders/CancelTransaction.d.ts +31 -6
- package/build/transaction/builders/CancelTransaction.d.ts.map +1 -0
- package/build/transaction/builders/CancelTransaction.js +116 -33
- package/build/transaction/builders/CancelTransaction.js.map +1 -0
- package/build/transaction/builders/ChallengeSolutionTransaction.d.ts +1 -0
- package/build/transaction/builders/ChallengeSolutionTransaction.d.ts.map +1 -0
- package/build/transaction/builders/ChallengeSolutionTransaction.js +88 -0
- package/build/transaction/builders/ChallengeSolutionTransaction.js.map +1 -0
- package/build/transaction/builders/ConsolidatedInteractionTransaction.d.ts +140 -13
- package/build/transaction/builders/ConsolidatedInteractionTransaction.d.ts.map +1 -0
- package/build/transaction/builders/ConsolidatedInteractionTransaction.js +197 -20
- package/build/transaction/builders/ConsolidatedInteractionTransaction.js.map +1 -0
- package/build/transaction/builders/CustomScriptTransaction.d.ts +108 -8
- package/build/transaction/builders/CustomScriptTransaction.d.ts.map +1 -0
- package/build/transaction/builders/CustomScriptTransaction.js +176 -39
- package/build/transaction/builders/CustomScriptTransaction.js.map +1 -0
- package/build/transaction/builders/DeploymentTransaction.d.ts +120 -9
- package/build/transaction/builders/DeploymentTransaction.d.ts.map +1 -0
- package/build/transaction/builders/DeploymentTransaction.js +194 -51
- package/build/transaction/builders/DeploymentTransaction.js.map +1 -0
- package/build/transaction/builders/FundingTransaction.d.ts +5 -4
- package/build/transaction/builders/FundingTransaction.d.ts.map +1 -0
- package/build/transaction/builders/FundingTransaction.js +15 -8
- package/build/transaction/builders/FundingTransaction.js.map +1 -0
- package/build/transaction/builders/InteractionTransaction.d.ts +14 -5
- package/build/transaction/builders/InteractionTransaction.d.ts.map +1 -0
- package/build/transaction/builders/InteractionTransaction.js +18 -5
- package/build/transaction/builders/InteractionTransaction.js.map +1 -0
- package/build/transaction/builders/InteractionTransactionP2WDA.d.ts +58 -7
- package/build/transaction/builders/InteractionTransactionP2WDA.d.ts.map +1 -0
- package/build/transaction/builders/InteractionTransactionP2WDA.js +95 -18
- package/build/transaction/builders/InteractionTransactionP2WDA.js.map +1 -0
- package/build/transaction/builders/MultiSignTransaction.d.ts +126 -17
- package/build/transaction/builders/MultiSignTransaction.d.ts.map +1 -0
- package/build/transaction/builders/MultiSignTransaction.js +201 -76
- package/build/transaction/builders/MultiSignTransaction.js.map +1 -0
- package/build/transaction/builders/SharedInteractionTransaction.d.ts +106 -18
- package/build/transaction/builders/SharedInteractionTransaction.d.ts.map +1 -0
- package/build/transaction/builders/SharedInteractionTransaction.js +158 -40
- package/build/transaction/builders/SharedInteractionTransaction.js.map +1 -0
- package/build/transaction/builders/TransactionBuilder.d.ts +249 -19
- package/build/transaction/builders/TransactionBuilder.d.ts.map +1 -0
- package/build/transaction/builders/TransactionBuilder.js +377 -60
- package/build/transaction/builders/TransactionBuilder.js.map +1 -0
- package/build/transaction/enums/TransactionType.d.ts +1 -0
- package/build/transaction/enums/TransactionType.d.ts.map +1 -0
- package/build/transaction/enums/TransactionType.js +1 -0
- package/build/transaction/enums/TransactionType.js.map +1 -0
- package/build/transaction/interfaces/ICancelTransactionParameters.d.ts +3 -2
- package/build/transaction/interfaces/ICancelTransactionParameters.d.ts.map +1 -0
- package/build/transaction/interfaces/ICancelTransactionParameters.js +1 -0
- package/build/transaction/interfaces/ICancelTransactionParameters.js.map +1 -0
- package/build/transaction/interfaces/IConsolidatedTransactionParameters.d.ts +48 -5
- package/build/transaction/interfaces/IConsolidatedTransactionParameters.d.ts.map +1 -0
- package/build/transaction/interfaces/IConsolidatedTransactionParameters.js +1 -0
- package/build/transaction/interfaces/IConsolidatedTransactionParameters.js.map +1 -0
- package/build/transaction/interfaces/ICustomTransactionParameters.d.ts +7 -5
- package/build/transaction/interfaces/ICustomTransactionParameters.d.ts.map +1 -0
- package/build/transaction/interfaces/ICustomTransactionParameters.js +1 -0
- package/build/transaction/interfaces/ICustomTransactionParameters.js.map +1 -0
- package/build/transaction/interfaces/ITransactionParameters.d.ts +27 -15
- package/build/transaction/interfaces/ITransactionParameters.d.ts.map +1 -0
- package/build/transaction/interfaces/ITransactionParameters.js +1 -0
- package/build/transaction/interfaces/ITransactionParameters.js.map +1 -0
- package/build/transaction/interfaces/ITransactionResponses.d.ts +3 -2
- package/build/transaction/interfaces/ITransactionResponses.d.ts.map +1 -0
- package/build/transaction/interfaces/ITransactionResponses.js +1 -0
- package/build/transaction/interfaces/ITransactionResponses.js.map +1 -0
- package/build/transaction/interfaces/ITweakedTransactionData.d.ts +21 -8
- package/build/transaction/interfaces/ITweakedTransactionData.d.ts.map +1 -0
- package/build/transaction/interfaces/ITweakedTransactionData.js +1 -0
- package/build/transaction/interfaces/ITweakedTransactionData.js.map +1 -0
- package/build/transaction/interfaces/IWeb3ProviderTypes.d.ts +29 -3
- package/build/transaction/interfaces/IWeb3ProviderTypes.d.ts.map +1 -0
- package/build/transaction/interfaces/IWeb3ProviderTypes.js +2 -1
- package/build/transaction/interfaces/IWeb3ProviderTypes.js.map +1 -0
- package/build/transaction/interfaces/Tap.d.ts +4 -3
- package/build/transaction/interfaces/Tap.d.ts.map +1 -0
- package/build/transaction/interfaces/Tap.js +1 -0
- package/build/transaction/interfaces/Tap.js.map +1 -0
- package/build/transaction/mineable/IP2WSHAddress.d.ts +2 -1
- package/build/transaction/mineable/IP2WSHAddress.d.ts.map +1 -0
- package/build/transaction/mineable/IP2WSHAddress.js +1 -0
- package/build/transaction/mineable/IP2WSHAddress.js.map +1 -0
- package/build/transaction/mineable/TimelockGenerator.d.ts +13 -4
- package/build/transaction/mineable/TimelockGenerator.d.ts.map +1 -0
- package/build/transaction/mineable/TimelockGenerator.js +12 -3
- package/build/transaction/mineable/TimelockGenerator.js.map +1 -0
- package/build/transaction/offline/OfflineTransactionManager.d.ts +193 -12
- package/build/transaction/offline/OfflineTransactionManager.d.ts.map +1 -0
- package/build/transaction/offline/OfflineTransactionManager.js +192 -8
- package/build/transaction/offline/OfflineTransactionManager.js.map +1 -0
- package/build/transaction/offline/TransactionReconstructor.d.ts +56 -6
- package/build/transaction/offline/TransactionReconstructor.d.ts.map +1 -0
- package/build/transaction/offline/TransactionReconstructor.js +111 -75
- package/build/transaction/offline/TransactionReconstructor.js.map +1 -0
- package/build/transaction/offline/TransactionSerializer.d.ts +54 -3
- package/build/transaction/offline/TransactionSerializer.d.ts.map +1 -0
- package/build/transaction/offline/TransactionSerializer.js +206 -95
- package/build/transaction/offline/TransactionSerializer.js.map +1 -0
- package/build/transaction/offline/TransactionStateCapture.d.ts +66 -7
- package/build/transaction/offline/TransactionStateCapture.d.ts.map +1 -0
- package/build/transaction/offline/TransactionStateCapture.js +124 -60
- package/build/transaction/offline/TransactionStateCapture.js.map +1 -0
- package/build/transaction/offline/interfaces/ISerializableState.d.ts +72 -1
- package/build/transaction/offline/interfaces/ISerializableState.d.ts.map +1 -0
- package/build/transaction/offline/interfaces/ISerializableState.js +10 -1
- package/build/transaction/offline/interfaces/ISerializableState.js.map +1 -0
- package/build/transaction/offline/interfaces/ITypeSpecificData.d.ts +77 -1
- package/build/transaction/offline/interfaces/ITypeSpecificData.d.ts.map +1 -0
- package/build/transaction/offline/interfaces/ITypeSpecificData.js +19 -0
- package/build/transaction/offline/interfaces/ITypeSpecificData.js.map +1 -0
- package/build/transaction/psbt/PSBTTypes.d.ts +1 -0
- package/build/transaction/psbt/PSBTTypes.d.ts.map +1 -0
- package/build/transaction/psbt/PSBTTypes.js +1 -0
- package/build/transaction/psbt/PSBTTypes.js.map +1 -0
- package/build/transaction/shared/P2TR_MS.d.ts +11 -2
- package/build/transaction/shared/P2TR_MS.d.ts.map +1 -0
- package/build/transaction/shared/P2TR_MS.js +10 -0
- package/build/transaction/shared/P2TR_MS.js.map +1 -0
- package/build/transaction/shared/TweakedTransaction.d.ts +281 -38
- package/build/transaction/shared/TweakedTransaction.d.ts.map +1 -0
- package/build/transaction/shared/TweakedTransaction.js +576 -114
- package/build/transaction/shared/TweakedTransaction.js.map +1 -0
- package/build/transaction/utils/WitnessUtils.d.ts +7 -1
- package/build/transaction/utils/WitnessUtils.d.ts.map +1 -0
- package/build/transaction/utils/WitnessUtils.js +17 -3
- package/build/transaction/utils/WitnessUtils.js.map +1 -0
- package/build/tsconfig.build.tsbuildinfo +1 -1
- package/build/utils/BitcoinUtils.d.ts +19 -0
- package/build/utils/BitcoinUtils.d.ts.map +1 -0
- package/build/utils/BitcoinUtils.js +19 -0
- package/build/utils/BitcoinUtils.js.map +1 -0
- package/build/utils/BufferHelper.d.ts +2 -1
- package/build/utils/BufferHelper.d.ts.map +1 -0
- package/build/utils/BufferHelper.js +38 -32
- package/build/utils/BufferHelper.js.map +1 -0
- package/build/utils/StringToBuffer.d.ts +1 -0
- package/build/utils/StringToBuffer.d.ts.map +1 -0
- package/build/utils/StringToBuffer.js +1 -0
- package/build/utils/StringToBuffer.js.map +1 -0
- package/build/utils/lengths.d.ts +1 -0
- package/build/utils/lengths.d.ts.map +1 -0
- package/build/utils/lengths.js +1 -0
- package/build/utils/lengths.js.map +1 -0
- package/build/utils/types.d.ts +1 -0
- package/build/utils/types.d.ts.map +1 -0
- package/build/utils/types.js +2 -1
- package/build/utils/types.js.map +1 -0
- package/build/utxo/OPNetLimitedProvider.d.ts +39 -3
- package/build/utxo/OPNetLimitedProvider.d.ts.map +1 -0
- package/build/utxo/OPNetLimitedProvider.js +41 -3
- package/build/utxo/OPNetLimitedProvider.js.map +1 -0
- package/build/utxo/interfaces/BroadcastResponse.d.ts +1 -0
- package/build/utxo/interfaces/BroadcastResponse.d.ts.map +1 -0
- package/build/utxo/interfaces/BroadcastResponse.js +1 -0
- package/build/utxo/interfaces/BroadcastResponse.js.map +1 -0
- package/build/utxo/interfaces/IUTXO.d.ts +13 -7
- package/build/utxo/interfaces/IUTXO.d.ts.map +1 -0
- package/build/utxo/interfaces/IUTXO.js +1 -0
- package/build/utxo/interfaces/IUTXO.js.map +1 -0
- package/build/verification/TapscriptVerificator.d.ts +12 -10
- package/build/verification/TapscriptVerificator.d.ts.map +1 -0
- package/build/verification/TapscriptVerificator.js +28 -38
- package/build/verification/TapscriptVerificator.js.map +1 -0
- package/eslint.config.js +0 -1
- package/package.json +12 -35
- package/src/abi/ABICoder.ts +0 -13
- package/src/branded/Branded.ts +5 -0
- package/src/buffer/BinaryReader.ts +7 -7
- package/src/buffer/BinaryWriter.ts +29 -24
- package/src/bytecode/Compressor.ts +1 -1
- package/src/chain/ChainData.ts +34 -27
- package/src/consensus/ConsensusConfig.ts +1 -1
- package/src/consensus/IConsensusConfig.ts +0 -17
- package/src/consensus/metadata/RoswellConsensus.ts +1 -17
- package/src/deterministic/AddressMap.ts +5 -1
- package/src/deterministic/AddressSet.ts +5 -1
- package/src/deterministic/CustomMap.ts +6 -2
- package/src/deterministic/DeterministicMap.ts +8 -4
- package/src/deterministic/DeterministicSet.ts +6 -2
- package/src/deterministic/ExtendedAddressMap.ts +9 -4
- package/src/deterministic/FastMap.ts +9 -5
- package/src/ecc/backend.ts +17 -0
- package/src/epoch/ChallengeSolution.ts +3 -3
- package/src/epoch/interfaces/IChallengeSolution.ts +13 -13
- package/src/epoch/validator/EpochValidator.ts +24 -43
- package/src/generators/AddressGenerator.ts +6 -6
- package/src/generators/Features.ts +3 -3
- package/src/generators/Generator.ts +42 -26
- package/src/generators/builders/CalldataGenerator.ts +26 -24
- package/src/generators/builders/CustomGenerator.ts +4 -4
- package/src/generators/builders/DeploymentGenerator.ts +25 -23
- package/src/generators/builders/HashCommitmentGenerator.ts +31 -31
- package/src/generators/builders/LegacyCalldataGenerator.ts +26 -24
- package/src/generators/builders/MultiSignGenerator.ts +12 -12
- package/src/generators/builders/P2WDAGenerator.ts +10 -10
- package/src/keypair/Address.ts +114 -71
- package/src/keypair/AddressVerificator.ts +16 -147
- package/src/keypair/EcKeyPair.ts +105 -114
- package/src/keypair/MessageSigner.ts +70 -150
- package/src/keypair/Wallet.ts +59 -240
- package/src/metadata/ContractBaseMetadata.ts +2 -2
- package/src/mnemonic/Mnemonic.ts +32 -221
- package/src/opnet.ts +12 -6
- package/src/p2wda/P2WDADetector.ts +23 -72
- package/src/polyfill/disposable.ts +29 -0
- package/src/signer/AddressRotation.ts +1 -1
- package/src/signer/IRotationSigner.ts +3 -3
- package/src/signer/ParallelSignerAdapter.ts +59 -0
- package/src/signer/SignerUtils.ts +4 -4
- package/src/signer/TweakedSigner.ts +28 -13
- package/src/transaction/ContractAddress.ts +3 -7
- package/src/transaction/TransactionFactory.ts +28 -50
- package/src/transaction/browser/BrowserSignerBase.ts +12 -6
- package/src/transaction/browser/Web3Provider.ts +3 -3
- package/src/transaction/browser/extensions/UnisatSigner.ts +52 -48
- package/src/transaction/browser/extensions/XverseSigner.ts +55 -38
- package/src/transaction/browser/types/OPWallet.ts +2 -2
- package/src/transaction/browser/types/Unisat.ts +1 -1
- package/src/transaction/builders/CancelTransaction.ts +59 -24
- package/src/transaction/builders/ChallengeSolutionTransaction.ts +3 -3
- package/src/transaction/builders/ConsolidatedInteractionTransaction.ts +39 -34
- package/src/transaction/builders/CustomScriptTransaction.ts +79 -56
- package/src/transaction/builders/DeploymentTransaction.ts +82 -63
- package/src/transaction/builders/FundingTransaction.ts +11 -11
- package/src/transaction/builders/InteractionTransaction.ts +10 -10
- package/src/transaction/builders/InteractionTransactionP2WDA.ts +38 -40
- package/src/transaction/builders/MultiSignTransaction.ts +68 -61
- package/src/transaction/builders/SharedInteractionTransaction.ts +81 -57
- package/src/transaction/builders/TransactionBuilder.ts +101 -79
- package/src/transaction/interfaces/ICancelTransactionParameters.ts +2 -2
- package/src/transaction/interfaces/IConsolidatedTransactionParameters.ts +5 -5
- package/src/transaction/interfaces/ICustomTransactionParameters.ts +5 -5
- package/src/transaction/interfaces/ITransactionParameters.ts +15 -15
- package/src/transaction/interfaces/ITransactionResponses.ts +2 -2
- package/src/transaction/interfaces/ITweakedTransactionData.ts +17 -8
- package/src/transaction/interfaces/IWeb3ProviderTypes.ts +3 -3
- package/src/transaction/interfaces/Tap.ts +3 -3
- package/src/transaction/mineable/IP2WSHAddress.ts +1 -1
- package/src/transaction/mineable/TimelockGenerator.ts +19 -12
- package/src/transaction/offline/OfflineTransactionManager.ts +22 -23
- package/src/transaction/offline/TransactionReconstructor.ts +83 -91
- package/src/transaction/offline/TransactionSerializer.ts +151 -101
- package/src/transaction/offline/TransactionStateCapture.ts +83 -79
- package/src/transaction/offline/interfaces/ISerializableState.ts +1 -1
- package/src/transaction/offline/interfaces/ITypeSpecificData.ts +1 -1
- package/src/transaction/shared/P2TR_MS.ts +4 -4
- package/src/transaction/shared/TweakedTransaction.ts +326 -124
- package/src/transaction/utils/WitnessUtils.ts +18 -9
- package/src/utils/BufferHelper.ts +39 -37
- package/src/utxo/OPNetLimitedProvider.ts +7 -7
- package/src/utxo/interfaces/IUTXO.ts +7 -7
- package/src/verification/TapscriptVerificator.ts +73 -86
- package/test/address-rotation.test.ts +24 -24
- package/test/address.test.ts +12 -12
- package/test/addressmap.test.ts +30 -30
- package/test/binary-reader-writer.test.ts +8 -8
- package/test/browser/offline-transaction.test.ts +2206 -0
- package/test/browser/parallel-signing.test.ts +316 -0
- package/test/browser/setup.ts +11 -0
- package/test/browser/transaction-signing.test.ts +416 -0
- package/test/buffer-helper.test.ts +287 -0
- package/test/derivePath.test.ts +4 -3
- package/test/disposable.test.ts +279 -0
- package/test/fastmap-setall.test.ts +1 -1
- package/test/fastmap.test.ts +3 -3
- package/test/messagesigner-mldsa.test.ts +3 -3
- package/test/messagesigner-schnorr.test.ts +9 -9
- package/test/offline-transaction.test.ts +461 -288
- package/test/old/FastBigIntMap.ts +3 -3
- package/test/oldfastmap.test.ts +6 -6
- package/test/transaction-builders.test.ts +321 -0
- package/tsconfig.base.json +34 -18
- package/tsconfig.browser.json +15 -0
- package/tsconfig.json +3 -8
- package/vite.config.browser.ts +4 -5
- package/vitest.config.browser.ts +68 -0
- package/vitest.config.ts +1 -1
- package/browser/valibot.js +0 -4948
- package/tsconfig.webpack.json +0 -18
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FastMap.js","sourceRoot":"","sources":["../../src/deterministic/FastMap.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { type CryptoBackend } from '@btc-vision/ecpair';
|
|
2
|
+
import { type EccLib } from '@btc-vision/bitcoin';
|
|
3
|
+
/**
|
|
4
|
+
* Shared noble-curves backend for all EC operations.
|
|
5
|
+
* Instantiated once and reused across the entire library.
|
|
6
|
+
*/
|
|
7
|
+
export declare const backend: CryptoBackend;
|
|
8
|
+
/**
|
|
9
|
+
* EccLib is now a type alias for CryptoBackend.
|
|
10
|
+
* The backend can be used directly.
|
|
11
|
+
*/
|
|
12
|
+
export declare const eccLib: EccLib;
|
|
13
|
+
//# sourceMappingURL=backend.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backend.d.ts","sourceRoot":"","sources":["../../src/ecc/backend.ts"],"names":[],"mappings":"AAAA,OAAO,EAAsB,KAAK,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAC5E,OAAO,EAAE,KAAK,MAAM,EAAc,MAAM,qBAAqB,CAAC;AAE9D;;;GAGG;AACH,eAAO,MAAM,OAAO,EAAE,aAAoC,CAAC;AAE3D;;;GAGG;AACH,eAAO,MAAM,MAAM,EAAE,MAAgB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { createNobleBackend } from '@btc-vision/ecpair';
|
|
2
|
+
import { initEccLib } from '@btc-vision/bitcoin';
|
|
3
|
+
/**
|
|
4
|
+
* Shared noble-curves backend for all EC operations.
|
|
5
|
+
* Instantiated once and reused across the entire library.
|
|
6
|
+
*/
|
|
7
|
+
export const backend = createNobleBackend();
|
|
8
|
+
/**
|
|
9
|
+
* EccLib is now a type alias for CryptoBackend.
|
|
10
|
+
* The backend can be used directly.
|
|
11
|
+
*/
|
|
12
|
+
export const eccLib = backend;
|
|
13
|
+
// Initialize the ECC library once at module load
|
|
14
|
+
initEccLib(eccLib);
|
|
15
|
+
//# sourceMappingURL=backend.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backend.js","sourceRoot":"","sources":["../../src/ecc/backend.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAsB,MAAM,oBAAoB,CAAC;AAC5E,OAAO,EAAe,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE9D;;;GAGG;AACH,MAAM,CAAC,MAAM,OAAO,GAAkB,kBAAkB,EAAE,CAAC;AAE3D;;;GAGG;AACH,MAAM,CAAC,MAAM,MAAM,GAAW,OAAO,CAAC;AAEtC,iDAAiD;AACjD,UAAU,CAAC,MAAM,CAAC,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IChallengeSolution, IChallengeSubmission, IChallengeVerification, RawChallenge, RawChallengeSubmission, RawChallengeVerification } from './interfaces/IChallengeSolution.js';
|
|
1
|
+
import type { IChallengeSolution, IChallengeSubmission, IChallengeVerification, RawChallenge, RawChallengeSubmission, RawChallengeVerification } from './interfaces/IChallengeSolution.js';
|
|
2
2
|
import { Address } from '../keypair/Address.js';
|
|
3
3
|
export declare class ChallengeVerification implements IChallengeVerification {
|
|
4
4
|
readonly epochHash: Buffer;
|
|
@@ -29,17 +29,49 @@ export declare class ChallengeSolution implements IChallengeSolution {
|
|
|
29
29
|
readonly verification: ChallengeVerification;
|
|
30
30
|
private readonly submission?;
|
|
31
31
|
constructor(data: RawChallenge);
|
|
32
|
+
/**
|
|
33
|
+
* Static method to validate from raw data directly
|
|
34
|
+
*/
|
|
32
35
|
static validateRaw(data: RawChallenge): boolean;
|
|
33
36
|
verifySubmissionSignature(): boolean;
|
|
34
37
|
getSubmission(): ChallengeSubmission | undefined;
|
|
38
|
+
/**
|
|
39
|
+
* Verify this challenge
|
|
40
|
+
* @returns {boolean} True if the challenge is valid
|
|
41
|
+
*/
|
|
35
42
|
verify(): boolean;
|
|
43
|
+
/**
|
|
44
|
+
* Get the preimage challenge
|
|
45
|
+
* @returns {Buffer} The solution/challenge as a buffer
|
|
46
|
+
*/
|
|
36
47
|
toBuffer(): Buffer;
|
|
48
|
+
/**
|
|
49
|
+
* Get the solution as a hex string
|
|
50
|
+
* @returns {string} The solution as a hex string with 0x prefix
|
|
51
|
+
*/
|
|
37
52
|
toHex(): string;
|
|
53
|
+
/**
|
|
54
|
+
* Convert to raw format for serialization
|
|
55
|
+
*/
|
|
38
56
|
toRaw(): RawChallenge;
|
|
39
|
-
|
|
57
|
+
/**
|
|
58
|
+
* Calculate the expected solution hash for this challenge
|
|
59
|
+
* @returns {Promise<Buffer>} The calculated solution hash
|
|
60
|
+
*/
|
|
61
|
+
calculateSolution(): Uint8Array;
|
|
62
|
+
/**
|
|
63
|
+
* Check if the challenge meets a specific difficulty requirement
|
|
64
|
+
* @param {number} minDifficulty The minimum difficulty required
|
|
65
|
+
* @returns {Promise<{valid: boolean; difficulty: number}>} Validation result
|
|
66
|
+
*/
|
|
40
67
|
checkDifficulty(minDifficulty: number): {
|
|
41
68
|
valid: boolean;
|
|
42
69
|
difficulty: number;
|
|
43
70
|
};
|
|
71
|
+
/**
|
|
72
|
+
* Get the mining target block for this epoch
|
|
73
|
+
* @returns {bigint | null} The target block number or null if epoch 0
|
|
74
|
+
*/
|
|
44
75
|
getMiningTargetBlock(): bigint | null;
|
|
45
76
|
}
|
|
77
|
+
//# sourceMappingURL=ChallengeSolution.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChallengeSolution.d.ts","sourceRoot":"","sources":["../../src/epoch/ChallengeSolution.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACR,kBAAkB,EAClB,oBAAoB,EACpB,sBAAsB,EACtB,YAAY,EACZ,sBAAsB,EACtB,wBAAwB,EAC3B,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AAKhD,qBAAa,qBAAsB,YAAW,sBAAsB;IAChE,SAAgB,SAAS,EAAE,MAAM,CAAC;IAClC,SAAgB,SAAS,EAAE,MAAM,CAAC;IAClC,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,cAAc,EAAE,MAAM,CAAC;IACvC,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,MAAM,EAAE,SAAS,MAAM,EAAE,CAAC;gBAE9B,IAAI,EAAE,wBAAwB;CAS7C;AAED,qBAAa,mBAAoB,YAAW,oBAAoB;aAQxC,WAAW,EAAE,MAAM;IAPvC,SAAgB,SAAS,EAAE,OAAO,CAAC;IACnC,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7C,SAAgB,SAAS,EAAE,MAAM,CAAC;gBAG9B,IAAI,EAAE,sBAAsB,EACZ,WAAW,EAAE,MAAM;IAQhC,eAAe,IAAI,OAAO;CAiBpC;AAED,qBAAa,iBAAkB,YAAW,kBAAkB;IACxD,SAAgB,WAAW,EAAE,MAAM,CAAC;IACpC,SAAgB,SAAS,EAAE,OAAO,CAAC;IACnC,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,IAAI,EAAE,MAAM,CAAC;IAC7B,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,YAAY,EAAE,qBAAqB,CAAC;IAEpD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAkC;gBAElD,IAAI,EAAE,YAAY;IAa9B;;OAEG;WACW,WAAW,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO;IAI/C,yBAAyB,IAAI,OAAO;IAQpC,aAAa,IAAI,mBAAmB,GAAG,SAAS;IAYvD;;;OAGG;IACI,MAAM,IAAI,OAAO;IAIxB;;;OAGG;IACI,QAAQ,IAAI,MAAM;IAIzB;;;OAGG;IACI,KAAK,IAAI,MAAM;IAItB;;OAEG;IACI,KAAK,IAAI,YAAY;IAqB5B;;;OAGG;IACI,iBAAiB,IAAI,UAAU;IAQtC;;;;OAIG;IACI,eAAe,CAAC,aAAa,EAAE,MAAM,GAAG;QAAE,KAAK,EAAE,OAAO,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE;IAQrF;;;OAGG;IACI,oBAAoB,IAAI,MAAM,GAAG,IAAI;CAG/C"}
|
|
@@ -4,6 +4,13 @@ import { EpochValidator } from './validator/EpochValidator.js';
|
|
|
4
4
|
import { BinaryWriter } from '../buffer/BinaryWriter.js';
|
|
5
5
|
import { MessageSigner } from '../keypair/MessageSigner.js';
|
|
6
6
|
export class ChallengeVerification {
|
|
7
|
+
epochHash;
|
|
8
|
+
epochRoot;
|
|
9
|
+
targetHash;
|
|
10
|
+
targetChecksum;
|
|
11
|
+
startBlock;
|
|
12
|
+
endBlock;
|
|
13
|
+
proofs;
|
|
7
14
|
constructor(data) {
|
|
8
15
|
this.epochHash = stringToBuffer(data.epochHash);
|
|
9
16
|
this.epochRoot = stringToBuffer(data.epochRoot);
|
|
@@ -15,6 +22,11 @@ export class ChallengeVerification {
|
|
|
15
22
|
}
|
|
16
23
|
}
|
|
17
24
|
export class ChallengeSubmission {
|
|
25
|
+
epochNumber;
|
|
26
|
+
publicKey;
|
|
27
|
+
solution;
|
|
28
|
+
graffiti;
|
|
29
|
+
signature;
|
|
18
30
|
constructor(data, epochNumber) {
|
|
19
31
|
this.epochNumber = epochNumber;
|
|
20
32
|
this.publicKey = Address.fromString(data.mldsaPublicKey, data.legacyPublicKey);
|
|
@@ -35,6 +47,14 @@ export class ChallengeSubmission {
|
|
|
35
47
|
}
|
|
36
48
|
}
|
|
37
49
|
export class ChallengeSolution {
|
|
50
|
+
epochNumber;
|
|
51
|
+
publicKey;
|
|
52
|
+
solution;
|
|
53
|
+
salt;
|
|
54
|
+
graffiti;
|
|
55
|
+
difficulty;
|
|
56
|
+
verification;
|
|
57
|
+
submission;
|
|
38
58
|
constructor(data) {
|
|
39
59
|
this.epochNumber = BigInt(data.epochNumber);
|
|
40
60
|
this.publicKey = Address.fromString(data.mldsaPublicKey, data.legacyPublicKey);
|
|
@@ -47,6 +67,9 @@ export class ChallengeSolution {
|
|
|
47
67
|
? new ChallengeSubmission(data.submission, this.epochNumber + 2n)
|
|
48
68
|
: data.submission;
|
|
49
69
|
}
|
|
70
|
+
/**
|
|
71
|
+
* Static method to validate from raw data directly
|
|
72
|
+
*/
|
|
50
73
|
static validateRaw(data) {
|
|
51
74
|
return EpochValidator.validateEpochWinner(data);
|
|
52
75
|
}
|
|
@@ -65,15 +88,30 @@ export class ChallengeSolution {
|
|
|
65
88
|
}
|
|
66
89
|
return this.submission;
|
|
67
90
|
}
|
|
91
|
+
/**
|
|
92
|
+
* Verify this challenge
|
|
93
|
+
* @returns {boolean} True if the challenge is valid
|
|
94
|
+
*/
|
|
68
95
|
verify() {
|
|
69
96
|
return EpochValidator.validateChallengeSolution(this);
|
|
70
97
|
}
|
|
98
|
+
/**
|
|
99
|
+
* Get the preimage challenge
|
|
100
|
+
* @returns {Buffer} The solution/challenge as a buffer
|
|
101
|
+
*/
|
|
71
102
|
toBuffer() {
|
|
72
103
|
return this.solution;
|
|
73
104
|
}
|
|
105
|
+
/**
|
|
106
|
+
* Get the solution as a hex string
|
|
107
|
+
* @returns {string} The solution as a hex string with 0x prefix
|
|
108
|
+
*/
|
|
74
109
|
toHex() {
|
|
75
110
|
return '0x' + this.solution.toString('hex');
|
|
76
111
|
}
|
|
112
|
+
/**
|
|
113
|
+
* Convert to raw format for serialization
|
|
114
|
+
*/
|
|
77
115
|
toRaw() {
|
|
78
116
|
return {
|
|
79
117
|
epochNumber: this.epochNumber.toString(),
|
|
@@ -94,13 +132,27 @@ export class ChallengeSolution {
|
|
|
94
132
|
},
|
|
95
133
|
};
|
|
96
134
|
}
|
|
135
|
+
/**
|
|
136
|
+
* Calculate the expected solution hash for this challenge
|
|
137
|
+
* @returns {Promise<Buffer>} The calculated solution hash
|
|
138
|
+
*/
|
|
97
139
|
calculateSolution() {
|
|
98
140
|
return EpochValidator.calculateSolution(this.verification.targetChecksum, this.publicKey.toBuffer(), this.salt);
|
|
99
141
|
}
|
|
142
|
+
/**
|
|
143
|
+
* Check if the challenge meets a specific difficulty requirement
|
|
144
|
+
* @param {number} minDifficulty The minimum difficulty required
|
|
145
|
+
* @returns {Promise<{valid: boolean; difficulty: number}>} Validation result
|
|
146
|
+
*/
|
|
100
147
|
checkDifficulty(minDifficulty) {
|
|
101
148
|
return EpochValidator.checkDifficulty(this.solution, this.verification.targetHash, minDifficulty);
|
|
102
149
|
}
|
|
150
|
+
/**
|
|
151
|
+
* Get the mining target block for this epoch
|
|
152
|
+
* @returns {bigint | null} The target block number or null if epoch 0
|
|
153
|
+
*/
|
|
103
154
|
getMiningTargetBlock() {
|
|
104
155
|
return EpochValidator.getMiningTargetBlock(this.epochNumber);
|
|
105
156
|
}
|
|
106
157
|
}
|
|
158
|
+
//# sourceMappingURL=ChallengeSolution.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChallengeSolution.js","sourceRoot":"","sources":["../../src/epoch/ChallengeSolution.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,28 +1,28 @@
|
|
|
1
1
|
import { Address } from '../../keypair/Address.js';
|
|
2
2
|
export interface IChallengeVerification {
|
|
3
|
-
readonly epochHash:
|
|
4
|
-
readonly epochRoot:
|
|
5
|
-
readonly targetHash:
|
|
6
|
-
readonly targetChecksum:
|
|
3
|
+
readonly epochHash: Uint8Array;
|
|
4
|
+
readonly epochRoot: Uint8Array;
|
|
5
|
+
readonly targetHash: Uint8Array;
|
|
6
|
+
readonly targetChecksum: Uint8Array;
|
|
7
7
|
readonly startBlock: bigint;
|
|
8
8
|
readonly endBlock: bigint;
|
|
9
|
-
readonly proofs: readonly
|
|
9
|
+
readonly proofs: readonly Uint8Array[];
|
|
10
10
|
}
|
|
11
11
|
export interface IChallengeSolution {
|
|
12
12
|
readonly epochNumber: bigint;
|
|
13
13
|
readonly publicKey: Address;
|
|
14
|
-
readonly solution:
|
|
15
|
-
readonly salt:
|
|
16
|
-
readonly graffiti:
|
|
14
|
+
readonly solution: Uint8Array;
|
|
15
|
+
readonly salt: Uint8Array;
|
|
16
|
+
readonly graffiti: Uint8Array;
|
|
17
17
|
readonly difficulty: number;
|
|
18
18
|
readonly verification: IChallengeVerification;
|
|
19
19
|
verifySubmissionSignature(): boolean;
|
|
20
20
|
getSubmission(): IChallengeSubmission | undefined;
|
|
21
21
|
toRaw(): RawChallenge;
|
|
22
22
|
verify(): boolean;
|
|
23
|
-
toBuffer():
|
|
23
|
+
toBuffer(): Uint8Array;
|
|
24
24
|
toHex(): string;
|
|
25
|
-
calculateSolution():
|
|
25
|
+
calculateSolution(): Uint8Array;
|
|
26
26
|
checkDifficulty(minDifficulty: number): {
|
|
27
27
|
valid: boolean;
|
|
28
28
|
difficulty: number;
|
|
@@ -47,9 +47,9 @@ export interface RawChallengeSubmission {
|
|
|
47
47
|
}
|
|
48
48
|
export interface IChallengeSubmission {
|
|
49
49
|
readonly publicKey: Address;
|
|
50
|
-
readonly solution:
|
|
51
|
-
readonly graffiti:
|
|
52
|
-
readonly signature:
|
|
50
|
+
readonly solution: Uint8Array;
|
|
51
|
+
readonly graffiti: Uint8Array | undefined;
|
|
52
|
+
readonly signature: Uint8Array;
|
|
53
53
|
readonly epochNumber: bigint;
|
|
54
54
|
verifySignature(): boolean;
|
|
55
55
|
}
|
|
@@ -64,3 +64,4 @@ export interface RawChallenge {
|
|
|
64
64
|
readonly verification: RawChallengeVerification;
|
|
65
65
|
readonly submission?: RawChallengeSubmission;
|
|
66
66
|
}
|
|
67
|
+
//# sourceMappingURL=IChallengeSolution.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IChallengeSolution.d.ts","sourceRoot":"","sources":["../../../src/epoch/interfaces/IChallengeSolution.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Address } from '../../keypair/Address.js';
|
|
2
|
+
//# sourceMappingURL=IChallengeSolution.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IChallengeSolution.js","sourceRoot":"","sources":["../../../src/epoch/interfaces/IChallengeSolution.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC"}
|
|
@@ -1,18 +1,48 @@
|
|
|
1
|
-
import { IChallengeSolution, RawChallenge } from '../interfaces/IChallengeSolution.js';
|
|
1
|
+
import type { IChallengeSolution, RawChallenge } from '../interfaces/IChallengeSolution.js';
|
|
2
2
|
export declare class EpochValidator {
|
|
3
3
|
private static readonly BLOCKS_PER_EPOCH;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
static
|
|
8
|
-
|
|
4
|
+
/**
|
|
5
|
+
* Calculate SHA-1 hash
|
|
6
|
+
*/
|
|
7
|
+
static sha1(data: Uint8Array): Uint8Array;
|
|
8
|
+
/**
|
|
9
|
+
* Calculate mining preimage
|
|
10
|
+
*/
|
|
11
|
+
static calculatePreimage(checksumRoot: Uint8Array, publicKey: Uint8Array, salt: Uint8Array): Uint8Array;
|
|
12
|
+
/**
|
|
13
|
+
* Count matching bits between two hashes
|
|
14
|
+
*/
|
|
15
|
+
static countMatchingBits(hash1: Uint8Array, hash2: Uint8Array): number;
|
|
16
|
+
/**
|
|
17
|
+
* Verify an epoch solution using IPreimage
|
|
18
|
+
*/
|
|
9
19
|
static verifySolution(challenge: IChallengeSolution, log?: boolean): boolean;
|
|
20
|
+
/**
|
|
21
|
+
* Get the mining target block for an epoch
|
|
22
|
+
*/
|
|
10
23
|
static getMiningTargetBlock(epochNumber: bigint): bigint | null;
|
|
24
|
+
/**
|
|
25
|
+
* Validate epoch winner from raw data
|
|
26
|
+
*/
|
|
11
27
|
static validateEpochWinner(epochData: RawChallenge): boolean;
|
|
28
|
+
/**
|
|
29
|
+
* Validate epoch winner from Preimage instance
|
|
30
|
+
*/
|
|
12
31
|
static validateChallengeSolution(challenge: IChallengeSolution): boolean;
|
|
13
|
-
|
|
14
|
-
|
|
32
|
+
/**
|
|
33
|
+
* Calculate solution hash from preimage components
|
|
34
|
+
* @param targetChecksum The target checksum (32 bytes)
|
|
35
|
+
* @param publicKey The public key buffer (32 bytes)
|
|
36
|
+
* @param salt The salt buffer (32 bytes)
|
|
37
|
+
* @returns The SHA-1 hash of the preimage
|
|
38
|
+
*/
|
|
39
|
+
static calculateSolution(targetChecksum: Uint8Array, publicKey: Uint8Array, salt: Uint8Array): Uint8Array;
|
|
40
|
+
/**
|
|
41
|
+
* Check if a solution meets the minimum difficulty requirement
|
|
42
|
+
*/
|
|
43
|
+
static checkDifficulty(solution: Uint8Array, targetHash: Uint8Array, minDifficulty: number): {
|
|
15
44
|
valid: boolean;
|
|
16
45
|
difficulty: number;
|
|
17
46
|
};
|
|
18
47
|
}
|
|
48
|
+
//# sourceMappingURL=EpochValidator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EpochValidator.d.ts","sourceRoot":"","sources":["../../../src/epoch/validator/EpochValidator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAK5F,qBAAa,cAAc;IACvB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAc;IAEtD;;OAEG;WACW,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,UAAU;IAIhD;;OAEG;WACW,iBAAiB,CAC3B,YAAY,EAAE,UAAU,EACxB,SAAS,EAAE,UAAU,EACrB,IAAI,EAAE,UAAU,GACjB,UAAU;IAcb;;OAEG;WACW,iBAAiB,CAAC,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,GAAG,MAAM;IA4B7E;;OAEG;WACW,cAAc,CAAC,SAAS,EAAE,kBAAkB,EAAE,GAAG,GAAE,OAAe,GAAG,OAAO;IAkC1F;;OAEG;WACW,oBAAoB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAStE;;OAEG;WACW,mBAAmB,CAAC,SAAS,EAAE,YAAY,GAAG,OAAO;IAmDnE;;OAEG;WACW,yBAAyB,CAAC,SAAS,EAAE,kBAAkB,GAAG,OAAO;IAI/E;;;;;;OAMG;WACW,iBAAiB,CAC3B,cAAc,EAAE,UAAU,EAC1B,SAAS,EAAE,UAAU,EACrB,IAAI,EAAE,UAAU,GACjB,UAAU;IAKb;;OAEG;WACW,eAAe,CACzB,QAAQ,EAAE,UAAU,EACpB,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,MAAM,GACtB;QAAE,KAAK,EAAE,OAAO,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE;CAO5C"}
|
|
@@ -1,26 +1,31 @@
|
|
|
1
|
-
import { crypto } from '@btc-vision/bitcoin';
|
|
1
|
+
import { crypto, equals } from '@btc-vision/bitcoin';
|
|
2
2
|
import { Address } from '../../keypair/Address.js';
|
|
3
3
|
import { stringToBuffer } from '../../utils/StringToBuffer.js';
|
|
4
4
|
export class EpochValidator {
|
|
5
|
-
static
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return Buffer.from(array);
|
|
10
|
-
}
|
|
5
|
+
static BLOCKS_PER_EPOCH = 5n;
|
|
6
|
+
/**
|
|
7
|
+
* Calculate SHA-1 hash
|
|
8
|
+
*/
|
|
11
9
|
static sha1(data) {
|
|
12
|
-
return crypto.sha1(
|
|
10
|
+
return crypto.sha1(data);
|
|
13
11
|
}
|
|
12
|
+
/**
|
|
13
|
+
* Calculate mining preimage
|
|
14
|
+
*/
|
|
14
15
|
static calculatePreimage(checksumRoot, publicKey, salt) {
|
|
16
|
+
// Ensure all are 32 bytes
|
|
15
17
|
if (checksumRoot.length !== 32 || publicKey.length !== 32 || salt.length !== 32) {
|
|
16
18
|
throw new Error('All inputs must be 32 bytes');
|
|
17
19
|
}
|
|
18
|
-
const preimage =
|
|
20
|
+
const preimage = new Uint8Array(32);
|
|
19
21
|
for (let i = 0; i < 32; i++) {
|
|
20
22
|
preimage[i] = checksumRoot[i] ^ publicKey[i] ^ salt[i];
|
|
21
23
|
}
|
|
22
24
|
return preimage;
|
|
23
25
|
}
|
|
26
|
+
/**
|
|
27
|
+
* Count matching bits between two hashes
|
|
28
|
+
*/
|
|
24
29
|
static countMatchingBits(hash1, hash2) {
|
|
25
30
|
let matchingBits = 0;
|
|
26
31
|
if (hash1.length !== hash2.length) {
|
|
@@ -34,6 +39,7 @@ export class EpochValidator {
|
|
|
34
39
|
matchingBits += 8;
|
|
35
40
|
}
|
|
36
41
|
else {
|
|
42
|
+
// Check individual bits
|
|
37
43
|
for (let bit = 7; bit >= 0; bit--) {
|
|
38
44
|
if (((byte1 >> bit) & 1) === ((byte2 >> bit) & 1)) {
|
|
39
45
|
matchingBits++;
|
|
@@ -46,16 +52,18 @@ export class EpochValidator {
|
|
|
46
52
|
}
|
|
47
53
|
return matchingBits;
|
|
48
54
|
}
|
|
55
|
+
/**
|
|
56
|
+
* Verify an epoch solution using IPreimage
|
|
57
|
+
*/
|
|
49
58
|
static verifySolution(challenge, log = false) {
|
|
50
59
|
try {
|
|
51
60
|
const verification = challenge.verification;
|
|
52
61
|
const calculatedPreimage = this.calculatePreimage(verification.targetChecksum, challenge.publicKey.toBuffer(), challenge.salt);
|
|
53
62
|
const computedSolution = this.sha1(calculatedPreimage);
|
|
54
|
-
|
|
55
|
-
if (!computedSolutionBuffer.equals(challenge.solution)) {
|
|
63
|
+
if (!equals(computedSolution, challenge.solution)) {
|
|
56
64
|
return false;
|
|
57
65
|
}
|
|
58
|
-
const matchingBits = this.countMatchingBits(
|
|
66
|
+
const matchingBits = this.countMatchingBits(computedSolution, verification.targetHash);
|
|
59
67
|
if (matchingBits !== challenge.difficulty) {
|
|
60
68
|
return false;
|
|
61
69
|
}
|
|
@@ -70,12 +78,19 @@ export class EpochValidator {
|
|
|
70
78
|
return false;
|
|
71
79
|
}
|
|
72
80
|
}
|
|
81
|
+
/**
|
|
82
|
+
* Get the mining target block for an epoch
|
|
83
|
+
*/
|
|
73
84
|
static getMiningTargetBlock(epochNumber) {
|
|
74
85
|
if (epochNumber === 0n) {
|
|
75
|
-
return null;
|
|
86
|
+
return null; // Epoch 0 cannot be mined
|
|
76
87
|
}
|
|
88
|
+
// Last block of previous epoch
|
|
77
89
|
return epochNumber * this.BLOCKS_PER_EPOCH - 1n;
|
|
78
90
|
}
|
|
91
|
+
/**
|
|
92
|
+
* Validate epoch winner from raw data
|
|
93
|
+
*/
|
|
79
94
|
static validateEpochWinner(epochData) {
|
|
80
95
|
try {
|
|
81
96
|
const epochNumber = BigInt(epochData.epochNumber);
|
|
@@ -94,11 +109,10 @@ export class EpochValidator {
|
|
|
94
109
|
};
|
|
95
110
|
const calculatedPreimage = this.calculatePreimage(verification.targetChecksum, publicKey.toBuffer(), salt);
|
|
96
111
|
const computedSolution = this.sha1(calculatedPreimage);
|
|
97
|
-
|
|
98
|
-
if (!computedSolutionBuffer.equals(solution)) {
|
|
112
|
+
if (!equals(computedSolution, solution)) {
|
|
99
113
|
return false;
|
|
100
114
|
}
|
|
101
|
-
const matchingBits = this.countMatchingBits(
|
|
115
|
+
const matchingBits = this.countMatchingBits(computedSolution, verification.targetHash);
|
|
102
116
|
if (matchingBits !== difficulty) {
|
|
103
117
|
return false;
|
|
104
118
|
}
|
|
@@ -111,14 +125,26 @@ export class EpochValidator {
|
|
|
111
125
|
return false;
|
|
112
126
|
}
|
|
113
127
|
}
|
|
128
|
+
/**
|
|
129
|
+
* Validate epoch winner from Preimage instance
|
|
130
|
+
*/
|
|
114
131
|
static validateChallengeSolution(challenge) {
|
|
115
132
|
return this.verifySolution(challenge);
|
|
116
133
|
}
|
|
134
|
+
/**
|
|
135
|
+
* Calculate solution hash from preimage components
|
|
136
|
+
* @param targetChecksum The target checksum (32 bytes)
|
|
137
|
+
* @param publicKey The public key buffer (32 bytes)
|
|
138
|
+
* @param salt The salt buffer (32 bytes)
|
|
139
|
+
* @returns The SHA-1 hash of the preimage
|
|
140
|
+
*/
|
|
117
141
|
static calculateSolution(targetChecksum, publicKey, salt) {
|
|
118
142
|
const preimage = this.calculatePreimage(targetChecksum, publicKey, salt);
|
|
119
|
-
|
|
120
|
-
return this.uint8ArrayToBuffer(hash);
|
|
143
|
+
return this.sha1(preimage);
|
|
121
144
|
}
|
|
145
|
+
/**
|
|
146
|
+
* Check if a solution meets the minimum difficulty requirement
|
|
147
|
+
*/
|
|
122
148
|
static checkDifficulty(solution, targetHash, minDifficulty) {
|
|
123
149
|
const difficulty = this.countMatchingBits(solution, targetHash);
|
|
124
150
|
return {
|
|
@@ -127,4 +153,4 @@ export class EpochValidator {
|
|
|
127
153
|
};
|
|
128
154
|
}
|
|
129
155
|
}
|
|
130
|
-
EpochValidator.
|
|
156
|
+
//# sourceMappingURL=EpochValidator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EpochValidator.js","sourceRoot":"","sources":["../../../src/epoch/validator/EpochValidator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D,MAAM,OAAO,cAAc;IACf,MAAM,CAAU,gBAAgB,GAAW,EAAE,CAAC;IAEtD;;OAEG;IACI,MAAM,CAAC,IAAI,CAAC,IAAgB;QAC/B,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,iBAAiB,CAC3B,YAAwB,EACxB,SAAqB,EACrB,IAAgB;QAEhB,0BAA0B;QAC1B,IAAI,YAAY,CAAC,MAAM,KAAK,EAAE,IAAI,SAAS,CAAC,MAAM,KAAK,EAAE,IAAI,IAAI,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YAC9E,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;QACnD,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC;QACpC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YAC1B,QAAQ,CAAC,CAAC,CAAC,GAAI,YAAY,CAAC,CAAC,CAAY,GAAI,SAAS,CAAC,CAAC,CAAY,GAAI,IAAI,CAAC,CAAC,CAAY,CAAC;QAC/F,CAAC;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,iBAAiB,CAAC,KAAiB,EAAE,KAAiB;QAChE,IAAI,YAAY,GAAG,CAAC,CAAC;QACrB,IAAI,KAAK,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;QACzD,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;YACjC,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YACvB,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAEvB,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;gBAClB,YAAY,IAAI,CAAC,CAAC;YACtB,CAAC;iBAAM,CAAC;gBACJ,wBAAwB;gBACxB,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,EAAE,EAAE,CAAC;oBAChC,IAAI,CAAC,CAAE,KAAgB,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAE,KAAgB,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;wBACxE,YAAY,EAAE,CAAC;oBACnB,CAAC;yBAAM,CAAC;wBACJ,OAAO,YAAY,CAAC;oBACxB,CAAC;gBACL,CAAC;YACL,CAAC;QACL,CAAC;QAED,OAAO,YAAY,CAAC;IACxB,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,cAAc,CAAC,SAA6B,EAAE,MAAe,KAAK;QAC5E,IAAI,CAAC;YACD,MAAM,YAAY,GAAG,SAAS,CAAC,YAAY,CAAC;YAC5C,MAAM,kBAAkB,GAAG,IAAI,CAAC,iBAAiB,CAC7C,YAAY,CAAC,cAAc,EAC3B,SAAS,CAAC,SAAS,CAAC,QAAQ,EAAE,EAC9B,SAAS,CAAC,IAAI,CACjB,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAEvD,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAChD,OAAO,KAAK,CAAC;YACjB,CAAC;YAED,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,YAAY,CAAC,UAAU,CAAC,CAAC;YAEvF,IAAI,YAAY,KAAK,SAAS,CAAC,UAAU,EAAE,CAAC;gBACxC,OAAO,KAAK,CAAC;YACjB,CAAC;YAED,MAAM,kBAAkB,GAAG,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC;YACzE,MAAM,gBAAgB,GAAG,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;YAEzE,OAAO,CAAC,CACJ,YAAY,CAAC,UAAU,KAAK,kBAAkB;gBAC9C,YAAY,CAAC,QAAQ,KAAK,gBAAgB,CAC7C,CAAC;QACN,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,IAAI,GAAG;gBAAE,OAAO,CAAC,KAAK,CAAC,qBAAqB,EAAE,KAAK,CAAC,CAAC;YACrD,OAAO,KAAK,CAAC;QACjB,CAAC;IACL,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,oBAAoB,CAAC,WAAmB;QAClD,IAAI,WAAW,KAAK,EAAE,EAAE,CAAC;YACrB,OAAO,IAAI,CAAC,CAAC,0BAA0B;QAC3C,CAAC;QAED,+BAA+B;QAC/B,OAAO,WAAW,GAAG,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IACpD,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,mBAAmB,CAAC,SAAuB;QACrD,IAAI,CAAC;YACD,MAAM,WAAW,GAAG,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;YAClD,MAAM,SAAS,GAAG,OAAO,CAAC,UAAU,CAChC,SAAS,CAAC,cAAc,EACxB,SAAS,CAAC,eAAe,CAC5B,CAAC;YACF,MAAM,QAAQ,GAAG,cAAc,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YACpD,MAAM,IAAI,GAAG,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAC5C,MAAM,UAAU,GAAG,SAAS,CAAC,UAAU,CAAC;YAExC,MAAM,YAAY,GAAG;gBACjB,SAAS,EAAE,cAAc,CAAC,SAAS,CAAC,YAAY,CAAC,SAAS,CAAC;gBAC3D,SAAS,EAAE,cAAc,CAAC,SAAS,CAAC,YAAY,CAAC,SAAS,CAAC;gBAC3D,UAAU,EAAE,cAAc,CAAC,SAAS,CAAC,YAAY,CAAC,UAAU,CAAC;gBAC7D,cAAc,EAAE,cAAc,CAAC,SAAS,CAAC,YAAY,CAAC,cAAc,CAAC;gBACrE,UAAU,EAAE,MAAM,CAAC,SAAS,CAAC,YAAY,CAAC,UAAU,CAAC;gBACrD,QAAQ,EAAE,MAAM,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC;gBACjD,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;aACrF,CAAC;YAEF,MAAM,kBAAkB,GAAG,IAAI,CAAC,iBAAiB,CAC7C,YAAY,CAAC,cAAc,EAC3B,SAAS,CAAC,QAAQ,EAAE,EACpB,IAAI,CACP,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAEvD,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,QAAQ,CAAC,EAAE,CAAC;gBACtC,OAAO,KAAK,CAAC;YACjB,CAAC;YAED,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,YAAY,CAAC,UAAU,CAAC,CAAC;YAEvF,IAAI,YAAY,KAAK,UAAU,EAAE,CAAC;gBAC9B,OAAO,KAAK,CAAC;YACjB,CAAC;YAED,MAAM,kBAAkB,GAAG,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC;YAC/D,MAAM,gBAAgB,GAAG,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;YAEzE,OAAO,CAAC,CACJ,YAAY,CAAC,UAAU,KAAK,kBAAkB;gBAC9C,YAAY,CAAC,QAAQ,KAAK,gBAAgB,CAC7C,CAAC;QACN,CAAC;QAAC,MAAM,CAAC;YACL,OAAO,KAAK,CAAC;QACjB,CAAC;IACL,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,yBAAyB,CAAC,SAA6B;QACjE,OAAO,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,iBAAiB,CAC3B,cAA0B,EAC1B,SAAqB,EACrB,IAAgB;QAEhB,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,cAAc,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;QACzE,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC/B,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,eAAe,CACzB,QAAoB,EACpB,UAAsB,EACtB,aAAqB;QAErB,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAChE,OAAO;YACH,KAAK,EAAE,UAAU,IAAI,aAAa;YAClC,UAAU;SACb,CAAC;IACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NetEvent.d.ts","sourceRoot":"","sources":["../../src/event/NetEvent.ts"],"names":[],"mappings":"AAAA,qBAAa,QAAQ;aAEG,IAAI,EAAE,MAAM;aACZ,IAAI,EAAE,UAAU;gBADhB,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,UAAU;CAEvC"}
|
package/build/event/NetEvent.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NetEvent.js","sourceRoot":"","sources":["../../src/event/NetEvent.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,QAAQ;IAEG;IACA;IAFpB,YACoB,IAAY,EACZ,IAAgB;QADhB,SAAI,GAAJ,IAAI,CAAQ;QACZ,SAAI,GAAJ,IAAI,CAAY;IACjC,CAAC;CACP"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { Network } from '@btc-vision/bitcoin';
|
|
1
|
+
import { type Network } from '@btc-vision/bitcoin';
|
|
2
2
|
export declare class AddressGenerator {
|
|
3
|
-
static generatePKSH(sha256Hash:
|
|
4
|
-
static generateTaprootAddress(pubKey:
|
|
3
|
+
static generatePKSH(sha256Hash: Uint8Array, network: Network): string;
|
|
4
|
+
static generateTaprootAddress(pubKey: Uint8Array, network: {
|
|
5
5
|
bech32: string;
|
|
6
6
|
}): string;
|
|
7
7
|
private static toSegwitAddress;
|
|
8
8
|
}
|
|
9
|
+
//# sourceMappingURL=AddressGenerator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AddressGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/AddressGenerator.ts"],"names":[],"mappings":"AACA,OAAO,EAAc,KAAK,OAAO,EAAa,MAAM,qBAAqB,CAAC;AAK1E,qBAAa,gBAAgB;WAEX,YAAY,CAAC,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,GAAG,MAAM;WAQ9D,sBAAsB,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,MAAM;IAc7F,OAAO,CAAC,MAAM,CAAC,eAAe;CAMjC"}
|
|
@@ -1,24 +1,31 @@
|
|
|
1
1
|
import { bech32, bech32m } from 'bech32';
|
|
2
2
|
import { initEccLib, ripemd160 } from '@btc-vision/bitcoin';
|
|
3
|
-
import
|
|
4
|
-
initEccLib(
|
|
3
|
+
import { eccLib } from '../ecc/backend.js';
|
|
4
|
+
initEccLib(eccLib);
|
|
5
5
|
export class AddressGenerator {
|
|
6
|
+
// Generate a valid SegWit address from random bytes
|
|
6
7
|
static generatePKSH(sha256Hash, network) {
|
|
7
8
|
if (sha256Hash.length !== 32)
|
|
8
9
|
throw new Error('Invalid hash length');
|
|
9
10
|
const pkh = ripemd160(sha256Hash);
|
|
10
11
|
return this.toSegwitAddress(pkh, network);
|
|
11
12
|
}
|
|
13
|
+
// Generate a valid Taproot address from a public key
|
|
12
14
|
static generateTaprootAddress(pubKey, network) {
|
|
13
15
|
if (pubKey.length !== 32)
|
|
14
16
|
throw new Error('Invalid public key length');
|
|
17
|
+
// Convert the public key to words
|
|
15
18
|
const words = bech32m.toWords(pubKey);
|
|
19
|
+
// Prepend the witness version (0x01 for Taproot)
|
|
16
20
|
words.unshift(0x01);
|
|
21
|
+
// Encode using Bech32m
|
|
17
22
|
return bech32m.encode(network.bech32, words);
|
|
18
23
|
}
|
|
24
|
+
// Convert a hash to a SegWit address
|
|
19
25
|
static toSegwitAddress(pkh, network) {
|
|
20
26
|
const words = bech32.toWords(pkh);
|
|
21
|
-
words.unshift(0x00);
|
|
27
|
+
words.unshift(0x00); // Add the witness version byte (0x00 for P2WPKH)
|
|
22
28
|
return bech32.encode(network.bech32, words);
|
|
23
29
|
}
|
|
24
30
|
}
|
|
31
|
+
//# sourceMappingURL=AddressGenerator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AddressGenerator.js","sourceRoot":"","sources":["../../src/generators/AddressGenerator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,UAAU,EAAgB,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAE3C,UAAU,CAAC,MAAM,CAAC,CAAC;AAEnB,MAAM,OAAO,gBAAgB;IACzB,oDAAoD;IAC7C,MAAM,CAAC,YAAY,CAAC,UAAsB,EAAE,OAAgB;QAC/D,IAAI,UAAU,CAAC,MAAM,KAAK,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAErE,MAAM,GAAG,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IAC9C,CAAC;IAED,qDAAqD;IAC9C,MAAM,CAAC,sBAAsB,CAAC,MAAkB,EAAE,OAA2B;QAChF,IAAI,MAAM,CAAC,MAAM,KAAK,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;QAEvE,kCAAkC;QAClC,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAEtC,iDAAiD;QACjD,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEpB,uBAAuB;QACvB,OAAO,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IACjD,CAAC;IAED,qCAAqC;IAC7B,MAAM,CAAC,eAAe,CAAC,GAAe,EAAE,OAAgB;QAC5D,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAClC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,iDAAiD;QAEtE,OAAO,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAChD,CAAC;CACJ"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { LoadedStorage } from '../transaction/interfaces/ITransactionParameters.js';
|
|
2
|
-
import { ChallengeSubmission } from '../epoch/ChallengeSolution.js';
|
|
3
|
-
import { MLDSARequestData } from './MLDSAData.js';
|
|
1
|
+
import type { LoadedStorage } from '../transaction/interfaces/ITransactionParameters.js';
|
|
2
|
+
import type { ChallengeSubmission } from '../epoch/ChallengeSolution.js';
|
|
3
|
+
import type { MLDSARequestData } from './MLDSAData.js';
|
|
4
4
|
export declare enum Features {
|
|
5
5
|
ACCESS_LIST = 1,
|
|
6
6
|
EPOCH_SUBMISSION = 2,
|
|
@@ -25,3 +25,4 @@ export interface EpochSubmissionFeature extends Feature<Features.EPOCH_SUBMISSIO
|
|
|
25
25
|
export interface MLDSALinkRequest extends Feature<Features.MLDSA_LINK_PUBKEY> {
|
|
26
26
|
data: MLDSARequestData;
|
|
27
27
|
}
|
|
28
|
+
//# sourceMappingURL=Features.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Features.d.ts","sourceRoot":"","sources":["../../src/generators/Features.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qDAAqD,CAAC;AACzF,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACzE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEvD,oBAAY,QAAQ;IAChB,WAAW,IAAM;IACjB,gBAAgB,IAAO;IACvB,iBAAiB,IAAQ;CAC5B;AAED,oBAAY,eAAe;IACvB,WAAW,IAAI;IACf,gBAAgB,IAAI;IACpB,iBAAiB,IAAI;CACxB;AAED,MAAM,WAAW,OAAO,CAAC,CAAC,SAAS,QAAQ;IACvC,MAAM,EAAE,CAAC,CAAC;IACV,IAAI,EAAE,OAAO,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,iBAAkB,SAAQ,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC;IACpE,IAAI,EAAE,aAAa,CAAC;CACvB;AAED,MAAM,WAAW,sBAAuB,SAAQ,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC;IAC9E,IAAI,EAAE,mBAAmB,CAAC;CAC7B;AAED,MAAM,WAAW,gBAAiB,SAAQ,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAC;IACzE,IAAI,EAAE,gBAAgB,CAAC;CAC1B"}
|
|
@@ -10,3 +10,4 @@ export var FeaturePriority;
|
|
|
10
10
|
FeaturePriority[FeaturePriority["EPOCH_SUBMISSION"] = 2] = "EPOCH_SUBMISSION";
|
|
11
11
|
FeaturePriority[FeaturePriority["MLDSA_LINK_PUBKEY"] = 3] = "MLDSA_LINK_PUBKEY";
|
|
12
12
|
})(FeaturePriority || (FeaturePriority = {}));
|
|
13
|
+
//# sourceMappingURL=Features.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Features.js","sourceRoot":"","sources":["../../src/generators/Features.ts"],"names":[],"mappings":"AAIA,MAAM,CAAN,IAAY,QAIX;AAJD,WAAY,QAAQ;IAChB,qDAAiB,CAAA;IACjB,+DAAuB,CAAA;IACvB,iEAAyB,CAAA;AAC7B,CAAC,EAJW,QAAQ,KAAR,QAAQ,QAInB;AAED,MAAM,CAAN,IAAY,eAIX;AAJD,WAAY,eAAe;IACvB,mEAAe,CAAA;IACf,6EAAoB,CAAA;IACpB,+EAAqB,CAAA;AACzB,CAAC,EAJW,eAAe,KAAf,eAAe,QAI1B"}
|