viem 0.0.1-alpha.24 → 0.0.1-alpha.26

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 (510) hide show
  1. package/contract/package.json +4 -0
  2. package/dist/call-3476b8ee.d.ts +22 -0
  3. package/dist/{chain-afa13f5a.d.ts → chain-42de87e5.d.ts} +20 -14
  4. package/dist/{chain-e33d019b.d.ts → chain-b0cfb141.d.ts} +1 -1
  5. package/dist/chains.d.ts +20 -8
  6. package/dist/chains.js +46 -46
  7. package/dist/chains.mjs +1 -1
  8. package/dist/{chunk-3ARWEJ3G.mjs → chunk-BSAB6UH4.mjs} +18 -2
  9. package/dist/chunk-BSAB6UH4.mjs.map +1 -0
  10. package/dist/{chunk-4D5XG6XB.js → chunk-DSQO3E4F.js} +367 -429
  11. package/dist/chunk-DSQO3E4F.js.map +1 -0
  12. package/dist/{chunk-A2HXAZXC.js → chunk-LINNE4N4.js} +199 -161
  13. package/dist/chunk-LINNE4N4.js.map +1 -0
  14. package/dist/{chunk-LQVMDX5I.mjs → chunk-PRG3BBPZ.mjs} +397 -459
  15. package/dist/chunk-PRG3BBPZ.mjs.map +1 -0
  16. package/dist/{chunk-YQUC52RL.mjs → chunk-QSIX64VZ.mjs} +136 -98
  17. package/dist/chunk-QSIX64VZ.mjs.map +1 -0
  18. package/dist/{chunk-ZYSXBTBB.js → chunk-YTG4YXMB.js} +30 -14
  19. package/dist/chunk-YTG4YXMB.js.map +1 -0
  20. package/dist/{contract-70f4ddbe.d.ts → contract-9dd2f98b.d.ts} +44 -31
  21. package/dist/contract.d.ts +129 -0
  22. package/dist/contract.js +55 -0
  23. package/dist/{clients/index.js.map → contract.js.map} +0 -0
  24. package/dist/contract.mjs +55 -0
  25. package/dist/{clients/index.mjs.map → contract.mjs.map} +0 -0
  26. package/dist/{createClient-60e3ab98.d.ts → createClient-6689596e.d.ts} +11 -5
  27. package/dist/{createPublicClient-d3d12dc3.d.ts → createPublicClient-fd558574.d.ts} +3 -3
  28. package/dist/{createTestClient-5f4532c4.d.ts → createTestClient-bc1d9028.d.ts} +3 -3
  29. package/dist/{createWalletClient-9ec3df4f.d.ts → createWalletClient-4df88244.d.ts} +3 -3
  30. package/dist/decodeErrorResult-ac835649.d.ts +16 -0
  31. package/dist/{eip1193-9317a312.d.ts → eip1193-617a05ae.d.ts} +2 -2
  32. package/dist/ens.d.ts +82 -1
  33. package/dist/ens.js +208 -3
  34. package/dist/ens.js.map +1 -1
  35. package/dist/ens.mjs +209 -4
  36. package/dist/ens.mjs.map +1 -1
  37. package/dist/getAbiItem-d2e8bd76.d.ts +97 -0
  38. package/dist/index.d.ts +113 -180
  39. package/dist/index.js +259 -279
  40. package/dist/index.js.map +1 -1
  41. package/dist/index.mjs +267 -287
  42. package/dist/index.mjs.map +1 -1
  43. package/dist/public.d.ts +353 -10
  44. package/dist/public.js +3 -4
  45. package/dist/public.mjs +6 -7
  46. package/dist/readContract-c460f23a.d.ts +10 -0
  47. package/dist/rpc-8c10fc98.d.ts +119 -0
  48. package/dist/{sendTransaction-54a0d509.d.ts → sendTransaction-7ce442c0.d.ts} +3 -3
  49. package/dist/test.d.ts +160 -5
  50. package/dist/test.js +222 -18
  51. package/dist/test.js.map +1 -1
  52. package/dist/test.mjs +233 -29
  53. package/dist/test.mjs.map +1 -1
  54. package/dist/transactionReceipt-44dbf122.d.ts +26 -0
  55. package/dist/{transactionRequest-bdf57f7d.d.ts → transactionRequest-f437b4ba.d.ts} +1 -1
  56. package/dist/utils/index.d.ts +228 -21
  57. package/dist/utils/index.js +2 -6
  58. package/dist/utils/index.mjs +3 -7
  59. package/dist/wallet.d.ts +41 -7
  60. package/dist/wallet.js +3 -3
  61. package/dist/wallet.mjs +2 -2
  62. package/dist/watchEvent-569c9976.d.ts +41 -0
  63. package/dist/window.d.ts +2 -2
  64. package/ens/package.json +4 -0
  65. package/package.json +16 -12
  66. package/public/package.json +4 -0
  67. package/test/package.json +4 -0
  68. package/wallet/package.json +4 -0
  69. package/clients/package.json +0 -4
  70. package/dist/chunk-3ARWEJ3G.mjs.map +0 -1
  71. package/dist/chunk-4D5XG6XB.js.map +0 -1
  72. package/dist/chunk-6QTEW2BE.mjs +0 -260
  73. package/dist/chunk-6QTEW2BE.mjs.map +0 -1
  74. package/dist/chunk-A2HXAZXC.js.map +0 -1
  75. package/dist/chunk-KRPS5CIB.mjs +0 -256
  76. package/dist/chunk-KRPS5CIB.mjs.map +0 -1
  77. package/dist/chunk-LQVMDX5I.mjs.map +0 -1
  78. package/dist/chunk-N3IOPT3R.js +0 -256
  79. package/dist/chunk-N3IOPT3R.js.map +0 -1
  80. package/dist/chunk-YQUC52RL.mjs.map +0 -1
  81. package/dist/chunk-ZSTVHQ6J.js +0 -260
  82. package/dist/chunk-ZSTVHQ6J.js.map +0 -1
  83. package/dist/chunk-ZYSXBTBB.js.map +0 -1
  84. package/dist/clients/index.d.ts +0 -9
  85. package/dist/clients/index.js +0 -24
  86. package/dist/clients/index.mjs +0 -24
  87. package/dist/normalize-ef9240c0.d.ts +0 -33
  88. package/dist/parseGwei-492ab7dd.d.ts +0 -355
  89. package/dist/rpc-26932bae.d.ts +0 -61
  90. package/dist/stopImpersonatingAccount-c1a4b7e5.d.ts +0 -156
  91. package/dist/watchAsset-d59d6e35.d.ts +0 -38
  92. package/dist/watchPendingTransactions-ea21b31d.d.ts +0 -373
  93. package/dist/webSocket-775b4037.d.ts +0 -83
  94. package/src/_test/abis.ts +0 -1420
  95. package/src/_test/bench.ts +0 -15
  96. package/src/_test/constants.ts +0 -61
  97. package/src/_test/globalSetup.ts +0 -11
  98. package/src/_test/index.ts +0 -25
  99. package/src/_test/setup.ts +0 -8
  100. package/src/_test/utils.ts +0 -150
  101. package/src/actions/index.test.ts +0 -81
  102. package/src/actions/index.ts +0 -182
  103. package/src/actions/public/call.bench.ts +0 -48
  104. package/src/actions/public/call.test.ts +0 -99
  105. package/src/actions/public/call.ts +0 -97
  106. package/src/actions/public/createBlockFilter.bench.ts +0 -11
  107. package/src/actions/public/createBlockFilter.test.ts +0 -9
  108. package/src/actions/public/createBlockFilter.ts +0 -14
  109. package/src/actions/public/createContractEventFilter.test.ts +0 -119
  110. package/src/actions/public/createContractEventFilter.ts +0 -69
  111. package/src/actions/public/createEventFilter.test.ts +0 -245
  112. package/src/actions/public/createEventFilter.ts +0 -76
  113. package/src/actions/public/createPendingTransactionFilter.bench.ts +0 -11
  114. package/src/actions/public/createPendingTransactionFilter.test.ts +0 -9
  115. package/src/actions/public/createPendingTransactionFilter.ts +0 -14
  116. package/src/actions/public/deployContract.test.ts +0 -56
  117. package/src/actions/public/deployContract.ts +0 -38
  118. package/src/actions/public/estimateGas.bench.ts +0 -46
  119. package/src/actions/public/estimateGas.test.ts +0 -92
  120. package/src/actions/public/estimateGas.ts +0 -61
  121. package/src/actions/public/getBalance.test.ts +0 -83
  122. package/src/actions/public/getBalance.ts +0 -37
  123. package/src/actions/public/getBlock.bench.ts +0 -28
  124. package/src/actions/public/getBlock.test.ts +0 -575
  125. package/src/actions/public/getBlock.ts +0 -65
  126. package/src/actions/public/getBlockNumber.bench.ts +0 -28
  127. package/src/actions/public/getBlockNumber.test.ts +0 -27
  128. package/src/actions/public/getBlockNumber.ts +0 -32
  129. package/src/actions/public/getBlockTransactionCount.bench.ts +0 -15
  130. package/src/actions/public/getBlockTransactionCount.test.ts +0 -57
  131. package/src/actions/public/getBlockTransactionCount.ts +0 -52
  132. package/src/actions/public/getBytecode.test.ts +0 -27
  133. package/src/actions/public/getBytecode.ts +0 -32
  134. package/src/actions/public/getChainId.bench.ts +0 -15
  135. package/src/actions/public/getChainId.test.ts +0 -8
  136. package/src/actions/public/getChainId.ts +0 -7
  137. package/src/actions/public/getFeeHistory.bench.ts +0 -18
  138. package/src/actions/public/getFeeHistory.test.ts +0 -137
  139. package/src/actions/public/getFeeHistory.ts +0 -44
  140. package/src/actions/public/getFilterChanges.bench.ts +0 -13
  141. package/src/actions/public/getFilterChanges.test.ts +0 -189
  142. package/src/actions/public/getFilterChanges.ts +0 -23
  143. package/src/actions/public/getFilterLogs.test.ts +0 -104
  144. package/src/actions/public/getFilterLogs.ts +0 -20
  145. package/src/actions/public/getGasPrice.bench.ts +0 -19
  146. package/src/actions/public/getGasPrice.test.ts +0 -8
  147. package/src/actions/public/getGasPrice.ts +0 -15
  148. package/src/actions/public/getLogs.test.ts +0 -107
  149. package/src/actions/public/getLogs.ts +0 -84
  150. package/src/actions/public/getStorageAt.test.ts +0 -34
  151. package/src/actions/public/getStorageAt.ts +0 -32
  152. package/src/actions/public/getTransaction.bench.ts +0 -33
  153. package/src/actions/public/getTransaction.test.ts +0 -311
  154. package/src/actions/public/getTransaction.ts +0 -95
  155. package/src/actions/public/getTransactionConfirmations.test.ts +0 -69
  156. package/src/actions/public/getTransactionConfirmations.ts +0 -38
  157. package/src/actions/public/getTransactionCount.test.ts +0 -56
  158. package/src/actions/public/getTransactionCount.ts +0 -34
  159. package/src/actions/public/getTransactionReceipt.bench.ts +0 -33
  160. package/src/actions/public/getTransactionReceipt.test.ts +0 -179
  161. package/src/actions/public/getTransactionReceipt.ts +0 -34
  162. package/src/actions/public/index.test.ts +0 -44
  163. package/src/actions/public/index.ts +0 -152
  164. package/src/actions/public/multicall.test.ts +0 -452
  165. package/src/actions/public/multicall.ts +0 -103
  166. package/src/actions/public/readContract.test.ts +0 -328
  167. package/src/actions/public/readContract.ts +0 -73
  168. package/src/actions/public/simulateContract.bench.ts +0 -41
  169. package/src/actions/public/simulateContract.test.ts +0 -410
  170. package/src/actions/public/simulateContract.ts +0 -94
  171. package/src/actions/public/uninstallFilter.bench.ts +0 -13
  172. package/src/actions/public/uninstallFilter.test.ts +0 -65
  173. package/src/actions/public/uninstallFilter.ts +0 -17
  174. package/src/actions/public/waitForTransactionReceipt.test.ts +0 -322
  175. package/src/actions/public/waitForTransactionReceipt.ts +0 -170
  176. package/src/actions/public/watchBlockNumber.test.ts +0 -166
  177. package/src/actions/public/watchBlockNumber.ts +0 -79
  178. package/src/actions/public/watchBlocks.test.ts +0 -210
  179. package/src/actions/public/watchBlocks.ts +0 -114
  180. package/src/actions/public/watchContractEvent.test.ts +0 -305
  181. package/src/actions/public/watchContractEvent.ts +0 -108
  182. package/src/actions/public/watchEvent.test.ts +0 -195
  183. package/src/actions/public/watchEvent.ts +0 -95
  184. package/src/actions/public/watchPendingTransactions.test.ts +0 -116
  185. package/src/actions/public/watchPendingTransactions.ts +0 -74
  186. package/src/actions/test/dropTransaction.test.ts +0 -34
  187. package/src/actions/test/dropTransaction.ts +0 -17
  188. package/src/actions/test/getAutomine.test.ts +0 -14
  189. package/src/actions/test/getAutomine.ts +0 -11
  190. package/src/actions/test/getTxpoolContent.test.ts +0 -45
  191. package/src/actions/test/getTxpoolContent.ts +0 -7
  192. package/src/actions/test/getTxpoolStatus.test.ts +0 -41
  193. package/src/actions/test/getTxpoolStatus.ts +0 -12
  194. package/src/actions/test/impersonateAccount.test.ts +0 -26
  195. package/src/actions/test/impersonateAccount.ts +0 -17
  196. package/src/actions/test/increaseTime.test.ts +0 -18
  197. package/src/actions/test/increaseTime.ts +0 -17
  198. package/src/actions/test/index.test.ts +0 -38
  199. package/src/actions/test/index.ts +0 -77
  200. package/src/actions/test/inspectTxpool.test.ts +0 -50
  201. package/src/actions/test/inspectTxpool.ts +0 -7
  202. package/src/actions/test/mine.test.ts +0 -20
  203. package/src/actions/test/mine.ts +0 -16
  204. package/src/actions/test/removeBlockTimestampInterval.test.ts +0 -23
  205. package/src/actions/test/removeBlockTimestampInterval.ts +0 -7
  206. package/src/actions/test/reset.test.ts +0 -19
  207. package/src/actions/test/reset.ts +0 -18
  208. package/src/actions/test/revert.test.ts +0 -39
  209. package/src/actions/test/revert.ts +0 -14
  210. package/src/actions/test/sendUnsignedTransaction.test.ts +0 -52
  211. package/src/actions/test/sendUnsignedTransaction.ts +0 -19
  212. package/src/actions/test/setAutomine.test.ts +0 -14
  213. package/src/actions/test/setAutomine.ts +0 -8
  214. package/src/actions/test/setBalance.test.ts +0 -29
  215. package/src/actions/test/setBalance.ts +0 -20
  216. package/src/actions/test/setBlockGasLimit.test.ts +0 -21
  217. package/src/actions/test/setBlockGasLimit.ts +0 -17
  218. package/src/actions/test/setBlockTimestampInterval.test.ts +0 -23
  219. package/src/actions/test/setBlockTimestampInterval.ts +0 -16
  220. package/src/actions/test/setCode.test.ts +0 -26
  221. package/src/actions/test/setCode.ts +0 -19
  222. package/src/actions/test/setCoinbase.test.ts +0 -11
  223. package/src/actions/test/setCoinbase.ts +0 -17
  224. package/src/actions/test/setIntervalMining.test.ts +0 -30
  225. package/src/actions/test/setIntervalMining.ts +0 -16
  226. package/src/actions/test/setLoggingEnabled.test.ts +0 -10
  227. package/src/actions/test/setLoggingEnabled.ts +0 -8
  228. package/src/actions/test/setMinGasPrice.test.ts +0 -22
  229. package/src/actions/test/setMinGasPrice.ts +0 -17
  230. package/src/actions/test/setNextBlockBaseFeePerGas.test.ts +0 -23
  231. package/src/actions/test/setNextBlockBaseFeePerGas.ts +0 -17
  232. package/src/actions/test/setNextBlockTimestamp.test.ts +0 -19
  233. package/src/actions/test/setNextBlockTimestamp.ts +0 -17
  234. package/src/actions/test/setNonce.test.ts +0 -28
  235. package/src/actions/test/setNonce.ts +0 -20
  236. package/src/actions/test/setRpcUrl.test.ts +0 -9
  237. package/src/actions/test/setRpcUrl.ts +0 -8
  238. package/src/actions/test/setStorageAt.test.ts +0 -36
  239. package/src/actions/test/setStorageAt.ts +0 -26
  240. package/src/actions/test/snapshot.test.ts +0 -18
  241. package/src/actions/test/snapshot.ts +0 -7
  242. package/src/actions/test/stopImpersonatingAccount.test.ts +0 -29
  243. package/src/actions/test/stopImpersonatingAccount.ts +0 -17
  244. package/src/actions/wallet/addChain.test.ts +0 -14
  245. package/src/actions/wallet/addChain.ts +0 -21
  246. package/src/actions/wallet/getAccounts.test.ts +0 -22
  247. package/src/actions/wallet/getAccounts.ts +0 -7
  248. package/src/actions/wallet/getPermissions.test.ts +0 -24
  249. package/src/actions/wallet/getPermissions.ts +0 -9
  250. package/src/actions/wallet/index.test.ts +0 -20
  251. package/src/actions/wallet/index.ts +0 -30
  252. package/src/actions/wallet/requestAccounts.test.ts +0 -13
  253. package/src/actions/wallet/requestAccounts.ts +0 -7
  254. package/src/actions/wallet/requestPermissions.test.ts +0 -26
  255. package/src/actions/wallet/requestPermissions.ts +0 -19
  256. package/src/actions/wallet/sendTransaction.bench.ts +0 -57
  257. package/src/actions/wallet/sendTransaction.test.ts +0 -440
  258. package/src/actions/wallet/sendTransaction.ts +0 -77
  259. package/src/actions/wallet/signMessage.test.ts +0 -61
  260. package/src/actions/wallet/signMessage.ts +0 -35
  261. package/src/actions/wallet/switchChain.test.ts +0 -21
  262. package/src/actions/wallet/switchChain.ts +0 -19
  263. package/src/actions/wallet/watchAsset.test.ts +0 -40
  264. package/src/actions/wallet/watchAsset.ts +0 -16
  265. package/src/actions/wallet/writeContract.test.ts +0 -84
  266. package/src/actions/wallet/writeContract.ts +0 -47
  267. package/src/chains.test.ts +0 -1912
  268. package/src/chains.ts +0 -99
  269. package/src/clients/createClient.test.ts +0 -295
  270. package/src/clients/createClient.ts +0 -81
  271. package/src/clients/createPublicClient.test.ts +0 -165
  272. package/src/clients/createPublicClient.ts +0 -49
  273. package/src/clients/createTestClient.test.ts +0 -145
  274. package/src/clients/createTestClient.ts +0 -72
  275. package/src/clients/createWalletClient.test.ts +0 -121
  276. package/src/clients/createWalletClient.ts +0 -54
  277. package/src/clients/index.test.ts +0 -19
  278. package/src/clients/index.ts +0 -31
  279. package/src/clients/transports/createTransport.test.ts +0 -58
  280. package/src/clients/transports/createTransport.ts +0 -48
  281. package/src/clients/transports/custom.test.ts +0 -98
  282. package/src/clients/transports/custom.ts +0 -34
  283. package/src/clients/transports/fallback.test.ts +0 -257
  284. package/src/clients/transports/fallback.ts +0 -50
  285. package/src/clients/transports/http.test.ts +0 -109
  286. package/src/clients/transports/http.ts +0 -51
  287. package/src/clients/transports/index.test.ts +0 -15
  288. package/src/clients/transports/index.ts +0 -17
  289. package/src/clients/transports/webSocket.test.ts +0 -163
  290. package/src/clients/transports/webSocket.ts +0 -117
  291. package/src/constants/abis.test.ts +0 -53
  292. package/src/constants/abis.ts +0 -44
  293. package/src/constants/index.test.ts +0 -14
  294. package/src/constants/index.ts +0 -3
  295. package/src/constants/solidity.test.ts +0 -41
  296. package/src/constants/solidity.ts +0 -35
  297. package/src/ens.ts +0 -5
  298. package/src/errors/abi.test.ts +0 -81
  299. package/src/errors/abi.ts +0 -238
  300. package/src/errors/address.test.ts +0 -14
  301. package/src/errors/address.ts +0 -9
  302. package/src/errors/base.test.ts +0 -114
  303. package/src/errors/base.ts +0 -57
  304. package/src/errors/block.test.ts +0 -24
  305. package/src/errors/block.ts +0 -18
  306. package/src/errors/contract.test.ts +0 -233
  307. package/src/errors/contract.ts +0 -178
  308. package/src/errors/data.ts +0 -20
  309. package/src/errors/encoding.ts +0 -60
  310. package/src/errors/index.ts +0 -79
  311. package/src/errors/log.ts +0 -8
  312. package/src/errors/request.test.ts +0 -330
  313. package/src/errors/request.ts +0 -163
  314. package/src/errors/rpc.test.ts +0 -87
  315. package/src/errors/rpc.ts +0 -113
  316. package/src/errors/transaction.test.ts +0 -83
  317. package/src/errors/transaction.ts +0 -54
  318. package/src/errors/transport.test.ts +0 -11
  319. package/src/errors/transport.ts +0 -12
  320. package/src/index.test.ts +0 -263
  321. package/src/index.ts +0 -389
  322. package/src/public.ts +0 -80
  323. package/src/test.ts +0 -51
  324. package/src/types/block.ts +0 -71
  325. package/src/types/chain.ts +0 -6
  326. package/src/types/contract.ts +0 -393
  327. package/src/types/eip1193.ts +0 -1041
  328. package/src/types/fee.ts +0 -47
  329. package/src/types/filter.ts +0 -8
  330. package/src/types/formatter.ts +0 -23
  331. package/src/types/index.ts +0 -83
  332. package/src/types/log.ts +0 -22
  333. package/src/types/misc.ts +0 -5
  334. package/src/types/multicall.ts +0 -82
  335. package/src/types/rpc.ts +0 -35
  336. package/src/types/transaction.ts +0 -145
  337. package/src/types/utils.ts +0 -67
  338. package/src/types/window.ts +0 -9
  339. package/src/utils/abi/decodeAbi.bench.ts +0 -135
  340. package/src/utils/abi/decodeAbi.test.ts +0 -1614
  341. package/src/utils/abi/decodeAbi.ts +0 -300
  342. package/src/utils/abi/decodeDeployData.test.ts +0 -151
  343. package/src/utils/abi/decodeDeployData.ts +0 -44
  344. package/src/utils/abi/decodeErrorResult.test.ts +0 -230
  345. package/src/utils/abi/decodeErrorResult.ts +0 -45
  346. package/src/utils/abi/decodeFunctionData.test.ts +0 -139
  347. package/src/utils/abi/decodeFunctionData.ts +0 -29
  348. package/src/utils/abi/decodeFunctionResult.test.ts +0 -333
  349. package/src/utils/abi/decodeFunctionResult.ts +0 -57
  350. package/src/utils/abi/encodeAbi.bench.ts +0 -163
  351. package/src/utils/abi/encodeAbi.test.ts +0 -1447
  352. package/src/utils/abi/encodeAbi.ts +0 -273
  353. package/src/utils/abi/encodeDeployData.test.ts +0 -124
  354. package/src/utils/abi/encodeDeployData.ts +0 -40
  355. package/src/utils/abi/encodeErrorResult.test.ts +0 -192
  356. package/src/utils/abi/encodeErrorResult.ts +0 -47
  357. package/src/utils/abi/encodeEventTopics.test.ts +0 -345
  358. package/src/utils/abi/encodeEventTopics.ts +0 -75
  359. package/src/utils/abi/encodeFunctionData.test.ts +0 -138
  360. package/src/utils/abi/encodeFunctionData.ts +0 -45
  361. package/src/utils/abi/encodeFunctionResult.test.ts +0 -279
  362. package/src/utils/abi/encodeFunctionResult.ts +0 -41
  363. package/src/utils/abi/formatAbiItem.test.ts +0 -335
  364. package/src/utils/abi/formatAbiItem.ts +0 -41
  365. package/src/utils/abi/formatAbiItemWithArgs.test.ts +0 -291
  366. package/src/utils/abi/formatAbiItemWithArgs.ts +0 -27
  367. package/src/utils/abi/getAbiItem.test.ts +0 -547
  368. package/src/utils/abi/getAbiItem.ts +0 -95
  369. package/src/utils/abi/index.test.ts +0 -23
  370. package/src/utils/abi/index.ts +0 -42
  371. package/src/utils/address/getAddress.bench.ts +0 -22
  372. package/src/utils/address/getAddress.test.ts +0 -46
  373. package/src/utils/address/getAddress.ts +0 -28
  374. package/src/utils/address/getContractAddress.bench.ts +0 -20
  375. package/src/utils/address/getContractAddress.test.ts +0 -78
  376. package/src/utils/address/getContractAddress.ts +0 -59
  377. package/src/utils/address/index.test.ts +0 -17
  378. package/src/utils/address/index.ts +0 -16
  379. package/src/utils/address/isAddress.test.ts +0 -10
  380. package/src/utils/address/isAddress.ts +0 -10
  381. package/src/utils/address/isAddressEqual.test.ts +0 -55
  382. package/src/utils/address/isAddressEqual.ts +0 -6
  383. package/src/utils/buildRequest.test.ts +0 -365
  384. package/src/utils/buildRequest.ts +0 -45
  385. package/src/utils/chain.test.ts +0 -43
  386. package/src/utils/chain.ts +0 -8
  387. package/src/utils/contract/extractFunctionParts.test.ts +0 -109
  388. package/src/utils/contract/extractFunctionParts.ts +0 -27
  389. package/src/utils/contract/getContractError.test.ts +0 -282
  390. package/src/utils/contract/getContractError.ts +0 -58
  391. package/src/utils/contract/index.test.ts +0 -15
  392. package/src/utils/contract/index.ts +0 -8
  393. package/src/utils/data/concat.test.ts +0 -35
  394. package/src/utils/data/concat.ts +0 -34
  395. package/src/utils/data/index.test.ts +0 -23
  396. package/src/utils/data/index.ts +0 -13
  397. package/src/utils/data/isBytes.test.ts +0 -9
  398. package/src/utils/data/isBytes.ts +0 -7
  399. package/src/utils/data/isHex.test.ts +0 -13
  400. package/src/utils/data/isHex.ts +0 -5
  401. package/src/utils/data/pad.bench.ts +0 -30
  402. package/src/utils/data/pad.test.ts +0 -367
  403. package/src/utils/data/pad.ts +0 -53
  404. package/src/utils/data/size.test.ts +0 -18
  405. package/src/utils/data/size.ts +0 -13
  406. package/src/utils/data/slice.test.ts +0 -203
  407. package/src/utils/data/slice.ts +0 -60
  408. package/src/utils/data/trim.bench.ts +0 -34
  409. package/src/utils/data/trim.test.ts +0 -175
  410. package/src/utils/data/trim.ts +0 -33
  411. package/src/utils/encoding/decodeBytes.bench.ts +0 -40
  412. package/src/utils/encoding/decodeBytes.test.ts +0 -144
  413. package/src/utils/encoding/decodeBytes.ts +0 -63
  414. package/src/utils/encoding/decodeHex.bench.ts +0 -24
  415. package/src/utils/encoding/decodeHex.test.ts +0 -167
  416. package/src/utils/encoding/decodeHex.ts +0 -76
  417. package/src/utils/encoding/decodeRlp.bench.ts +0 -34
  418. package/src/utils/encoding/decodeRlp.test.ts +0 -350
  419. package/src/utils/encoding/decodeRlp.ts +0 -121
  420. package/src/utils/encoding/encodeBytes.bench.ts +0 -29
  421. package/src/utils/encoding/encodeBytes.test.ts +0 -676
  422. package/src/utils/encoding/encodeBytes.ts +0 -59
  423. package/src/utils/encoding/encodeHex.bench.ts +0 -49
  424. package/src/utils/encoding/encodeHex.test.ts +0 -232
  425. package/src/utils/encoding/encodeHex.ts +0 -104
  426. package/src/utils/encoding/encodeRlp.bench.ts +0 -54
  427. package/src/utils/encoding/encodeRlp.test.ts +0 -254
  428. package/src/utils/encoding/encodeRlp.ts +0 -48
  429. package/src/utils/encoding/index.test.ts +0 -32
  430. package/src/utils/encoding/index.ts +0 -36
  431. package/src/utils/ens/index.test.ts +0 -13
  432. package/src/utils/ens/index.ts +0 -5
  433. package/src/utils/ens/labelhash.test.ts +0 -55
  434. package/src/utils/ens/labelhash.ts +0 -16
  435. package/src/utils/ens/namehash.test.ts +0 -65
  436. package/src/utils/ens/namehash.ts +0 -28
  437. package/src/utils/ens/normalize.bench.ts +0 -14
  438. package/src/utils/ens/normalize.test.ts +0 -35
  439. package/src/utils/ens/normalize.ts +0 -14
  440. package/src/utils/formatters/block.bench.ts +0 -51
  441. package/src/utils/formatters/block.test.ts +0 -115
  442. package/src/utils/formatters/block.ts +0 -37
  443. package/src/utils/formatters/extract.test.ts +0 -14
  444. package/src/utils/formatters/extract.ts +0 -18
  445. package/src/utils/formatters/feeHistory.test.ts +0 -66
  446. package/src/utils/formatters/feeHistory.ts +0 -12
  447. package/src/utils/formatters/format.test.ts +0 -93
  448. package/src/utils/formatters/format.ts +0 -90
  449. package/src/utils/formatters/index.test.ts +0 -27
  450. package/src/utils/formatters/index.ts +0 -34
  451. package/src/utils/formatters/log.test.ts +0 -79
  452. package/src/utils/formatters/log.ts +0 -12
  453. package/src/utils/formatters/transaction.test.ts +0 -271
  454. package/src/utils/formatters/transaction.ts +0 -63
  455. package/src/utils/formatters/transactionReceipt.bench.ts +0 -73
  456. package/src/utils/formatters/transactionReceipt.test.ts +0 -151
  457. package/src/utils/formatters/transactionReceipt.ts +0 -63
  458. package/src/utils/formatters/transactionRequest.bench.ts +0 -29
  459. package/src/utils/formatters/transactionRequest.test.ts +0 -237
  460. package/src/utils/formatters/transactionRequest.ts +0 -56
  461. package/src/utils/hash/getEventSignature.test.ts +0 -61
  462. package/src/utils/hash/getEventSignature.ts +0 -4
  463. package/src/utils/hash/getFunctionSignature.test.ts +0 -22
  464. package/src/utils/hash/getFunctionSignature.ts +0 -5
  465. package/src/utils/hash/hashFunction.test.ts +0 -65
  466. package/src/utils/hash/hashFunction.ts +0 -12
  467. package/src/utils/hash/index.test.ts +0 -13
  468. package/src/utils/hash/index.ts +0 -5
  469. package/src/utils/hash/keccak256.test.ts +0 -59
  470. package/src/utils/hash/keccak256.ts +0 -21
  471. package/src/utils/index.test.ts +0 -113
  472. package/src/utils/index.ts +0 -141
  473. package/src/utils/observe.test.ts +0 -176
  474. package/src/utils/observe.ts +0 -66
  475. package/src/utils/poll.test.ts +0 -127
  476. package/src/utils/poll.ts +0 -42
  477. package/src/utils/promise/index.test.ts +0 -14
  478. package/src/utils/promise/index.ts +0 -3
  479. package/src/utils/promise/withCache.test.ts +0 -97
  480. package/src/utils/promise/withCache.ts +0 -73
  481. package/src/utils/promise/withRetry.test.ts +0 -231
  482. package/src/utils/promise/withRetry.ts +0 -61
  483. package/src/utils/promise/withTimeout.test.ts +0 -37
  484. package/src/utils/promise/withTimeout.ts +0 -39
  485. package/src/utils/rpc.test.ts +0 -989
  486. package/src/utils/rpc.ts +0 -292
  487. package/src/utils/stringify.test.ts +0 -13
  488. package/src/utils/stringify.ts +0 -5
  489. package/src/utils/uid.ts +0 -14
  490. package/src/utils/unit/constants.test.ts +0 -22
  491. package/src/utils/unit/constants.ts +0 -12
  492. package/src/utils/unit/formatEther.test.ts +0 -75
  493. package/src/utils/unit/formatEther.ts +0 -6
  494. package/src/utils/unit/formatGwei.test.ts +0 -32
  495. package/src/utils/unit/formatGwei.ts +0 -6
  496. package/src/utils/unit/formatUnit.bench.ts +0 -21
  497. package/src/utils/unit/formatUnit.test.ts +0 -40
  498. package/src/utils/unit/formatUnit.ts +0 -16
  499. package/src/utils/unit/index.test.ts +0 -28
  500. package/src/utils/unit/index.ts +0 -7
  501. package/src/utils/unit/parseEther.test.ts +0 -126
  502. package/src/utils/unit/parseEther.ts +0 -6
  503. package/src/utils/unit/parseGwei.test.ts +0 -50
  504. package/src/utils/unit/parseGwei.ts +0 -6
  505. package/src/utils/unit/parseUnit.bench.ts +0 -21
  506. package/src/utils/unit/parseUnit.test.ts +0 -54
  507. package/src/utils/unit/parseUnit.ts +0 -27
  508. package/src/utils/wait.ts +0 -3
  509. package/src/wallet.ts +0 -23
  510. package/src/window.ts +0 -1
@@ -1,189 +0,0 @@
1
- import { afterAll, assertType, beforeAll, describe, expect, test } from 'vitest'
2
-
3
- import {
4
- accounts,
5
- address,
6
- initialBlockNumber,
7
- publicClient,
8
- testClient,
9
- transfer1Data,
10
- walletClient,
11
- usdcContractConfig,
12
- } from '../../_test'
13
-
14
- import {
15
- impersonateAccount,
16
- mine,
17
- setIntervalMining,
18
- stopImpersonatingAccount,
19
- } from '../test'
20
- import { sendTransaction } from '../wallet'
21
- import { parseEther } from '../../utils'
22
- import type { Hash, Log } from '../../types'
23
- import { createBlockFilter } from './createBlockFilter'
24
- import { createEventFilter } from './createEventFilter'
25
- import { createPendingTransactionFilter } from './createPendingTransactionFilter'
26
- import { getFilterChanges } from './getFilterChanges'
27
-
28
- beforeAll(async () => {
29
- await setIntervalMining(testClient, { interval: 0 })
30
- await impersonateAccount(testClient, {
31
- address: address.vitalik,
32
- })
33
- })
34
-
35
- afterAll(async () => {
36
- await setIntervalMining(testClient, { interval: 1 })
37
- await stopImpersonatingAccount(testClient, {
38
- address: address.vitalik,
39
- })
40
- })
41
-
42
- test('default', async () => {
43
- const filter = await createPendingTransactionFilter(publicClient)
44
- expect(
45
- await getFilterChanges(publicClient, { filter }),
46
- ).toMatchInlineSnapshot('[]')
47
- })
48
-
49
- test('pending txns', async () => {
50
- const filter = await createPendingTransactionFilter(publicClient)
51
-
52
- await sendTransaction(walletClient, {
53
- from: accounts[0].address,
54
- to: accounts[1].address,
55
- value: parseEther('1'),
56
- })
57
- await sendTransaction(walletClient, {
58
- from: accounts[0].address,
59
- to: accounts[1].address,
60
- value: parseEther('1'),
61
- })
62
-
63
- let hashes = await getFilterChanges(publicClient, { filter })
64
- assertType<Hash[]>(hashes)
65
- expect(hashes.length).toBe(2)
66
-
67
- mine(testClient, { blocks: 1 })
68
-
69
- hashes = await getFilterChanges(publicClient, { filter })
70
- expect(hashes.length).toBe(0)
71
-
72
- await sendTransaction(walletClient, {
73
- from: accounts[0].address,
74
- to: accounts[1].address,
75
- value: parseEther('1'),
76
- })
77
-
78
- hashes = await getFilterChanges(publicClient, { filter })
79
- expect(hashes.length).toBe(1)
80
- })
81
-
82
- test('new blocks', async () => {
83
- const filter = await createBlockFilter(publicClient)
84
-
85
- await mine(testClient, { blocks: 2 })
86
-
87
- let hashes = await getFilterChanges(publicClient, { filter })
88
- assertType<Hash[]>(hashes)
89
- expect(hashes.length).toBe(2)
90
-
91
- hashes = await getFilterChanges(publicClient, { filter })
92
- expect(hashes.length).toBe(0)
93
-
94
- await mine(testClient, { blocks: 1 })
95
-
96
- hashes = await getFilterChanges(publicClient, { filter })
97
- expect(hashes.length).toBe(1)
98
- })
99
-
100
- describe('events', () => {
101
- test('no args', async () => {
102
- const filter = await createEventFilter(publicClient)
103
-
104
- await sendTransaction(walletClient, {
105
- from: address.vitalik,
106
- to: usdcContractConfig.address,
107
- data: transfer1Data(accounts[0].address),
108
- })
109
- await sendTransaction(walletClient, {
110
- from: address.vitalik,
111
- to: usdcContractConfig.address,
112
- data: transfer1Data(accounts[1].address),
113
- })
114
-
115
- await mine(testClient, { blocks: 1 })
116
-
117
- let logs = await getFilterChanges(publicClient, { filter })
118
- assertType<Log[]>(logs)
119
- expect(logs.length).toBe(2)
120
-
121
- logs = await getFilterChanges(publicClient, { filter })
122
- expect(logs.length).toBe(0)
123
-
124
- await sendTransaction(walletClient, {
125
- from: address.vitalik,
126
- to: usdcContractConfig.address,
127
- data: transfer1Data(accounts[2].address),
128
- })
129
-
130
- await mine(testClient, { blocks: 1 })
131
-
132
- logs = await getFilterChanges(publicClient, { filter })
133
- expect(logs.length).toBe(1)
134
- })
135
-
136
- test('args: event', async () => {
137
- const filter = await createEventFilter(publicClient, {
138
- event: 'Transfer(address from, address to, uint256 value)',
139
- })
140
-
141
- await sendTransaction(walletClient, {
142
- from: address.vitalik,
143
- to: usdcContractConfig.address,
144
- data: transfer1Data(accounts[0].address),
145
- })
146
- await sendTransaction(walletClient, {
147
- from: address.vitalik,
148
- to: usdcContractConfig.address,
149
- data: transfer1Data(accounts[1].address),
150
- })
151
-
152
- await mine(testClient, { blocks: 1 })
153
-
154
- let logs = await getFilterChanges(publicClient, { filter })
155
- assertType<Log[]>(logs)
156
- expect(logs.length).toBe(2)
157
-
158
- logs = await getFilterChanges(publicClient, { filter })
159
- expect(logs.length).toBe(0)
160
-
161
- await sendTransaction(walletClient, {
162
- from: address.vitalik,
163
- to: usdcContractConfig.address,
164
- data: transfer1Data(accounts[2].address),
165
- })
166
-
167
- await mine(testClient, { blocks: 1 })
168
-
169
- logs = await getFilterChanges(publicClient, { filter })
170
- expect(logs.length).toBe(1)
171
- })
172
-
173
- test('args: fromBlock/toBlock', async () => {
174
- const filter = await createEventFilter(publicClient, {
175
- event: 'Transfer(address from, address to, uint256 value)',
176
- fromBlock: initialBlockNumber - 5n,
177
- toBlock: initialBlockNumber,
178
- })
179
-
180
- let logs = await getFilterChanges(publicClient, { filter })
181
- assertType<Log[]>(logs)
182
- expect(logs.length).toBe(1056)
183
-
184
- logs = await getFilterChanges(publicClient, { filter })
185
- expect(logs.length).toBe(0)
186
- })
187
-
188
- test.todo('args: args')
189
- })
@@ -1,23 +0,0 @@
1
- import type { PublicClient } from '../../clients'
2
- import type { Filter, FilterType, Hash, Log } from '../../types'
3
-
4
- import { formatLog } from '../../utils/formatters/log'
5
-
6
- export type GetFilterChangesArgs<TFilterType extends FilterType> = {
7
- filter: Filter<TFilterType>
8
- }
9
- export type GetFilterChangesResponse<TFilterType extends FilterType> =
10
- TFilterType extends 'event' ? Log[] : Hash[]
11
-
12
- export async function getFilterChanges<TFilterType extends FilterType>(
13
- client: PublicClient,
14
- { filter }: GetFilterChangesArgs<TFilterType>,
15
- ) {
16
- const logs = await client.request({
17
- method: 'eth_getFilterChanges',
18
- params: [filter.id],
19
- })
20
- return logs.map((log) =>
21
- typeof log === 'string' ? log : formatLog(log),
22
- ) as GetFilterChangesResponse<TFilterType>
23
- }
@@ -1,104 +0,0 @@
1
- import { afterAll, assertType, beforeAll, describe, expect, test } from 'vitest'
2
-
3
- import {
4
- accounts,
5
- address,
6
- initialBlockNumber,
7
- publicClient,
8
- testClient,
9
- transfer1Data,
10
- usdcContractConfig,
11
- walletClient,
12
- } from '../../_test'
13
-
14
- import {
15
- impersonateAccount,
16
- mine,
17
- setIntervalMining,
18
- stopImpersonatingAccount,
19
- } from '../test'
20
- import { sendTransaction } from '../wallet'
21
- import type { Log } from '../../types'
22
- import { createEventFilter } from './createEventFilter'
23
- import { getFilterLogs } from './getFilterLogs'
24
-
25
- beforeAll(async () => {
26
- await setIntervalMining(testClient, { interval: 0 })
27
- await impersonateAccount(testClient, {
28
- address: address.vitalik,
29
- })
30
- })
31
-
32
- afterAll(async () => {
33
- await setIntervalMining(testClient, { interval: 1 })
34
- await stopImpersonatingAccount(testClient, {
35
- address: address.vitalik,
36
- })
37
- })
38
-
39
- test('default', async () => {
40
- const filter = await createEventFilter(publicClient)
41
- expect(await getFilterLogs(publicClient, { filter })).toMatchInlineSnapshot(
42
- '[]',
43
- )
44
- })
45
-
46
- describe('events', () => {
47
- test('no args', async () => {
48
- const filter = await createEventFilter(publicClient)
49
-
50
- await sendTransaction(walletClient, {
51
- from: address.vitalik,
52
- to: usdcContractConfig.address,
53
- data: transfer1Data(accounts[0].address),
54
- })
55
- await sendTransaction(walletClient, {
56
- from: address.vitalik,
57
- to: usdcContractConfig.address,
58
- data: transfer1Data(accounts[1].address),
59
- })
60
-
61
- await mine(testClient, { blocks: 1 })
62
-
63
- let logs = await getFilterLogs(publicClient, { filter })
64
- assertType<Log[]>(logs)
65
- expect(logs.length).toBe(2)
66
- })
67
-
68
- test('args: event', async () => {
69
- const filter = await createEventFilter(publicClient, {
70
- event: 'Transfer(address from, address to, uint256 value)',
71
- })
72
-
73
- await sendTransaction(walletClient, {
74
- from: address.vitalik,
75
- to: usdcContractConfig.address,
76
- data: transfer1Data(accounts[0].address),
77
- })
78
- await sendTransaction(walletClient, {
79
- from: address.vitalik,
80
- to: usdcContractConfig.address,
81
- data: transfer1Data(accounts[1].address),
82
- })
83
-
84
- await mine(testClient, { blocks: 1 })
85
-
86
- let logs = await getFilterLogs(publicClient, { filter })
87
- assertType<Log[]>(logs)
88
- expect(logs.length).toBe(2)
89
- })
90
-
91
- test('args: fromBlock/toBlock', async () => {
92
- const filter = await createEventFilter(publicClient, {
93
- event: 'Transfer(address from, address to, uint256 value)',
94
- fromBlock: initialBlockNumber - 5n,
95
- toBlock: initialBlockNumber,
96
- })
97
-
98
- let logs = await getFilterLogs(publicClient, { filter })
99
- assertType<Log[]>(logs)
100
- expect(logs.length).toBe(1056)
101
- })
102
-
103
- test.todo('args: args')
104
- })
@@ -1,20 +0,0 @@
1
- import type { PublicClient } from '../../clients'
2
- import type { Filter, FilterType, Hash, Log } from '../../types'
3
-
4
- import { formatLog } from '../../utils/formatters/log'
5
-
6
- export type GetFilterLogsArgs = {
7
- filter: Filter<'event'>
8
- }
9
- export type GetFilterLogsResponse = Log[]
10
-
11
- export async function getFilterLogs<TFilterType extends FilterType>(
12
- client: PublicClient,
13
- { filter }: GetFilterLogsArgs,
14
- ): Promise<GetFilterLogsResponse> {
15
- const logs = await client.request({
16
- method: 'eth_getFilterLogs',
17
- params: [filter.id],
18
- })
19
- return logs.map(formatLog)
20
- }
@@ -1,19 +0,0 @@
1
- import { bench, describe } from 'vitest'
2
-
3
- import { ethersProvider, publicClient, web3Provider } from '../../_test'
4
-
5
- import { getGasPrice } from './getGasPrice'
6
-
7
- describe('Get Gas Price', () => {
8
- bench('viem: `getGasPrice`', async () => {
9
- await getGasPrice(publicClient)
10
- })
11
-
12
- bench('ethers: `getGasPrice`', async () => {
13
- await ethersProvider.getGasPrice()
14
- })
15
-
16
- bench('web3.js: `getGasPrice`', async () => {
17
- await web3Provider.eth.getGasPrice()
18
- })
19
- })
@@ -1,8 +0,0 @@
1
- import { expect, test } from 'vitest'
2
-
3
- import { publicClient } from '../../_test'
4
- import { getGasPrice } from './getGasPrice'
5
-
6
- test('getGasPrice', async () => {
7
- expect(await getGasPrice(publicClient)).toBeDefined()
8
- })
@@ -1,15 +0,0 @@
1
- import type { PublicClient } from '../../clients'
2
-
3
- export type GetGasPriceResponse = bigint
4
-
5
- /**
6
- * @description Returns the current price of gas (in wei).
7
- */
8
- export async function getGasPrice(
9
- client: PublicClient,
10
- ): Promise<GetGasPriceResponse> {
11
- const gasPrice = await client.request({
12
- method: 'eth_gasPrice',
13
- })
14
- return BigInt(gasPrice)
15
- }
@@ -1,107 +0,0 @@
1
- import { afterAll, assertType, beforeAll, describe, expect, test } from 'vitest'
2
-
3
- import {
4
- accounts,
5
- address,
6
- initialBlockNumber,
7
- publicClient,
8
- testClient,
9
- transfer1Data,
10
- usdcContractConfig,
11
- walletClient,
12
- } from '../../_test'
13
-
14
- import {
15
- impersonateAccount,
16
- mine,
17
- setIntervalMining,
18
- stopImpersonatingAccount,
19
- } from '../test'
20
- import { sendTransaction } from '../wallet'
21
- import type { Log } from '../../types'
22
- import { getLogs } from './getLogs'
23
- import { getBlock } from './getBlock'
24
-
25
- beforeAll(async () => {
26
- await setIntervalMining(testClient, { interval: 0 })
27
- await impersonateAccount(testClient, {
28
- address: address.vitalik,
29
- })
30
- })
31
-
32
- afterAll(async () => {
33
- await setIntervalMining(testClient, { interval: 1 })
34
- await stopImpersonatingAccount(testClient, {
35
- address: address.vitalik,
36
- })
37
- })
38
-
39
- test('default', async () => {
40
- const logs = await getLogs(publicClient)
41
- expect(logs).toMatchInlineSnapshot('[]')
42
- })
43
-
44
- describe('events', () => {
45
- test('no args', async () => {
46
- await sendTransaction(walletClient, {
47
- from: address.vitalik,
48
- to: usdcContractConfig.address,
49
- data: transfer1Data(accounts[0].address),
50
- })
51
- await sendTransaction(walletClient, {
52
- from: address.vitalik,
53
- to: usdcContractConfig.address,
54
- data: transfer1Data(accounts[1].address),
55
- })
56
- await mine(testClient, { blocks: 1 })
57
-
58
- let logs = await getLogs(publicClient)
59
- assertType<Log[]>(logs)
60
- expect(logs.length).toBe(2)
61
- })
62
-
63
- test('args: event', async () => {
64
- await sendTransaction(walletClient, {
65
- from: address.vitalik,
66
- to: usdcContractConfig.address,
67
- data: transfer1Data(accounts[0].address),
68
- })
69
- await sendTransaction(walletClient, {
70
- from: address.vitalik,
71
- to: usdcContractConfig.address,
72
- data: transfer1Data(accounts[1].address),
73
- })
74
-
75
- await mine(testClient, { blocks: 1 })
76
-
77
- let logs = await getLogs(publicClient, {
78
- event: 'Transfer(address from, address to, uint256 value)',
79
- })
80
- assertType<Log[]>(logs)
81
- expect(logs.length).toBe(2)
82
- })
83
-
84
- test('args: fromBlock/toBlock', async () => {
85
- let logs = await getLogs(publicClient, {
86
- event: 'Transfer(address from, address to, uint256 value)',
87
- fromBlock: initialBlockNumber - 5n,
88
- toBlock: initialBlockNumber,
89
- })
90
- assertType<Log[]>(logs)
91
- expect(logs.length).toBe(1056)
92
- })
93
-
94
- test('args: blockHash', async () => {
95
- const block = await getBlock(publicClient, {
96
- blockNumber: initialBlockNumber - 1n,
97
- })
98
- let logs = await getLogs(publicClient, {
99
- event: 'Transfer(address from, address to, uint256 value)',
100
- blockHash: block.hash!,
101
- })
102
- assertType<Log[]>(logs)
103
- expect(logs.length).toBe(118)
104
- })
105
-
106
- test.todo('args: args')
107
- })
@@ -1,84 +0,0 @@
1
- import type { PublicClient } from '../../clients'
2
- import type {
3
- Log,
4
- RpcLog,
5
- Address,
6
- BlockNumber,
7
- BlockTag,
8
- EventDefinition,
9
- Hash,
10
- LogTopic,
11
- } from '../../types'
12
- import { numberToHex } from '../../utils'
13
- import { formatLog } from '../../utils/formatters/log'
14
- import { buildFilterTopics, EventFilterArgs } from './createEventFilter'
15
-
16
- export type GetLogsArgs<TEventDefinition extends EventDefinition> = {
17
- /** Address or list of addresses from which logs originated */
18
- address?: Address | Address[]
19
- } & (
20
- | { event: TEventDefinition; args?: EventFilterArgs<TEventDefinition> }
21
- | {
22
- event?: never
23
- args?: never
24
- }
25
- ) &
26
- (
27
- | {
28
- /** Block number or tag after which to include logs */
29
- fromBlock?: BlockNumber<bigint> | BlockTag
30
- /** Block number or tag before which to include logs */
31
- toBlock?: BlockNumber<bigint> | BlockTag
32
- blockHash?: never
33
- }
34
- | {
35
- fromBlock?: never
36
- toBlock?: never
37
- /** Hash of block to include logs from */
38
- blockHash?: Hash
39
- }
40
- )
41
-
42
- export type GetLogsResponse = Log[]
43
-
44
- /**
45
- * @description Returns a collection of event logs.
46
- */
47
- export async function getLogs<TEventDefinition extends EventDefinition,>(
48
- client: PublicClient,
49
- {
50
- address,
51
- blockHash,
52
- fromBlock,
53
- toBlock,
54
- event,
55
- args,
56
- }: GetLogsArgs<TEventDefinition> = {},
57
- ): Promise<GetLogsResponse> {
58
- let topics: LogTopic[] = []
59
- if (event) {
60
- topics = buildFilterTopics({ event, args })
61
- }
62
- let logs: RpcLog[]
63
- if (blockHash) {
64
- logs = await client.request({
65
- method: 'eth_getLogs',
66
- params: [{ address, topics, blockHash }],
67
- })
68
- } else {
69
- logs = await client.request({
70
- method: 'eth_getLogs',
71
- params: [
72
- {
73
- address,
74
- topics,
75
- fromBlock:
76
- typeof fromBlock === 'bigint' ? numberToHex(fromBlock) : fromBlock,
77
- toBlock: typeof toBlock === 'bigint' ? numberToHex(toBlock) : toBlock,
78
- },
79
- ],
80
- })
81
- }
82
-
83
- return logs.map(formatLog)
84
- }
@@ -1,34 +0,0 @@
1
- import { expect, test } from 'vitest'
2
- import {
3
- initialBlockNumber,
4
- publicClient,
5
- wagmiContractConfig,
6
- } from '../../_test'
7
-
8
- import { getBytecode } from './getBytecode'
9
- import { getStorageAt } from './getStorageAt'
10
-
11
- test('default', async () => {
12
- expect(
13
- await getStorageAt(publicClient, {
14
- address: wagmiContractConfig.address,
15
- slot: '0x0',
16
- }),
17
- ).toBe('0x7761676d6900000000000000000000000000000000000000000000000000000a')
18
- expect(
19
- await getStorageAt(publicClient, {
20
- address: wagmiContractConfig.address,
21
- slot: '0x1',
22
- }),
23
- ).toBe('0x5741474d4900000000000000000000000000000000000000000000000000000a')
24
- })
25
-
26
- test('args: blockNumber', async () => {
27
- expect(
28
- await getStorageAt(publicClient, {
29
- address: wagmiContractConfig.address,
30
- slot: '0x0',
31
- blockNumber: initialBlockNumber,
32
- }),
33
- ).toBe('0x7761676d6900000000000000000000000000000000000000000000000000000a')
34
- })
@@ -1,32 +0,0 @@
1
- import { PublicClient } from '../../clients'
2
- import { Address, BlockTag, Hex } from '../../types'
3
- import { numberToHex } from '../../utils'
4
-
5
- export type GetStorageAtArgs = {
6
- address: Address
7
- slot: Hex
8
- } & (
9
- | {
10
- blockNumber?: never
11
- blockTag?: BlockTag
12
- }
13
- | {
14
- blockNumber?: bigint
15
- blockTag?: never
16
- }
17
- )
18
-
19
- export type GetStorageAtResponse = Hex | undefined
20
-
21
- export async function getStorageAt(
22
- client: PublicClient,
23
- { address, blockNumber, blockTag = 'latest', slot }: GetStorageAtArgs,
24
- ): Promise<GetStorageAtResponse> {
25
- const blockNumberHex =
26
- blockNumber !== undefined ? numberToHex(blockNumber) : undefined
27
- const data = await client.request({
28
- method: 'eth_getStorageAt',
29
- params: [address, slot, blockNumberHex || blockTag],
30
- })
31
- return data
32
- }
@@ -1,33 +0,0 @@
1
- import { bench, describe } from 'vitest'
2
-
3
- import {
4
- ethersProvider,
5
- ethersV6Provider,
6
- publicClient,
7
- web3Provider,
8
- } from '../../_test'
9
-
10
- import { getTransaction } from './getTransaction'
11
-
12
- const hash =
13
- '0xa4b1f606b66105fa45cb5db23d2f6597075701e7f0e2367f4e6a39d17a8cf98b'
14
-
15
- describe('Get Transaction', () => {
16
- bench('viem: `getTransaction`', async () => {
17
- await getTransaction(publicClient, {
18
- hash,
19
- })
20
- })
21
-
22
- bench('ethers: `getTransaction`', async () => {
23
- await ethersProvider.getTransaction(hash)
24
- })
25
-
26
- bench('ethers@6: `getTransaction`', async () => {
27
- await ethersV6Provider.getTransaction(hash)
28
- })
29
-
30
- bench('web3.js: `getTransaction`', async () => {
31
- await web3Provider.eth.getTransaction(hash)
32
- })
33
- })