@btc-vision/transaction 1.8.0-beta.1 → 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 +12420 -3637
- 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 +3602 -3203
- 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 +920 -2966
- package/browser/noble-hashes.js +2067 -1038
- 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 +13940 -9389
- 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 +447 -129
- 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 +223 -54
- 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 +16 -39
- 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/crypto/crypto-browser.js +3 -4
- 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 +115 -72
- package/src/keypair/AddressVerificator.ts +16 -147
- package/src/keypair/EcKeyPair.ts +109 -118
- 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
|
@@ -1,16 +1,22 @@
|
|
|
1
|
-
import { Network, Psbt, Signer } from '@btc-vision/bitcoin';
|
|
1
|
+
import { type Network, Psbt, type Signer } from '@btc-vision/bitcoin';
|
|
2
|
+
import { type MessageHash, type PublicKey, type SchnorrSignature, type Signature } from '@btc-vision/ecpair';
|
|
3
|
+
/**
|
|
4
|
+
* Create a custom keypair.
|
|
5
|
+
* @class CustomKeypair
|
|
6
|
+
*/
|
|
2
7
|
export declare abstract class CustomKeypair implements Signer {
|
|
3
8
|
abstract network: Network;
|
|
4
|
-
abstract publicKey:
|
|
9
|
+
abstract publicKey: PublicKey;
|
|
5
10
|
abstract addresses: string[];
|
|
6
11
|
abstract p2tr: string;
|
|
7
12
|
abstract p2wpkh: string;
|
|
8
13
|
protected constructor();
|
|
9
14
|
abstract signTaprootInput(transaction: Psbt, i: number, sighashTypes: number[]): Promise<void>;
|
|
10
15
|
abstract signInput(transaction: Psbt, i: number, sighashTypes: number[]): Promise<void>;
|
|
11
|
-
abstract getPublicKey():
|
|
12
|
-
abstract sign(hash:
|
|
13
|
-
abstract signSchnorr(hash:
|
|
14
|
-
abstract verify(hash:
|
|
16
|
+
abstract getPublicKey(): PublicKey;
|
|
17
|
+
abstract sign(hash: MessageHash, lowR?: boolean): Signature;
|
|
18
|
+
abstract signSchnorr(hash: MessageHash): SchnorrSignature;
|
|
19
|
+
abstract verify(hash: MessageHash, signature: Signature): boolean;
|
|
15
20
|
abstract init(): Promise<void>;
|
|
16
21
|
}
|
|
22
|
+
//# sourceMappingURL=BrowserSignerBase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BrowserSignerBase.d.ts","sourceRoot":"","sources":["../../../src/transaction/browser/BrowserSignerBase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,IAAI,EAAE,KAAK,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACtE,OAAO,EACH,KAAK,WAAW,EAChB,KAAK,SAAS,EACd,KAAK,gBAAgB,EACrB,KAAK,SAAS,EACjB,MAAM,oBAAoB,CAAC;AAE5B;;;GAGG;AACH,8BAAsB,aAAc,YAAW,MAAM;IACjD,SAAgB,OAAO,EAAE,OAAO,CAAC;IAEjC,SAAgB,SAAS,EAAE,SAAS,CAAC;IAErC,SAAgB,SAAS,EAAE,MAAM,EAAE,CAAC;IAEpC,SAAgB,IAAI,EAAE,MAAM,CAAC;IAC7B,SAAgB,MAAM,EAAE,MAAM,CAAC;IAE/B,SAAS;aAEO,gBAAgB,CAC5B,WAAW,EAAE,IAAI,EACjB,CAAC,EAAE,MAAM,EACT,YAAY,EAAE,MAAM,EAAE,GACvB,OAAO,CAAC,IAAI,CAAC;aAEA,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;aAE9E,YAAY,IAAI,SAAS;aAEzB,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,SAAS;aAElD,WAAW,CAAC,IAAI,EAAE,WAAW,GAAG,gBAAgB;aAEhD,MAAM,CAAC,IAAI,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,GAAG,OAAO;aAExD,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CACxC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BrowserSignerBase.js","sourceRoot":"","sources":["../../../src/transaction/browser/BrowserSignerBase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,IAAI,EAAe,MAAM,qBAAqB,CAAC;AACtE,OAAO,EAKN,MAAM,oBAAoB,CAAC;AAE5B;;;GAGG;AACH,MAAM,OAAgB,aAAa;IAU/B,gBAAyB,CAAC;CAmB7B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WalletNetworks.d.ts","sourceRoot":"","sources":["../../../src/transaction/browser/WalletNetworks.ts"],"names":[],"mappings":"AAAA,oBAAY,cAAc;IACtB,OAAO,YAAY;IACnB,OAAO,YAAY;IACnB,OAAO,YAAY;CACtB;AAED,oBAAY,eAAe;IACvB,eAAe,oBAAoB;IACnC,eAAe,oBAAoB;IACnC,gBAAgB,qBAAqB;IACrC,eAAe,oBAAoB;IACnC,cAAc,mBAAmB;IACjC,uBAAuB,4BAA4B;IACnD,uBAAuB,4BAA4B;CACtD"}
|
|
@@ -14,3 +14,4 @@ export var UnisatChainType;
|
|
|
14
14
|
UnisatChainType["FRACTAL_BITCOIN_MAINNET"] = "FRACTAL_BITCOIN_MAINNET";
|
|
15
15
|
UnisatChainType["FRACTAL_BITCOIN_TESTNET"] = "FRACTAL_BITCOIN_TESTNET";
|
|
16
16
|
})(UnisatChainType || (UnisatChainType = {}));
|
|
17
|
+
//# sourceMappingURL=WalletNetworks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WalletNetworks.js","sourceRoot":"","sources":["../../../src/transaction/browser/WalletNetworks.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,cAIX;AAJD,WAAY,cAAc;IACtB,qCAAmB,CAAA;IACnB,qCAAmB,CAAA;IACnB,qCAAmB,CAAA;AACvB,CAAC,EAJW,cAAc,KAAd,cAAc,QAIzB;AAED,MAAM,CAAN,IAAY,eAQX;AARD,WAAY,eAAe;IACvB,sDAAmC,CAAA;IACnC,sDAAmC,CAAA;IACnC,wDAAqC,CAAA;IACrC,sDAAmC,CAAA;IACnC,oDAAiC,CAAA;IACjC,sEAAmD,CAAA;IACnD,sEAAmD,CAAA;AACvD,CAAC,EARW,eAAe,KAAf,eAAe,QAQ1B"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { UTXO } from '../../utxo/interfaces/IUTXO.js';
|
|
2
|
-
import { CancelledTransaction, DeploymentResult, InteractionResponse } from '../interfaces/ITransactionResponses.js';
|
|
3
|
-
import { BroadcastedTransaction, BroadcastTransactionOptions, ICancelTransactionParametersWithoutSigner, ICustomTransactionWithoutSigner, IDeploymentParametersWithoutSigner, InteractionParametersWithoutSigner, MLDSASignature } from '../interfaces/IWeb3ProviderTypes.js';
|
|
1
|
+
import type { UTXO } from '../../utxo/interfaces/IUTXO.js';
|
|
2
|
+
import type { CancelledTransaction, DeploymentResult, InteractionResponse } from '../interfaces/ITransactionResponses.js';
|
|
3
|
+
import type { BroadcastedTransaction, BroadcastTransactionOptions, ICancelTransactionParametersWithoutSigner, ICustomTransactionWithoutSigner, IDeploymentParametersWithoutSigner, InteractionParametersWithoutSigner, MLDSASignature } from '../interfaces/IWeb3ProviderTypes.js';
|
|
4
4
|
export interface Web3Provider {
|
|
5
5
|
signInteraction(interactionParameters: InteractionParametersWithoutSigner): Promise<InteractionResponse>;
|
|
6
6
|
signAndBroadcastInteraction(interactionParameters: InteractionParametersWithoutSigner): Promise<[BroadcastedTransaction, BroadcastedTransaction, UTXO[], string]>;
|
|
@@ -8,8 +8,35 @@ export interface Web3Provider {
|
|
|
8
8
|
customTransaction(params: ICustomTransactionWithoutSigner): Promise<BroadcastedTransaction>;
|
|
9
9
|
deployContract(params: IDeploymentParametersWithoutSigner): Promise<DeploymentResult>;
|
|
10
10
|
broadcast(transactions: BroadcastTransactionOptions[]): Promise<BroadcastedTransaction[]>;
|
|
11
|
+
/**
|
|
12
|
+
* Sign a message using Schnorr signature
|
|
13
|
+
* @param message - Hexadecimal string message to sign
|
|
14
|
+
* @returns The Schnorr signature in hex format
|
|
15
|
+
* @throws {Error} If signing fails or wallet is not connected
|
|
16
|
+
*/
|
|
11
17
|
signSchnorr(message: string): Promise<string>;
|
|
18
|
+
/**
|
|
19
|
+
* Get the ML-DSA public key for the current account
|
|
20
|
+
*
|
|
21
|
+
* @returns The ML-DSA public key in hex format (never exposes private keys)
|
|
22
|
+
* @throws {Error} If the wallet is not connected
|
|
23
|
+
*/
|
|
12
24
|
getMLDSAPublicKey(): Promise<string>;
|
|
25
|
+
/**
|
|
26
|
+
* Sign a message using ML-DSA signature
|
|
27
|
+
*
|
|
28
|
+
* @param message - The message to sign as a hexadecimal string
|
|
29
|
+
* @returns The ML-DSA signature
|
|
30
|
+
* @throws {Error} If signing fails or wallet is not connected
|
|
31
|
+
*/
|
|
13
32
|
signMLDSAMessage(message: string): Promise<MLDSASignature>;
|
|
33
|
+
/**
|
|
34
|
+
* Verify an ML-DSA signature
|
|
35
|
+
*
|
|
36
|
+
* @param message - The original message, hexadecimal string
|
|
37
|
+
* @param signature - The ML-DSA signature to verify
|
|
38
|
+
* @returns True if the signature is valid
|
|
39
|
+
*/
|
|
14
40
|
verifyMLDSASignature(message: string, signature: MLDSASignature): Promise<boolean>;
|
|
15
41
|
}
|
|
42
|
+
//# sourceMappingURL=Web3Provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Web3Provider.d.ts","sourceRoot":"","sources":["../../../src/transaction/browser/Web3Provider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gCAAgC,CAAC;AAC3D,OAAO,KAAK,EACR,oBAAoB,EACpB,gBAAgB,EAChB,mBAAmB,EACtB,MAAM,wCAAwC,CAAC;AAChD,OAAO,KAAK,EACR,sBAAsB,EACtB,2BAA2B,EAC3B,yCAAyC,EACzC,+BAA+B,EAC/B,kCAAkC,EAClC,kCAAkC,EAClC,cAAc,EACjB,MAAM,qCAAqC,CAAC;AAE7C,MAAM,WAAW,YAAY;IACzB,eAAe,CACX,qBAAqB,EAAE,kCAAkC,GAC1D,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAEhC,2BAA2B,CACvB,qBAAqB,EAAE,kCAAkC,GAC1D,OAAO,CAAC,CAAC,sBAAsB,EAAE,sBAAsB,EAAE,IAAI,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC;IAE7E,iBAAiB,CACb,MAAM,EAAE,yCAAyC,GAClD,OAAO,CAAC,oBAAoB,CAAC,CAAC;IAEjC,iBAAiB,CAAC,MAAM,EAAE,+BAA+B,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAC;IAE5F,cAAc,CAAC,MAAM,EAAE,kCAAkC,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAEtF,SAAS,CAAC,YAAY,EAAE,2BAA2B,EAAE,GAAG,OAAO,CAAC,sBAAsB,EAAE,CAAC,CAAC;IAE1F;;;;;OAKG;IACH,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAE9C;;;;;OAKG;IACH,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;IAErC;;;;;;OAMG;IACH,gBAAgB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;IAE3D;;;;;;OAMG;IACH,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,cAAc,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACtF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Web3Provider.js","sourceRoot":"","sources":["../../../src/transaction/browser/Web3Provider.ts"],"names":[],"mappings":""}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { Network, Psbt } from '@btc-vision/bitcoin';
|
|
1
|
+
import { type Network, Psbt } from '@btc-vision/bitcoin';
|
|
2
|
+
import { type MessageHash, type PublicKey, type SchnorrSignature, type Signature } from '@btc-vision/ecpair';
|
|
2
3
|
import { CustomKeypair } from '../BrowserSignerBase.js';
|
|
3
|
-
import { SignatureType, Unisat } from '../types/Unisat.js';
|
|
4
|
-
import { OPWallet } from '../types/OPWallet.js';
|
|
4
|
+
import { SignatureType, type Unisat } from '../types/Unisat.js';
|
|
5
|
+
import type { OPWallet } from '../types/OPWallet.js';
|
|
5
6
|
export interface WindowWithWallets {
|
|
6
7
|
unisat?: Unisat;
|
|
7
8
|
opnet?: OPWallet;
|
|
@@ -16,16 +17,16 @@ export declare class UnisatSigner extends CustomKeypair {
|
|
|
16
17
|
private _addresses;
|
|
17
18
|
get addresses(): string[];
|
|
18
19
|
private _publicKey;
|
|
19
|
-
get publicKey():
|
|
20
|
+
get publicKey(): PublicKey;
|
|
20
21
|
_network: Network | undefined;
|
|
21
22
|
get network(): Network;
|
|
22
23
|
get unisat(): Unisat;
|
|
23
|
-
signData(data:
|
|
24
|
+
signData(data: Uint8Array, type: SignatureType): Promise<Uint8Array>;
|
|
24
25
|
init(): Promise<void>;
|
|
25
|
-
getPublicKey():
|
|
26
|
-
sign(_hash:
|
|
27
|
-
signSchnorr(_hash:
|
|
28
|
-
verify(_hash:
|
|
26
|
+
getPublicKey(): PublicKey;
|
|
27
|
+
sign(_hash: MessageHash, _lowR?: boolean): Signature;
|
|
28
|
+
signSchnorr(_hash: MessageHash): SchnorrSignature;
|
|
29
|
+
verify(_hash: MessageHash, _signature: Signature): boolean;
|
|
29
30
|
signTaprootInput(transaction: Psbt, i: number, sighashTypes: number[]): Promise<void>;
|
|
30
31
|
signInput(transaction: Psbt, i: number, sighashTypes: number[]): Promise<void>;
|
|
31
32
|
multiSignPsbt(transactions: Psbt[]): Promise<void>;
|
|
@@ -35,3 +36,4 @@ export declare class UnisatSigner extends CustomKeypair {
|
|
|
35
36
|
private signAllTweaked;
|
|
36
37
|
private getNonDuplicateScriptSig;
|
|
37
38
|
}
|
|
39
|
+
//# sourceMappingURL=UnisatSigner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UnisatSigner.d.ts","sourceRoot":"","sources":["../../../../src/transaction/browser/extensions/UnisatSigner.ts"],"names":[],"mappings":"AAAA,OAAO,EAIH,KAAK,OAAO,EAEZ,IAAI,EAMP,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAEH,KAAK,WAAW,EAChB,KAAK,SAAS,EACd,KAAK,gBAAgB,EACrB,KAAK,SAAS,EACjB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAA6B,aAAa,EAAE,KAAK,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE3F,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAErD,MAAM,WAAW,iBAAiB;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,QAAQ,CAAC;CACpB;AAED,qBAAa,YAAa,SAAQ,aAAa;IAC3C,OAAO,CAAC,aAAa,CAAkB;;IAUvC,OAAO,CAAC,KAAK,CAAqB;IAElC,IAAW,IAAI,IAAI,MAAM,CAMxB;IAED,OAAO,CAAC,OAAO,CAAqB;IAEpC,IAAW,MAAM,IAAI,MAAM,CAM1B;IAED,OAAO,CAAC,UAAU,CAAuB;IAEzC,IAAW,SAAS,IAAI,MAAM,EAAE,CAM/B;IAED,OAAO,CAAC,UAAU,CAAwB;IAE1C,IAAW,SAAS,IAAI,SAAS,CAMhC;IAEM,QAAQ,EAAE,OAAO,GAAG,SAAS,CAAC;IAErC,IAAW,OAAO,IAAI,OAAO,CAM5B;IAED,IAAW,MAAM,IAAI,MAAM,CAS1B;IAEY,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,aAAa,GAAG,OAAO,CAAC,UAAU,CAAC;IAOpE,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAoC3B,YAAY,IAAI,SAAS;IAQzB,IAAI,CAAC,KAAK,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,SAAS;IAIpD,WAAW,CAAC,KAAK,EAAE,WAAW,GAAG,gBAAgB;IAIjD,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,SAAS,GAAG,OAAO;IAIpD,gBAAgB,CACzB,WAAW,EAAE,IAAI,EACjB,CAAC,EAAE,MAAM,EACT,YAAY,EAAE,MAAM,EAAE,GACvB,OAAO,CAAC,IAAI,CAAC;IAmBH,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB9E,aAAa,CAAC,YAAY,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IA+D/D,OAAO,CAAC,4BAA4B;IAYpC,OAAO,CAAC,oBAAoB;IAY5B,OAAO,CAAC,OAAO;YA6BD,cAAc;IA4B5B,OAAO,CAAC,wBAAwB;CAenC"}
|
|
@@ -1,40 +1,47 @@
|
|
|
1
|
-
import { crypto as bitCrypto, networks, Psbt, script as bitScript, toXOnly, } from '@btc-vision/bitcoin';
|
|
1
|
+
import { crypto as bitCrypto, equals, fromHex, networks, Psbt, script as bitScript, toHex, toXOnly, } from '@btc-vision/bitcoin';
|
|
2
|
+
import { createPublicKey, } from '@btc-vision/ecpair';
|
|
2
3
|
import { EcKeyPair } from '../../../keypair/EcKeyPair.js';
|
|
3
4
|
import { canSignNonTaprootInput, isTaprootInput } from '../../../signer/SignerUtils.js';
|
|
4
5
|
import { CustomKeypair } from '../BrowserSignerBase.js';
|
|
6
|
+
import { SignatureType } from '../types/Unisat.js';
|
|
5
7
|
import { WalletNetworks } from '../WalletNetworks.js';
|
|
6
8
|
export class UnisatSigner extends CustomKeypair {
|
|
9
|
+
isInitialized = false;
|
|
7
10
|
constructor() {
|
|
8
11
|
super();
|
|
9
|
-
this.isInitialized = false;
|
|
10
12
|
if (!window) {
|
|
11
13
|
throw new Error('UnisatSigner can only be used in a browser environment');
|
|
12
14
|
}
|
|
13
15
|
}
|
|
16
|
+
_p2tr;
|
|
14
17
|
get p2tr() {
|
|
15
18
|
if (!this._p2tr) {
|
|
16
19
|
throw new Error('P2TR address not set');
|
|
17
20
|
}
|
|
18
21
|
return this._p2tr;
|
|
19
22
|
}
|
|
23
|
+
_p2wpkh;
|
|
20
24
|
get p2wpkh() {
|
|
21
25
|
if (!this._p2wpkh) {
|
|
22
26
|
throw new Error('P2PKH address not set');
|
|
23
27
|
}
|
|
24
28
|
return this._p2wpkh;
|
|
25
29
|
}
|
|
30
|
+
_addresses;
|
|
26
31
|
get addresses() {
|
|
27
32
|
if (!this._addresses) {
|
|
28
33
|
throw new Error('Addresses not set');
|
|
29
34
|
}
|
|
30
35
|
return this._addresses;
|
|
31
36
|
}
|
|
37
|
+
_publicKey;
|
|
32
38
|
get publicKey() {
|
|
33
39
|
if (!this._publicKey) {
|
|
34
40
|
throw new Error('Public key not set');
|
|
35
41
|
}
|
|
36
42
|
return this._publicKey;
|
|
37
43
|
}
|
|
44
|
+
_network;
|
|
38
45
|
get network() {
|
|
39
46
|
if (!this._network) {
|
|
40
47
|
throw new Error('Network not set');
|
|
@@ -51,9 +58,9 @@ export class UnisatSigner extends CustomKeypair {
|
|
|
51
58
|
return module;
|
|
52
59
|
}
|
|
53
60
|
async signData(data, type) {
|
|
54
|
-
const str = data
|
|
61
|
+
const str = toHex(data);
|
|
55
62
|
const signature = await this.unisat.signData(str, type);
|
|
56
|
-
return
|
|
63
|
+
return fromHex(signature);
|
|
57
64
|
}
|
|
58
65
|
async init() {
|
|
59
66
|
if (this.isInitialized) {
|
|
@@ -77,7 +84,7 @@ export class UnisatSigner extends CustomKeypair {
|
|
|
77
84
|
if (publicKey === '') {
|
|
78
85
|
throw new Error('Unlock your wallet first');
|
|
79
86
|
}
|
|
80
|
-
this._publicKey =
|
|
87
|
+
this._publicKey = createPublicKey(fromHex(publicKey));
|
|
81
88
|
this._p2wpkh = EcKeyPair.getP2WPKHAddress(this, this.network);
|
|
82
89
|
this._p2tr = EcKeyPair.getTaprootAddress(this, this.network);
|
|
83
90
|
this._addresses = [this._p2wpkh, this._p2tr];
|
|
@@ -143,7 +150,7 @@ export class UnisatSigner extends CustomKeypair {
|
|
|
143
150
|
for (const tapLeafScript of input.tapLeafScript) {
|
|
144
151
|
if (pubkeyInScript(this.publicKey, tapLeafScript.script)) {
|
|
145
152
|
needsToSign = true;
|
|
146
|
-
viaTaproot = false;
|
|
153
|
+
viaTaproot = false; // for opnet, we use original keys.
|
|
147
154
|
break;
|
|
148
155
|
}
|
|
149
156
|
}
|
|
@@ -151,20 +158,21 @@ export class UnisatSigner extends CustomKeypair {
|
|
|
151
158
|
if (!needsToSign && input.tapInternalKey) {
|
|
152
159
|
const tapInternalKey = input.tapInternalKey;
|
|
153
160
|
const xOnlyPubKey = toXOnly(this.publicKey);
|
|
154
|
-
if (
|
|
161
|
+
if (equals(tapInternalKey, xOnlyPubKey)) {
|
|
155
162
|
needsToSign = true;
|
|
156
163
|
viaTaproot = true;
|
|
157
164
|
}
|
|
158
165
|
}
|
|
159
166
|
}
|
|
160
167
|
else if (canSignNonTaprootInput(input, this.publicKey)) {
|
|
168
|
+
// Non-Taproot input
|
|
161
169
|
needsToSign = true;
|
|
162
170
|
viaTaproot = false;
|
|
163
171
|
}
|
|
164
172
|
if (needsToSign) {
|
|
165
173
|
return {
|
|
166
174
|
index: i,
|
|
167
|
-
publicKey: this.publicKey
|
|
175
|
+
publicKey: toHex(this.publicKey),
|
|
168
176
|
disableTweakSigner: !viaTaproot,
|
|
169
177
|
};
|
|
170
178
|
}
|
|
@@ -185,8 +193,8 @@ export class UnisatSigner extends CustomKeypair {
|
|
|
185
193
|
hasAlreadySignedTapScriptSig(input) {
|
|
186
194
|
for (let i = 0; i < input.length; i++) {
|
|
187
195
|
const item = input[i];
|
|
188
|
-
const buf =
|
|
189
|
-
if (
|
|
196
|
+
const buf = new Uint8Array(item.pubkey);
|
|
197
|
+
if (equals(buf, this.publicKey) && item.signature) {
|
|
190
198
|
return true;
|
|
191
199
|
}
|
|
192
200
|
}
|
|
@@ -195,8 +203,8 @@ export class UnisatSigner extends CustomKeypair {
|
|
|
195
203
|
hasAlreadyPartialSig(input) {
|
|
196
204
|
for (let i = 0; i < input.length; i++) {
|
|
197
205
|
const item = input[i];
|
|
198
|
-
const buf =
|
|
199
|
-
if (
|
|
206
|
+
const buf = new Uint8Array(item.pubkey);
|
|
207
|
+
if (equals(buf, this.publicKey) && item.signature) {
|
|
200
208
|
return true;
|
|
201
209
|
}
|
|
202
210
|
}
|
|
@@ -225,7 +233,7 @@ export class UnisatSigner extends CustomKeypair {
|
|
|
225
233
|
}
|
|
226
234
|
}
|
|
227
235
|
async signAllTweaked(transaction, sighashTypes, disableTweakSigner = false) {
|
|
228
|
-
const pubKey = this.publicKey
|
|
236
|
+
const pubKey = toHex(this.publicKey);
|
|
229
237
|
const toSign = transaction.data.inputs.map((_, i) => {
|
|
230
238
|
return [
|
|
231
239
|
{
|
|
@@ -247,9 +255,10 @@ export class UnisatSigner extends CustomKeypair {
|
|
|
247
255
|
getNonDuplicateScriptSig(scriptSig1, scriptSig2) {
|
|
248
256
|
const nonDuplicate = [];
|
|
249
257
|
for (let i = 0; i < scriptSig2.length; i++) {
|
|
250
|
-
const
|
|
258
|
+
const sig2 = scriptSig2[i];
|
|
259
|
+
const found = scriptSig1.find((item) => equals(item.pubkey, sig2.pubkey));
|
|
251
260
|
if (!found) {
|
|
252
|
-
nonDuplicate.push(
|
|
261
|
+
nonDuplicate.push(sig2);
|
|
253
262
|
}
|
|
254
263
|
}
|
|
255
264
|
return nonDuplicate;
|
|
@@ -267,7 +276,8 @@ function pubkeyPositionInScript(pubkey, script) {
|
|
|
267
276
|
return decompiled.findIndex((element) => {
|
|
268
277
|
if (typeof element === 'number')
|
|
269
278
|
return false;
|
|
270
|
-
return (
|
|
271
|
-
(
|
|
279
|
+
return (element instanceof Uint8Array &&
|
|
280
|
+
(equals(element, pubkey) || equals(element, pubkeyHash) || equals(element, pubkeyXOnly)));
|
|
272
281
|
});
|
|
273
282
|
}
|
|
283
|
+
//# sourceMappingURL=UnisatSigner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UnisatSigner.js","sourceRoot":"","sources":["../../../../src/transaction/browser/extensions/UnisatSigner.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { Network, Psbt } from '@btc-vision/bitcoin';
|
|
1
|
+
import { type Network, Psbt } from '@btc-vision/bitcoin';
|
|
2
|
+
import { type MessageHash, type PublicKey, type SchnorrSignature, type Signature } from '@btc-vision/ecpair';
|
|
2
3
|
import { CustomKeypair } from '../BrowserSignerBase.js';
|
|
3
|
-
import { SigningProtocol, Xverse } from '../types/Xverse.js';
|
|
4
|
+
import { SigningProtocol, type Xverse } from '../types/Xverse.js';
|
|
4
5
|
declare global {
|
|
5
6
|
interface Window {
|
|
6
7
|
BitcoinProvider?: Xverse;
|
|
@@ -16,16 +17,16 @@ export declare class XverseSigner extends CustomKeypair {
|
|
|
16
17
|
private _addresses;
|
|
17
18
|
get addresses(): string[];
|
|
18
19
|
private _publicKey;
|
|
19
|
-
get publicKey():
|
|
20
|
+
get publicKey(): PublicKey;
|
|
20
21
|
_network: Network | undefined;
|
|
21
22
|
get network(): Network;
|
|
22
23
|
get BitcoinProvider(): Xverse;
|
|
23
24
|
init(): Promise<void>;
|
|
24
|
-
signData(data:
|
|
25
|
-
getPublicKey():
|
|
26
|
-
sign(_hash:
|
|
27
|
-
signSchnorr(_hash:
|
|
28
|
-
verify(_hash:
|
|
25
|
+
signData(data: Uint8Array, address: string, protocol: SigningProtocol): Promise<Uint8Array>;
|
|
26
|
+
getPublicKey(): PublicKey;
|
|
27
|
+
sign(_hash: MessageHash, _lowR?: boolean): Signature;
|
|
28
|
+
signSchnorr(_hash: MessageHash): SchnorrSignature;
|
|
29
|
+
verify(_hash: MessageHash, _signature: Signature): boolean;
|
|
29
30
|
signTaprootInput(transaction: Psbt, i: number, sighashTypes: number[]): Promise<void>;
|
|
30
31
|
signInput(transaction: Psbt, i: number, sighashTypes: number[]): Promise<void>;
|
|
31
32
|
multiSignPsbt(transactions: Psbt[]): Promise<void>;
|
|
@@ -35,3 +36,4 @@ export declare class XverseSigner extends CustomKeypair {
|
|
|
35
36
|
private signAllTweaked;
|
|
36
37
|
private getNonDuplicateScriptSig;
|
|
37
38
|
}
|
|
39
|
+
//# sourceMappingURL=XverseSigner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"XverseSigner.d.ts","sourceRoot":"","sources":["../../../../src/transaction/browser/extensions/XverseSigner.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,KAAK,OAAO,EAEZ,IAAI,EAKP,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAEH,KAAK,WAAW,EAChB,KAAK,SAAS,EACd,KAAK,gBAAgB,EACrB,KAAK,SAAS,EACjB,MAAM,oBAAoB,CAAC;AAO5B,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EAAE,eAAe,EAAE,KAAK,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAElE,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,MAAM;QACZ,eAAe,CAAC,EAAE,MAAM,CAAC;KAC5B;CACJ;AAED,qBAAa,YAAa,SAAQ,aAAa;IAC3C,OAAO,CAAC,aAAa,CAAkB;;IAUvC,OAAO,CAAC,KAAK,CAAqB;IAElC,IAAW,IAAI,IAAI,MAAM,CAMxB;IAED,OAAO,CAAC,OAAO,CAAqB;IAEpC,IAAW,MAAM,IAAI,MAAM,CAM1B;IAED,OAAO,CAAC,UAAU,CAAuB;IAEzC,IAAW,SAAS,IAAI,MAAM,EAAE,CAM/B;IAED,OAAO,CAAC,UAAU,CAAwB;IAE1C,IAAW,SAAS,IAAI,SAAS,CAMhC;IAEM,QAAQ,EAAE,OAAO,GAAG,SAAS,CAAC;IAErC,IAAW,OAAO,IAAI,OAAO,CAM5B;IAED,IAAW,eAAe,IAAI,MAAM,CAOnC;IAEY,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAoCrB,QAAQ,CACjB,IAAI,EAAE,UAAU,EAChB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,eAAe,GAC1B,OAAO,CAAC,UAAU,CAAC;IA0Bf,YAAY,IAAI,SAAS;IAQzB,IAAI,CAAC,KAAK,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,SAAS;IAIpD,WAAW,CAAC,KAAK,EAAE,WAAW,GAAG,gBAAgB;IAIjD,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,SAAS,GAAG,OAAO;IAIpD,gBAAgB,CACzB,WAAW,EAAE,IAAI,EACjB,CAAC,EAAE,MAAM,EACT,YAAY,EAAE,MAAM,EAAE,GACvB,OAAO,CAAC,IAAI,CAAC;IAmBH,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB9E,aAAa,CAAC,YAAY,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IA2E/D,OAAO,CAAC,4BAA4B;IAYpC,OAAO,CAAC,oBAAoB;IAY5B,OAAO,CAAC,OAAO;YA6BD,cAAc;IAwC5B,OAAO,CAAC,wBAAwB;CAenC"}
|
|
@@ -1,39 +1,46 @@
|
|
|
1
|
-
import { networks, Psbt, toXOnly } from '@btc-vision/bitcoin';
|
|
1
|
+
import { equals, fromHex, networks, Psbt, toHex, toXOnly, } from '@btc-vision/bitcoin';
|
|
2
|
+
import { createPublicKey, } from '@btc-vision/ecpair';
|
|
2
3
|
import { EcKeyPair } from '../../../keypair/EcKeyPair.js';
|
|
3
4
|
import { canSignNonTaprootInput, isTaprootInput, pubkeyInScript, } from '../../../signer/SignerUtils.js';
|
|
4
5
|
import { CustomKeypair } from '../BrowserSignerBase.js';
|
|
6
|
+
import { SigningProtocol } from '../types/Xverse.js';
|
|
5
7
|
export class XverseSigner extends CustomKeypair {
|
|
8
|
+
isInitialized = false;
|
|
6
9
|
constructor() {
|
|
7
10
|
super();
|
|
8
|
-
this.isInitialized = false;
|
|
9
11
|
if (!window) {
|
|
10
12
|
throw new Error('XverseSigner can only be used in a browser environment');
|
|
11
13
|
}
|
|
12
14
|
}
|
|
15
|
+
_p2tr;
|
|
13
16
|
get p2tr() {
|
|
14
17
|
if (!this._p2tr) {
|
|
15
18
|
throw new Error('P2TR address not set');
|
|
16
19
|
}
|
|
17
20
|
return this._p2tr;
|
|
18
21
|
}
|
|
22
|
+
_p2wpkh;
|
|
19
23
|
get p2wpkh() {
|
|
20
24
|
if (!this._p2wpkh) {
|
|
21
25
|
throw new Error('P2PKH address not set');
|
|
22
26
|
}
|
|
23
27
|
return this._p2wpkh;
|
|
24
28
|
}
|
|
29
|
+
_addresses;
|
|
25
30
|
get addresses() {
|
|
26
31
|
if (!this._addresses) {
|
|
27
32
|
throw new Error('Addresses not set');
|
|
28
33
|
}
|
|
29
34
|
return this._addresses;
|
|
30
35
|
}
|
|
36
|
+
_publicKey;
|
|
31
37
|
get publicKey() {
|
|
32
38
|
if (!this._publicKey) {
|
|
33
39
|
throw new Error('Public key not set');
|
|
34
40
|
}
|
|
35
41
|
return this._publicKey;
|
|
36
42
|
}
|
|
43
|
+
_network;
|
|
37
44
|
get network() {
|
|
38
45
|
if (!this._network) {
|
|
39
46
|
throw new Error('Network not set');
|
|
@@ -65,7 +72,7 @@ export class XverseSigner extends CustomKeypair {
|
|
|
65
72
|
if (!network)
|
|
66
73
|
throw new Error('Network not supported');
|
|
67
74
|
this._network = network;
|
|
68
|
-
this._publicKey =
|
|
75
|
+
this._publicKey = createPublicKey(fromHex(payementAddress.publicKey));
|
|
69
76
|
this._p2wpkh = EcKeyPair.getP2WPKHAddress(this, this.network);
|
|
70
77
|
this._p2tr = EcKeyPair.getTaprootAddress(this, this.network);
|
|
71
78
|
this._addresses = [this._p2wpkh, this._p2tr];
|
|
@@ -77,7 +84,7 @@ export class XverseSigner extends CustomKeypair {
|
|
|
77
84
|
}
|
|
78
85
|
const callSign = await this.BitcoinProvider.request('signMessage', {
|
|
79
86
|
address,
|
|
80
|
-
message:
|
|
87
|
+
message: new TextDecoder().decode(data),
|
|
81
88
|
protocol,
|
|
82
89
|
});
|
|
83
90
|
if ('error' in callSign)
|
|
@@ -86,7 +93,7 @@ export class XverseSigner extends CustomKeypair {
|
|
|
86
93
|
if (!res.signature) {
|
|
87
94
|
throw new Error('Signature not found');
|
|
88
95
|
}
|
|
89
|
-
return
|
|
96
|
+
return fromHex(res.signature);
|
|
90
97
|
}
|
|
91
98
|
getPublicKey() {
|
|
92
99
|
if (!this.isInitialized) {
|
|
@@ -148,7 +155,7 @@ export class XverseSigner extends CustomKeypair {
|
|
|
148
155
|
for (const tapLeafScript of input.tapLeafScript) {
|
|
149
156
|
if (pubkeyInScript(this.publicKey, tapLeafScript.script)) {
|
|
150
157
|
needsToSign = true;
|
|
151
|
-
viaTaproot = false;
|
|
158
|
+
viaTaproot = false; // for opnet, we use original keys.
|
|
152
159
|
break;
|
|
153
160
|
}
|
|
154
161
|
}
|
|
@@ -156,20 +163,21 @@ export class XverseSigner extends CustomKeypair {
|
|
|
156
163
|
if (!needsToSign && input.tapInternalKey) {
|
|
157
164
|
const tapInternalKey = input.tapInternalKey;
|
|
158
165
|
const xOnlyPubKey = toXOnly(this.publicKey);
|
|
159
|
-
if (
|
|
166
|
+
if (equals(tapInternalKey, xOnlyPubKey)) {
|
|
160
167
|
needsToSign = true;
|
|
161
168
|
viaTaproot = true;
|
|
162
169
|
}
|
|
163
170
|
}
|
|
164
171
|
}
|
|
165
172
|
else if (canSignNonTaprootInput(input, this.publicKey)) {
|
|
173
|
+
// Non-Taproot input
|
|
166
174
|
needsToSign = true;
|
|
167
175
|
viaTaproot = false;
|
|
168
176
|
}
|
|
169
177
|
if (needsToSign) {
|
|
170
178
|
return {
|
|
171
179
|
index: i,
|
|
172
|
-
publicKey: this.publicKey
|
|
180
|
+
publicKey: toHex(this.publicKey),
|
|
173
181
|
disableTweakSigner: !viaTaproot,
|
|
174
182
|
};
|
|
175
183
|
}
|
|
@@ -198,8 +206,8 @@ export class XverseSigner extends CustomKeypair {
|
|
|
198
206
|
hasAlreadySignedTapScriptSig(input) {
|
|
199
207
|
for (let i = 0; i < input.length; i++) {
|
|
200
208
|
const item = input[i];
|
|
201
|
-
const buf =
|
|
202
|
-
if (
|
|
209
|
+
const buf = new Uint8Array(item.pubkey);
|
|
210
|
+
if (equals(buf, this.publicKey) && item.signature) {
|
|
203
211
|
return true;
|
|
204
212
|
}
|
|
205
213
|
}
|
|
@@ -208,8 +216,8 @@ export class XverseSigner extends CustomKeypair {
|
|
|
208
216
|
hasAlreadyPartialSig(input) {
|
|
209
217
|
for (let i = 0; i < input.length; i++) {
|
|
210
218
|
const item = input[i];
|
|
211
|
-
const buf =
|
|
212
|
-
if (
|
|
219
|
+
const buf = new Uint8Array(item.pubkey);
|
|
220
|
+
if (equals(buf, this.publicKey) && item.signature) {
|
|
213
221
|
return true;
|
|
214
222
|
}
|
|
215
223
|
}
|
|
@@ -238,7 +246,7 @@ export class XverseSigner extends CustomKeypair {
|
|
|
238
246
|
}
|
|
239
247
|
}
|
|
240
248
|
async signAllTweaked(transaction, sighashTypes, disableTweakSigner = false) {
|
|
241
|
-
const pubKey = this.publicKey
|
|
249
|
+
const pubKey = toHex(this.publicKey);
|
|
242
250
|
const toSign = transaction.data.inputs.map((_, i) => {
|
|
243
251
|
return [
|
|
244
252
|
{
|
|
@@ -268,11 +276,13 @@ export class XverseSigner extends CustomKeypair {
|
|
|
268
276
|
getNonDuplicateScriptSig(scriptSig1, scriptSig2) {
|
|
269
277
|
const nonDuplicate = [];
|
|
270
278
|
for (let i = 0; i < scriptSig2.length; i++) {
|
|
271
|
-
const
|
|
279
|
+
const sig2 = scriptSig2[i];
|
|
280
|
+
const found = scriptSig1.find((item) => equals(item.pubkey, sig2.pubkey));
|
|
272
281
|
if (!found) {
|
|
273
|
-
nonDuplicate.push(
|
|
282
|
+
nonDuplicate.push(sig2);
|
|
274
283
|
}
|
|
275
284
|
}
|
|
276
285
|
return nonDuplicate;
|
|
277
286
|
}
|
|
278
287
|
}
|
|
288
|
+
//# sourceMappingURL=XverseSigner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"XverseSigner.js","sourceRoot":"","sources":["../../../../src/transaction/browser/extensions/XverseSigner.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,16 @@
|
|
|
1
|
-
import { Unisat } from './Unisat.js';
|
|
2
|
-
import { Web3Provider } from '../Web3Provider.js';
|
|
1
|
+
import type { Unisat } from './Unisat.js';
|
|
2
|
+
import type { Web3Provider } from '../Web3Provider.js';
|
|
3
|
+
/**
|
|
4
|
+
* OPWallet interface extending Unisat with ML-DSA (FIPS 204) support
|
|
5
|
+
*
|
|
6
|
+
* SECURITY NOTE: All methods only expose public keys and signatures.
|
|
7
|
+
* Private keys are NEVER exposed through this interface.
|
|
8
|
+
*/
|
|
3
9
|
export interface OPWallet extends Unisat {
|
|
4
10
|
web3: Web3Provider;
|
|
5
11
|
}
|
|
12
|
+
/**
|
|
13
|
+
* Type guard to check if a wallet supports OPWallet features
|
|
14
|
+
*/
|
|
6
15
|
export declare function isOPWallet(wallet: unknown): wallet is OPWallet;
|
|
16
|
+
//# sourceMappingURL=OPWallet.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OPWallet.d.ts","sourceRoot":"","sources":["../../../../src/transaction/browser/types/OPWallet.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEvD;;;;;GAKG;AACH,MAAM,WAAW,QAAS,SAAQ,MAAM;IACpC,IAAI,EAAE,YAAY,CAAC;CACtB;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,MAAM,EAAE,OAAO,GAAG,MAAM,IAAI,QAAQ,CAS9D"}
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Type guard to check if a wallet supports OPWallet features
|
|
3
|
+
*/
|
|
1
4
|
export function isOPWallet(wallet) {
|
|
2
5
|
return (typeof wallet === 'object' &&
|
|
3
6
|
wallet !== null &&
|
|
@@ -6,3 +9,4 @@ export function isOPWallet(wallet) {
|
|
|
6
9
|
'getMLDSAPublicKey' in wallet.web3 &&
|
|
7
10
|
'signMLDSAMessage' in wallet.web3);
|
|
8
11
|
}
|
|
12
|
+
//# sourceMappingURL=OPWallet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OPWallet.js","sourceRoot":"","sources":["../../../../src/transaction/browser/types/OPWallet.ts"],"names":[],"mappings":"AAaA;;GAEG;AACH,MAAM,UAAU,UAAU,CAAC,MAAe;IACtC,OAAO,CACH,OAAO,MAAM,KAAK,QAAQ;QAC1B,MAAM,KAAK,IAAI;QACf,MAAM,IAAI,MAAM;QAChB,OAAO,MAAM,CAAC,IAAI,KAAK,QAAQ;QAC/B,mBAAmB,IAAK,MAAM,CAAC,IAAqB;QACpD,kBAAkB,IAAK,MAAM,CAAC,IAAqB,CACtD,CAAC;AACN,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Web3Provider } from '../Web3Provider.js';
|
|
1
|
+
import type { Web3Provider } from '../Web3Provider.js';
|
|
2
2
|
import { UnisatChainType, WalletNetworks } from '../WalletNetworks.js';
|
|
3
3
|
export interface UnisatChainInfo {
|
|
4
4
|
readonly enum: UnisatChainType;
|
|
@@ -69,3 +69,4 @@ export interface Unisat {
|
|
|
69
69
|
removeListener(event: 'disconnect', listener: () => void): void;
|
|
70
70
|
}
|
|
71
71
|
export {};
|
|
72
|
+
//# sourceMappingURL=Unisat.d.ts.map
|