viem 0.0.0-w-20230725184008 → 0.0.0-w-20230810155401

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 (438) hide show
  1. package/README.md +6 -0
  2. package/chains/utils/package.json +5 -0
  3. package/dist/cjs/accounts/index.js +6 -2
  4. package/dist/cjs/accounts/index.js.map +1 -1
  5. package/dist/cjs/accounts/utils/privateKeyToAddress.js +12 -0
  6. package/dist/cjs/accounts/utils/privateKeyToAddress.js.map +1 -0
  7. package/dist/cjs/accounts/utils/signMessage.js +1 -1
  8. package/dist/cjs/accounts/utils/signMessage.js.map +1 -1
  9. package/dist/cjs/accounts/utils/signTransaction.js.map +1 -1
  10. package/dist/cjs/accounts/utils/signTypedData.js +1 -1
  11. package/dist/cjs/accounts/utils/signTypedData.js.map +1 -1
  12. package/dist/cjs/actions/ens/getEnsAddress.js +18 -13
  13. package/dist/cjs/actions/ens/getEnsAddress.js.map +1 -1
  14. package/dist/cjs/actions/index.js.map +1 -1
  15. package/dist/cjs/actions/public/createContractEventFilter.js.map +1 -1
  16. package/dist/cjs/actions/public/createEventFilter.js +16 -8
  17. package/dist/cjs/actions/public/createEventFilter.js.map +1 -1
  18. package/dist/cjs/actions/public/estimateContractGas.js +1 -1
  19. package/dist/cjs/actions/public/estimateContractGas.js.map +1 -1
  20. package/dist/cjs/actions/public/estimateGas.js +3 -1
  21. package/dist/cjs/actions/public/estimateGas.js.map +1 -1
  22. package/dist/cjs/actions/public/getBlock.js +3 -1
  23. package/dist/cjs/actions/public/getBlock.js.map +1 -1
  24. package/dist/cjs/actions/public/getBlockNumber.js +2 -2
  25. package/dist/cjs/actions/public/getBlockNumber.js.map +1 -1
  26. package/dist/cjs/actions/public/getFilterChanges.js.map +1 -1
  27. package/dist/cjs/actions/public/getFilterLogs.js +1 -1
  28. package/dist/cjs/actions/public/getFilterLogs.js.map +1 -1
  29. package/dist/cjs/actions/public/getLogs.js +16 -10
  30. package/dist/cjs/actions/public/getLogs.js.map +1 -1
  31. package/dist/cjs/actions/public/getTransaction.js +2 -1
  32. package/dist/cjs/actions/public/getTransaction.js.map +1 -1
  33. package/dist/cjs/actions/public/watchBlockNumber.js +1 -1
  34. package/dist/cjs/actions/public/watchBlockNumber.js.map +1 -1
  35. package/dist/cjs/actions/public/watchBlocks.js +2 -1
  36. package/dist/cjs/actions/public/watchBlocks.js.map +1 -1
  37. package/dist/cjs/actions/public/watchContractEvent.js +135 -65
  38. package/dist/cjs/actions/public/watchContractEvent.js.map +1 -1
  39. package/dist/cjs/actions/public/watchEvent.js +138 -59
  40. package/dist/cjs/actions/public/watchEvent.js.map +1 -1
  41. package/dist/cjs/actions/wallet/sendTransaction.js.map +1 -1
  42. package/dist/cjs/actions/wallet/writeContract.js.map +1 -1
  43. package/dist/cjs/chains/{formatters/celo.js → celo/formatters.js} +1 -1
  44. package/dist/cjs/chains/celo/formatters.js.map +1 -0
  45. package/dist/cjs/chains/{serializers/celo.js → celo/serializers.js} +1 -1
  46. package/dist/cjs/chains/celo/serializers.js.map +1 -0
  47. package/dist/cjs/{types/formatter.js → chains/celo/types.js} +1 -1
  48. package/dist/cjs/chains/celo/types.js.map +1 -0
  49. package/dist/cjs/chains/index.js +30 -15
  50. package/dist/cjs/chains/index.js.map +1 -1
  51. package/dist/cjs/chains/optimism/fees.js +7 -0
  52. package/dist/cjs/chains/optimism/fees.js.map +1 -0
  53. package/dist/cjs/chains/{formatters/optimism.js → optimism/formatters.js} +13 -1
  54. package/dist/cjs/chains/optimism/formatters.js.map +1 -0
  55. package/dist/cjs/{types/serializer.js → chains/optimism/types.js} +1 -1
  56. package/dist/cjs/chains/optimism/types.js.map +1 -0
  57. package/dist/cjs/chains/utils.js +11 -0
  58. package/dist/cjs/chains/utils.js.map +1 -0
  59. package/dist/cjs/clients/createClient.js +2 -1
  60. package/dist/cjs/clients/createClient.js.map +1 -1
  61. package/dist/cjs/clients/createPublicClient.js.map +1 -1
  62. package/dist/cjs/clients/createTestClient.js.map +1 -1
  63. package/dist/cjs/clients/createWalletClient.js.map +1 -1
  64. package/dist/cjs/clients/decorators/public.js.map +1 -1
  65. package/dist/cjs/constants/abis.js +12 -2
  66. package/dist/cjs/constants/abis.js.map +1 -1
  67. package/dist/cjs/constants/number.js +101 -0
  68. package/dist/cjs/constants/number.js.map +1 -0
  69. package/dist/cjs/contract.js.map +1 -1
  70. package/dist/cjs/errors/abi.js +8 -1
  71. package/dist/cjs/errors/abi.js.map +1 -1
  72. package/dist/cjs/errors/contract.js +56 -32
  73. package/dist/cjs/errors/contract.js.map +1 -1
  74. package/dist/cjs/errors/node.js +1 -1
  75. package/dist/cjs/errors/node.js.map +1 -1
  76. package/dist/cjs/errors/version.js +1 -1
  77. package/dist/cjs/errors/version.js.map +1 -1
  78. package/dist/cjs/index.js +110 -7
  79. package/dist/cjs/index.js.map +1 -1
  80. package/dist/cjs/public.js.map +1 -1
  81. package/dist/cjs/utils/abi/encodeAbiParameters.js +11 -14
  82. package/dist/cjs/utils/abi/encodeAbiParameters.js.map +1 -1
  83. package/dist/cjs/utils/abi/encodePacked.js +2 -0
  84. package/dist/cjs/utils/abi/encodePacked.js.map +1 -1
  85. package/dist/cjs/utils/chain.js +5 -3
  86. package/dist/cjs/utils/chain.js.map +1 -1
  87. package/dist/cjs/utils/formatters/block.js.map +1 -1
  88. package/dist/cjs/utils/formatters/extract.js.map +1 -1
  89. package/dist/cjs/utils/formatters/formatter.js +1 -0
  90. package/dist/cjs/utils/formatters/formatter.js.map +1 -1
  91. package/dist/cjs/utils/formatters/transaction.js.map +1 -1
  92. package/dist/cjs/utils/formatters/transactionReceipt.js.map +1 -1
  93. package/dist/cjs/utils/formatters/transactionRequest.js.map +1 -1
  94. package/dist/cjs/utils/hash/hashFunction.js +3 -2
  95. package/dist/cjs/utils/hash/hashFunction.js.map +1 -1
  96. package/dist/cjs/utils/promise/withCache.js +3 -3
  97. package/dist/cjs/utils/promise/withCache.js.map +1 -1
  98. package/dist/cjs/utils/signature/hexToSignature.js +12 -0
  99. package/dist/cjs/utils/signature/hexToSignature.js.map +1 -0
  100. package/dist/cjs/utils/signature/signatureToHex.js.map +1 -0
  101. package/dist/cjs/utils/transaction/prepareRequest.js +19 -12
  102. package/dist/cjs/utils/transaction/prepareRequest.js.map +1 -1
  103. package/dist/cjs/utils/unit/parseUnits.js +2 -1
  104. package/dist/cjs/utils/unit/parseUnits.js.map +1 -1
  105. package/dist/esm/accounts/index.js +3 -1
  106. package/dist/esm/accounts/index.js.map +1 -1
  107. package/dist/esm/accounts/utils/privateKeyToAddress.js +15 -0
  108. package/dist/esm/accounts/utils/privateKeyToAddress.js.map +1 -0
  109. package/dist/esm/accounts/utils/signMessage.js +1 -1
  110. package/dist/esm/accounts/utils/signMessage.js.map +1 -1
  111. package/dist/esm/accounts/utils/signTransaction.js.map +1 -1
  112. package/dist/esm/accounts/utils/signTypedData.js +1 -1
  113. package/dist/esm/accounts/utils/signTypedData.js.map +1 -1
  114. package/dist/esm/actions/ens/getEnsAddress.js +19 -14
  115. package/dist/esm/actions/ens/getEnsAddress.js.map +1 -1
  116. package/dist/esm/actions/index.js.map +1 -1
  117. package/dist/esm/actions/public/createContractEventFilter.js.map +1 -1
  118. package/dist/esm/actions/public/createEventFilter.js +16 -8
  119. package/dist/esm/actions/public/createEventFilter.js.map +1 -1
  120. package/dist/esm/actions/public/estimateContractGas.js +1 -1
  121. package/dist/esm/actions/public/estimateContractGas.js.map +1 -1
  122. package/dist/esm/actions/public/estimateGas.js +4 -2
  123. package/dist/esm/actions/public/estimateGas.js.map +1 -1
  124. package/dist/esm/actions/public/getBlock.js +3 -1
  125. package/dist/esm/actions/public/getBlock.js.map +1 -1
  126. package/dist/esm/actions/public/getBlockNumber.js +2 -2
  127. package/dist/esm/actions/public/getBlockNumber.js.map +1 -1
  128. package/dist/esm/actions/public/getFilterChanges.js.map +1 -1
  129. package/dist/esm/actions/public/getFilterLogs.js +1 -1
  130. package/dist/esm/actions/public/getFilterLogs.js.map +1 -1
  131. package/dist/esm/actions/public/getLogs.js +16 -10
  132. package/dist/esm/actions/public/getLogs.js.map +1 -1
  133. package/dist/esm/actions/public/getTransaction.js +2 -1
  134. package/dist/esm/actions/public/getTransaction.js.map +1 -1
  135. package/dist/esm/actions/public/watchBlockNumber.js +1 -1
  136. package/dist/esm/actions/public/watchBlockNumber.js.map +1 -1
  137. package/dist/esm/actions/public/watchBlocks.js +2 -1
  138. package/dist/esm/actions/public/watchBlocks.js.map +1 -1
  139. package/dist/esm/actions/public/watchContractEvent.js +145 -71
  140. package/dist/esm/actions/public/watchContractEvent.js.map +1 -1
  141. package/dist/esm/actions/public/watchEvent.js +148 -65
  142. package/dist/esm/actions/public/watchEvent.js.map +1 -1
  143. package/dist/esm/actions/wallet/sendTransaction.js +1 -1
  144. package/dist/esm/actions/wallet/sendTransaction.js.map +1 -1
  145. package/dist/esm/actions/wallet/writeContract.js.map +1 -1
  146. package/dist/esm/chains/{formatters/celo.js → celo/formatters.js} +2 -2
  147. package/dist/esm/chains/celo/formatters.js.map +1 -0
  148. package/dist/esm/chains/{serializers/celo.js → celo/serializers.js} +1 -1
  149. package/dist/esm/chains/celo/serializers.js.map +1 -0
  150. package/dist/esm/chains/celo/types.js +2 -0
  151. package/dist/esm/chains/celo/types.js.map +1 -0
  152. package/dist/esm/chains/index.js +22 -7
  153. package/dist/esm/chains/index.js.map +1 -1
  154. package/dist/esm/chains/optimism/fees.js +4 -0
  155. package/dist/esm/chains/optimism/fees.js.map +1 -0
  156. package/dist/esm/chains/{formatters/optimism.js → optimism/formatters.js} +15 -2
  157. package/dist/esm/chains/optimism/formatters.js.map +1 -0
  158. package/dist/esm/chains/optimism/types.js +2 -0
  159. package/dist/esm/chains/optimism/types.js.map +1 -0
  160. package/dist/esm/chains/utils.js +4 -0
  161. package/dist/esm/chains/utils.js.map +1 -0
  162. package/dist/esm/clients/createClient.js +2 -1
  163. package/dist/esm/clients/createClient.js.map +1 -1
  164. package/dist/esm/clients/createPublicClient.js.map +1 -1
  165. package/dist/esm/clients/createTestClient.js.map +1 -1
  166. package/dist/esm/clients/createWalletClient.js.map +1 -1
  167. package/dist/esm/clients/decorators/public.js.map +1 -1
  168. package/dist/esm/constants/abis.js +11 -1
  169. package/dist/esm/constants/abis.js.map +1 -1
  170. package/dist/esm/constants/number.js +97 -0
  171. package/dist/esm/constants/number.js.map +1 -0
  172. package/dist/esm/contract.js.map +1 -1
  173. package/dist/esm/errors/abi.js +8 -1
  174. package/dist/esm/errors/abi.js.map +1 -1
  175. package/dist/esm/errors/contract.js +56 -32
  176. package/dist/esm/errors/contract.js.map +1 -1
  177. package/dist/esm/errors/node.js +1 -1
  178. package/dist/esm/errors/node.js.map +1 -1
  179. package/dist/esm/errors/version.js +1 -1
  180. package/dist/esm/errors/version.js.map +1 -1
  181. package/dist/esm/index.js +4 -1
  182. package/dist/esm/index.js.map +1 -1
  183. package/dist/esm/public.js.map +1 -1
  184. package/dist/esm/utils/abi/encodeAbiParameters.js +13 -14
  185. package/dist/esm/utils/abi/encodeAbiParameters.js.map +1 -1
  186. package/dist/esm/utils/abi/encodePacked.js +2 -0
  187. package/dist/esm/utils/abi/encodePacked.js.map +1 -1
  188. package/dist/esm/utils/chain.js +5 -3
  189. package/dist/esm/utils/chain.js.map +1 -1
  190. package/dist/esm/utils/formatters/block.js.map +1 -1
  191. package/dist/esm/utils/formatters/extract.js.map +1 -1
  192. package/dist/esm/utils/formatters/formatter.js +1 -0
  193. package/dist/esm/utils/formatters/formatter.js.map +1 -1
  194. package/dist/esm/utils/formatters/transaction.js.map +1 -1
  195. package/dist/esm/utils/formatters/transactionReceipt.js.map +1 -1
  196. package/dist/esm/utils/formatters/transactionRequest.js.map +1 -1
  197. package/dist/esm/utils/hash/hashFunction.js +3 -2
  198. package/dist/esm/utils/hash/hashFunction.js.map +1 -1
  199. package/dist/esm/utils/promise/withCache.js +3 -3
  200. package/dist/esm/utils/promise/withCache.js.map +1 -1
  201. package/dist/esm/utils/signature/hexToSignature.js +18 -0
  202. package/dist/esm/utils/signature/hexToSignature.js.map +1 -0
  203. package/dist/esm/utils/signature/signatureToHex.js +21 -0
  204. package/dist/esm/utils/signature/signatureToHex.js.map +1 -0
  205. package/dist/esm/utils/transaction/prepareRequest.js +20 -13
  206. package/dist/esm/utils/transaction/prepareRequest.js.map +1 -1
  207. package/dist/esm/utils/unit/parseUnits.js +2 -1
  208. package/dist/esm/utils/unit/parseUnits.js.map +1 -1
  209. package/dist/types/accounts/index.d.ts +3 -1
  210. package/dist/types/accounts/index.d.ts.map +1 -1
  211. package/dist/types/accounts/utils/privateKeyToAddress.d.ts +11 -0
  212. package/dist/types/accounts/utils/privateKeyToAddress.d.ts.map +1 -0
  213. package/dist/types/accounts/utils/signTransaction.d.ts +2 -2
  214. package/dist/types/accounts/utils/signTransaction.d.ts.map +1 -1
  215. package/dist/types/actions/ens/getEnsAddress.d.ts +3 -1
  216. package/dist/types/actions/ens/getEnsAddress.d.ts.map +1 -1
  217. package/dist/types/actions/index.d.ts +5 -1
  218. package/dist/types/actions/index.d.ts.map +1 -1
  219. package/dist/types/actions/public/createContractEventFilter.d.ts +5 -5
  220. package/dist/types/actions/public/createContractEventFilter.d.ts.map +1 -1
  221. package/dist/types/actions/public/createEventFilter.d.ts +20 -7
  222. package/dist/types/actions/public/createEventFilter.d.ts.map +1 -1
  223. package/dist/types/actions/public/estimateGas.d.ts.map +1 -1
  224. package/dist/types/actions/public/getBlock.d.ts +5 -5
  225. package/dist/types/actions/public/getBlock.d.ts.map +1 -1
  226. package/dist/types/actions/public/getBlockNumber.d.ts +4 -2
  227. package/dist/types/actions/public/getBlockNumber.d.ts.map +1 -1
  228. package/dist/types/actions/public/getFilterChanges.d.ts +5 -8
  229. package/dist/types/actions/public/getFilterChanges.d.ts.map +1 -1
  230. package/dist/types/actions/public/getFilterLogs.d.ts +5 -4
  231. package/dist/types/actions/public/getFilterLogs.d.ts.map +1 -1
  232. package/dist/types/actions/public/getLogs.d.ts +17 -6
  233. package/dist/types/actions/public/getLogs.d.ts.map +1 -1
  234. package/dist/types/actions/public/getTransaction.d.ts +4 -4
  235. package/dist/types/actions/public/getTransaction.d.ts.map +1 -1
  236. package/dist/types/actions/public/getTransactionReceipt.d.ts +1 -1
  237. package/dist/types/actions/public/getTransactionReceipt.d.ts.map +1 -1
  238. package/dist/types/actions/public/simulateContract.d.ts +2 -2
  239. package/dist/types/actions/public/simulateContract.d.ts.map +1 -1
  240. package/dist/types/actions/public/watchBlocks.d.ts +10 -10
  241. package/dist/types/actions/public/watchBlocks.d.ts.map +1 -1
  242. package/dist/types/actions/public/watchContractEvent.d.ts +35 -9
  243. package/dist/types/actions/public/watchContractEvent.d.ts.map +1 -1
  244. package/dist/types/actions/public/watchEvent.d.ts +48 -14
  245. package/dist/types/actions/public/watchEvent.d.ts.map +1 -1
  246. package/dist/types/actions/wallet/deployContract.d.ts +1 -1
  247. package/dist/types/actions/wallet/deployContract.d.ts.map +1 -1
  248. package/dist/types/actions/wallet/sendTransaction.d.ts +2 -2
  249. package/dist/types/actions/wallet/sendTransaction.d.ts.map +1 -1
  250. package/dist/types/actions/wallet/writeContract.d.ts +4 -2
  251. package/dist/types/actions/wallet/writeContract.d.ts.map +1 -1
  252. package/dist/types/chains/{formatters/celo.d.ts → celo/formatters.d.ts} +30 -85
  253. package/dist/types/chains/celo/formatters.d.ts.map +1 -0
  254. package/dist/types/chains/{serializers/celo.d.ts → celo/serializers.d.ts} +4 -4
  255. package/dist/types/chains/celo/serializers.d.ts.map +1 -0
  256. package/dist/types/chains/celo/types.d.ts +60 -0
  257. package/dist/types/chains/celo/types.d.ts.map +1 -0
  258. package/dist/types/chains/index.d.ts +2527 -2722
  259. package/dist/types/chains/index.d.ts.map +1 -1
  260. package/dist/types/chains/optimism/fees.d.ts +4 -0
  261. package/dist/types/chains/optimism/fees.d.ts.map +1 -0
  262. package/dist/types/chains/{formatters/optimism.d.ts → optimism/formatters.d.ts} +79 -54
  263. package/dist/types/chains/optimism/formatters.d.ts.map +1 -0
  264. package/dist/types/chains/optimism/types.d.ts +53 -0
  265. package/dist/types/chains/optimism/types.d.ts.map +1 -0
  266. package/dist/types/chains/utils.d.ts +6 -0
  267. package/dist/types/chains/utils.d.ts.map +1 -0
  268. package/dist/types/clients/createClient.d.ts +7 -0
  269. package/dist/types/clients/createClient.d.ts.map +1 -1
  270. package/dist/types/clients/createPublicClient.d.ts +1 -1
  271. package/dist/types/clients/createPublicClient.d.ts.map +1 -1
  272. package/dist/types/clients/createTestClient.d.ts +1 -1
  273. package/dist/types/clients/createTestClient.d.ts.map +1 -1
  274. package/dist/types/clients/createWalletClient.d.ts +1 -1
  275. package/dist/types/clients/createWalletClient.d.ts.map +1 -1
  276. package/dist/types/clients/decorators/public.d.ts +11 -10
  277. package/dist/types/clients/decorators/public.d.ts.map +1 -1
  278. package/dist/types/constants/abis.d.ts +16 -1
  279. package/dist/types/constants/abis.d.ts.map +1 -1
  280. package/dist/types/constants/number.d.ts +97 -0
  281. package/dist/types/constants/number.d.ts.map +1 -0
  282. package/dist/types/contract.d.ts +5 -1
  283. package/dist/types/contract.d.ts.map +1 -1
  284. package/dist/types/errors/abi.d.ts +1 -0
  285. package/dist/types/errors/abi.d.ts.map +1 -1
  286. package/dist/types/errors/contract.d.ts +1 -0
  287. package/dist/types/errors/contract.d.ts.map +1 -1
  288. package/dist/types/errors/node.d.ts.map +1 -1
  289. package/dist/types/errors/version.d.ts +1 -1
  290. package/dist/types/errors/version.d.ts.map +1 -1
  291. package/dist/types/index.d.ts +24 -6
  292. package/dist/types/index.d.ts.map +1 -1
  293. package/dist/types/public.d.ts +5 -1
  294. package/dist/types/public.d.ts.map +1 -1
  295. package/dist/types/types/block.d.ts +7 -7
  296. package/dist/types/types/block.d.ts.map +1 -1
  297. package/dist/types/types/chain.d.ts +52 -8
  298. package/dist/types/types/chain.d.ts.map +1 -1
  299. package/dist/types/types/contract.d.ts +1 -1
  300. package/dist/types/types/contract.d.ts.map +1 -1
  301. package/dist/types/types/filter.d.ts +7 -3
  302. package/dist/types/types/filter.d.ts.map +1 -1
  303. package/dist/types/types/log.d.ts +8 -8
  304. package/dist/types/types/log.d.ts.map +1 -1
  305. package/dist/types/types/misc.d.ts.map +1 -1
  306. package/dist/types/types/rpc.d.ts +3 -3
  307. package/dist/types/types/rpc.d.ts.map +1 -1
  308. package/dist/types/types/transaction.d.ts +8 -8
  309. package/dist/types/types/transaction.d.ts.map +1 -1
  310. package/dist/types/types/utils.d.ts +10 -0
  311. package/dist/types/types/utils.d.ts.map +1 -1
  312. package/dist/types/utils/abi/encodeAbiParameters.d.ts.map +1 -1
  313. package/dist/types/utils/chain.d.ts +3 -6
  314. package/dist/types/utils/chain.d.ts.map +1 -1
  315. package/dist/types/utils/formatters/block.d.ts +18 -4
  316. package/dist/types/utils/formatters/block.d.ts.map +1 -1
  317. package/dist/types/utils/formatters/extract.d.ts +2 -2
  318. package/dist/types/utils/formatters/extract.d.ts.map +1 -1
  319. package/dist/types/utils/formatters/formatter.d.ts +2 -1
  320. package/dist/types/utils/formatters/formatter.d.ts.map +1 -1
  321. package/dist/types/utils/formatters/transaction.d.ts +15 -4
  322. package/dist/types/utils/formatters/transaction.d.ts.map +1 -1
  323. package/dist/types/utils/formatters/transactionReceipt.d.ts +4 -4
  324. package/dist/types/utils/formatters/transactionReceipt.d.ts.map +1 -1
  325. package/dist/types/utils/formatters/transactionRequest.d.ts +5 -5
  326. package/dist/types/utils/formatters/transactionRequest.d.ts.map +1 -1
  327. package/dist/types/utils/hash/hashFunction.d.ts +1 -1
  328. package/dist/types/utils/hash/hashFunction.d.ts.map +1 -1
  329. package/dist/types/utils/promise/withCache.d.ts +3 -3
  330. package/dist/types/utils/promise/withCache.d.ts.map +1 -1
  331. package/dist/types/utils/signature/hexToSignature.d.ts +13 -0
  332. package/dist/types/utils/signature/hexToSignature.d.ts.map +1 -0
  333. package/dist/types/utils/signature/signatureToHex.d.ts +17 -0
  334. package/dist/types/utils/signature/signatureToHex.d.ts.map +1 -0
  335. package/dist/types/utils/transaction/prepareRequest.d.ts +6 -11
  336. package/dist/types/utils/transaction/prepareRequest.d.ts.map +1 -1
  337. package/dist/types/utils/unit/parseUnits.d.ts.map +1 -1
  338. package/package.json +9 -2
  339. package/src/accounts/index.ts +7 -1
  340. package/src/accounts/utils/privateKeyToAddress.ts +20 -0
  341. package/src/accounts/utils/signMessage.ts +1 -1
  342. package/src/accounts/utils/signTransaction.ts +2 -2
  343. package/src/accounts/utils/signTypedData.ts +1 -1
  344. package/src/actions/ens/getEnsAddress.ts +24 -15
  345. package/src/actions/index.ts +6 -2
  346. package/src/actions/public/createContractEventFilter.ts +30 -7
  347. package/src/actions/public/createEventFilter.ts +78 -24
  348. package/src/actions/public/estimateContractGas.ts +1 -1
  349. package/src/actions/public/estimateGas.ts +11 -2
  350. package/src/actions/public/getBlock.ts +18 -8
  351. package/src/actions/public/getBlockNumber.ts +5 -3
  352. package/src/actions/public/getFilterChanges.ts +46 -10
  353. package/src/actions/public/getFilterLogs.ts +26 -10
  354. package/src/actions/public/getLogs.ts +73 -18
  355. package/src/actions/public/getTransaction.ts +15 -8
  356. package/src/actions/public/simulateContract.ts +2 -2
  357. package/src/actions/public/watchBlockNumber.ts +1 -1
  358. package/src/actions/public/watchBlocks.ts +37 -18
  359. package/src/actions/public/watchContractEvent.ts +208 -90
  360. package/src/actions/public/watchEvent.ts +262 -104
  361. package/src/actions/wallet/deployContract.ts +1 -1
  362. package/src/actions/wallet/sendTransaction.ts +9 -6
  363. package/src/actions/wallet/writeContract.ts +11 -7
  364. package/src/chains/{formatters/celo.ts → celo/formatters.ts} +29 -48
  365. package/src/chains/{serializers/celo.ts → celo/serializers.ts} +5 -5
  366. package/src/chains/celo/types.ts +111 -0
  367. package/src/chains/index.ts +22 -7
  368. package/src/chains/optimism/fees.ts +5 -0
  369. package/src/chains/optimism/formatters.ts +74 -0
  370. package/src/chains/optimism/types.ts +102 -0
  371. package/src/chains/utils.ts +41 -0
  372. package/src/clients/createClient.ts +9 -0
  373. package/src/clients/createPublicClient.ts +7 -1
  374. package/src/clients/createTestClient.ts +7 -1
  375. package/src/clients/createWalletClient.ts +7 -1
  376. package/src/clients/decorators/public.ts +117 -28
  377. package/src/constants/abis.ts +11 -1
  378. package/src/constants/number.ts +98 -0
  379. package/src/contract.ts +6 -2
  380. package/src/errors/abi.ts +5 -1
  381. package/src/errors/contract.ts +52 -31
  382. package/src/errors/node.ts +2 -1
  383. package/src/errors/version.ts +1 -1
  384. package/src/index.ts +133 -11
  385. package/src/public.ts +6 -2
  386. package/src/types/block.ts +25 -10
  387. package/src/types/chain.ts +91 -14
  388. package/src/types/contract.ts +7 -3
  389. package/src/types/filter.ts +32 -26
  390. package/src/types/log.ts +13 -8
  391. package/src/types/misc.ts +3 -0
  392. package/src/types/rpc.ts +16 -6
  393. package/src/types/transaction.ts +22 -11
  394. package/src/types/utils.ts +11 -0
  395. package/src/utils/abi/encodeAbiParameters.ts +14 -17
  396. package/src/utils/abi/encodePacked.ts +1 -0
  397. package/src/utils/chain.ts +21 -10
  398. package/src/utils/formatters/block.ts +34 -5
  399. package/src/utils/formatters/extract.ts +2 -2
  400. package/src/utils/formatters/formatter.ts +3 -2
  401. package/src/utils/formatters/transaction.ts +28 -3
  402. package/src/utils/formatters/transactionReceipt.ts +9 -3
  403. package/src/utils/formatters/transactionRequest.ts +9 -3
  404. package/src/utils/hash/hashFunction.ts +3 -2
  405. package/src/utils/promise/withCache.ts +5 -5
  406. package/src/utils/signature/hexToSignature.ts +20 -0
  407. package/src/utils/signature/signatureToHex.ts +26 -0
  408. package/src/utils/transaction/prepareRequest.ts +55 -30
  409. package/src/utils/unit/parseUnits.ts +2 -1
  410. package/dist/cjs/accounts/utils/signatureToHex.js.map +0 -1
  411. package/dist/cjs/chains/formatters/celo.js.map +0 -1
  412. package/dist/cjs/chains/formatters/optimism.js.map +0 -1
  413. package/dist/cjs/chains/serializers/celo.js.map +0 -1
  414. package/dist/cjs/types/formatter.js.map +0 -1
  415. package/dist/cjs/types/serializer.js.map +0 -1
  416. package/dist/esm/accounts/utils/signatureToHex.js +0 -7
  417. package/dist/esm/accounts/utils/signatureToHex.js.map +0 -1
  418. package/dist/esm/chains/formatters/celo.js.map +0 -1
  419. package/dist/esm/chains/formatters/optimism.js.map +0 -1
  420. package/dist/esm/chains/serializers/celo.js.map +0 -1
  421. package/dist/esm/types/formatter.js +0 -2
  422. package/dist/esm/types/formatter.js.map +0 -1
  423. package/dist/esm/types/serializer.js +0 -2
  424. package/dist/esm/types/serializer.js.map +0 -1
  425. package/dist/types/accounts/utils/signatureToHex.d.ts +0 -3
  426. package/dist/types/accounts/utils/signatureToHex.d.ts.map +0 -1
  427. package/dist/types/chains/formatters/celo.d.ts.map +0 -1
  428. package/dist/types/chains/formatters/optimism.d.ts.map +0 -1
  429. package/dist/types/chains/serializers/celo.d.ts.map +0 -1
  430. package/dist/types/types/formatter.d.ts +0 -14
  431. package/dist/types/types/formatter.d.ts.map +0 -1
  432. package/dist/types/types/serializer.d.ts +0 -7
  433. package/dist/types/types/serializer.d.ts.map +0 -1
  434. package/src/accounts/utils/signatureToHex.ts +0 -12
  435. package/src/chains/formatters/optimism.ts +0 -91
  436. package/src/types/formatter.ts +0 -33
  437. package/src/types/serializer.ts +0 -19
  438. /package/dist/cjs/{accounts/utils → utils/signature}/signatureToHex.js +0 -0
@@ -1,4 +1,4 @@
1
1
  import type { AbiEvent, AbiFunction } from 'abitype';
2
2
  export declare function hashFunction(def: string): `0x${string}`;
3
- export declare function hashAbiItem(def: AbiFunction | AbiEvent): `0x${string}`;
3
+ export declare function hashAbiItem(abiItem: AbiFunction | AbiEvent): `0x${string}`;
4
4
  //# sourceMappingURL=hashFunction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"hashFunction.d.ts","sourceRoot":"","sources":["../../../../src/utils/hash/hashFunction.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAMpD,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,iBAIvC;AAED,wBAAgB,WAAW,CAAC,GAAG,EAAE,WAAW,GAAG,QAAQ,iBAEtD"}
1
+ {"version":3,"file":"hashFunction.d.ts","sourceRoot":"","sources":["../../../../src/utils/hash/hashFunction.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAMpD,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,iBAIvC;AAED,wBAAgB,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,QAAQ,iBAE1D"}
@@ -25,12 +25,12 @@ export declare function getCache<TData>(cacheKey: string): {
25
25
  export type WithCacheParameters = {
26
26
  /** The key to cache the data against. */
27
27
  cacheKey: string;
28
- /** The maximum age (in ms) of the cached value. Default: Infinity (no expiry) */
29
- maxAge?: number;
28
+ /** The time that cached data will remain in memory. Default: Infinity (no expiry) */
29
+ cacheTime?: number;
30
30
  };
31
31
  /**
32
32
  * @description Returns the result of a given promise, and caches the result for
33
33
  * subsequent invocations against a provided cache key.
34
34
  */
35
- export declare function withCache<TData>(fn: () => Promise<TData>, { cacheKey, maxAge }: WithCacheParameters): Promise<TData>;
35
+ export declare function withCache<TData>(fn: () => Promise<TData>, { cacheKey, cacheTime }: WithCacheParameters): Promise<TData>;
36
36
  //# sourceMappingURL=withCache.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"withCache.d.ts","sourceRoot":"","sources":["../../../../src/utils/promise/withCache.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY,eAA0B,CAAA;AACnD,eAAO,MAAM,aAAa,eAA0B,CAAA;AAEpD,wBAAgB,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM;;;;;;;;;;qBAQP,IAAI;kBAAQ,KAAK;;;qBAAjB,IAAI;kBAAQ,KAAK;;qBAAjB,IAAI;kBAAQ,KAAK;;;EAazD;AAED,MAAM,MAAM,mBAAmB,GAAG;IAChC,yCAAyC;IACzC,QAAQ,EAAE,MAAM,CAAA;IAChB,iFAAiF;IACjF,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB,CAAA;AAED;;;GAGG;AACH,wBAAsB,SAAS,CAAC,KAAK,EACnC,EAAE,EAAE,MAAM,OAAO,CAAC,KAAK,CAAC,EACxB,EAAE,QAAQ,EAAE,MAAiB,EAAE,EAAE,mBAAmB,kBAmCrD"}
1
+ {"version":3,"file":"withCache.d.ts","sourceRoot":"","sources":["../../../../src/utils/promise/withCache.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY,eAA0B,CAAA;AACnD,eAAO,MAAM,aAAa,eAA0B,CAAA;AAEpD,wBAAgB,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM;;;;;;;;;;qBAQP,IAAI;kBAAQ,KAAK;;;qBAAjB,IAAI;kBAAQ,KAAK;;qBAAjB,IAAI;kBAAQ,KAAK;;;EAazD;AAED,MAAM,MAAM,mBAAmB,GAAG;IAChC,yCAAyC;IACzC,QAAQ,EAAE,MAAM,CAAA;IAChB,qFAAqF;IACrF,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED;;;GAGG;AACH,wBAAsB,SAAS,CAAC,KAAK,EACnC,EAAE,EAAE,MAAM,OAAO,CAAC,KAAK,CAAC,EACxB,EAAE,QAAQ,EAAE,SAAoB,EAAE,EAAE,mBAAmB,kBAmCxD"}
@@ -0,0 +1,13 @@
1
+ import type { Hex, Signature } from '../../types/misc.js';
2
+ /**
3
+ * @description Parses a hex formatted signature into a structured signature.
4
+ *
5
+ * @param signatureHex Signature in hex format.
6
+ * @returns The structured signature.
7
+ *
8
+ * @example
9
+ * hexToSignature('0x6e100a352ec6ad1b70802290e18aeed190704973570f3b8ed42cb9808e2ea6bf4a90a229a244495b41890987806fcbd2d5d23fc0dbe5f5256c2613c039d76db81c')
10
+ * // { r: '0x...', s: '0x...', v: 28n }
11
+ */
12
+ export declare function hexToSignature(signatureHex: Hex): Signature;
13
+ //# sourceMappingURL=hexToSignature.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hexToSignature.d.ts","sourceRoot":"","sources":["../../../../src/utils/signature/hexToSignature.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAGzD;;;;;;;;;GASG;AACH,wBAAgB,cAAc,CAAC,YAAY,EAAE,GAAG,GAAG,SAAS,CAI3D"}
@@ -0,0 +1,17 @@
1
+ import type { Hex, Signature } from '../../types/misc.js';
2
+ /**
3
+ * @description Converts a signature into hex format.
4
+ *
5
+ * @param signature The signature to convert.
6
+ * @returns The signature in hex format.
7
+ *
8
+ * @example
9
+ * signatureToHex({
10
+ * r: '0x6e100a352ec6ad1b70802290e18aeed190704973570f3b8ed42cb9808e2ea6bf',
11
+ * s: '0x4a90a229a244495b41890987806fcbd2d5d23fc0dbe5f5256c2613c039d76db8',
12
+ * v: 28n
13
+ * })
14
+ * // "0x6e100a352ec6ad1b70802290e18aeed190704973570f3b8ed42cb9808e2ea6bf4a90a229a244495b41890987806fcbd2d5d23fc0dbe5f5256c2613c039d76db81c"
15
+ */
16
+ export declare function signatureToHex({ r, s, v }: Signature): Hex;
17
+ //# sourceMappingURL=signatureToHex.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signatureToHex.d.ts","sourceRoot":"","sources":["../../../../src/utils/signature/signatureToHex.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAIzD;;;;;;;;;;;;;GAaG;AACH,wBAAgB,cAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,SAAS,GAAG,GAAG,CAK1D"}
@@ -4,15 +4,11 @@ import type { SendTransactionParameters } from '../../actions/wallet/sendTransac
4
4
  import type { Client } from '../../clients/createClient.js';
5
5
  import type { Transport } from '../../clients/transports/createTransport.js';
6
6
  import type { GetAccountParameter } from '../../types/account.js';
7
- import type { Chain } from '../../types/chain.js';
8
- export type PrepareRequestParameters<TAccount extends Account | undefined = undefined> = GetAccountParameter<TAccount> & {
9
- gas?: SendTransactionParameters['gas'];
10
- gasPrice?: SendTransactionParameters['gasPrice'];
11
- maxFeePerGas?: SendTransactionParameters['maxFeePerGas'];
12
- maxPriorityFeePerGas?: SendTransactionParameters['maxPriorityFeePerGas'];
13
- nonce?: SendTransactionParameters['nonce'];
14
- };
15
- export type PrepareRequestReturnType<TAccount extends Account | undefined = undefined, TParameters extends PrepareRequestParameters<TAccount> = PrepareRequestParameters<TAccount>> = TParameters & {
7
+ import type { Chain, GetChain } from '../../types/chain.js';
8
+ import type { UnionOmit } from '../../types/utils.js';
9
+ import type { FormattedTransactionRequest } from '../index.js';
10
+ export type PrepareRequestParameters<TChain extends Chain | undefined = Chain | undefined, TAccount extends Account | undefined = Account | undefined, TChainOverride extends Chain | undefined = Chain | undefined> = UnionOmit<FormattedTransactionRequest<TChainOverride extends Chain ? TChainOverride : TChain>, 'from'> & GetAccountParameter<TAccount> & GetChain<TChain, TChainOverride>;
11
+ export type PrepareRequestReturnType<TChain extends Chain | undefined = Chain | undefined, TAccount extends Account | undefined = Account | undefined, TChainOverride extends Chain | undefined = Chain | undefined, TArgs extends PrepareRequestParameters<TChain, TAccount, TChainOverride> = PrepareRequestParameters<TChain, TAccount, TChainOverride>> = TArgs & {
16
12
  from: Address;
17
13
  gas: SendTransactionParameters['gas'];
18
14
  gasPrice?: SendTransactionParameters['gasPrice'];
@@ -20,6 +16,5 @@ export type PrepareRequestReturnType<TAccount extends Account | undefined = unde
20
16
  maxPriorityFeePerGas?: SendTransactionParameters['maxPriorityFeePerGas'];
21
17
  nonce: SendTransactionParameters['nonce'];
22
18
  };
23
- export declare const defaultTip = 1500000000n;
24
- export declare function prepareRequest<TChain extends Chain | undefined, TAccount extends Account | undefined, TParameters extends PrepareRequestParameters<TAccount>>(client: Client<Transport, TChain, TAccount>, args: TParameters): Promise<PrepareRequestReturnType<TAccount, TParameters>>;
19
+ export declare function prepareRequest<TChain extends Chain | undefined, TAccount extends Account | undefined, TChainOverride extends Chain | undefined, TArgs extends PrepareRequestParameters<TChain, TAccount, TChainOverride>>(client: Client<Transport, TChain, TAccount>, args: TArgs): Promise<PrepareRequestReturnType<TChain, TAccount, TChainOverride, TArgs>>;
25
20
  //# sourceMappingURL=prepareRequest.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"prepareRequest.d.ts","sourceRoot":"","sources":["../../../../src/utils/transaction/prepareRequest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAEtC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAA;AAStD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,yCAAyC,CAAA;AACxF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAA;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6CAA6C,CAAA;AAG5E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AACjE,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAA;AAIjD,MAAM,MAAM,wBAAwB,CAClC,QAAQ,SAAS,OAAO,GAAG,SAAS,GAAG,SAAS,IAC9C,mBAAmB,CAAC,QAAQ,CAAC,GAAG;IAClC,GAAG,CAAC,EAAE,yBAAyB,CAAC,KAAK,CAAC,CAAA;IACtC,QAAQ,CAAC,EAAE,yBAAyB,CAAC,UAAU,CAAC,CAAA;IAChD,YAAY,CAAC,EAAE,yBAAyB,CAAC,cAAc,CAAC,CAAA;IACxD,oBAAoB,CAAC,EAAE,yBAAyB,CAAC,sBAAsB,CAAC,CAAA;IACxE,KAAK,CAAC,EAAE,yBAAyB,CAAC,OAAO,CAAC,CAAA;CAC3C,CAAA;AAED,MAAM,MAAM,wBAAwB,CAClC,QAAQ,SAAS,OAAO,GAAG,SAAS,GAAG,SAAS,EAChD,WAAW,SAAS,wBAAwB,CAAC,QAAQ,CAAC,GAAG,wBAAwB,CAAC,QAAQ,CAAC,IACzF,WAAW,GAAG;IAChB,IAAI,EAAE,OAAO,CAAA;IACb,GAAG,EAAE,yBAAyB,CAAC,KAAK,CAAC,CAAA;IACrC,QAAQ,CAAC,EAAE,yBAAyB,CAAC,UAAU,CAAC,CAAA;IAChD,YAAY,CAAC,EAAE,yBAAyB,CAAC,cAAc,CAAC,CAAA;IACxD,oBAAoB,CAAC,EAAE,yBAAyB,CAAC,sBAAsB,CAAC,CAAA;IACxE,KAAK,EAAE,yBAAyB,CAAC,OAAO,CAAC,CAAA;CAC1C,CAAA;AAED,eAAO,MAAM,UAAU,cAAiB,CAAA;AAExC,wBAAsB,cAAc,CAClC,MAAM,SAAS,KAAK,GAAG,SAAS,EAChC,QAAQ,SAAS,OAAO,GAAG,SAAS,EACpC,WAAW,SAAS,wBAAwB,CAAC,QAAQ,CAAC,EAEtD,MAAM,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,EAC3C,IAAI,EAAE,WAAW,GAChB,OAAO,CAAC,wBAAwB,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,CAiE1D"}
1
+ {"version":3,"file":"prepareRequest.d.ts","sourceRoot":"","sources":["../../../../src/utils/transaction/prepareRequest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAEtC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAA;AAStD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,yCAAyC,CAAA;AACxF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAA;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6CAA6C,CAAA;AAG5E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AACjE,OAAO,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAA;AAC3D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAA;AACrD,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,aAAa,CAAA;AAG9D,MAAM,MAAM,wBAAwB,CAClC,MAAM,SAAS,KAAK,GAAG,SAAS,GAAG,KAAK,GAAG,SAAS,EACpD,QAAQ,SAAS,OAAO,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,EAC1D,cAAc,SAAS,KAAK,GAAG,SAAS,GAAG,KAAK,GAAG,SAAS,IAC1D,SAAS,CACX,2BAA2B,CACzB,cAAc,SAAS,KAAK,GAAG,cAAc,GAAG,MAAM,CACvD,EACD,MAAM,CACP,GACC,mBAAmB,CAAC,QAAQ,CAAC,GAC7B,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC,CAAA;AAElC,MAAM,MAAM,wBAAwB,CAClC,MAAM,SAAS,KAAK,GAAG,SAAS,GAAG,KAAK,GAAG,SAAS,EACpD,QAAQ,SAAS,OAAO,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,EAC1D,cAAc,SAAS,KAAK,GAAG,SAAS,GAAG,KAAK,GAAG,SAAS,EAC5D,KAAK,SAAS,wBAAwB,CACpC,MAAM,EACN,QAAQ,EACR,cAAc,CACf,GAAG,wBAAwB,CAAC,MAAM,EAAE,QAAQ,EAAE,cAAc,CAAC,IAC5D,KAAK,GAAG;IACV,IAAI,EAAE,OAAO,CAAA;IACb,GAAG,EAAE,yBAAyB,CAAC,KAAK,CAAC,CAAA;IACrC,QAAQ,CAAC,EAAE,yBAAyB,CAAC,UAAU,CAAC,CAAA;IAChD,YAAY,CAAC,EAAE,yBAAyB,CAAC,cAAc,CAAC,CAAA;IACxD,oBAAoB,CAAC,EAAE,yBAAyB,CAAC,sBAAsB,CAAC,CAAA;IACxE,KAAK,EAAE,yBAAyB,CAAC,OAAO,CAAC,CAAA;CAC1C,CAAA;AAED,wBAAsB,cAAc,CAClC,MAAM,SAAS,KAAK,GAAG,SAAS,EAChC,QAAQ,SAAS,OAAO,GAAG,SAAS,EACpC,cAAc,SAAS,KAAK,GAAG,SAAS,EACxC,KAAK,SAAS,wBAAwB,CAAC,MAAM,EAAE,QAAQ,EAAE,cAAc,CAAC,EAExE,MAAM,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,EAC3C,IAAI,EAAE,KAAK,GACV,OAAO,CAAC,wBAAwB,CAAC,MAAM,EAAE,QAAQ,EAAE,cAAc,EAAE,KAAK,CAAC,CAAC,CAiF5E"}
@@ -1 +1 @@
1
- {"version":3,"file":"parseUnits.d.ts","sourceRoot":"","sources":["../../../../src/utils/unit/parseUnits.ts"],"names":[],"mappings":"AAAA,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,UAoCzD"}
1
+ {"version":3,"file":"parseUnits.d.ts","sourceRoot":"","sources":["../../../../src/utils/unit/parseUnits.ts"],"names":[],"mappings":"AAAA,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,UAqCzD"}
package/package.json CHANGED
@@ -3,10 +3,11 @@
3
3
  "description": "TypeScript Interface for Ethereum",
4
4
  "dependencies": {
5
5
  "@adraffy/ens-normalize": "1.9.0",
6
- "@noble/curves": "1.0.0",
6
+ "@noble/curves": "1.1.0",
7
7
  "@noble/hashes": "1.3.0",
8
8
  "@scure/bip32": "1.3.0",
9
9
  "@scure/bip39": "1.2.0",
10
+ "@types/ws": "^8.5.4",
10
11
  "@wagmi/chains": "1.6.0",
11
12
  "abitype": "0.9.3",
12
13
  "isomorphic-ws": "5.0.0",
@@ -20,7 +21,7 @@
20
21
  "optional": true
21
22
  }
22
23
  },
23
- "version": "0.0.0-w-20230725184008",
24
+ "version": "0.0.0-w-20230810155401",
24
25
  "files": [
25
26
  "dist",
26
27
  "!dist/**/*.tsbuildinfo",
@@ -33,6 +34,7 @@
33
34
  "accounts",
34
35
  "actions",
35
36
  "chains",
37
+ "chains/utils",
36
38
  "contract",
37
39
  "ens",
38
40
  "public",
@@ -67,6 +69,11 @@
67
69
  "import": "./dist/esm/chains/index.js",
68
70
  "default": "./dist/cjs/chains/index.js"
69
71
  },
72
+ "./chains/utils": {
73
+ "types": "./dist/types/chains/utils.d.ts",
74
+ "import": "./dist/esm/chains/utils.js",
75
+ "default": "./dist/cjs/chains/utils.js"
76
+ },
70
77
  "./contract": {
71
78
  "types": "./dist/types/contract.d.ts",
72
79
  "import": "./dist/esm/contract.js",
@@ -17,12 +17,17 @@ export type {
17
17
  PrivateKeyAccount,
18
18
  } from './types.js'
19
19
  export { type SignParameters, type SignReturnType, sign } from './utils/sign.js'
20
- export { signatureToHex } from './utils/signatureToHex.js'
20
+ export { signatureToHex } from '../utils/signature/signatureToHex.js'
21
21
  export {
22
22
  type SignMessageParameters,
23
23
  type SignMessageReturnType,
24
24
  signMessage,
25
25
  } from './utils/signMessage.js'
26
+ export {
27
+ type SignTransactionParameters,
28
+ type SignTransactionReturnType,
29
+ signTransaction,
30
+ } from './utils/signTransaction.js'
26
31
  export {
27
32
  type SignTypedDataParameters,
28
33
  type SignTypedDataReturnType,
@@ -30,6 +35,7 @@ export {
30
35
  } from './utils/signTypedData.js'
31
36
  export { parseAccount } from './utils/parseAccount.js'
32
37
  export { publicKeyToAddress } from './utils/publicKeyToAddress.js'
38
+ export { privateKeyToAddress } from './utils/privateKeyToAddress.js'
33
39
  export { czech } from './wordlists/czech.js'
34
40
  export { english } from './wordlists/english.js'
35
41
  export { french } from './wordlists/french.js'
@@ -0,0 +1,20 @@
1
+ import { secp256k1 } from '@noble/curves/secp256k1'
2
+ import type { Address } from 'abitype'
3
+
4
+ import type { Hex } from '../../types/misc.js'
5
+ import { bytesToHex } from '../../utils/encoding/toHex.js'
6
+ import { publicKeyToAddress } from './publicKeyToAddress.js'
7
+
8
+ /**
9
+ * @description Converts an ECDSA private key to an address.
10
+ *
11
+ * @param privateKey The private key to convert.
12
+ *
13
+ * @returns The address.
14
+ */
15
+ export function privateKeyToAddress(privateKey: Hex): Address {
16
+ const publicKey = bytesToHex(
17
+ secp256k1.getPublicKey(privateKey.slice(2), false),
18
+ )
19
+ return publicKeyToAddress(publicKey)
20
+ }
@@ -1,8 +1,8 @@
1
1
  import type { Hex, SignableMessage } from '../../types/misc.js'
2
2
  import { hashMessage } from '../../utils/signature/hashMessage.js'
3
+ import { signatureToHex } from '../../utils/signature/signatureToHex.js'
3
4
 
4
5
  import { sign } from './sign.js'
5
- import { signatureToHex } from './signatureToHex.js'
6
6
 
7
7
  export type SignMessageParameters = {
8
8
  /** The message to sign. */
@@ -12,7 +12,7 @@ import {
12
12
 
13
13
  import { sign } from './sign.js'
14
14
 
15
- export type SignTransactionArgs<
15
+ export type SignTransactionParameters<
16
16
  TTransactionSerializable extends TransactionSerializable = TransactionSerializable,
17
17
  > = {
18
18
  privateKey: Hex
@@ -31,7 +31,7 @@ export async function signTransaction<
31
31
  privateKey,
32
32
  transaction,
33
33
  serializer = serializeTransaction,
34
- }: SignTransactionArgs<TTransactionSerializable>): Promise<
34
+ }: SignTransactionParameters<TTransactionSerializable>): Promise<
35
35
  SignTransactionReturnType<TTransactionSerializable>
36
36
  > {
37
37
  const signature = await sign({
@@ -3,9 +3,9 @@ import type { TypedData } from 'abitype'
3
3
  import type { Hex } from '../../types/misc.js'
4
4
  import type { TypedDataDefinition } from '../../types/typedData.js'
5
5
  import { hashTypedData } from '../../utils/signature/hashTypedData.js'
6
+ import { signatureToHex } from '../../utils/signature/signatureToHex.js'
6
7
 
7
8
  import { sign } from './sign.js'
8
- import { signatureToHex } from './signatureToHex.js'
9
9
 
10
10
  export type SignTypedDataParameters<
11
11
  typedData extends TypedData | Record<string, unknown> = TypedData,
@@ -3,7 +3,7 @@ import type { Address } from 'abitype'
3
3
  import type { Client } from '../../clients/createClient.js'
4
4
  import type { Transport } from '../../clients/transports/createTransport.js'
5
5
  import {
6
- singleAddressResolverAbi,
6
+ addressResolverAbi,
7
7
  universalResolverResolveAbi,
8
8
  } from '../../constants/abis.js'
9
9
  import type { Chain } from '../../types/chain.js'
@@ -23,6 +23,8 @@ import {
23
23
 
24
24
  export type GetEnsAddressParameters = Prettify<
25
25
  Pick<ReadContractParameters, 'blockNumber' | 'blockTag'> & {
26
+ /** ENSIP-9 compliant coinType used to resolve addresses for other chains */
27
+ coinType?: number
26
28
  /** Name to get the address for. */
27
29
  name: string
28
30
  /** Address of ENS Universal Resolver Contract. */
@@ -65,6 +67,7 @@ export async function getEnsAddress<TChain extends Chain | undefined,>(
65
67
  {
66
68
  blockNumber,
67
69
  blockTag,
70
+ coinType,
68
71
  name,
69
72
  universalResolverAddress: universalResolverAddress_,
70
73
  }: GetEnsAddressParameters,
@@ -84,31 +87,37 @@ export async function getEnsAddress<TChain extends Chain | undefined,>(
84
87
  }
85
88
 
86
89
  try {
90
+ const functionData = encodeFunctionData({
91
+ abi: addressResolverAbi,
92
+ functionName: 'addr',
93
+ ...(coinType != null
94
+ ? { args: [namehash(name), BigInt(coinType)] }
95
+ : { args: [namehash(name)] }),
96
+ })
97
+
87
98
  const res = await readContract(client, {
88
99
  address: universalResolverAddress,
89
100
  abi: universalResolverResolveAbi,
90
101
  functionName: 'resolve',
91
- args: [
92
- toHex(packetToBytes(name)),
93
- encodeFunctionData({
94
- abi: singleAddressResolverAbi,
95
- functionName: 'addr',
96
- args: [namehash(name)],
97
- }),
98
- ],
102
+ args: [toHex(packetToBytes(name)), functionData],
99
103
  blockNumber,
100
104
  blockTag,
101
105
  })
102
106
 
103
107
  if (res[0] === '0x') return null
104
108
 
105
- const address = decodeFunctionResult({
106
- abi: singleAddressResolverAbi,
107
- functionName: 'addr',
108
- data: res[0],
109
- })
109
+ const address = trim(
110
+ decodeFunctionResult({
111
+ abi: addressResolverAbi,
112
+ args: coinType != null ? [namehash(name), BigInt(coinType)] : undefined,
113
+ functionName: 'addr',
114
+ data: res[0],
115
+ }),
116
+ )
110
117
 
111
- return trim(address) === '0x00' ? null : address
118
+ if (address === '0x') return null
119
+ if (trim(address) === '0x00') return null
120
+ return address
112
121
  } catch (err) {
113
122
  if (isNullUniversalResolverError(err, 'resolve')) return null
114
123
  throw err
@@ -160,8 +160,12 @@ export {
160
160
  watchBlockNumber,
161
161
  } from './public/watchBlockNumber.js'
162
162
  export {
163
- type OnLogsFn,
164
- type OnLogsParameter,
163
+ type WatchEventOnLogsFn,
164
+ /** @deprecated - use `WatchEventOnLogsFn` instead. */
165
+ type WatchEventOnLogsFn as OnLogsFn,
166
+ type WatchEventOnLogsParameter,
167
+ /** @deprecated - use `WatchEventOnLogsParameter` instead. */
168
+ type WatchEventOnLogsParameter as OnLogsParameter,
165
169
  type WatchEventParameters,
166
170
  type WatchEventReturnType,
167
171
  watchEvent,
@@ -9,6 +9,7 @@ import type {
9
9
  MaybeExtractEventArgsFromAbi,
10
10
  } from '../../types/contract.js'
11
11
  import type { Filter } from '../../types/filter.js'
12
+ import type { Hex } from '../../types/misc.js'
12
13
  import {
13
14
  type EncodeEventTopicsParameters,
14
15
  encodeEventTopics,
@@ -23,17 +24,19 @@ export type CreateContractEventFilterParameters<
23
24
  | MaybeExtractEventArgsFromAbi<TAbi, TEventName>
24
25
  | undefined = undefined,
25
26
  TStrict extends boolean | undefined = undefined,
27
+ TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
28
+ TToBlock extends BlockNumber | BlockTag | undefined = undefined,
26
29
  > = {
27
30
  address?: Address | Address[]
28
31
  abi: Narrow<TAbi>
29
32
  eventName?: InferEventName<TAbi, TEventName>
30
- fromBlock?: BlockNumber | BlockTag
33
+ fromBlock?: TFromBlock | BlockNumber | BlockTag
31
34
  /**
32
35
  * Whether or not the logs must match the indexed/non-indexed arguments in the event ABI item.
33
36
  * @default false
34
37
  */
35
38
  strict?: TStrict
36
- toBlock?: BlockNumber | BlockTag
39
+ toBlock?: TToBlock | BlockNumber | BlockTag
37
40
  } & (undefined extends TEventName
38
41
  ? {
39
42
  args?: never
@@ -56,7 +59,9 @@ export type CreateContractEventFilterReturnType<
56
59
  | MaybeExtractEventArgsFromAbi<TAbi, TEventName>
57
60
  | undefined = undefined,
58
61
  TStrict extends boolean | undefined = undefined,
59
- > = Filter<'event', TAbi, TEventName, TArgs, TStrict>
62
+ TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
63
+ TToBlock extends BlockNumber | BlockTag | undefined = undefined,
64
+ > = Filter<'event', TAbi, TEventName, TArgs, TStrict, TFromBlock, TToBlock>
60
65
 
61
66
  /**
62
67
  * Creates a Filter to retrieve event logs that can be used with [`getFilterChanges`](https://viem.sh/docs/actions/public/getFilterChanges.html) or [`getFilterLogs`](https://viem.sh/docs/actions/public/getFilterLogs.html).
@@ -86,6 +91,8 @@ export async function createContractEventFilter<
86
91
  TEventName extends string | undefined,
87
92
  TArgs extends MaybeExtractEventArgsFromAbi<TAbi, TEventName> | undefined,
88
93
  TStrict extends boolean | undefined = undefined,
94
+ TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
95
+ TToBlock extends BlockNumber | BlockTag | undefined = undefined,
89
96
  >(
90
97
  client: Client<Transport, TChain>,
91
98
  {
@@ -96,9 +103,23 @@ export async function createContractEventFilter<
96
103
  fromBlock,
97
104
  strict,
98
105
  toBlock,
99
- }: CreateContractEventFilterParameters<TAbi, TEventName, TArgs, TStrict>,
106
+ }: CreateContractEventFilterParameters<
107
+ TAbi,
108
+ TEventName,
109
+ TArgs,
110
+ TStrict,
111
+ TFromBlock,
112
+ TToBlock
113
+ >,
100
114
  ): Promise<
101
- CreateContractEventFilterReturnType<TAbi, TEventName, TArgs, TStrict>
115
+ CreateContractEventFilterReturnType<
116
+ TAbi,
117
+ TEventName,
118
+ TArgs,
119
+ TStrict,
120
+ TFromBlock,
121
+ TToBlock
122
+ >
102
123
  > {
103
124
  const getRequest = createFilterRequestScope(client, {
104
125
  method: 'eth_newFilter',
@@ -111,7 +132,7 @@ export async function createContractEventFilter<
111
132
  eventName,
112
133
  } as unknown as EncodeEventTopicsParameters)
113
134
  : undefined
114
- const id = await client.request({
135
+ const id: Hex = await client.request({
115
136
  method: 'eth_newFilter',
116
137
  params: [
117
138
  {
@@ -136,6 +157,8 @@ export async function createContractEventFilter<
136
157
  TAbi,
137
158
  TEventName,
138
159
  TArgs,
139
- TStrict
160
+ TStrict,
161
+ TFromBlock,
162
+ TToBlock
140
163
  >
141
164
  }
@@ -1,4 +1,4 @@
1
- import type { Abi, AbiEvent, Address, Narrow } from 'abitype'
1
+ import type { AbiEvent, Address, Narrow } from 'abitype'
2
2
 
3
3
  import type { Client } from '../../clients/createClient.js'
4
4
  import type { Transport } from '../../clients/transports/createTransport.js'
@@ -9,7 +9,7 @@ import type {
9
9
  MaybeExtractEventArgsFromAbi,
10
10
  } from '../../types/contract.js'
11
11
  import type { Filter } from '../../types/filter.js'
12
- import type { LogTopic } from '../../types/misc.js'
12
+ import type { Hex, LogTopic } from '../../types/misc.js'
13
13
  import type { Prettify } from '../../types/utils.js'
14
14
  import {
15
15
  type EncodeEventTopicsParameters,
@@ -20,18 +20,23 @@ import { createFilterRequestScope } from '../../utils/filters/createFilterReques
20
20
 
21
21
  export type CreateEventFilterParameters<
22
22
  TAbiEvent extends AbiEvent | undefined = undefined,
23
+ TAbiEvents extends
24
+ | readonly AbiEvent[]
25
+ | readonly unknown[]
26
+ | undefined = TAbiEvent extends AbiEvent ? [TAbiEvent] : undefined,
23
27
  TStrict extends boolean | undefined = undefined,
24
- _Abi extends Abi | readonly unknown[] = [TAbiEvent],
28
+ TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
29
+ TToBlock extends BlockNumber | BlockTag | undefined = undefined,
25
30
  _EventName extends string | undefined = MaybeAbiEventName<TAbiEvent>,
26
31
  _Args extends
27
- | MaybeExtractEventArgsFromAbi<_Abi, _EventName>
32
+ | MaybeExtractEventArgsFromAbi<TAbiEvents, _EventName>
28
33
  | undefined = undefined,
29
34
  > = {
30
35
  address?: Address | Address[]
31
- fromBlock?: BlockNumber | BlockTag
32
- toBlock?: BlockNumber | BlockTag
36
+ fromBlock?: TFromBlock | BlockNumber | BlockTag
37
+ toBlock?: TToBlock | BlockNumber | BlockTag
33
38
  } & (MaybeExtractEventArgsFromAbi<
34
- _Abi,
39
+ TAbiEvents,
35
40
  _EventName
36
41
  > extends infer TEventFilterArgs
37
42
  ?
@@ -40,6 +45,7 @@ export type CreateEventFilterParameters<
40
45
  | TEventFilterArgs
41
46
  | (_Args extends TEventFilterArgs ? _Args : never)
42
47
  event: Narrow<TAbiEvent>
48
+ events?: never
43
49
  /**
44
50
  * Whether or not the logs must match the indexed/non-indexed arguments on `event`.
45
51
  * @default false
@@ -49,6 +55,7 @@ export type CreateEventFilterParameters<
49
55
  | {
50
56
  args?: never
51
57
  event?: Narrow<TAbiEvent>
58
+ events?: never
52
59
  /**
53
60
  * Whether or not the logs must match the indexed/non-indexed arguments on `event`.
54
61
  * @default false
@@ -58,23 +65,42 @@ export type CreateEventFilterParameters<
58
65
  | {
59
66
  args?: never
60
67
  event?: never
68
+ events: Narrow<TAbiEvents>
69
+ /**
70
+ * Whether or not the logs must match the indexed/non-indexed arguments on `event`.
71
+ * @default false
72
+ */
73
+ strict?: TStrict
74
+ }
75
+ | {
76
+ args?: never
77
+ event?: never
78
+ events?: never
61
79
  strict?: never
62
80
  }
63
81
  : {
64
82
  args?: never
65
83
  event?: never
84
+ events?: never
66
85
  strict?: never
67
86
  })
68
87
 
69
88
  export type CreateEventFilterReturnType<
70
89
  TAbiEvent extends AbiEvent | undefined = undefined,
90
+ TAbiEvents extends
91
+ | readonly AbiEvent[]
92
+ | readonly unknown[]
93
+ | undefined = TAbiEvent extends AbiEvent ? [TAbiEvent] : undefined,
71
94
  TStrict extends boolean | undefined = undefined,
72
- _Abi extends Abi | readonly unknown[] = [TAbiEvent],
95
+ TFromBlock extends BlockNumber | BlockTag | undefined = undefined,
96
+ TToBlock extends BlockNumber | BlockTag | undefined = undefined,
73
97
  _EventName extends string | undefined = MaybeAbiEventName<TAbiEvent>,
74
98
  _Args extends
75
- | MaybeExtractEventArgsFromAbi<_Abi, _EventName>
99
+ | MaybeExtractEventArgsFromAbi<TAbiEvents, _EventName>
76
100
  | undefined = undefined,
77
- > = Prettify<Filter<'event', _Abi, _EventName, _Args, TStrict>>
101
+ > = Prettify<
102
+ Filter<'event', TAbiEvents, _EventName, _Args, TStrict, TFromBlock, TToBlock>
103
+ >
78
104
 
79
105
  /**
80
106
  * Creates a [`Filter`](https://viem.sh/docs/glossary/types.html#filter) to listen for new events that can be used with [`getFilterChanges`](https://viem.sh/docs/actions/public/getFilterChanges.html).
@@ -101,12 +127,17 @@ export type CreateEventFilterReturnType<
101
127
  */
102
128
  export async function createEventFilter<
103
129
  TChain extends Chain | undefined,
104
- TAbiEvent extends AbiEvent | undefined,
130
+ TAbiEvent extends AbiEvent | undefined = undefined,
131
+ TAbiEvents extends
132
+ | readonly AbiEvent[]
133
+ | readonly unknown[]
134
+ | undefined = TAbiEvent extends AbiEvent ? [TAbiEvent] : undefined,
105
135
  TStrict extends boolean | undefined = undefined,
106
- _Abi extends Abi | readonly unknown[] = [TAbiEvent],
136
+ TFromBlock extends BlockNumber<bigint> | BlockTag | undefined = undefined,
137
+ TToBlock extends BlockNumber<bigint> | BlockTag | undefined = undefined,
107
138
  _EventName extends string | undefined = MaybeAbiEventName<TAbiEvent>,
108
139
  _Args extends
109
- | MaybeExtractEventArgsFromAbi<_Abi, _EventName>
140
+ | MaybeExtractEventArgsFromAbi<TAbiEvents, _EventName>
110
141
  | undefined = undefined,
111
142
  >(
112
143
  client: Client<Transport, TChain>,
@@ -114,32 +145,51 @@ export async function createEventFilter<
114
145
  address,
115
146
  args,
116
147
  event,
148
+ events: events_,
117
149
  fromBlock,
118
150
  strict,
119
151
  toBlock,
120
152
  }: CreateEventFilterParameters<
121
153
  TAbiEvent,
154
+ TAbiEvents,
122
155
  TStrict,
123
- _Abi,
156
+ TFromBlock,
157
+ TToBlock,
124
158
  _EventName,
125
159
  _Args
126
160
  > = {} as any,
127
161
  ): Promise<
128
- CreateEventFilterReturnType<TAbiEvent, TStrict, _Abi, _EventName, _Args>
162
+ CreateEventFilterReturnType<
163
+ TAbiEvent,
164
+ TAbiEvents,
165
+ TStrict,
166
+ TFromBlock,
167
+ TToBlock,
168
+ _EventName,
169
+ _Args
170
+ >
129
171
  > {
172
+ const events = events_ ?? (event ? [event] : undefined)
173
+
130
174
  const getRequest = createFilterRequestScope(client, {
131
175
  method: 'eth_newFilter',
132
176
  })
133
177
 
134
178
  let topics: LogTopic[] = []
135
- if (event)
136
- topics = encodeEventTopics({
137
- abi: [event],
138
- eventName: (event as AbiEvent).name,
139
- args,
140
- } as EncodeEventTopicsParameters)
179
+ if (events) {
180
+ topics = [
181
+ (events as AbiEvent[]).flatMap((event) =>
182
+ encodeEventTopics({
183
+ abi: [event],
184
+ eventName: (event as AbiEvent).name,
185
+ args,
186
+ } as EncodeEventTopicsParameters),
187
+ ),
188
+ ]
189
+ if (event) topics = topics[0] as LogTopic[]
190
+ }
141
191
 
142
- const id = await client.request({
192
+ const id: Hex = await client.request({
143
193
  method: 'eth_newFilter',
144
194
  params: [
145
195
  {
@@ -153,17 +203,21 @@ export async function createEventFilter<
153
203
  })
154
204
 
155
205
  return {
156
- abi: event ? [event] : undefined,
206
+ abi: events,
157
207
  args,
158
208
  eventName: event ? (event as AbiEvent).name : undefined,
209
+ fromBlock,
159
210
  id,
160
211
  request: getRequest(id),
161
212
  strict,
213
+ toBlock,
162
214
  type: 'event',
163
215
  } as unknown as CreateEventFilterReturnType<
164
216
  TAbiEvent,
217
+ TAbiEvents,
165
218
  TStrict,
166
- _Abi,
219
+ TFromBlock,
220
+ TToBlock,
167
221
  _EventName,
168
222
  _Args
169
223
  >