@btc-vision/transaction 1.8.0-beta.3 → 1.8.0-beta.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (764) hide show
  1. package/browser/_version.d.ts +1 -0
  2. package/browser/_version.d.ts.map +1 -0
  3. package/browser/abi/ABICoder.d.ts +1 -1
  4. package/browser/abi/ABICoder.d.ts.map +1 -0
  5. package/browser/branded/Branded.d.ts +4 -0
  6. package/browser/branded/Branded.d.ts.map +1 -0
  7. package/browser/btc-vision-bitcoin.js +11999 -2647
  8. package/browser/buffer/BinaryReader.d.ts +120 -1
  9. package/browser/buffer/BinaryReader.d.ts.map +1 -0
  10. package/browser/buffer/BinaryWriter.d.ts +51 -1
  11. package/browser/buffer/BinaryWriter.d.ts.map +1 -0
  12. package/browser/bytecode/Compressor.d.ts +12 -0
  13. package/browser/bytecode/Compressor.d.ts.map +1 -0
  14. package/browser/chain/ChainData.d.ts +2 -2
  15. package/browser/chain/ChainData.d.ts.map +1 -0
  16. package/browser/consensus/Consensus.d.ts +11 -3
  17. package/browser/consensus/Consensus.d.ts.map +1 -0
  18. package/browser/consensus/ConsensusConfig.d.ts +1 -0
  19. package/browser/consensus/ConsensusConfig.d.ts.map +1 -0
  20. package/browser/consensus/IConsensusConfig.d.ts +1 -0
  21. package/browser/consensus/IConsensusConfig.d.ts.map +1 -0
  22. package/browser/consensus/metadata/RoswellConsensus.d.ts +1 -0
  23. package/browser/consensus/metadata/RoswellConsensus.d.ts.map +1 -0
  24. package/browser/crypto/crypto.d.ts +1 -0
  25. package/browser/crypto/crypto.d.ts.map +1 -0
  26. package/browser/deterministic/AddressMap.d.ts +6 -1
  27. package/browser/deterministic/AddressMap.d.ts.map +1 -0
  28. package/browser/deterministic/AddressSet.d.ts +3 -1
  29. package/browser/deterministic/AddressSet.d.ts.map +1 -0
  30. package/browser/deterministic/CustomMap.d.ts +3 -1
  31. package/browser/deterministic/CustomMap.d.ts.map +1 -0
  32. package/browser/deterministic/DeterministicMap.d.ts +3 -1
  33. package/browser/deterministic/DeterministicMap.d.ts.map +1 -0
  34. package/browser/deterministic/DeterministicSet.d.ts +3 -1
  35. package/browser/deterministic/DeterministicSet.d.ts.map +1 -0
  36. package/browser/deterministic/ExtendedAddressMap.d.ts +7 -1
  37. package/browser/deterministic/ExtendedAddressMap.d.ts.map +1 -0
  38. package/browser/deterministic/FastMap.d.ts +7 -1
  39. package/browser/deterministic/FastMap.d.ts.map +1 -0
  40. package/browser/ecc/backend.d.ts +13 -0
  41. package/browser/ecc/backend.d.ts.map +1 -0
  42. package/browser/epoch/ChallengeSolution.d.ts +33 -1
  43. package/browser/epoch/ChallengeSolution.d.ts.map +1 -0
  44. package/browser/epoch/interfaces/IChallengeSolution.d.ts +14 -13
  45. package/browser/epoch/interfaces/IChallengeSolution.d.ts.map +1 -0
  46. package/browser/epoch/validator/EpochValidator.d.ts +37 -7
  47. package/browser/epoch/validator/EpochValidator.d.ts.map +1 -0
  48. package/browser/event/NetEvent.d.ts +1 -0
  49. package/browser/event/NetEvent.d.ts.map +1 -0
  50. package/browser/generators/AddressGenerator.d.ts +4 -3
  51. package/browser/generators/AddressGenerator.d.ts.map +1 -0
  52. package/browser/generators/Features.d.ts +1 -0
  53. package/browser/generators/Features.d.ts.map +1 -0
  54. package/browser/generators/Generator.d.ts +46 -10
  55. package/browser/generators/Generator.d.ts.map +1 -0
  56. package/browser/generators/MLDSAData.d.ts +1 -0
  57. package/browser/generators/MLDSAData.d.ts.map +1 -0
  58. package/browser/generators/builders/CalldataGenerator.d.ts +25 -4
  59. package/browser/generators/builders/CalldataGenerator.d.ts.map +1 -0
  60. package/browser/generators/builders/CustomGenerator.d.ts +13 -3
  61. package/browser/generators/builders/CustomGenerator.d.ts.map +1 -0
  62. package/browser/generators/builders/DeploymentGenerator.d.ts +15 -4
  63. package/browser/generators/builders/DeploymentGenerator.d.ts.map +1 -0
  64. package/browser/generators/builders/HashCommitmentGenerator.d.ts +164 -12
  65. package/browser/generators/builders/HashCommitmentGenerator.d.ts.map +1 -0
  66. package/browser/generators/builders/LegacyCalldataGenerator.d.ts +26 -4
  67. package/browser/generators/builders/LegacyCalldataGenerator.d.ts.map +1 -0
  68. package/browser/generators/builders/MultiSignGenerator.d.ts +6 -1
  69. package/browser/generators/builders/MultiSignGenerator.d.ts.map +1 -0
  70. package/browser/generators/builders/P2WDAGenerator.d.ts +42 -4
  71. package/browser/generators/builders/P2WDAGenerator.d.ts.map +1 -0
  72. package/browser/index.d.ts +1 -0
  73. package/browser/index.d.ts.map +1 -0
  74. package/browser/index.js +3558 -3167
  75. package/browser/keypair/Address.d.ts +283 -13
  76. package/browser/keypair/Address.d.ts.map +1 -0
  77. package/browser/keypair/AddressVerificator.d.ts +7 -6
  78. package/browser/keypair/AddressVerificator.d.ts.map +1 -0
  79. package/browser/keypair/EcKeyPair.d.ts +183 -21
  80. package/browser/keypair/EcKeyPair.d.ts.map +1 -0
  81. package/browser/keypair/MessageSigner.d.ts +17 -16
  82. package/browser/keypair/MessageSigner.d.ts.map +1 -0
  83. package/browser/keypair/Secp256k1PointDeriver.d.ts +55 -0
  84. package/browser/keypair/Secp256k1PointDeriver.d.ts.map +1 -0
  85. package/browser/keypair/Wallet.d.ts +27 -13
  86. package/browser/keypair/Wallet.d.ts.map +1 -0
  87. package/browser/keypair/interfaces/IWallet.d.ts +19 -0
  88. package/browser/keypair/interfaces/IWallet.d.ts.map +1 -0
  89. package/browser/metadata/ContractBaseMetadata.d.ts +10 -2
  90. package/browser/metadata/ContractBaseMetadata.d.ts.map +1 -0
  91. package/browser/mnemonic/BIPStandard.d.ts +59 -0
  92. package/browser/mnemonic/BIPStandard.d.ts.map +1 -0
  93. package/browser/mnemonic/Mnemonic.d.ts +15 -3
  94. package/browser/mnemonic/Mnemonic.d.ts.map +1 -0
  95. package/browser/mnemonic/MnemonicStrength.d.ts +6 -0
  96. package/browser/mnemonic/MnemonicStrength.d.ts.map +1 -0
  97. package/browser/network/ChainId.d.ts +1 -0
  98. package/browser/network/ChainId.d.ts.map +1 -0
  99. package/browser/noble-curves.js +844 -2746
  100. package/browser/noble-hashes.js +1338 -2067
  101. package/browser/opnet.d.ts +22 -1
  102. package/browser/opnet.d.ts.map +1 -0
  103. package/browser/p2wda/P2WDADetector.d.ts +36 -9
  104. package/browser/p2wda/P2WDADetector.d.ts.map +1 -0
  105. package/browser/polyfill/disposable.d.ts +16 -0
  106. package/browser/polyfill/disposable.d.ts.map +1 -0
  107. package/browser/signer/AddressRotation.d.ts +36 -0
  108. package/browser/signer/AddressRotation.d.ts.map +1 -0
  109. package/browser/signer/IRotationSigner.d.ts +27 -3
  110. package/browser/signer/IRotationSigner.d.ts.map +1 -0
  111. package/browser/signer/ParallelSignerAdapter.d.ts +14 -0
  112. package/browser/signer/ParallelSignerAdapter.d.ts.map +1 -0
  113. package/browser/signer/SignerUtils.d.ts +11 -4
  114. package/browser/signer/SignerUtils.d.ts.map +1 -0
  115. package/browser/signer/TweakedSigner.d.ts +28 -4
  116. package/browser/signer/TweakedSigner.d.ts.map +1 -0
  117. package/browser/transaction/ContractAddress.d.ts +2 -2
  118. package/browser/transaction/ContractAddress.d.ts.map +1 -0
  119. package/browser/transaction/TransactionFactory.d.ts +140 -2
  120. package/browser/transaction/TransactionFactory.d.ts.map +1 -0
  121. package/browser/transaction/browser/BrowserSignerBase.d.ts +12 -6
  122. package/browser/transaction/browser/BrowserSignerBase.d.ts.map +1 -0
  123. package/browser/transaction/browser/WalletNetworks.d.ts +1 -0
  124. package/browser/transaction/browser/WalletNetworks.d.ts.map +1 -0
  125. package/browser/transaction/browser/Web3Provider.d.ts +27 -0
  126. package/browser/transaction/browser/Web3Provider.d.ts.map +1 -0
  127. package/browser/transaction/browser/extensions/UnisatSigner.d.ts +9 -7
  128. package/browser/transaction/browser/extensions/UnisatSigner.d.ts.map +1 -0
  129. package/browser/transaction/browser/extensions/XverseSigner.d.ts +9 -7
  130. package/browser/transaction/browser/extensions/XverseSigner.d.ts.map +1 -0
  131. package/browser/transaction/browser/types/OPWallet.d.ts +10 -0
  132. package/browser/transaction/browser/types/OPWallet.d.ts.map +1 -0
  133. package/browser/transaction/browser/types/Unisat.d.ts +1 -0
  134. package/browser/transaction/browser/types/Unisat.d.ts.map +1 -0
  135. package/browser/transaction/browser/types/Xverse.d.ts +1 -0
  136. package/browser/transaction/browser/types/Xverse.d.ts.map +1 -0
  137. package/browser/transaction/builders/CancelTransaction.d.ts +29 -4
  138. package/browser/transaction/builders/CancelTransaction.d.ts.map +1 -0
  139. package/browser/transaction/builders/ChallengeSolutionTransaction.d.ts +1 -0
  140. package/browser/transaction/builders/ChallengeSolutionTransaction.d.ts.map +1 -0
  141. package/browser/transaction/builders/ConsolidatedInteractionTransaction.d.ts +137 -10
  142. package/browser/transaction/builders/ConsolidatedInteractionTransaction.d.ts.map +1 -0
  143. package/browser/transaction/builders/CustomScriptTransaction.d.ts +106 -6
  144. package/browser/transaction/builders/CustomScriptTransaction.d.ts.map +1 -0
  145. package/browser/transaction/builders/DeploymentTransaction.d.ts +116 -5
  146. package/browser/transaction/builders/DeploymentTransaction.d.ts.map +1 -0
  147. package/browser/transaction/builders/FundingTransaction.d.ts +4 -3
  148. package/browser/transaction/builders/FundingTransaction.d.ts.map +1 -0
  149. package/browser/transaction/builders/InteractionTransaction.d.ts +12 -3
  150. package/browser/transaction/builders/InteractionTransaction.d.ts.map +1 -0
  151. package/browser/transaction/builders/InteractionTransactionP2WDA.d.ts +56 -5
  152. package/browser/transaction/builders/InteractionTransactionP2WDA.d.ts.map +1 -0
  153. package/browser/transaction/builders/MultiSignTransaction.d.ts +125 -16
  154. package/browser/transaction/builders/MultiSignTransaction.d.ts.map +1 -0
  155. package/browser/transaction/builders/SharedInteractionTransaction.d.ts +103 -15
  156. package/browser/transaction/builders/SharedInteractionTransaction.d.ts.map +1 -0
  157. package/browser/transaction/builders/TransactionBuilder.d.ts +243 -14
  158. package/browser/transaction/builders/TransactionBuilder.d.ts.map +1 -0
  159. package/browser/transaction/enums/TransactionType.d.ts +1 -0
  160. package/browser/transaction/enums/TransactionType.d.ts.map +1 -0
  161. package/browser/transaction/interfaces/ICancelTransactionParameters.d.ts +2 -1
  162. package/browser/transaction/interfaces/ICancelTransactionParameters.d.ts.map +1 -0
  163. package/browser/transaction/interfaces/IConsolidatedTransactionParameters.d.ts +46 -3
  164. package/browser/transaction/interfaces/IConsolidatedTransactionParameters.d.ts.map +1 -0
  165. package/browser/transaction/interfaces/ICustomTransactionParameters.d.ts +6 -4
  166. package/browser/transaction/interfaces/ICustomTransactionParameters.d.ts.map +1 -0
  167. package/browser/transaction/interfaces/ITransactionParameters.d.ts +22 -10
  168. package/browser/transaction/interfaces/ITransactionParameters.d.ts.map +1 -0
  169. package/browser/transaction/interfaces/ITransactionResponses.d.ts +1 -0
  170. package/browser/transaction/interfaces/ITransactionResponses.d.ts.map +1 -0
  171. package/browser/transaction/interfaces/ITweakedTransactionData.d.ts +17 -5
  172. package/browser/transaction/interfaces/ITweakedTransactionData.d.ts.map +1 -0
  173. package/browser/transaction/interfaces/IWeb3ProviderTypes.d.ts +26 -0
  174. package/browser/transaction/interfaces/IWeb3ProviderTypes.d.ts.map +1 -0
  175. package/browser/transaction/interfaces/Tap.d.ts +4 -3
  176. package/browser/transaction/interfaces/Tap.d.ts.map +1 -0
  177. package/browser/transaction/mineable/IP2WSHAddress.d.ts +2 -1
  178. package/browser/transaction/mineable/IP2WSHAddress.d.ts.map +1 -0
  179. package/browser/transaction/mineable/TimelockGenerator.d.ts +12 -3
  180. package/browser/transaction/mineable/TimelockGenerator.d.ts.map +1 -0
  181. package/browser/transaction/offline/OfflineTransactionManager.d.ts +190 -9
  182. package/browser/transaction/offline/OfflineTransactionManager.d.ts.map +1 -0
  183. package/browser/transaction/offline/TransactionReconstructor.d.ts +53 -3
  184. package/browser/transaction/offline/TransactionReconstructor.d.ts.map +1 -0
  185. package/browser/transaction/offline/TransactionSerializer.d.ts +53 -2
  186. package/browser/transaction/offline/TransactionSerializer.d.ts.map +1 -0
  187. package/browser/transaction/offline/TransactionStateCapture.d.ts +64 -5
  188. package/browser/transaction/offline/TransactionStateCapture.d.ts.map +1 -0
  189. package/browser/transaction/offline/interfaces/ISerializableState.d.ts +71 -0
  190. package/browser/transaction/offline/interfaces/ISerializableState.d.ts.map +1 -0
  191. package/browser/transaction/offline/interfaces/ITypeSpecificData.d.ts +76 -0
  192. package/browser/transaction/offline/interfaces/ITypeSpecificData.d.ts.map +1 -0
  193. package/browser/transaction/psbt/PSBTTypes.d.ts +1 -0
  194. package/browser/transaction/psbt/PSBTTypes.d.ts.map +1 -0
  195. package/browser/transaction/shared/P2TR_MS.d.ts +11 -2
  196. package/browser/transaction/shared/P2TR_MS.d.ts.map +1 -0
  197. package/browser/transaction/shared/TweakedTransaction.d.ts +274 -33
  198. package/browser/transaction/shared/TweakedTransaction.d.ts.map +1 -0
  199. package/browser/transaction/utils/WitnessUtils.d.ts +7 -1
  200. package/browser/transaction/utils/WitnessUtils.d.ts.map +1 -0
  201. package/browser/utils/BitcoinUtils.d.ts +19 -0
  202. package/browser/utils/BitcoinUtils.d.ts.map +1 -0
  203. package/browser/utils/BufferHelper.d.ts +1 -0
  204. package/browser/utils/BufferHelper.d.ts.map +1 -0
  205. package/browser/utils/StringToBuffer.d.ts +1 -0
  206. package/browser/utils/StringToBuffer.d.ts.map +1 -0
  207. package/browser/utils/lengths.d.ts +1 -0
  208. package/browser/utils/lengths.d.ts.map +1 -0
  209. package/browser/utils/types.d.ts +1 -0
  210. package/browser/utils/types.d.ts.map +1 -0
  211. package/browser/utxo/OPNetLimitedProvider.d.ts +37 -1
  212. package/browser/utxo/OPNetLimitedProvider.d.ts.map +1 -0
  213. package/browser/utxo/interfaces/BroadcastResponse.d.ts +1 -0
  214. package/browser/utxo/interfaces/BroadcastResponse.d.ts.map +1 -0
  215. package/browser/utxo/interfaces/IUTXO.d.ts +11 -5
  216. package/browser/utxo/interfaces/IUTXO.d.ts.map +1 -0
  217. package/browser/vendors.js +14351 -10031
  218. package/browser/verification/TapscriptVerificator.d.ts +10 -8
  219. package/browser/verification/TapscriptVerificator.d.ts.map +1 -0
  220. package/build/_version.d.ts +1 -0
  221. package/build/_version.d.ts.map +1 -0
  222. package/build/_version.js +1 -0
  223. package/build/_version.js.map +1 -0
  224. package/build/abi/ABICoder.d.ts +1 -1
  225. package/build/abi/ABICoder.d.ts.map +1 -0
  226. package/build/abi/ABICoder.js +9 -10
  227. package/build/abi/ABICoder.js.map +1 -0
  228. package/build/branded/Branded.d.ts +4 -0
  229. package/build/branded/Branded.d.ts.map +1 -0
  230. package/build/branded/Branded.js +2 -0
  231. package/build/branded/Branded.js.map +1 -0
  232. package/build/buffer/BinaryReader.d.ts +121 -2
  233. package/build/buffer/BinaryReader.d.ts.map +1 -0
  234. package/build/buffer/BinaryReader.js +129 -5
  235. package/build/buffer/BinaryReader.js.map +1 -0
  236. package/build/buffer/BinaryWriter.d.ts +52 -2
  237. package/build/buffer/BinaryWriter.d.ts.map +1 -0
  238. package/build/buffer/BinaryWriter.js +62 -2
  239. package/build/buffer/BinaryWriter.js.map +1 -0
  240. package/build/bytecode/Compressor.d.ts +12 -0
  241. package/build/bytecode/Compressor.d.ts.map +1 -0
  242. package/build/bytecode/Compressor.js +17 -5
  243. package/build/bytecode/Compressor.js.map +1 -0
  244. package/build/chain/ChainData.d.ts +2 -2
  245. package/build/chain/ChainData.d.ts.map +1 -0
  246. package/build/chain/ChainData.js +35 -17
  247. package/build/chain/ChainData.js.map +1 -0
  248. package/build/consensus/Consensus.d.ts +11 -3
  249. package/build/consensus/Consensus.d.ts.map +1 -0
  250. package/build/consensus/Consensus.js +8 -0
  251. package/build/consensus/Consensus.js.map +1 -0
  252. package/build/consensus/ConsensusConfig.d.ts +2 -1
  253. package/build/consensus/ConsensusConfig.d.ts.map +1 -0
  254. package/build/consensus/ConsensusConfig.js +1 -0
  255. package/build/consensus/ConsensusConfig.js.map +1 -0
  256. package/build/consensus/IConsensusConfig.d.ts +1 -0
  257. package/build/consensus/IConsensusConfig.d.ts.map +1 -0
  258. package/build/consensus/IConsensusConfig.js +2 -1
  259. package/build/consensus/IConsensusConfig.js.map +1 -0
  260. package/build/consensus/metadata/RoswellConsensus.d.ts +2 -1
  261. package/build/consensus/metadata/RoswellConsensus.d.ts.map +1 -0
  262. package/build/consensus/metadata/RoswellConsensus.js +2 -0
  263. package/build/consensus/metadata/RoswellConsensus.js.map +1 -0
  264. package/build/crypto/crypto.d.ts +1 -0
  265. package/build/crypto/crypto.d.ts.map +1 -0
  266. package/build/crypto/crypto.js +1 -0
  267. package/build/crypto/crypto.js.map +1 -0
  268. package/build/deterministic/AddressMap.d.ts +6 -1
  269. package/build/deterministic/AddressMap.d.ts.map +1 -0
  270. package/build/deterministic/AddressMap.js +8 -0
  271. package/build/deterministic/AddressMap.js.map +1 -0
  272. package/build/deterministic/AddressSet.d.ts +3 -1
  273. package/build/deterministic/AddressSet.d.ts.map +1 -0
  274. package/build/deterministic/AddressSet.js +7 -0
  275. package/build/deterministic/AddressSet.js.map +1 -0
  276. package/build/deterministic/CustomMap.d.ts +3 -1
  277. package/build/deterministic/CustomMap.d.ts.map +1 -0
  278. package/build/deterministic/CustomMap.js +65 -47
  279. package/build/deterministic/CustomMap.js.map +1 -0
  280. package/build/deterministic/DeterministicMap.d.ts +4 -2
  281. package/build/deterministic/DeterministicMap.d.ts.map +1 -0
  282. package/build/deterministic/DeterministicMap.js +24 -27
  283. package/build/deterministic/DeterministicMap.js.map +1 -0
  284. package/build/deterministic/DeterministicSet.d.ts +3 -1
  285. package/build/deterministic/DeterministicSet.d.ts.map +1 -0
  286. package/build/deterministic/DeterministicSet.js +6 -0
  287. package/build/deterministic/DeterministicSet.js.map +1 -0
  288. package/build/deterministic/ExtendedAddressMap.d.ts +7 -1
  289. package/build/deterministic/ExtendedAddressMap.d.ts.map +1 -0
  290. package/build/deterministic/ExtendedAddressMap.js +18 -2
  291. package/build/deterministic/ExtendedAddressMap.js.map +1 -0
  292. package/build/deterministic/FastMap.d.ts +7 -1
  293. package/build/deterministic/FastMap.d.ts.map +1 -0
  294. package/build/deterministic/FastMap.js +7 -2
  295. package/build/deterministic/FastMap.js.map +1 -0
  296. package/build/ecc/backend.d.ts +13 -0
  297. package/build/ecc/backend.d.ts.map +1 -0
  298. package/build/ecc/backend.js +15 -0
  299. package/build/ecc/backend.js.map +1 -0
  300. package/build/epoch/ChallengeSolution.d.ts +34 -2
  301. package/build/epoch/ChallengeSolution.d.ts.map +1 -0
  302. package/build/epoch/ChallengeSolution.js +52 -0
  303. package/build/epoch/ChallengeSolution.js.map +1 -0
  304. package/build/epoch/interfaces/IChallengeSolution.d.ts +14 -13
  305. package/build/epoch/interfaces/IChallengeSolution.d.ts.map +1 -0
  306. package/build/epoch/interfaces/IChallengeSolution.js +2 -1
  307. package/build/epoch/interfaces/IChallengeSolution.js.map +1 -0
  308. package/build/epoch/validator/EpochValidator.d.ts +38 -8
  309. package/build/epoch/validator/EpochValidator.d.ts.map +1 -0
  310. package/build/epoch/validator/EpochValidator.js +45 -19
  311. package/build/epoch/validator/EpochValidator.js.map +1 -0
  312. package/build/event/NetEvent.d.ts +1 -0
  313. package/build/event/NetEvent.d.ts.map +1 -0
  314. package/build/event/NetEvent.js +3 -0
  315. package/build/event/NetEvent.js.map +1 -0
  316. package/build/generators/AddressGenerator.d.ts +4 -3
  317. package/build/generators/AddressGenerator.d.ts.map +1 -0
  318. package/build/generators/AddressGenerator.js +9 -4
  319. package/build/generators/AddressGenerator.js.map +1 -0
  320. package/build/generators/Features.d.ts +4 -3
  321. package/build/generators/Features.d.ts.map +1 -0
  322. package/build/generators/Features.js +1 -0
  323. package/build/generators/Features.js.map +1 -0
  324. package/build/generators/Generator.d.ts +47 -11
  325. package/build/generators/Generator.d.ts.map +1 -0
  326. package/build/generators/Generator.js +48 -12
  327. package/build/generators/Generator.js.map +1 -0
  328. package/build/generators/MLDSAData.d.ts +1 -0
  329. package/build/generators/MLDSAData.d.ts.map +1 -0
  330. package/build/generators/MLDSAData.js +1 -0
  331. package/build/generators/MLDSAData.js.map +1 -0
  332. package/build/generators/builders/CalldataGenerator.d.ts +27 -6
  333. package/build/generators/builders/CalldataGenerator.d.ts.map +1 -0
  334. package/build/generators/builders/CalldataGenerator.js +33 -4
  335. package/build/generators/builders/CalldataGenerator.js.map +1 -0
  336. package/build/generators/builders/CustomGenerator.d.ts +13 -3
  337. package/build/generators/builders/CustomGenerator.d.ts.map +1 -0
  338. package/build/generators/builders/CustomGenerator.js +11 -0
  339. package/build/generators/builders/CustomGenerator.js.map +1 -0
  340. package/build/generators/builders/DeploymentGenerator.d.ts +17 -6
  341. package/build/generators/builders/DeploymentGenerator.d.ts.map +1 -0
  342. package/build/generators/builders/DeploymentGenerator.js +18 -2
  343. package/build/generators/builders/DeploymentGenerator.js.map +1 -0
  344. package/build/generators/builders/HashCommitmentGenerator.d.ts +166 -14
  345. package/build/generators/builders/HashCommitmentGenerator.d.ts.map +1 -0
  346. package/build/generators/builders/HashCommitmentGenerator.js +193 -27
  347. package/build/generators/builders/HashCommitmentGenerator.js.map +1 -0
  348. package/build/generators/builders/LegacyCalldataGenerator.d.ts +27 -5
  349. package/build/generators/builders/LegacyCalldataGenerator.d.ts.map +1 -0
  350. package/build/generators/builders/LegacyCalldataGenerator.js +35 -5
  351. package/build/generators/builders/LegacyCalldataGenerator.js.map +1 -0
  352. package/build/generators/builders/MultiSignGenerator.d.ts +6 -1
  353. package/build/generators/builders/MultiSignGenerator.d.ts.map +1 -0
  354. package/build/generators/builders/MultiSignGenerator.js +20 -10
  355. package/build/generators/builders/MultiSignGenerator.js.map +1 -0
  356. package/build/generators/builders/P2WDAGenerator.d.ts +44 -6
  357. package/build/generators/builders/P2WDAGenerator.d.ts.map +1 -0
  358. package/build/generators/builders/P2WDAGenerator.js +41 -2
  359. package/build/generators/builders/P2WDAGenerator.js.map +1 -0
  360. package/build/index.d.ts +1 -0
  361. package/build/index.d.ts.map +1 -0
  362. package/build/index.js +1 -0
  363. package/build/index.js.map +1 -0
  364. package/build/keypair/Address.d.ts +284 -14
  365. package/build/keypair/Address.d.ts.map +1 -0
  366. package/build/keypair/Address.js +446 -128
  367. package/build/keypair/Address.js.map +1 -0
  368. package/build/keypair/AddressVerificator.d.ts +7 -6
  369. package/build/keypair/AddressVerificator.d.ts.map +1 -0
  370. package/build/keypair/AddressVerificator.js +4 -5
  371. package/build/keypair/AddressVerificator.js.map +1 -0
  372. package/build/keypair/EcKeyPair.d.ts +185 -23
  373. package/build/keypair/EcKeyPair.d.ts.map +1 -0
  374. package/build/keypair/EcKeyPair.js +218 -50
  375. package/build/keypair/EcKeyPair.js.map +1 -0
  376. package/build/keypair/MessageSigner.d.ts +18 -17
  377. package/build/keypair/MessageSigner.d.ts.map +1 -0
  378. package/build/keypair/MessageSigner.js +34 -25
  379. package/build/keypair/MessageSigner.js.map +1 -0
  380. package/build/keypair/Secp256k1PointDeriver.d.ts +55 -0
  381. package/build/keypair/Secp256k1PointDeriver.d.ts.map +1 -0
  382. package/build/keypair/Secp256k1PointDeriver.js +66 -0
  383. package/build/keypair/Secp256k1PointDeriver.js.map +1 -0
  384. package/build/keypair/Wallet.d.ts +29 -15
  385. package/build/keypair/Wallet.d.ts.map +1 -0
  386. package/build/keypair/Wallet.js +46 -14
  387. package/build/keypair/Wallet.js.map +1 -0
  388. package/build/keypair/interfaces/IWallet.d.ts +19 -0
  389. package/build/keypair/interfaces/IWallet.d.ts.map +1 -0
  390. package/build/keypair/interfaces/IWallet.js +1 -0
  391. package/build/keypair/interfaces/IWallet.js.map +1 -0
  392. package/build/metadata/ContractBaseMetadata.d.ts +10 -2
  393. package/build/metadata/ContractBaseMetadata.d.ts.map +1 -0
  394. package/build/metadata/ContractBaseMetadata.js +10 -1
  395. package/build/metadata/ContractBaseMetadata.js.map +1 -0
  396. package/build/mnemonic/BIPStandard.d.ts +59 -0
  397. package/build/mnemonic/BIPStandard.d.ts.map +1 -0
  398. package/build/mnemonic/BIPStandard.js +59 -0
  399. package/build/mnemonic/BIPStandard.js.map +1 -0
  400. package/build/mnemonic/Mnemonic.d.ts +16 -4
  401. package/build/mnemonic/Mnemonic.d.ts.map +1 -0
  402. package/build/mnemonic/Mnemonic.js +35 -8
  403. package/build/mnemonic/Mnemonic.js.map +1 -0
  404. package/build/mnemonic/MnemonicStrength.d.ts +6 -0
  405. package/build/mnemonic/MnemonicStrength.d.ts.map +1 -0
  406. package/build/mnemonic/MnemonicStrength.js +6 -0
  407. package/build/mnemonic/MnemonicStrength.js.map +1 -0
  408. package/build/network/ChainId.d.ts +1 -0
  409. package/build/network/ChainId.d.ts.map +1 -0
  410. package/build/network/ChainId.js +1 -0
  411. package/build/network/ChainId.js.map +1 -0
  412. package/build/opnet.d.ts +26 -3
  413. package/build/opnet.d.ts.map +1 -0
  414. package/build/opnet.js +23 -0
  415. package/build/opnet.js.map +1 -0
  416. package/build/p2wda/P2WDADetector.d.ts +38 -11
  417. package/build/p2wda/P2WDADetector.d.ts.map +1 -0
  418. package/build/p2wda/P2WDADetector.js +43 -10
  419. package/build/p2wda/P2WDADetector.js.map +1 -0
  420. package/build/polyfill/disposable.d.ts +16 -0
  421. package/build/polyfill/disposable.d.ts.map +1 -0
  422. package/build/polyfill/disposable.js +23 -0
  423. package/build/polyfill/disposable.js.map +1 -0
  424. package/build/signer/AddressRotation.d.ts +37 -1
  425. package/build/signer/AddressRotation.d.ts.map +1 -0
  426. package/build/signer/AddressRotation.js +16 -0
  427. package/build/signer/AddressRotation.js.map +1 -0
  428. package/build/signer/IRotationSigner.d.ts +27 -3
  429. package/build/signer/IRotationSigner.d.ts.map +1 -0
  430. package/build/signer/IRotationSigner.js +2 -1
  431. package/build/signer/IRotationSigner.js.map +1 -0
  432. package/build/signer/ParallelSignerAdapter.d.ts +14 -0
  433. package/build/signer/ParallelSignerAdapter.d.ts.map +1 -0
  434. package/build/signer/ParallelSignerAdapter.js +51 -0
  435. package/build/signer/ParallelSignerAdapter.js.map +1 -0
  436. package/build/signer/SignerUtils.d.ts +11 -4
  437. package/build/signer/SignerUtils.d.ts.map +1 -0
  438. package/build/signer/SignerUtils.js +16 -0
  439. package/build/signer/SignerUtils.js.map +1 -0
  440. package/build/signer/TweakedSigner.d.ts +28 -4
  441. package/build/signer/TweakedSigner.d.ts.map +1 -0
  442. package/build/signer/TweakedSigner.js +23 -6
  443. package/build/signer/TweakedSigner.js.map +1 -0
  444. package/build/transaction/ContractAddress.d.ts +2 -2
  445. package/build/transaction/ContractAddress.d.ts.map +1 -0
  446. package/build/transaction/ContractAddress.js +4 -8
  447. package/build/transaction/ContractAddress.js.map +1 -0
  448. package/build/transaction/TransactionFactory.d.ts +147 -9
  449. package/build/transaction/TransactionFactory.d.ts.map +1 -0
  450. package/build/transaction/TransactionFactory.js +145 -26
  451. package/build/transaction/TransactionFactory.js.map +1 -0
  452. package/build/transaction/browser/BrowserSignerBase.d.ts +12 -6
  453. package/build/transaction/browser/BrowserSignerBase.d.ts.map +1 -0
  454. package/build/transaction/browser/BrowserSignerBase.js +7 -0
  455. package/build/transaction/browser/BrowserSignerBase.js.map +1 -0
  456. package/build/transaction/browser/WalletNetworks.d.ts +1 -0
  457. package/build/transaction/browser/WalletNetworks.d.ts.map +1 -0
  458. package/build/transaction/browser/WalletNetworks.js +1 -0
  459. package/build/transaction/browser/WalletNetworks.js.map +1 -0
  460. package/build/transaction/browser/Web3Provider.d.ts +30 -3
  461. package/build/transaction/browser/Web3Provider.d.ts.map +1 -0
  462. package/build/transaction/browser/Web3Provider.js +1 -0
  463. package/build/transaction/browser/Web3Provider.js.map +1 -0
  464. package/build/transaction/browser/extensions/UnisatSigner.d.ts +11 -9
  465. package/build/transaction/browser/extensions/UnisatSigner.d.ts.map +1 -0
  466. package/build/transaction/browser/extensions/UnisatSigner.js +27 -17
  467. package/build/transaction/browser/extensions/UnisatSigner.js.map +1 -0
  468. package/build/transaction/browser/extensions/XverseSigner.d.ts +10 -8
  469. package/build/transaction/browser/extensions/XverseSigner.d.ts.map +1 -0
  470. package/build/transaction/browser/extensions/XverseSigner.js +25 -15
  471. package/build/transaction/browser/extensions/XverseSigner.js.map +1 -0
  472. package/build/transaction/browser/types/OPWallet.d.ts +12 -2
  473. package/build/transaction/browser/types/OPWallet.d.ts.map +1 -0
  474. package/build/transaction/browser/types/OPWallet.js +4 -0
  475. package/build/transaction/browser/types/OPWallet.js.map +1 -0
  476. package/build/transaction/browser/types/Unisat.d.ts +2 -1
  477. package/build/transaction/browser/types/Unisat.d.ts.map +1 -0
  478. package/build/transaction/browser/types/Unisat.js +2 -0
  479. package/build/transaction/browser/types/Unisat.js.map +1 -0
  480. package/build/transaction/browser/types/Xverse.d.ts +1 -0
  481. package/build/transaction/browser/types/Xverse.d.ts.map +1 -0
  482. package/build/transaction/browser/types/Xverse.js +1 -0
  483. package/build/transaction/browser/types/Xverse.js.map +1 -0
  484. package/build/transaction/builders/CancelTransaction.d.ts +31 -6
  485. package/build/transaction/builders/CancelTransaction.d.ts.map +1 -0
  486. package/build/transaction/builders/CancelTransaction.js +116 -33
  487. package/build/transaction/builders/CancelTransaction.js.map +1 -0
  488. package/build/transaction/builders/ChallengeSolutionTransaction.d.ts +1 -0
  489. package/build/transaction/builders/ChallengeSolutionTransaction.d.ts.map +1 -0
  490. package/build/transaction/builders/ChallengeSolutionTransaction.js +88 -0
  491. package/build/transaction/builders/ChallengeSolutionTransaction.js.map +1 -0
  492. package/build/transaction/builders/ConsolidatedInteractionTransaction.d.ts +140 -13
  493. package/build/transaction/builders/ConsolidatedInteractionTransaction.d.ts.map +1 -0
  494. package/build/transaction/builders/ConsolidatedInteractionTransaction.js +197 -20
  495. package/build/transaction/builders/ConsolidatedInteractionTransaction.js.map +1 -0
  496. package/build/transaction/builders/CustomScriptTransaction.d.ts +108 -8
  497. package/build/transaction/builders/CustomScriptTransaction.d.ts.map +1 -0
  498. package/build/transaction/builders/CustomScriptTransaction.js +176 -39
  499. package/build/transaction/builders/CustomScriptTransaction.js.map +1 -0
  500. package/build/transaction/builders/DeploymentTransaction.d.ts +120 -9
  501. package/build/transaction/builders/DeploymentTransaction.d.ts.map +1 -0
  502. package/build/transaction/builders/DeploymentTransaction.js +194 -51
  503. package/build/transaction/builders/DeploymentTransaction.js.map +1 -0
  504. package/build/transaction/builders/FundingTransaction.d.ts +5 -4
  505. package/build/transaction/builders/FundingTransaction.d.ts.map +1 -0
  506. package/build/transaction/builders/FundingTransaction.js +15 -8
  507. package/build/transaction/builders/FundingTransaction.js.map +1 -0
  508. package/build/transaction/builders/InteractionTransaction.d.ts +14 -5
  509. package/build/transaction/builders/InteractionTransaction.d.ts.map +1 -0
  510. package/build/transaction/builders/InteractionTransaction.js +18 -5
  511. package/build/transaction/builders/InteractionTransaction.js.map +1 -0
  512. package/build/transaction/builders/InteractionTransactionP2WDA.d.ts +58 -7
  513. package/build/transaction/builders/InteractionTransactionP2WDA.d.ts.map +1 -0
  514. package/build/transaction/builders/InteractionTransactionP2WDA.js +95 -18
  515. package/build/transaction/builders/InteractionTransactionP2WDA.js.map +1 -0
  516. package/build/transaction/builders/MultiSignTransaction.d.ts +126 -17
  517. package/build/transaction/builders/MultiSignTransaction.d.ts.map +1 -0
  518. package/build/transaction/builders/MultiSignTransaction.js +201 -76
  519. package/build/transaction/builders/MultiSignTransaction.js.map +1 -0
  520. package/build/transaction/builders/SharedInteractionTransaction.d.ts +106 -18
  521. package/build/transaction/builders/SharedInteractionTransaction.d.ts.map +1 -0
  522. package/build/transaction/builders/SharedInteractionTransaction.js +158 -40
  523. package/build/transaction/builders/SharedInteractionTransaction.js.map +1 -0
  524. package/build/transaction/builders/TransactionBuilder.d.ts +249 -19
  525. package/build/transaction/builders/TransactionBuilder.d.ts.map +1 -0
  526. package/build/transaction/builders/TransactionBuilder.js +375 -60
  527. package/build/transaction/builders/TransactionBuilder.js.map +1 -0
  528. package/build/transaction/enums/TransactionType.d.ts +1 -0
  529. package/build/transaction/enums/TransactionType.d.ts.map +1 -0
  530. package/build/transaction/enums/TransactionType.js +1 -0
  531. package/build/transaction/enums/TransactionType.js.map +1 -0
  532. package/build/transaction/interfaces/ICancelTransactionParameters.d.ts +3 -2
  533. package/build/transaction/interfaces/ICancelTransactionParameters.d.ts.map +1 -0
  534. package/build/transaction/interfaces/ICancelTransactionParameters.js +1 -0
  535. package/build/transaction/interfaces/ICancelTransactionParameters.js.map +1 -0
  536. package/build/transaction/interfaces/IConsolidatedTransactionParameters.d.ts +48 -5
  537. package/build/transaction/interfaces/IConsolidatedTransactionParameters.d.ts.map +1 -0
  538. package/build/transaction/interfaces/IConsolidatedTransactionParameters.js +1 -0
  539. package/build/transaction/interfaces/IConsolidatedTransactionParameters.js.map +1 -0
  540. package/build/transaction/interfaces/ICustomTransactionParameters.d.ts +7 -5
  541. package/build/transaction/interfaces/ICustomTransactionParameters.d.ts.map +1 -0
  542. package/build/transaction/interfaces/ICustomTransactionParameters.js +1 -0
  543. package/build/transaction/interfaces/ICustomTransactionParameters.js.map +1 -0
  544. package/build/transaction/interfaces/ITransactionParameters.d.ts +27 -15
  545. package/build/transaction/interfaces/ITransactionParameters.d.ts.map +1 -0
  546. package/build/transaction/interfaces/ITransactionParameters.js +1 -0
  547. package/build/transaction/interfaces/ITransactionParameters.js.map +1 -0
  548. package/build/transaction/interfaces/ITransactionResponses.d.ts +3 -2
  549. package/build/transaction/interfaces/ITransactionResponses.d.ts.map +1 -0
  550. package/build/transaction/interfaces/ITransactionResponses.js +1 -0
  551. package/build/transaction/interfaces/ITransactionResponses.js.map +1 -0
  552. package/build/transaction/interfaces/ITweakedTransactionData.d.ts +21 -8
  553. package/build/transaction/interfaces/ITweakedTransactionData.d.ts.map +1 -0
  554. package/build/transaction/interfaces/ITweakedTransactionData.js +1 -0
  555. package/build/transaction/interfaces/ITweakedTransactionData.js.map +1 -0
  556. package/build/transaction/interfaces/IWeb3ProviderTypes.d.ts +29 -3
  557. package/build/transaction/interfaces/IWeb3ProviderTypes.d.ts.map +1 -0
  558. package/build/transaction/interfaces/IWeb3ProviderTypes.js +2 -1
  559. package/build/transaction/interfaces/IWeb3ProviderTypes.js.map +1 -0
  560. package/build/transaction/interfaces/Tap.d.ts +4 -3
  561. package/build/transaction/interfaces/Tap.d.ts.map +1 -0
  562. package/build/transaction/interfaces/Tap.js +1 -0
  563. package/build/transaction/interfaces/Tap.js.map +1 -0
  564. package/build/transaction/mineable/IP2WSHAddress.d.ts +2 -1
  565. package/build/transaction/mineable/IP2WSHAddress.d.ts.map +1 -0
  566. package/build/transaction/mineable/IP2WSHAddress.js +1 -0
  567. package/build/transaction/mineable/IP2WSHAddress.js.map +1 -0
  568. package/build/transaction/mineable/TimelockGenerator.d.ts +13 -4
  569. package/build/transaction/mineable/TimelockGenerator.d.ts.map +1 -0
  570. package/build/transaction/mineable/TimelockGenerator.js +12 -3
  571. package/build/transaction/mineable/TimelockGenerator.js.map +1 -0
  572. package/build/transaction/offline/OfflineTransactionManager.d.ts +193 -12
  573. package/build/transaction/offline/OfflineTransactionManager.d.ts.map +1 -0
  574. package/build/transaction/offline/OfflineTransactionManager.js +192 -8
  575. package/build/transaction/offline/OfflineTransactionManager.js.map +1 -0
  576. package/build/transaction/offline/TransactionReconstructor.d.ts +56 -6
  577. package/build/transaction/offline/TransactionReconstructor.d.ts.map +1 -0
  578. package/build/transaction/offline/TransactionReconstructor.js +111 -75
  579. package/build/transaction/offline/TransactionReconstructor.js.map +1 -0
  580. package/build/transaction/offline/TransactionSerializer.d.ts +54 -3
  581. package/build/transaction/offline/TransactionSerializer.d.ts.map +1 -0
  582. package/build/transaction/offline/TransactionSerializer.js +206 -95
  583. package/build/transaction/offline/TransactionSerializer.js.map +1 -0
  584. package/build/transaction/offline/TransactionStateCapture.d.ts +66 -7
  585. package/build/transaction/offline/TransactionStateCapture.d.ts.map +1 -0
  586. package/build/transaction/offline/TransactionStateCapture.js +124 -60
  587. package/build/transaction/offline/TransactionStateCapture.js.map +1 -0
  588. package/build/transaction/offline/interfaces/ISerializableState.d.ts +72 -1
  589. package/build/transaction/offline/interfaces/ISerializableState.d.ts.map +1 -0
  590. package/build/transaction/offline/interfaces/ISerializableState.js +10 -1
  591. package/build/transaction/offline/interfaces/ISerializableState.js.map +1 -0
  592. package/build/transaction/offline/interfaces/ITypeSpecificData.d.ts +77 -1
  593. package/build/transaction/offline/interfaces/ITypeSpecificData.d.ts.map +1 -0
  594. package/build/transaction/offline/interfaces/ITypeSpecificData.js +19 -0
  595. package/build/transaction/offline/interfaces/ITypeSpecificData.js.map +1 -0
  596. package/build/transaction/psbt/PSBTTypes.d.ts +1 -0
  597. package/build/transaction/psbt/PSBTTypes.d.ts.map +1 -0
  598. package/build/transaction/psbt/PSBTTypes.js +1 -0
  599. package/build/transaction/psbt/PSBTTypes.js.map +1 -0
  600. package/build/transaction/shared/P2TR_MS.d.ts +11 -2
  601. package/build/transaction/shared/P2TR_MS.d.ts.map +1 -0
  602. package/build/transaction/shared/P2TR_MS.js +10 -0
  603. package/build/transaction/shared/P2TR_MS.js.map +1 -0
  604. package/build/transaction/shared/TweakedTransaction.d.ts +281 -38
  605. package/build/transaction/shared/TweakedTransaction.d.ts.map +1 -0
  606. package/build/transaction/shared/TweakedTransaction.js +576 -114
  607. package/build/transaction/shared/TweakedTransaction.js.map +1 -0
  608. package/build/transaction/utils/WitnessUtils.d.ts +7 -1
  609. package/build/transaction/utils/WitnessUtils.d.ts.map +1 -0
  610. package/build/transaction/utils/WitnessUtils.js +17 -3
  611. package/build/transaction/utils/WitnessUtils.js.map +1 -0
  612. package/build/tsconfig.build.tsbuildinfo +1 -1
  613. package/build/utils/BitcoinUtils.d.ts +19 -0
  614. package/build/utils/BitcoinUtils.d.ts.map +1 -0
  615. package/build/utils/BitcoinUtils.js +19 -0
  616. package/build/utils/BitcoinUtils.js.map +1 -0
  617. package/build/utils/BufferHelper.d.ts +2 -1
  618. package/build/utils/BufferHelper.d.ts.map +1 -0
  619. package/build/utils/BufferHelper.js +38 -32
  620. package/build/utils/BufferHelper.js.map +1 -0
  621. package/build/utils/StringToBuffer.d.ts +1 -0
  622. package/build/utils/StringToBuffer.d.ts.map +1 -0
  623. package/build/utils/StringToBuffer.js +1 -0
  624. package/build/utils/StringToBuffer.js.map +1 -0
  625. package/build/utils/lengths.d.ts +1 -0
  626. package/build/utils/lengths.d.ts.map +1 -0
  627. package/build/utils/lengths.js +1 -0
  628. package/build/utils/lengths.js.map +1 -0
  629. package/build/utils/types.d.ts +1 -0
  630. package/build/utils/types.d.ts.map +1 -0
  631. package/build/utils/types.js +2 -1
  632. package/build/utils/types.js.map +1 -0
  633. package/build/utxo/OPNetLimitedProvider.d.ts +39 -3
  634. package/build/utxo/OPNetLimitedProvider.d.ts.map +1 -0
  635. package/build/utxo/OPNetLimitedProvider.js +43 -5
  636. package/build/utxo/OPNetLimitedProvider.js.map +1 -0
  637. package/build/utxo/interfaces/BroadcastResponse.d.ts +1 -0
  638. package/build/utxo/interfaces/BroadcastResponse.d.ts.map +1 -0
  639. package/build/utxo/interfaces/BroadcastResponse.js +1 -0
  640. package/build/utxo/interfaces/BroadcastResponse.js.map +1 -0
  641. package/build/utxo/interfaces/IUTXO.d.ts +13 -7
  642. package/build/utxo/interfaces/IUTXO.d.ts.map +1 -0
  643. package/build/utxo/interfaces/IUTXO.js +1 -0
  644. package/build/utxo/interfaces/IUTXO.js.map +1 -0
  645. package/build/verification/TapscriptVerificator.d.ts +12 -10
  646. package/build/verification/TapscriptVerificator.d.ts.map +1 -0
  647. package/build/verification/TapscriptVerificator.js +28 -38
  648. package/build/verification/TapscriptVerificator.js.map +1 -0
  649. package/eslint.config.js +0 -1
  650. package/package.json +12 -35
  651. package/src/abi/ABICoder.ts +0 -13
  652. package/src/branded/Branded.ts +5 -0
  653. package/src/buffer/BinaryReader.ts +7 -7
  654. package/src/buffer/BinaryWriter.ts +29 -24
  655. package/src/bytecode/Compressor.ts +1 -1
  656. package/src/chain/ChainData.ts +34 -27
  657. package/src/consensus/ConsensusConfig.ts +1 -1
  658. package/src/consensus/IConsensusConfig.ts +0 -17
  659. package/src/consensus/metadata/RoswellConsensus.ts +1 -17
  660. package/src/deterministic/AddressMap.ts +5 -1
  661. package/src/deterministic/AddressSet.ts +5 -1
  662. package/src/deterministic/CustomMap.ts +6 -2
  663. package/src/deterministic/DeterministicMap.ts +8 -4
  664. package/src/deterministic/DeterministicSet.ts +6 -2
  665. package/src/deterministic/ExtendedAddressMap.ts +9 -4
  666. package/src/deterministic/FastMap.ts +9 -5
  667. package/src/ecc/backend.ts +17 -0
  668. package/src/epoch/ChallengeSolution.ts +3 -3
  669. package/src/epoch/interfaces/IChallengeSolution.ts +13 -13
  670. package/src/epoch/validator/EpochValidator.ts +24 -43
  671. package/src/generators/AddressGenerator.ts +4 -7
  672. package/src/generators/Features.ts +3 -3
  673. package/src/generators/Generator.ts +42 -26
  674. package/src/generators/builders/CalldataGenerator.ts +26 -24
  675. package/src/generators/builders/CustomGenerator.ts +4 -4
  676. package/src/generators/builders/DeploymentGenerator.ts +25 -23
  677. package/src/generators/builders/HashCommitmentGenerator.ts +31 -31
  678. package/src/generators/builders/LegacyCalldataGenerator.ts +26 -24
  679. package/src/generators/builders/MultiSignGenerator.ts +12 -12
  680. package/src/generators/builders/P2WDAGenerator.ts +10 -10
  681. package/src/keypair/Address.ts +114 -71
  682. package/src/keypair/AddressVerificator.ts +14 -148
  683. package/src/keypair/EcKeyPair.ts +104 -116
  684. package/src/keypair/MessageSigner.ts +70 -150
  685. package/src/keypair/Wallet.ts +56 -241
  686. package/src/metadata/ContractBaseMetadata.ts +2 -2
  687. package/src/mnemonic/Mnemonic.ts +31 -222
  688. package/src/opnet.ts +12 -6
  689. package/src/p2wda/P2WDADetector.ts +23 -72
  690. package/src/polyfill/disposable.ts +29 -0
  691. package/src/signer/AddressRotation.ts +1 -1
  692. package/src/signer/IRotationSigner.ts +3 -3
  693. package/src/signer/ParallelSignerAdapter.ts +59 -0
  694. package/src/signer/SignerUtils.ts +4 -4
  695. package/src/signer/TweakedSigner.ts +26 -14
  696. package/src/transaction/ContractAddress.ts +3 -7
  697. package/src/transaction/TransactionFactory.ts +28 -50
  698. package/src/transaction/browser/BrowserSignerBase.ts +12 -6
  699. package/src/transaction/browser/Web3Provider.ts +3 -3
  700. package/src/transaction/browser/extensions/UnisatSigner.ts +52 -48
  701. package/src/transaction/browser/extensions/XverseSigner.ts +55 -38
  702. package/src/transaction/browser/types/OPWallet.ts +2 -2
  703. package/src/transaction/browser/types/Unisat.ts +1 -1
  704. package/src/transaction/builders/CancelTransaction.ts +59 -24
  705. package/src/transaction/builders/ChallengeSolutionTransaction.ts +3 -3
  706. package/src/transaction/builders/ConsolidatedInteractionTransaction.ts +39 -34
  707. package/src/transaction/builders/CustomScriptTransaction.ts +79 -56
  708. package/src/transaction/builders/DeploymentTransaction.ts +82 -63
  709. package/src/transaction/builders/FundingTransaction.ts +11 -11
  710. package/src/transaction/builders/InteractionTransaction.ts +10 -10
  711. package/src/transaction/builders/InteractionTransactionP2WDA.ts +38 -40
  712. package/src/transaction/builders/MultiSignTransaction.ts +68 -61
  713. package/src/transaction/builders/SharedInteractionTransaction.ts +81 -57
  714. package/src/transaction/builders/TransactionBuilder.ts +99 -81
  715. package/src/transaction/interfaces/ICancelTransactionParameters.ts +2 -2
  716. package/src/transaction/interfaces/IConsolidatedTransactionParameters.ts +5 -5
  717. package/src/transaction/interfaces/ICustomTransactionParameters.ts +5 -5
  718. package/src/transaction/interfaces/ITransactionParameters.ts +15 -15
  719. package/src/transaction/interfaces/ITransactionResponses.ts +2 -2
  720. package/src/transaction/interfaces/ITweakedTransactionData.ts +17 -8
  721. package/src/transaction/interfaces/IWeb3ProviderTypes.ts +3 -3
  722. package/src/transaction/interfaces/Tap.ts +3 -3
  723. package/src/transaction/mineable/IP2WSHAddress.ts +1 -1
  724. package/src/transaction/mineable/TimelockGenerator.ts +19 -12
  725. package/src/transaction/offline/OfflineTransactionManager.ts +22 -23
  726. package/src/transaction/offline/TransactionReconstructor.ts +83 -91
  727. package/src/transaction/offline/TransactionSerializer.ts +151 -101
  728. package/src/transaction/offline/TransactionStateCapture.ts +83 -79
  729. package/src/transaction/offline/interfaces/ISerializableState.ts +1 -1
  730. package/src/transaction/offline/interfaces/ITypeSpecificData.ts +1 -1
  731. package/src/transaction/shared/P2TR_MS.ts +4 -4
  732. package/src/transaction/shared/TweakedTransaction.ts +326 -124
  733. package/src/transaction/utils/WitnessUtils.ts +18 -9
  734. package/src/utils/BufferHelper.ts +39 -37
  735. package/src/utxo/OPNetLimitedProvider.ts +9 -9
  736. package/src/utxo/interfaces/IUTXO.ts +7 -7
  737. package/src/verification/TapscriptVerificator.ts +73 -86
  738. package/test/address-rotation.test.ts +24 -24
  739. package/test/address.test.ts +12 -12
  740. package/test/addressmap.test.ts +30 -30
  741. package/test/binary-reader-writer.test.ts +8 -8
  742. package/test/browser/offline-transaction.test.ts +2206 -0
  743. package/test/browser/parallel-signing.test.ts +316 -0
  744. package/test/browser/setup.ts +11 -0
  745. package/test/browser/transaction-signing.test.ts +416 -0
  746. package/test/buffer-helper.test.ts +287 -0
  747. package/test/derivePath.test.ts +4 -3
  748. package/test/disposable.test.ts +279 -0
  749. package/test/fastmap-setall.test.ts +1 -1
  750. package/test/fastmap.test.ts +3 -3
  751. package/test/messagesigner-mldsa.test.ts +3 -3
  752. package/test/messagesigner-schnorr.test.ts +9 -9
  753. package/test/offline-transaction.test.ts +461 -288
  754. package/test/old/FastBigIntMap.ts +3 -3
  755. package/test/oldfastmap.test.ts +6 -6
  756. package/test/transaction-builders.test.ts +321 -0
  757. package/tsconfig.base.json +34 -18
  758. package/tsconfig.browser.json +15 -0
  759. package/tsconfig.json +3 -8
  760. package/vite.config.browser.ts +4 -5
  761. package/vitest.config.browser.ts +68 -0
  762. package/vitest.config.ts +1 -1
  763. package/browser/valibot.js +0 -4948
  764. 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: Buffer;
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(): Buffer;
12
- abstract sign(hash: Buffer, lowR?: boolean): Buffer;
13
- abstract signSchnorr(hash: Buffer): Buffer;
14
- abstract verify(hash: Buffer, signature: Buffer): boolean | Buffer;
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"}
@@ -1,3 +1,10 @@
1
+ import { Psbt } from '@btc-vision/bitcoin';
2
+ import {} from '@btc-vision/ecpair';
3
+ /**
4
+ * Create a custom keypair.
5
+ * @class CustomKeypair
6
+ */
1
7
  export class CustomKeypair {
2
8
  constructor() { }
3
9
  }
10
+ //# sourceMappingURL=BrowserSignerBase.js.map
@@ -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"}
@@ -12,3 +12,4 @@ export declare enum UnisatChainType {
12
12
  FRACTAL_BITCOIN_MAINNET = "FRACTAL_BITCOIN_MAINNET",
13
13
  FRACTAL_BITCOIN_TESTNET = "FRACTAL_BITCOIN_TESTNET"
14
14
  }
15
+ //# sourceMappingURL=WalletNetworks.d.ts.map
@@ -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"}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=Web3Provider.js.map
@@ -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(): Buffer;
20
+ get publicKey(): PublicKey;
20
21
  _network: Network | undefined;
21
22
  get network(): Network;
22
23
  get unisat(): Unisat;
23
- signData(data: Buffer, type: SignatureType): Promise<Buffer>;
24
+ signData(data: Uint8Array, type: SignatureType): Promise<Uint8Array>;
24
25
  init(): Promise<void>;
25
- getPublicKey(): Buffer;
26
- sign(_hash: Buffer, _lowR?: boolean): Buffer;
27
- signSchnorr(_hash: Buffer): Buffer;
28
- verify(_hash: Buffer, _signature: Buffer): boolean;
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.toString('hex');
61
+ const str = toHex(data);
55
62
  const signature = await this.unisat.signData(str, type);
56
- return Buffer.from(signature, 'hex');
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 = Buffer.from(publicKey, 'hex');
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 (tapInternalKey.equals(xOnlyPubKey)) {
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.toString('hex'),
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 = Buffer.from(item.pubkey);
189
- if (buf.equals(this.publicKey) && item.signature) {
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 = Buffer.from(item.pubkey);
199
- if (buf.equals(this.publicKey) && item.signature) {
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.toString('hex');
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 found = scriptSig1.find((item) => item.pubkey.equals(scriptSig2[i].pubkey));
258
+ const sig2 = scriptSig2[i];
259
+ const found = scriptSig1.find((item) => equals(item.pubkey, sig2.pubkey));
251
260
  if (!found) {
252
- nonDuplicate.push(scriptSig2[i]);
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 (Buffer.isBuffer(element) &&
271
- (element.equals(pubkey) || element.equals(pubkeyHash) || element.equals(pubkeyXOnly)));
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(): Buffer;
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: Buffer, address: string, protocol: SigningProtocol): Promise<Buffer>;
25
- getPublicKey(): Buffer;
26
- sign(_hash: Buffer, _lowR?: boolean): Buffer;
27
- signSchnorr(_hash: Buffer): Buffer;
28
- verify(_hash: Buffer, _signature: Buffer): boolean;
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 = Buffer.from(payementAddress.publicKey, 'hex');
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: data.toString(),
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 Buffer.from(res.signature, 'hex');
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 (tapInternalKey.equals(xOnlyPubKey)) {
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.toString('hex'),
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 = Buffer.from(item.pubkey);
202
- if (buf.equals(this.publicKey) && item.signature) {
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 = Buffer.from(item.pubkey);
212
- if (buf.equals(this.publicKey) && item.signature) {
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.toString('hex');
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 found = scriptSig1.find((item) => item.pubkey.equals(scriptSig2[i].pubkey));
279
+ const sig2 = scriptSig2[i];
280
+ const found = scriptSig1.find((item) => equals(item.pubkey, sig2.pubkey));
272
281
  if (!found) {
273
- nonDuplicate.push(scriptSig2[i]);
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