viem 0.0.1-alpha.25 → 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 (500) hide show
  1. package/dist/{call-ac509982.d.ts → call-3476b8ee.d.ts} +4 -5
  2. package/dist/{chain-f16512e8.d.ts → chain-42de87e5.d.ts} +1 -14
  3. package/dist/{chain-c4ccb458.d.ts → chain-b0cfb141.d.ts} +1 -1
  4. package/dist/chains.d.ts +3 -3
  5. package/dist/chains.js +46 -46
  6. package/dist/chains.mjs +1 -1
  7. package/dist/{chunk-LEPQJNVO.mjs → chunk-BSAB6UH4.mjs} +2 -2
  8. package/dist/{chunk-LEPQJNVO.mjs.map → chunk-BSAB6UH4.mjs.map} +0 -0
  9. package/dist/{chunk-THMRUG4D.js → chunk-DSQO3E4F.js} +257 -398
  10. package/dist/chunk-DSQO3E4F.js.map +1 -0
  11. package/dist/{chunk-CD2XJOBJ.js → chunk-LINNE4N4.js} +136 -91
  12. package/dist/chunk-LINNE4N4.js.map +1 -0
  13. package/dist/{chunk-KSAO4Y4Q.mjs → chunk-PRG3BBPZ.mjs} +293 -434
  14. package/dist/chunk-PRG3BBPZ.mjs.map +1 -0
  15. package/dist/{chunk-2Y3UZMSP.mjs → chunk-QSIX64VZ.mjs} +61 -16
  16. package/dist/chunk-QSIX64VZ.mjs.map +1 -0
  17. package/dist/{chunk-NUXMGPMK.js → chunk-YTG4YXMB.js} +14 -14
  18. package/dist/{chunk-NUXMGPMK.js.map → chunk-YTG4YXMB.js.map} +0 -0
  19. package/dist/{contract-9e76e561.d.ts → contract-9dd2f98b.d.ts} +1 -1
  20. package/dist/contract.d.ts +21 -15
  21. package/dist/contract.js +6 -4
  22. package/dist/contract.mjs +5 -3
  23. package/dist/{createClient-68ee4bb4.d.ts → createClient-6689596e.d.ts} +10 -4
  24. package/dist/{createPublicClient-b732194e.d.ts → createPublicClient-fd558574.d.ts} +3 -3
  25. package/dist/{createTestClient-dedf321e.d.ts → createTestClient-bc1d9028.d.ts} +3 -3
  26. package/dist/{createWalletClient-75813d83.d.ts → createWalletClient-4df88244.d.ts} +3 -3
  27. package/dist/{decodeErrorResult-0b934d23.d.ts → decodeErrorResult-ac835649.d.ts} +2 -2
  28. package/dist/{eip1193-6f9ba163.d.ts → eip1193-617a05ae.d.ts} +2 -2
  29. package/dist/ens.d.ts +8 -8
  30. package/dist/ens.js +21 -21
  31. package/dist/ens.mjs +2 -2
  32. package/dist/{getAbiItem-c8e6e7d4.d.ts → getAbiItem-d2e8bd76.d.ts} +2 -2
  33. package/dist/index.d.ts +44 -21
  34. package/dist/index.js +54 -32
  35. package/dist/index.js.map +1 -1
  36. package/dist/index.mjs +43 -21
  37. package/dist/index.mjs.map +1 -1
  38. package/dist/public.d.ts +13 -12
  39. package/dist/public.js +3 -3
  40. package/dist/public.mjs +2 -2
  41. package/dist/{readContract-4f6e2692.d.ts → readContract-c460f23a.d.ts} +3 -3
  42. package/dist/{rpc-a5a7f376.d.ts → rpc-8c10fc98.d.ts} +3 -5
  43. package/dist/{sendTransaction-e713f90c.d.ts → sendTransaction-7ce442c0.d.ts} +3 -3
  44. package/dist/test.d.ts +4 -4
  45. package/dist/test.js +13 -13
  46. package/dist/test.mjs +1 -1
  47. package/dist/{transactionReceipt-2a86c7c7.d.ts → transactionReceipt-44dbf122.d.ts} +1 -1
  48. package/dist/{transactionRequest-c7794f5e.d.ts → transactionRequest-f437b4ba.d.ts} +1 -1
  49. package/dist/utils/index.d.ts +14 -11
  50. package/dist/utils/index.js +2 -2
  51. package/dist/utils/index.mjs +1 -1
  52. package/dist/wallet.d.ts +6 -6
  53. package/dist/wallet.js +3 -3
  54. package/dist/wallet.mjs +2 -2
  55. package/dist/{watchEvent-c346c12d.d.ts → watchEvent-569c9976.d.ts} +3 -3
  56. package/dist/window.d.ts +2 -2
  57. package/package.json +4 -4
  58. package/public/package.json +4 -0
  59. package/test/package.json +4 -0
  60. package/dist/chunk-2Y3UZMSP.mjs.map +0 -1
  61. package/dist/chunk-CD2XJOBJ.js.map +0 -1
  62. package/dist/chunk-KSAO4Y4Q.mjs.map +0 -1
  63. package/dist/chunk-THMRUG4D.js.map +0 -1
  64. package/src/_test/abis.ts +0 -1420
  65. package/src/_test/bench.ts +0 -15
  66. package/src/_test/constants.ts +0 -63
  67. package/src/_test/globalSetup.ts +0 -11
  68. package/src/_test/index.ts +0 -25
  69. package/src/_test/setup.ts +0 -8
  70. package/src/_test/utils.ts +0 -155
  71. package/src/actions/ens/getEnsAddress.bench.ts +0 -26
  72. package/src/actions/ens/getEnsAddress.test.ts +0 -97
  73. package/src/actions/ens/getEnsAddress.ts +0 -122
  74. package/src/actions/ens/getEnsName.bench.ts +0 -30
  75. package/src/actions/ens/getEnsName.test.ts +0 -101
  76. package/src/actions/ens/getEnsName.ts +0 -106
  77. package/src/actions/ens/index.test.ts +0 -12
  78. package/src/actions/ens/index.ts +0 -3
  79. package/src/actions/index.test.ts +0 -81
  80. package/src/actions/index.ts +0 -182
  81. package/src/actions/public/call.bench.ts +0 -48
  82. package/src/actions/public/call.test.ts +0 -99
  83. package/src/actions/public/call.ts +0 -97
  84. package/src/actions/public/createBlockFilter.bench.ts +0 -11
  85. package/src/actions/public/createBlockFilter.test.ts +0 -9
  86. package/src/actions/public/createBlockFilter.ts +0 -14
  87. package/src/actions/public/createContractEventFilter.test.ts +0 -119
  88. package/src/actions/public/createContractEventFilter.ts +0 -69
  89. package/src/actions/public/createEventFilter.test.ts +0 -277
  90. package/src/actions/public/createEventFilter.ts +0 -93
  91. package/src/actions/public/createPendingTransactionFilter.bench.ts +0 -11
  92. package/src/actions/public/createPendingTransactionFilter.test.ts +0 -9
  93. package/src/actions/public/createPendingTransactionFilter.ts +0 -14
  94. package/src/actions/public/estimateGas.bench.ts +0 -46
  95. package/src/actions/public/estimateGas.test.ts +0 -92
  96. package/src/actions/public/estimateGas.ts +0 -61
  97. package/src/actions/public/getBalance.test.ts +0 -83
  98. package/src/actions/public/getBalance.ts +0 -37
  99. package/src/actions/public/getBlock.bench.ts +0 -28
  100. package/src/actions/public/getBlock.test.ts +0 -575
  101. package/src/actions/public/getBlock.ts +0 -65
  102. package/src/actions/public/getBlockNumber.bench.ts +0 -28
  103. package/src/actions/public/getBlockNumber.test.ts +0 -27
  104. package/src/actions/public/getBlockNumber.ts +0 -32
  105. package/src/actions/public/getBlockTransactionCount.bench.ts +0 -15
  106. package/src/actions/public/getBlockTransactionCount.test.ts +0 -57
  107. package/src/actions/public/getBlockTransactionCount.ts +0 -52
  108. package/src/actions/public/getBytecode.test.ts +0 -27
  109. package/src/actions/public/getBytecode.ts +0 -32
  110. package/src/actions/public/getChainId.bench.ts +0 -15
  111. package/src/actions/public/getChainId.test.ts +0 -8
  112. package/src/actions/public/getChainId.ts +0 -7
  113. package/src/actions/public/getFeeHistory.bench.ts +0 -18
  114. package/src/actions/public/getFeeHistory.test.ts +0 -137
  115. package/src/actions/public/getFeeHistory.ts +0 -44
  116. package/src/actions/public/getFilterChanges.bench.ts +0 -13
  117. package/src/actions/public/getFilterChanges.test.ts +0 -383
  118. package/src/actions/public/getFilterChanges.ts +0 -23
  119. package/src/actions/public/getFilterLogs.test.ts +0 -297
  120. package/src/actions/public/getFilterLogs.ts +0 -20
  121. package/src/actions/public/getGasPrice.bench.ts +0 -19
  122. package/src/actions/public/getGasPrice.test.ts +0 -8
  123. package/src/actions/public/getGasPrice.ts +0 -15
  124. package/src/actions/public/getLogs.test.ts +0 -306
  125. package/src/actions/public/getLogs.ts +0 -84
  126. package/src/actions/public/getStorageAt.test.ts +0 -34
  127. package/src/actions/public/getStorageAt.ts +0 -32
  128. package/src/actions/public/getTransaction.bench.ts +0 -33
  129. package/src/actions/public/getTransaction.test.ts +0 -311
  130. package/src/actions/public/getTransaction.ts +0 -95
  131. package/src/actions/public/getTransactionConfirmations.test.ts +0 -69
  132. package/src/actions/public/getTransactionConfirmations.ts +0 -38
  133. package/src/actions/public/getTransactionCount.test.ts +0 -56
  134. package/src/actions/public/getTransactionCount.ts +0 -34
  135. package/src/actions/public/getTransactionReceipt.bench.ts +0 -33
  136. package/src/actions/public/getTransactionReceipt.test.ts +0 -179
  137. package/src/actions/public/getTransactionReceipt.ts +0 -34
  138. package/src/actions/public/index.test.ts +0 -43
  139. package/src/actions/public/index.ts +0 -146
  140. package/src/actions/public/multicall.test.ts +0 -452
  141. package/src/actions/public/multicall.ts +0 -108
  142. package/src/actions/public/readContract.test.ts +0 -328
  143. package/src/actions/public/readContract.ts +0 -73
  144. package/src/actions/public/simulateContract.bench.ts +0 -41
  145. package/src/actions/public/simulateContract.test.ts +0 -410
  146. package/src/actions/public/simulateContract.ts +0 -91
  147. package/src/actions/public/uninstallFilter.bench.ts +0 -13
  148. package/src/actions/public/uninstallFilter.test.ts +0 -65
  149. package/src/actions/public/uninstallFilter.ts +0 -17
  150. package/src/actions/public/waitForTransactionReceipt.test.ts +0 -322
  151. package/src/actions/public/waitForTransactionReceipt.ts +0 -170
  152. package/src/actions/public/watchBlockNumber.test.ts +0 -166
  153. package/src/actions/public/watchBlockNumber.ts +0 -79
  154. package/src/actions/public/watchBlocks.test.ts +0 -210
  155. package/src/actions/public/watchBlocks.ts +0 -114
  156. package/src/actions/public/watchContractEvent.test.ts +0 -305
  157. package/src/actions/public/watchContractEvent.ts +0 -108
  158. package/src/actions/public/watchEvent.test.ts +0 -195
  159. package/src/actions/public/watchEvent.ts +0 -95
  160. package/src/actions/public/watchPendingTransactions.test.ts +0 -116
  161. package/src/actions/public/watchPendingTransactions.ts +0 -74
  162. package/src/actions/test/dropTransaction.test.ts +0 -34
  163. package/src/actions/test/dropTransaction.ts +0 -17
  164. package/src/actions/test/getAutomine.test.ts +0 -14
  165. package/src/actions/test/getAutomine.ts +0 -11
  166. package/src/actions/test/getTxpoolContent.test.ts +0 -45
  167. package/src/actions/test/getTxpoolContent.ts +0 -7
  168. package/src/actions/test/getTxpoolStatus.test.ts +0 -41
  169. package/src/actions/test/getTxpoolStatus.ts +0 -12
  170. package/src/actions/test/impersonateAccount.test.ts +0 -26
  171. package/src/actions/test/impersonateAccount.ts +0 -17
  172. package/src/actions/test/increaseTime.test.ts +0 -18
  173. package/src/actions/test/increaseTime.ts +0 -17
  174. package/src/actions/test/index.test.ts +0 -38
  175. package/src/actions/test/index.ts +0 -77
  176. package/src/actions/test/inspectTxpool.test.ts +0 -50
  177. package/src/actions/test/inspectTxpool.ts +0 -7
  178. package/src/actions/test/mine.test.ts +0 -20
  179. package/src/actions/test/mine.ts +0 -16
  180. package/src/actions/test/removeBlockTimestampInterval.test.ts +0 -23
  181. package/src/actions/test/removeBlockTimestampInterval.ts +0 -7
  182. package/src/actions/test/reset.test.ts +0 -19
  183. package/src/actions/test/reset.ts +0 -18
  184. package/src/actions/test/revert.test.ts +0 -39
  185. package/src/actions/test/revert.ts +0 -14
  186. package/src/actions/test/sendUnsignedTransaction.test.ts +0 -52
  187. package/src/actions/test/sendUnsignedTransaction.ts +0 -19
  188. package/src/actions/test/setAutomine.test.ts +0 -14
  189. package/src/actions/test/setAutomine.ts +0 -8
  190. package/src/actions/test/setBalance.test.ts +0 -29
  191. package/src/actions/test/setBalance.ts +0 -20
  192. package/src/actions/test/setBlockGasLimit.test.ts +0 -21
  193. package/src/actions/test/setBlockGasLimit.ts +0 -17
  194. package/src/actions/test/setBlockTimestampInterval.test.ts +0 -23
  195. package/src/actions/test/setBlockTimestampInterval.ts +0 -16
  196. package/src/actions/test/setCode.test.ts +0 -26
  197. package/src/actions/test/setCode.ts +0 -19
  198. package/src/actions/test/setCoinbase.test.ts +0 -11
  199. package/src/actions/test/setCoinbase.ts +0 -17
  200. package/src/actions/test/setIntervalMining.test.ts +0 -30
  201. package/src/actions/test/setIntervalMining.ts +0 -16
  202. package/src/actions/test/setLoggingEnabled.test.ts +0 -10
  203. package/src/actions/test/setLoggingEnabled.ts +0 -8
  204. package/src/actions/test/setMinGasPrice.test.ts +0 -22
  205. package/src/actions/test/setMinGasPrice.ts +0 -17
  206. package/src/actions/test/setNextBlockBaseFeePerGas.test.ts +0 -23
  207. package/src/actions/test/setNextBlockBaseFeePerGas.ts +0 -17
  208. package/src/actions/test/setNextBlockTimestamp.test.ts +0 -19
  209. package/src/actions/test/setNextBlockTimestamp.ts +0 -17
  210. package/src/actions/test/setNonce.test.ts +0 -28
  211. package/src/actions/test/setNonce.ts +0 -20
  212. package/src/actions/test/setRpcUrl.test.ts +0 -9
  213. package/src/actions/test/setRpcUrl.ts +0 -8
  214. package/src/actions/test/setStorageAt.test.ts +0 -36
  215. package/src/actions/test/setStorageAt.ts +0 -26
  216. package/src/actions/test/snapshot.test.ts +0 -18
  217. package/src/actions/test/snapshot.ts +0 -7
  218. package/src/actions/test/stopImpersonatingAccount.test.ts +0 -29
  219. package/src/actions/test/stopImpersonatingAccount.ts +0 -17
  220. package/src/actions/wallet/addChain.test.ts +0 -14
  221. package/src/actions/wallet/addChain.ts +0 -21
  222. package/src/actions/wallet/deployContract.test.ts +0 -55
  223. package/src/actions/wallet/deployContract.ts +0 -38
  224. package/src/actions/wallet/getAccounts.test.ts +0 -22
  225. package/src/actions/wallet/getAccounts.ts +0 -7
  226. package/src/actions/wallet/getPermissions.test.ts +0 -24
  227. package/src/actions/wallet/getPermissions.ts +0 -9
  228. package/src/actions/wallet/index.test.ts +0 -21
  229. package/src/actions/wallet/index.ts +0 -36
  230. package/src/actions/wallet/requestAccounts.test.ts +0 -13
  231. package/src/actions/wallet/requestAccounts.ts +0 -7
  232. package/src/actions/wallet/requestPermissions.test.ts +0 -26
  233. package/src/actions/wallet/requestPermissions.ts +0 -19
  234. package/src/actions/wallet/sendTransaction.bench.ts +0 -57
  235. package/src/actions/wallet/sendTransaction.test.ts +0 -440
  236. package/src/actions/wallet/sendTransaction.ts +0 -77
  237. package/src/actions/wallet/signMessage.test.ts +0 -61
  238. package/src/actions/wallet/signMessage.ts +0 -35
  239. package/src/actions/wallet/switchChain.test.ts +0 -21
  240. package/src/actions/wallet/switchChain.ts +0 -19
  241. package/src/actions/wallet/watchAsset.test.ts +0 -40
  242. package/src/actions/wallet/watchAsset.ts +0 -16
  243. package/src/actions/wallet/writeContract.test.ts +0 -84
  244. package/src/actions/wallet/writeContract.ts +0 -47
  245. package/src/chains.test.ts +0 -439
  246. package/src/chains.ts +0 -99
  247. package/src/clients/createClient.test.ts +0 -295
  248. package/src/clients/createClient.ts +0 -81
  249. package/src/clients/createPublicClient.test.ts +0 -165
  250. package/src/clients/createPublicClient.ts +0 -49
  251. package/src/clients/createTestClient.test.ts +0 -145
  252. package/src/clients/createTestClient.ts +0 -72
  253. package/src/clients/createWalletClient.test.ts +0 -121
  254. package/src/clients/createWalletClient.ts +0 -54
  255. package/src/clients/index.test.ts +0 -19
  256. package/src/clients/index.ts +0 -31
  257. package/src/clients/transports/createTransport.test.ts +0 -58
  258. package/src/clients/transports/createTransport.ts +0 -48
  259. package/src/clients/transports/custom.test.ts +0 -98
  260. package/src/clients/transports/custom.ts +0 -34
  261. package/src/clients/transports/fallback.test.ts +0 -257
  262. package/src/clients/transports/fallback.ts +0 -50
  263. package/src/clients/transports/http.test.ts +0 -109
  264. package/src/clients/transports/http.ts +0 -51
  265. package/src/clients/transports/index.test.ts +0 -15
  266. package/src/clients/transports/index.ts +0 -17
  267. package/src/clients/transports/webSocket.test.ts +0 -164
  268. package/src/clients/transports/webSocket.ts +0 -118
  269. package/src/constants/abis.test.ts +0 -53
  270. package/src/constants/abis.ts +0 -44
  271. package/src/constants/index.test.ts +0 -14
  272. package/src/constants/index.ts +0 -3
  273. package/src/constants/solidity.test.ts +0 -41
  274. package/src/constants/solidity.ts +0 -35
  275. package/src/contract.test.ts +0 -31
  276. package/src/contract.ts +0 -68
  277. package/src/ens.test.ts +0 -15
  278. package/src/ens.ts +0 -8
  279. package/src/errors/abi.test.ts +0 -81
  280. package/src/errors/abi.ts +0 -254
  281. package/src/errors/address.test.ts +0 -14
  282. package/src/errors/address.ts +0 -9
  283. package/src/errors/base.test.ts +0 -114
  284. package/src/errors/base.ts +0 -57
  285. package/src/errors/block.test.ts +0 -24
  286. package/src/errors/block.ts +0 -18
  287. package/src/errors/chain.test.ts +0 -46
  288. package/src/errors/chain.ts +0 -33
  289. package/src/errors/contract.test.ts +0 -233
  290. package/src/errors/contract.ts +0 -178
  291. package/src/errors/data.ts +0 -20
  292. package/src/errors/encoding.ts +0 -60
  293. package/src/errors/index.ts +0 -82
  294. package/src/errors/log.ts +0 -8
  295. package/src/errors/request.test.ts +0 -330
  296. package/src/errors/request.ts +0 -163
  297. package/src/errors/rpc.test.ts +0 -87
  298. package/src/errors/rpc.ts +0 -113
  299. package/src/errors/transaction.test.ts +0 -83
  300. package/src/errors/transaction.ts +0 -54
  301. package/src/errors/transport.test.ts +0 -11
  302. package/src/errors/transport.ts +0 -12
  303. package/src/index.test.ts +0 -116
  304. package/src/index.ts +0 -132
  305. package/src/public.test.ts +0 -36
  306. package/src/public.ts +0 -76
  307. package/src/test.test.ts +0 -38
  308. package/src/test.ts +0 -52
  309. package/src/types/block.ts +0 -71
  310. package/src/types/chain.ts +0 -6
  311. package/src/types/contract.ts +0 -497
  312. package/src/types/eip1193.ts +0 -1041
  313. package/src/types/fee.ts +0 -47
  314. package/src/types/filter.ts +0 -8
  315. package/src/types/formatter.ts +0 -23
  316. package/src/types/index.ts +0 -84
  317. package/src/types/log.ts +0 -22
  318. package/src/types/misc.ts +0 -5
  319. package/src/types/multicall.ts +0 -82
  320. package/src/types/rpc.ts +0 -35
  321. package/src/types/transaction.ts +0 -145
  322. package/src/types/utils.ts +0 -88
  323. package/src/types/window.ts +0 -9
  324. package/src/utils/abi/decodeAbi.bench.ts +0 -135
  325. package/src/utils/abi/decodeAbi.test.ts +0 -1614
  326. package/src/utils/abi/decodeAbi.ts +0 -300
  327. package/src/utils/abi/decodeDeployData.test.ts +0 -151
  328. package/src/utils/abi/decodeDeployData.ts +0 -44
  329. package/src/utils/abi/decodeErrorResult.test.ts +0 -230
  330. package/src/utils/abi/decodeErrorResult.ts +0 -45
  331. package/src/utils/abi/decodeEventLog.test.ts +0 -542
  332. package/src/utils/abi/decodeEventLog.ts +0 -107
  333. package/src/utils/abi/decodeFunctionData.test.ts +0 -138
  334. package/src/utils/abi/decodeFunctionData.ts +0 -32
  335. package/src/utils/abi/decodeFunctionResult.test.ts +0 -333
  336. package/src/utils/abi/decodeFunctionResult.ts +0 -57
  337. package/src/utils/abi/encodeAbi.bench.ts +0 -163
  338. package/src/utils/abi/encodeAbi.test.ts +0 -1447
  339. package/src/utils/abi/encodeAbi.ts +0 -273
  340. package/src/utils/abi/encodeDeployData.test.ts +0 -124
  341. package/src/utils/abi/encodeDeployData.ts +0 -40
  342. package/src/utils/abi/encodeErrorResult.test.ts +0 -192
  343. package/src/utils/abi/encodeErrorResult.ts +0 -47
  344. package/src/utils/abi/encodeEventTopics.test.ts +0 -345
  345. package/src/utils/abi/encodeEventTopics.ts +0 -75
  346. package/src/utils/abi/encodeFunctionData.test.ts +0 -138
  347. package/src/utils/abi/encodeFunctionData.ts +0 -42
  348. package/src/utils/abi/encodeFunctionResult.test.ts +0 -279
  349. package/src/utils/abi/encodeFunctionResult.ts +0 -41
  350. package/src/utils/abi/formatAbiItem.test.ts +0 -335
  351. package/src/utils/abi/formatAbiItem.ts +0 -41
  352. package/src/utils/abi/formatAbiItemWithArgs.test.ts +0 -291
  353. package/src/utils/abi/formatAbiItemWithArgs.ts +0 -27
  354. package/src/utils/abi/getAbiItem.test.ts +0 -547
  355. package/src/utils/abi/getAbiItem.ts +0 -95
  356. package/src/utils/abi/index.test.ts +0 -24
  357. package/src/utils/abi/index.ts +0 -48
  358. package/src/utils/address/getAddress.bench.ts +0 -22
  359. package/src/utils/address/getAddress.test.ts +0 -46
  360. package/src/utils/address/getAddress.ts +0 -28
  361. package/src/utils/address/getContractAddress.bench.ts +0 -20
  362. package/src/utils/address/getContractAddress.test.ts +0 -78
  363. package/src/utils/address/getContractAddress.ts +0 -59
  364. package/src/utils/address/index.test.ts +0 -17
  365. package/src/utils/address/index.ts +0 -16
  366. package/src/utils/address/isAddress.test.ts +0 -10
  367. package/src/utils/address/isAddress.ts +0 -10
  368. package/src/utils/address/isAddressEqual.test.ts +0 -55
  369. package/src/utils/address/isAddressEqual.ts +0 -6
  370. package/src/utils/buildRequest.test.ts +0 -365
  371. package/src/utils/buildRequest.ts +0 -45
  372. package/src/utils/chain.test.ts +0 -43
  373. package/src/utils/chain.ts +0 -8
  374. package/src/utils/contract/extractFunctionParts.test.ts +0 -109
  375. package/src/utils/contract/extractFunctionParts.ts +0 -27
  376. package/src/utils/contract/getContractError.test.ts +0 -282
  377. package/src/utils/contract/getContractError.ts +0 -58
  378. package/src/utils/contract/index.test.ts +0 -15
  379. package/src/utils/contract/index.ts +0 -8
  380. package/src/utils/data/concat.test.ts +0 -35
  381. package/src/utils/data/concat.ts +0 -34
  382. package/src/utils/data/index.test.ts +0 -23
  383. package/src/utils/data/index.ts +0 -13
  384. package/src/utils/data/isBytes.test.ts +0 -9
  385. package/src/utils/data/isBytes.ts +0 -7
  386. package/src/utils/data/isHex.test.ts +0 -13
  387. package/src/utils/data/isHex.ts +0 -5
  388. package/src/utils/data/pad.bench.ts +0 -30
  389. package/src/utils/data/pad.test.ts +0 -367
  390. package/src/utils/data/pad.ts +0 -53
  391. package/src/utils/data/size.test.ts +0 -18
  392. package/src/utils/data/size.ts +0 -13
  393. package/src/utils/data/slice.test.ts +0 -203
  394. package/src/utils/data/slice.ts +0 -60
  395. package/src/utils/data/trim.bench.ts +0 -34
  396. package/src/utils/data/trim.test.ts +0 -175
  397. package/src/utils/data/trim.ts +0 -33
  398. package/src/utils/encoding/decodeBytes.bench.ts +0 -40
  399. package/src/utils/encoding/decodeBytes.test.ts +0 -144
  400. package/src/utils/encoding/decodeBytes.ts +0 -63
  401. package/src/utils/encoding/decodeHex.bench.ts +0 -24
  402. package/src/utils/encoding/decodeHex.test.ts +0 -167
  403. package/src/utils/encoding/decodeHex.ts +0 -76
  404. package/src/utils/encoding/decodeRlp.bench.ts +0 -34
  405. package/src/utils/encoding/decodeRlp.test.ts +0 -350
  406. package/src/utils/encoding/decodeRlp.ts +0 -121
  407. package/src/utils/encoding/encodeBytes.bench.ts +0 -29
  408. package/src/utils/encoding/encodeBytes.test.ts +0 -676
  409. package/src/utils/encoding/encodeBytes.ts +0 -59
  410. package/src/utils/encoding/encodeHex.bench.ts +0 -49
  411. package/src/utils/encoding/encodeHex.test.ts +0 -232
  412. package/src/utils/encoding/encodeHex.ts +0 -104
  413. package/src/utils/encoding/encodeRlp.bench.ts +0 -54
  414. package/src/utils/encoding/encodeRlp.test.ts +0 -254
  415. package/src/utils/encoding/encodeRlp.ts +0 -48
  416. package/src/utils/encoding/index.test.ts +0 -32
  417. package/src/utils/encoding/index.ts +0 -36
  418. package/src/utils/ens/index.test.ts +0 -14
  419. package/src/utils/ens/index.ts +0 -7
  420. package/src/utils/ens/labelhash.test.ts +0 -55
  421. package/src/utils/ens/labelhash.ts +0 -16
  422. package/src/utils/ens/namehash.test.ts +0 -65
  423. package/src/utils/ens/namehash.ts +0 -28
  424. package/src/utils/ens/normalize.bench.ts +0 -14
  425. package/src/utils/ens/normalize.test.ts +0 -35
  426. package/src/utils/ens/normalize.ts +0 -14
  427. package/src/utils/ens/packetToBytes.test.ts +0 -11
  428. package/src/utils/ens/packetToBytes.ts +0 -29
  429. package/src/utils/formatters/block.bench.ts +0 -51
  430. package/src/utils/formatters/block.test.ts +0 -115
  431. package/src/utils/formatters/block.ts +0 -37
  432. package/src/utils/formatters/extract.test.ts +0 -14
  433. package/src/utils/formatters/extract.ts +0 -18
  434. package/src/utils/formatters/feeHistory.test.ts +0 -66
  435. package/src/utils/formatters/feeHistory.ts +0 -12
  436. package/src/utils/formatters/format.test.ts +0 -93
  437. package/src/utils/formatters/format.ts +0 -90
  438. package/src/utils/formatters/index.test.ts +0 -27
  439. package/src/utils/formatters/index.ts +0 -34
  440. package/src/utils/formatters/log.test.ts +0 -79
  441. package/src/utils/formatters/log.ts +0 -12
  442. package/src/utils/formatters/transaction.test.ts +0 -271
  443. package/src/utils/formatters/transaction.ts +0 -63
  444. package/src/utils/formatters/transactionReceipt.bench.ts +0 -73
  445. package/src/utils/formatters/transactionReceipt.test.ts +0 -151
  446. package/src/utils/formatters/transactionReceipt.ts +0 -63
  447. package/src/utils/formatters/transactionRequest.bench.ts +0 -29
  448. package/src/utils/formatters/transactionRequest.test.ts +0 -237
  449. package/src/utils/formatters/transactionRequest.ts +0 -56
  450. package/src/utils/hash/getEventSignature.test.ts +0 -61
  451. package/src/utils/hash/getEventSignature.ts +0 -4
  452. package/src/utils/hash/getFunctionSignature.test.ts +0 -22
  453. package/src/utils/hash/getFunctionSignature.ts +0 -5
  454. package/src/utils/hash/hashFunction.test.ts +0 -65
  455. package/src/utils/hash/hashFunction.ts +0 -12
  456. package/src/utils/hash/index.test.ts +0 -13
  457. package/src/utils/hash/index.ts +0 -5
  458. package/src/utils/hash/keccak256.test.ts +0 -59
  459. package/src/utils/hash/keccak256.ts +0 -21
  460. package/src/utils/index.test.ts +0 -111
  461. package/src/utils/index.ts +0 -142
  462. package/src/utils/observe.test.ts +0 -176
  463. package/src/utils/observe.ts +0 -66
  464. package/src/utils/poll.test.ts +0 -127
  465. package/src/utils/poll.ts +0 -42
  466. package/src/utils/promise/index.test.ts +0 -14
  467. package/src/utils/promise/index.ts +0 -3
  468. package/src/utils/promise/withCache.test.ts +0 -97
  469. package/src/utils/promise/withCache.ts +0 -73
  470. package/src/utils/promise/withRetry.test.ts +0 -231
  471. package/src/utils/promise/withRetry.ts +0 -61
  472. package/src/utils/promise/withTimeout.test.ts +0 -37
  473. package/src/utils/promise/withTimeout.ts +0 -39
  474. package/src/utils/rpc.test.ts +0 -990
  475. package/src/utils/rpc.ts +0 -294
  476. package/src/utils/stringify.test.ts +0 -13
  477. package/src/utils/stringify.ts +0 -5
  478. package/src/utils/uid.ts +0 -14
  479. package/src/utils/unit/constants.test.ts +0 -22
  480. package/src/utils/unit/constants.ts +0 -12
  481. package/src/utils/unit/formatEther.test.ts +0 -75
  482. package/src/utils/unit/formatEther.ts +0 -6
  483. package/src/utils/unit/formatGwei.test.ts +0 -32
  484. package/src/utils/unit/formatGwei.ts +0 -6
  485. package/src/utils/unit/formatUnit.bench.ts +0 -21
  486. package/src/utils/unit/formatUnit.test.ts +0 -40
  487. package/src/utils/unit/formatUnit.ts +0 -16
  488. package/src/utils/unit/index.test.ts +0 -28
  489. package/src/utils/unit/index.ts +0 -7
  490. package/src/utils/unit/parseEther.test.ts +0 -126
  491. package/src/utils/unit/parseEther.ts +0 -6
  492. package/src/utils/unit/parseGwei.test.ts +0 -50
  493. package/src/utils/unit/parseGwei.ts +0 -6
  494. package/src/utils/unit/parseUnit.bench.ts +0 -21
  495. package/src/utils/unit/parseUnit.test.ts +0 -54
  496. package/src/utils/unit/parseUnit.ts +0 -27
  497. package/src/utils/wait.ts +0 -3
  498. package/src/wallet.test.ts +0 -19
  499. package/src/wallet.ts +0 -23
  500. package/src/window.ts +0 -1
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/clients/transports/createTransport.ts","../src/clients/transports/custom.ts","../src/clients/transports/fallback.ts","../src/clients/transports/http.ts","../src/clients/transports/webSocket.ts","../src/utils/uid.ts","../src/clients/createClient.ts","../src/clients/createPublicClient.ts","../src/clients/createTestClient.ts","../src/clients/createWalletClient.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Chain } from '../../types'\nimport type { Requests } from '../../types/eip1193'\n\nexport type BaseRpcRequests = {\n request(...args: any): Promise<any>\n}\n\nexport type TransportConfig<\n TType extends string = string,\n TRequests extends BaseRpcRequests['request'] = Requests['request'],\n> = {\n /** The name of the transport. */\n name: string\n /** The key of the transport. */\n key: string\n /** The JSON-RPC request function that matches the EIP-1193 request spec. */\n request: TRequests\n /** The type of the transport. */\n type: TType\n}\n\nexport type Transport<\n TType extends string = string,\n TRpcAttributes = Record<string, any>,\n> = <TChain extends Chain = Chain>({\n chain,\n}: {\n chain?: TChain\n}) => {\n config: TransportConfig<TType>\n value?: TRpcAttributes\n}\n\n/**\n * @description Creates an transport intended to be used with a client.\n */\nexport function createTransport<\n TType extends string = string,\n TRpcAttributes = any,\n>(\n config: TransportConfig<TType>,\n value?: TRpcAttributes,\n): ReturnType<Transport<TType, TRpcAttributes>> {\n return {\n config,\n value,\n }\n}\n","import type {\n BaseRpcRequests,\n Transport,\n TransportConfig,\n} from './createTransport'\nimport { createTransport } from './createTransport'\n\ntype EthereumProvider = { request: BaseRpcRequests['request'] }\n\nexport type CustomTransportConfig = {\n /** The key of the transport. */\n key?: TransportConfig['key']\n /** The name of the transport. */\n name?: TransportConfig['name']\n}\n\nexport type CustomTransport = Transport<'custom', EthereumProvider['request']>\n\n/**\n * @description Creates a custom transport given an EIP-1193 compliant `request` attribute.\n */\nexport function custom<TProvider extends EthereumProvider>(\n /** An Ethereum provider with an EIP-1193 \"request\" attribute. */\n provider: TProvider,\n { key = 'custom', name = 'Custom Provider' }: CustomTransportConfig = {},\n): CustomTransport {\n return () =>\n createTransport({\n key,\n name,\n request: provider.request.bind(provider),\n type: 'custom',\n })\n}\n","import { HttpRequestError, RpcError } from '../../errors'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\nexport type FallbackTransportConfig = {\n /** The key of the Fallback transport. */\n key?: TransportConfig['key']\n /** The name of the Fallback transport. */\n name?: TransportConfig['name']\n}\n\nexport type FallbackTransport = Transport<\n 'fallback',\n { transports: Transport[] }\n>\n\nexport function fallback(\n transports: Transport[],\n { key = 'fallback', name = 'Fallback' }: FallbackTransportConfig = {},\n): FallbackTransport {\n return ({ chain }) =>\n createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const fetch = async (i: number = 0): Promise<any> => {\n const transport = transports[i]({ chain })\n try {\n return await transport.config.request({\n method,\n params,\n } as any)\n } catch (err) {\n if (!(err instanceof RpcError) && i < transports.length - 1)\n return fetch(i + 1)\n throw err\n }\n }\n return fetch()\n },\n type: 'fallback',\n },\n {\n transports: transports.map(\n (fn) => fn({ chain }) as unknown as Transport,\n ),\n },\n )\n}\n","import { UrlRequiredError } from '../../errors'\nimport { rpc } from '../../utils/rpc'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\nexport type HttpTransportConfig = {\n /** The key of the HTTP transport. */\n key?: TransportConfig['key']\n /** The name of the HTTP transport. */\n name?: TransportConfig['name']\n}\n\nexport type HttpTransport = Transport<\n 'http',\n {\n url?: string\n }\n>\n\n/**\n * @description Creates a HTTP transport that connects to a JSON-RPC API.\n */\nexport function http(\n /** URL of the JSON-RPC API. Defaults to the chain's public RPC URL. */\n url?: string,\n { key = 'http', name = 'HTTP JSON-RPC' }: HttpTransportConfig = {},\n): HttpTransport {\n return ({ chain }) => {\n const url_ = url || chain?.rpcUrls.default.http[0]\n if (!url_) throw new UrlRequiredError()\n return createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const { result } = await rpc.http(url_, {\n body: {\n method,\n params,\n },\n })\n return result\n },\n type: 'http',\n },\n {\n url,\n },\n )\n }\n}\n","import WebSocket from 'isomorphic-ws'\nimport { UrlRequiredError } from '../../errors'\nimport type { Hash } from '../../types'\nimport type { RpcResponse } from '../../utils/rpc'\nimport { getSocket, rpc } from '../../utils/rpc'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\ntype WebSocketTransportSubscribeArgs = {\n onData: (data: RpcResponse) => void\n onError?: (error: any) => void\n}\n\ntype WebSocketTransportSubscribeResponse = {\n subscriptionId: Hash\n unsubscribe: () => Promise<RpcResponse<boolean>>\n}\n\ntype WebSocketTransportSubscribe = {\n subscribe(\n args: WebSocketTransportSubscribeArgs & {\n /**\n * @description Add information about compiled contracts\n * @link https://hardhat.org/hardhat-network/docs/reference#hardhat_addcompilationresult\n */\n params: ['newHeads']\n },\n ): Promise<WebSocketTransportSubscribeResponse>\n}\n\nexport type WebSocketTransportConfig = {\n /** The key of the WebSocket transport. */\n key?: TransportConfig['key']\n /** The name of the WebSocket transport. */\n name?: TransportConfig['name']\n}\n\nexport type WebSocketTransport = Transport<\n 'webSocket',\n {\n getSocket(): Promise<WebSocket>\n subscribe: WebSocketTransportSubscribe['subscribe']\n }\n>\n\n/**\n * @description Creates a WebSocket transport that connects to a JSON-RPC API.\n */\nexport function webSocket(\n /** URL of the JSON-RPC API. Defaults to the chain's public RPC URL. */\n url?: string,\n {\n key = 'webSocket',\n name = 'WebSocket JSON-RPC',\n }: WebSocketTransportConfig = {},\n): WebSocketTransport {\n return ({ chain }) => {\n const url_ = url || chain?.rpcUrls.default.webSocket?.[0]\n if (!url_) throw new UrlRequiredError()\n return createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const socket = await getSocket(url_)\n const { result } = await rpc.webSocketAsync(socket, {\n body: { method, params },\n })\n return result\n },\n type: 'webSocket',\n },\n {\n getSocket() {\n return getSocket(url_)\n },\n async subscribe({ params, onData, onError }: any) {\n const socket = await getSocket(url_)\n const { result: subscriptionId } = await new Promise<any>(\n (resolve, reject) =>\n rpc.webSocket(socket, {\n body: {\n method: 'eth_subscribe',\n params,\n },\n onData: (data) => {\n if (typeof data.id === 'number') {\n resolve(data)\n return\n }\n onData(data)\n },\n onError: (error) => {\n reject(error)\n onError?.(error)\n },\n }),\n )\n return {\n subscriptionId,\n async unsubscribe() {\n return new Promise<any>((resolve, reject) =>\n rpc.webSocket(socket, {\n body: {\n method: 'eth_unsubscribe',\n params: [subscriptionId],\n },\n onData: resolve,\n onError: reject,\n }),\n )\n },\n }\n },\n },\n )\n }\n}\n","let size = 256\nlet index = size\nlet buffer: string\n\nexport function uid(length = 11) {\n if (!buffer || index + length > size * 2) {\n buffer = ''\n index = 0\n for (let i = 0; i < size; i++) {\n buffer += ((256 + Math.random() * 256) | 0).toString(16).substring(1)\n }\n }\n return buffer.substring(index, index++ + length)\n}\n","import { Chain } from '../types'\nimport type { Requests } from '../types/eip1193'\nimport { buildRequest } from '../utils/buildRequest'\nimport { uid } from '../utils/uid'\nimport type { BaseRpcRequests, Transport } from './transports/createTransport'\n\nexport type Client<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TRequests extends BaseRpcRequests = Requests,\n> = {\n /** Chain for the client. */\n chain?: TChain\n /** A key for the client. */\n key: string\n /** A name for the client. */\n name: string\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval: number\n /** Request function wrapped with friendly error handling */\n request: TRequests['request']\n /** The RPC transport (http, webSocket, custom, etc) */\n transport: ReturnType<TTransport>['config'] & ReturnType<TTransport>['value']\n /** The type of client. */\n type: string\n /** A unique ID for the client. */\n uid: string\n}\n\nexport type ClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TRequests extends BaseRpcRequests = Requests,\n> = Partial<\n Pick<\n Client<TTransport, TChain, TRequests>,\n 'chain' | 'key' | 'name' | 'pollingInterval' | 'type'\n >\n> & {\n transport: TTransport\n}\n\n/**\n * @description Creates a base RPC client with the given transport.\n *\n * - Intended to be used as a base for other RPC clients.\n * - Has access to _all_ EIP-1474 RPC methods.\n *\n * @example\n * import { mainnet } from 'viem/chains'\n * import { createClient, http } from 'viem/clients'\n * const client = createClient(http({ chain: mainnet }))\n */\nexport function createClient<\n TTransport extends Transport,\n TChain extends Chain,\n TRequests extends BaseRpcRequests,\n>({\n chain,\n key = 'base',\n name = 'Base Client',\n pollingInterval = 4_000,\n transport,\n type = 'base',\n}: ClientConfig<TTransport, TChain, TRequests>): Client<\n TTransport,\n TChain,\n TRequests\n> {\n const { config, value } = transport({ chain })\n return {\n chain,\n key,\n name,\n pollingInterval,\n request: buildRequest(config.request),\n transport: { ...config, ...value },\n type,\n uid: uid(),\n }\n}\n","import type { PublicRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\nexport type PublicClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Pick<\n ClientConfig<TTransport, TChain>,\n 'chain' | 'key' | 'name' | 'pollingInterval' | 'transport'\n>\n\nexport type PublicClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Client<TTransport, TChain, PublicRequests>\n\n/**\n * @description Creates a public client with a given transport.\n *\n * - Only has access to \"public\" EIP-1474 RPC methods (ie. `eth_blockNumber`, etc).\n *\n * @example\n * import { mainnet } from 'viem/chains'\n * import { createPublicClient, http } from 'viem/clients'\n * const client = createPublicClient(http({ chain: mainnet }))\n */\nexport function createPublicClient<\n TTransport extends Transport,\n TChain extends Chain,\n>({\n chain,\n key = 'public',\n name = 'Public Client',\n transport,\n pollingInterval,\n}: PublicClientConfig<TTransport, TChain>): PublicClient<TTransport, TChain> {\n chain\n return createClient({\n chain,\n key,\n name,\n pollingInterval,\n transport,\n type: 'publicClient',\n })\n}\n","import type { TestRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\ntype TestClientModes = 'anvil' | 'hardhat'\n\nexport type TestClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TMode extends TestClientModes = TestClientModes,\n> = {\n chain?: ClientConfig<TTransport, TChain>['chain']\n /** The key of the client. */\n key?: ClientConfig['key']\n /** Mode of the test client. Available: \"anvil\" | \"hardhat\" */\n mode: TMode\n /** The name of the client. */\n name?: ClientConfig['name']\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval?: ClientConfig['pollingInterval']\n transport: ClientConfig<TTransport, TChain>['transport']\n}\n\nexport type TestClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TMode extends TestClientModes = TestClientModes,\n> = Client<TTransport, TChain, TestRequests<TMode>> & {\n mode: TMode\n}\n\n/**\n * @description Creates a test client with a given transport.\n *\n * - Only has access to \"test\" RPC methods (ie. `anvil_setBalance`,\n * `evm_mine`, etc).\n *\n * @example\n * import { createTestClient, http } from 'viem'\n * import { local } from 'viem/chains'\n * const client = createTestClient({ chain: local, mode: 'anvil', transport: http() })\n */\nexport function createTestClient<\n TTransport extends Transport,\n TChain extends Chain,\n TMode extends TestClientModes,\n>({\n chain,\n key = 'test',\n name = 'Test Client',\n mode,\n pollingInterval,\n transport,\n}: TestClientConfig<TTransport, TChain, TMode>): TestClient<\n TTransport,\n TChain,\n TMode\n> {\n return {\n ...createClient({\n chain,\n key,\n name,\n pollingInterval,\n transport,\n type: 'testClient',\n }),\n mode,\n }\n}\n","import type { SignableRequests, WalletRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\nexport type WalletClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = {\n chain?: ClientConfig<TTransport, TChain>['chain']\n /** The key of the Wallet Client. */\n key?: ClientConfig['key']\n /** The name of the Wallet Client. */\n name?: ClientConfig['name']\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval?: ClientConfig['pollingInterval']\n transport: ClientConfig<TTransport, TChain>['transport']\n}\n\nexport type WalletClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Client<TTransport, TChain, SignableRequests & WalletRequests>\n\n/**\n * @description Creates a wallet client with a given transport.\n *\n * - Only has access to \"wallet\" & \"signable\" EIP-1474 RPC methods\n * (ie. `eth_sendTransaction`, `eth_requestAccounts`, etc).\n *\n * @example\n * import { createWalletClient, custom } from 'viem'\n * const client = createWalletClient(\n * custom(window.ethereum)\n * )\n */\nexport function createWalletClient<\n TTransport extends Transport,\n TChain extends Chain,\n>({\n transport,\n key = 'wallet',\n name = 'Wallet Client',\n pollingInterval,\n}: WalletClientConfig<TTransport, TChain>): WalletClient<TTransport, TChain> {\n return createClient({\n key,\n name,\n pollingInterval,\n transport,\n type: 'walletClient',\n })\n}\n"]}
1
+ {"version":3,"sources":["../src/clients/transports/createTransport.ts","../src/clients/transports/custom.ts","../src/clients/transports/fallback.ts","../src/clients/transports/http.ts","../src/clients/transports/webSocket.ts","../src/utils/uid.ts","../src/clients/createClient.ts","../src/clients/createPublicClient.ts","../src/clients/createTestClient.ts","../src/clients/createWalletClient.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Chain } from '../../types'\nimport type { Requests } from '../../types/eip1193'\nimport { buildRequest } from '../../utils'\n\nexport type BaseRpcRequests = {\n request(...args: any): Promise<any>\n}\n\nexport type TransportConfig<\n TType extends string = string,\n TRequests extends BaseRpcRequests['request'] = Requests['request'],\n> = {\n /** The name of the transport. */\n name: string\n /** The key of the transport. */\n key: string\n /** The JSON-RPC request function that matches the EIP-1193 request spec. */\n request: TRequests\n /** The base delay (in ms) between retries. */\n retryDelay?: number\n /** The max number of times to retry. */\n retryCount?: number\n /** The type of the transport. */\n type: TType\n}\n\nexport type Transport<\n TType extends string = string,\n TRpcAttributes = Record<string, any>,\n TRequests extends BaseRpcRequests['request'] = Requests['request'],\n> = <TChain extends Chain = Chain>({\n chain,\n}: {\n chain?: TChain\n retryCount?: TransportConfig['retryCount']\n}) => {\n config: TransportConfig<TType>\n request: TRequests\n value?: TRpcAttributes\n}\n\n/**\n * @description Creates an transport intended to be used with a client.\n */\nexport function createTransport<\n TType extends string = string,\n TRpcAttributes = any,\n>(\n {\n key,\n name,\n request,\n retryCount = 3,\n retryDelay = 150,\n type,\n }: TransportConfig<TType>,\n value?: TRpcAttributes,\n): ReturnType<Transport<TType, TRpcAttributes>> {\n return {\n config: { key, name, request, retryCount, retryDelay, type },\n request: buildRequest(request, { retryCount, retryDelay }),\n value,\n }\n}\n","import type {\n BaseRpcRequests,\n Transport,\n TransportConfig,\n} from './createTransport'\nimport { createTransport } from './createTransport'\n\ntype EthereumProvider = { request: BaseRpcRequests['request'] }\n\nexport type CustomTransportConfig = {\n /** The key of the transport. */\n key?: TransportConfig['key']\n /** The name of the transport. */\n name?: TransportConfig['name']\n /** The max number of times to retry. */\n retryCount?: TransportConfig['retryCount']\n /** The base delay (in ms) between retries. */\n retryDelay?: TransportConfig['retryDelay']\n}\n\nexport type CustomTransport = Transport<'custom', EthereumProvider['request']>\n\n/**\n * @description Creates a custom transport given an EIP-1193 compliant `request` attribute.\n */\nexport function custom<TProvider extends EthereumProvider>(\n /** An Ethereum provider with an EIP-1193 \"request\" attribute. */\n provider: TProvider,\n config: CustomTransportConfig = {},\n): CustomTransport {\n const { key = 'custom', name = 'Custom Provider', retryDelay } = config\n return ({ retryCount: defaultRetryCount }) =>\n createTransport({\n key,\n name,\n request: provider.request.bind(provider),\n retryCount: config.retryCount ?? defaultRetryCount,\n retryDelay,\n type: 'custom',\n })\n}\n","import { isDeterministicError } from '../../utils/buildRequest'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\nexport type FallbackTransportConfig = {\n /** The key of the Fallback transport. */\n key?: TransportConfig['key']\n /** The name of the Fallback transport. */\n name?: TransportConfig['name']\n /** The max number of times to retry. */\n retryCount?: TransportConfig['retryCount']\n /** The base delay (in ms) between retries. */\n retryDelay?: TransportConfig['retryDelay']\n}\n\nexport type FallbackTransport = Transport<\n 'fallback',\n { transports: Transport[] }\n>\n\nexport function fallback(\n transports: Transport[],\n config: FallbackTransportConfig = {},\n): FallbackTransport {\n const { key = 'fallback', name = 'Fallback', retryCount, retryDelay } = config\n return ({ chain }) =>\n createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const fetch = async (i: number = 0): Promise<any> => {\n const transport = transports[i]({ chain, retryCount: 0 })\n try {\n return await transport.request({\n method,\n params,\n } as any)\n } catch (err) {\n // If the error is deterministic, we don't need to fall back.\n // So throw the error.\n if (isDeterministicError(err as Error)) throw err\n\n // If we've reached the end of the fallbacks, throw the error.\n if (i === transports.length - 1) throw err\n\n // Otherwise, try the next fallback.\n return fetch(i + 1)\n }\n }\n return fetch()\n },\n retryCount,\n retryDelay,\n type: 'fallback',\n },\n {\n transports: transports.map(\n (fn) => fn({ chain, retryCount: 0 }) as unknown as Transport,\n ),\n },\n )\n}\n","import { UrlRequiredError } from '../../errors'\nimport { rpc } from '../../utils/rpc'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\nexport type HttpTransportConfig = {\n /** The key of the HTTP transport. */\n key?: TransportConfig['key']\n /** The name of the HTTP transport. */\n name?: TransportConfig['name']\n /** The max number of times to retry. */\n retryCount?: TransportConfig['retryCount']\n /** The base delay (in ms) between retries. */\n retryDelay?: TransportConfig['retryDelay']\n}\n\nexport type HttpTransport = Transport<\n 'http',\n {\n url?: string\n }\n>\n\n/**\n * @description Creates a HTTP transport that connects to a JSON-RPC API.\n */\nexport function http(\n /** URL of the JSON-RPC API. Defaults to the chain's public RPC URL. */\n url?: string,\n config: HttpTransportConfig = {},\n): HttpTransport {\n const { key = 'http', name = 'HTTP JSON-RPC', retryDelay } = config\n return ({ chain, retryCount: defaultRetryCount }) => {\n const retryCount = config.retryCount ?? defaultRetryCount\n const url_ = url || chain?.rpcUrls.default.http[0]\n if (!url_) throw new UrlRequiredError()\n return createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const { result } = await rpc.http(url_, {\n body: {\n method,\n params,\n },\n })\n return result\n },\n retryCount,\n retryDelay,\n type: 'http',\n },\n {\n url,\n },\n )\n }\n}\n","import WebSocket from 'isomorphic-ws'\nimport { UrlRequiredError } from '../../errors'\nimport type { Hash } from '../../types'\nimport type { RpcResponse } from '../../utils/rpc'\nimport { getSocket, rpc } from '../../utils/rpc'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\ntype WebSocketTransportSubscribeArgs = {\n onData: (data: RpcResponse) => void\n onError?: (error: any) => void\n}\n\ntype WebSocketTransportSubscribeResponse = {\n subscriptionId: Hash\n unsubscribe: () => Promise<RpcResponse<boolean>>\n}\n\ntype WebSocketTransportSubscribe = {\n subscribe(\n args: WebSocketTransportSubscribeArgs & {\n /**\n * @description Add information about compiled contracts\n * @link https://hardhat.org/hardhat-network/docs/reference#hardhat_addcompilationresult\n */\n params: ['newHeads']\n },\n ): Promise<WebSocketTransportSubscribeResponse>\n}\n\nexport type WebSocketTransportConfig = {\n /** The key of the WebSocket transport. */\n key?: TransportConfig['key']\n /** The name of the WebSocket transport. */\n name?: TransportConfig['name']\n /** The max number of times to retry. */\n retryCount?: TransportConfig['retryCount']\n /** The base delay (in ms) between retries. */\n retryDelay?: TransportConfig['retryDelay']\n}\n\nexport type WebSocketTransport = Transport<\n 'webSocket',\n {\n getSocket(): Promise<WebSocket>\n subscribe: WebSocketTransportSubscribe['subscribe']\n }\n>\n\n/**\n * @description Creates a WebSocket transport that connects to a JSON-RPC API.\n */\nexport function webSocket(\n /** URL of the JSON-RPC API. Defaults to the chain's public RPC URL. */\n url?: string,\n config: WebSocketTransportConfig = {},\n): WebSocketTransport {\n const { key = 'webSocket', name = 'WebSocket JSON-RPC', retryDelay } = config\n return ({ chain, retryCount: defaultRetryCount }) => {\n const retryCount = config.retryCount ?? defaultRetryCount\n const url_ = url || chain?.rpcUrls.default.webSocket?.[0]\n if (!url_) throw new UrlRequiredError()\n return createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const socket = await getSocket(url_)\n const { result } = await rpc.webSocketAsync(socket, {\n body: { method, params },\n })\n return result\n },\n retryCount,\n retryDelay,\n type: 'webSocket',\n },\n {\n getSocket() {\n return getSocket(url_)\n },\n async subscribe({ params, onData, onError }: any) {\n const socket = await getSocket(url_)\n const { result: subscriptionId } = await new Promise<any>(\n (resolve, reject) =>\n rpc.webSocket(socket, {\n body: {\n method: 'eth_subscribe',\n params,\n },\n onData: (data) => {\n if (typeof data.id === 'number') {\n resolve(data)\n return\n }\n onData(data)\n },\n onError: (error) => {\n reject(error)\n onError?.(error)\n },\n }),\n )\n return {\n subscriptionId,\n async unsubscribe() {\n return new Promise<any>((resolve, reject) =>\n rpc.webSocket(socket, {\n body: {\n method: 'eth_unsubscribe',\n params: [subscriptionId],\n },\n onData: resolve,\n onError: reject,\n }),\n )\n },\n }\n },\n },\n )\n }\n}\n","let size = 256\nlet index = size\nlet buffer: string\n\nexport function uid(length = 11) {\n if (!buffer || index + length > size * 2) {\n buffer = ''\n index = 0\n for (let i = 0; i < size; i++) {\n buffer += ((256 + Math.random() * 256) | 0).toString(16).substring(1)\n }\n }\n return buffer.substring(index, index++ + length)\n}\n","import { Chain } from '../types'\nimport type { Requests } from '../types/eip1193'\nimport { buildRequest } from '../utils/buildRequest'\nimport { uid } from '../utils/uid'\nimport type { BaseRpcRequests, Transport } from './transports/createTransport'\n\nexport type Client<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TRequests extends BaseRpcRequests = Requests,\n> = {\n /** Chain for the client. */\n chain?: TChain\n /** A key for the client. */\n key: string\n /** A name for the client. */\n name: string\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval: number\n /** Request function wrapped with friendly error handling */\n request: TRequests['request']\n /** The RPC transport (http, webSocket, custom, etc) */\n transport: ReturnType<TTransport>['config'] & ReturnType<TTransport>['value']\n /** The type of client. */\n type: string\n /** A unique ID for the client. */\n uid: string\n}\n\nexport type ClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TRequests extends BaseRpcRequests = Requests,\n> = Partial<\n Pick<\n Client<TTransport, TChain, TRequests>,\n 'chain' | 'key' | 'name' | 'pollingInterval' | 'type'\n >\n> & {\n transport: TTransport\n}\n\n/**\n * @description Creates a base RPC client with the given transport.\n *\n * - Intended to be used as a base for other RPC clients.\n * - Has access to _all_ EIP-1474 RPC methods.\n *\n * @example\n * import { mainnet } from 'viem/chains'\n * import { createClient, http } from 'viem/clients'\n * const client = createClient(http({ chain: mainnet }))\n */\nexport function createClient<\n TTransport extends Transport,\n TChain extends Chain,\n TRequests extends BaseRpcRequests,\n>({\n chain,\n key = 'base',\n name = 'Base Client',\n pollingInterval = 4_000,\n transport,\n type = 'base',\n}: ClientConfig<TTransport, TChain, TRequests>): Client<\n TTransport,\n TChain,\n TRequests\n> {\n const { config, request, value } = transport({ chain })\n return {\n chain,\n key,\n name,\n pollingInterval,\n request,\n transport: { ...config, ...value },\n type,\n uid: uid(),\n }\n}\n","import type { PublicRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\nexport type PublicClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Pick<\n ClientConfig<TTransport, TChain>,\n 'chain' | 'key' | 'name' | 'pollingInterval' | 'transport'\n>\n\nexport type PublicClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Client<TTransport, TChain, PublicRequests>\n\n/**\n * @description Creates a public client with a given transport.\n *\n * - Only has access to \"public\" EIP-1474 RPC methods (ie. `eth_blockNumber`, etc).\n *\n * @example\n * import { mainnet } from 'viem/chains'\n * import { createPublicClient, http } from 'viem/clients'\n * const client = createPublicClient(http({ chain: mainnet }))\n */\nexport function createPublicClient<\n TTransport extends Transport,\n TChain extends Chain,\n>({\n chain,\n key = 'public',\n name = 'Public Client',\n transport,\n pollingInterval,\n}: PublicClientConfig<TTransport, TChain>): PublicClient<TTransport, TChain> {\n chain\n return createClient({\n chain,\n key,\n name,\n pollingInterval,\n transport,\n type: 'publicClient',\n })\n}\n","import type { TestRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\ntype TestClientModes = 'anvil' | 'hardhat'\n\nexport type TestClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TMode extends TestClientModes = TestClientModes,\n> = {\n chain?: ClientConfig<TTransport, TChain>['chain']\n /** The key of the client. */\n key?: ClientConfig['key']\n /** Mode of the test client. Available: \"anvil\" | \"hardhat\" */\n mode: TMode\n /** The name of the client. */\n name?: ClientConfig['name']\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval?: ClientConfig['pollingInterval']\n transport: ClientConfig<TTransport, TChain>['transport']\n}\n\nexport type TestClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TMode extends TestClientModes = TestClientModes,\n> = Client<TTransport, TChain, TestRequests<TMode>> & {\n mode: TMode\n}\n\n/**\n * @description Creates a test client with a given transport.\n *\n * - Only has access to \"test\" RPC methods (ie. `anvil_setBalance`,\n * `evm_mine`, etc).\n *\n * @example\n * import { createTestClient, http } from 'viem'\n * import { local } from 'viem/chains'\n * const client = createTestClient({ chain: local, mode: 'anvil', transport: http() })\n */\nexport function createTestClient<\n TTransport extends Transport,\n TChain extends Chain,\n TMode extends TestClientModes,\n>({\n chain,\n key = 'test',\n name = 'Test Client',\n mode,\n pollingInterval,\n transport,\n}: TestClientConfig<TTransport, TChain, TMode>): TestClient<\n TTransport,\n TChain,\n TMode\n> {\n return {\n ...createClient({\n chain,\n key,\n name,\n pollingInterval,\n transport,\n type: 'testClient',\n }),\n mode,\n }\n}\n","import type { SignableRequests, WalletRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\nexport type WalletClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = {\n chain?: ClientConfig<TTransport, TChain>['chain']\n /** The key of the Wallet Client. */\n key?: ClientConfig['key']\n /** The name of the Wallet Client. */\n name?: ClientConfig['name']\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval?: ClientConfig['pollingInterval']\n transport: ClientConfig<TTransport, TChain>['transport']\n}\n\nexport type WalletClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Client<TTransport, TChain, SignableRequests & WalletRequests>\n\n/**\n * @description Creates a wallet client with a given transport.\n *\n * - Only has access to \"wallet\" & \"signable\" EIP-1474 RPC methods\n * (ie. `eth_sendTransaction`, `eth_requestAccounts`, etc).\n *\n * @example\n * import { createWalletClient, custom } from 'viem'\n * const client = createWalletClient(\n * custom(window.ethereum)\n * )\n */\nexport function createWalletClient<\n TTransport extends Transport,\n TChain extends Chain,\n>({\n transport,\n key = 'wallet',\n name = 'Wallet Client',\n pollingInterval,\n}: WalletClientConfig<TTransport, TChain>): WalletClient<TTransport, TChain> {\n return createClient({\n key,\n name,\n pollingInterval,\n transport,\n type: 'walletClient',\n })\n}\n"]}
package/dist/index.mjs CHANGED
@@ -55,63 +55,82 @@ import {
55
55
  WebSocketRequestError,
56
56
  buildRequest,
57
57
  getSocket,
58
+ isDeterministicError,
58
59
  multicall3Abi,
59
60
  rpc
60
- } from "./chunk-KSAO4Y4Q.mjs";
61
+ } from "./chunk-PRG3BBPZ.mjs";
61
62
 
62
63
  // src/clients/transports/createTransport.ts
63
- function createTransport(config, value) {
64
+ function createTransport({
65
+ key,
66
+ name,
67
+ request,
68
+ retryCount = 3,
69
+ retryDelay = 150,
70
+ type
71
+ }, value) {
64
72
  return {
65
- config,
73
+ config: { key, name, request, retryCount, retryDelay, type },
74
+ request: buildRequest(request, { retryCount, retryDelay }),
66
75
  value
67
76
  };
68
77
  }
69
78
 
70
79
  // src/clients/transports/custom.ts
71
- function custom(provider, { key = "custom", name = "Custom Provider" } = {}) {
72
- return () => createTransport({
80
+ function custom(provider, config = {}) {
81
+ const { key = "custom", name = "Custom Provider", retryDelay } = config;
82
+ return ({ retryCount: defaultRetryCount }) => createTransport({
73
83
  key,
74
84
  name,
75
85
  request: provider.request.bind(provider),
86
+ retryCount: config.retryCount ?? defaultRetryCount,
87
+ retryDelay,
76
88
  type: "custom"
77
89
  });
78
90
  }
79
91
 
80
92
  // src/clients/transports/fallback.ts
81
- function fallback(transports, { key = "fallback", name = "Fallback" } = {}) {
93
+ function fallback(transports, config = {}) {
94
+ const { key = "fallback", name = "Fallback", retryCount, retryDelay } = config;
82
95
  return ({ chain }) => createTransport(
83
96
  {
84
97
  key,
85
98
  name,
86
99
  async request({ method, params }) {
87
100
  const fetch = async (i = 0) => {
88
- const transport = transports[i]({ chain });
101
+ const transport = transports[i]({ chain, retryCount: 0 });
89
102
  try {
90
- return await transport.config.request({
103
+ return await transport.request({
91
104
  method,
92
105
  params
93
106
  });
94
107
  } catch (err) {
95
- if (!(err instanceof RpcError) && i < transports.length - 1)
96
- return fetch(i + 1);
97
- throw err;
108
+ if (isDeterministicError(err))
109
+ throw err;
110
+ if (i === transports.length - 1)
111
+ throw err;
112
+ return fetch(i + 1);
98
113
  }
99
114
  };
100
115
  return fetch();
101
116
  },
117
+ retryCount,
118
+ retryDelay,
102
119
  type: "fallback"
103
120
  },
104
121
  {
105
122
  transports: transports.map(
106
- (fn) => fn({ chain })
123
+ (fn) => fn({ chain, retryCount: 0 })
107
124
  )
108
125
  }
109
126
  );
110
127
  }
111
128
 
112
129
  // src/clients/transports/http.ts
113
- function http(url, { key = "http", name = "HTTP JSON-RPC" } = {}) {
114
- return ({ chain }) => {
130
+ function http(url, config = {}) {
131
+ const { key = "http", name = "HTTP JSON-RPC", retryDelay } = config;
132
+ return ({ chain, retryCount: defaultRetryCount }) => {
133
+ const retryCount = config.retryCount ?? defaultRetryCount;
115
134
  const url_ = url || chain?.rpcUrls.default.http[0];
116
135
  if (!url_)
117
136
  throw new UrlRequiredError();
@@ -128,6 +147,8 @@ function http(url, { key = "http", name = "HTTP JSON-RPC" } = {}) {
128
147
  });
129
148
  return result;
130
149
  },
150
+ retryCount,
151
+ retryDelay,
131
152
  type: "http"
132
153
  },
133
154
  {
@@ -138,11 +159,10 @@ function http(url, { key = "http", name = "HTTP JSON-RPC" } = {}) {
138
159
  }
139
160
 
140
161
  // src/clients/transports/webSocket.ts
141
- function webSocket(url, {
142
- key = "webSocket",
143
- name = "WebSocket JSON-RPC"
144
- } = {}) {
145
- return ({ chain }) => {
162
+ function webSocket(url, config = {}) {
163
+ const { key = "webSocket", name = "WebSocket JSON-RPC", retryDelay } = config;
164
+ return ({ chain, retryCount: defaultRetryCount }) => {
165
+ const retryCount = config.retryCount ?? defaultRetryCount;
146
166
  const url_ = url || chain?.rpcUrls.default.webSocket?.[0];
147
167
  if (!url_)
148
168
  throw new UrlRequiredError();
@@ -157,6 +177,8 @@ function webSocket(url, {
157
177
  });
158
178
  return result;
159
179
  },
180
+ retryCount,
181
+ retryDelay,
160
182
  type: "webSocket"
161
183
  },
162
184
  {
@@ -229,13 +251,13 @@ function createClient({
229
251
  transport,
230
252
  type = "base"
231
253
  }) {
232
- const { config, value } = transport({ chain });
254
+ const { config, request, value } = transport({ chain });
233
255
  return {
234
256
  chain,
235
257
  key,
236
258
  name,
237
259
  pollingInterval,
238
- request: buildRequest(config.request),
260
+ request,
239
261
  transport: { ...config, ...value },
240
262
  type,
241
263
  uid: uid()
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/clients/transports/createTransport.ts","../src/clients/transports/custom.ts","../src/clients/transports/fallback.ts","../src/clients/transports/http.ts","../src/clients/transports/webSocket.ts","../src/utils/uid.ts","../src/clients/createClient.ts","../src/clients/createPublicClient.ts","../src/clients/createTestClient.ts","../src/clients/createWalletClient.ts"],"sourcesContent":["import type { Chain } from '../../types'\nimport type { Requests } from '../../types/eip1193'\n\nexport type BaseRpcRequests = {\n request(...args: any): Promise<any>\n}\n\nexport type TransportConfig<\n TType extends string = string,\n TRequests extends BaseRpcRequests['request'] = Requests['request'],\n> = {\n /** The name of the transport. */\n name: string\n /** The key of the transport. */\n key: string\n /** The JSON-RPC request function that matches the EIP-1193 request spec. */\n request: TRequests\n /** The type of the transport. */\n type: TType\n}\n\nexport type Transport<\n TType extends string = string,\n TRpcAttributes = Record<string, any>,\n> = <TChain extends Chain = Chain>({\n chain,\n}: {\n chain?: TChain\n}) => {\n config: TransportConfig<TType>\n value?: TRpcAttributes\n}\n\n/**\n * @description Creates an transport intended to be used with a client.\n */\nexport function createTransport<\n TType extends string = string,\n TRpcAttributes = any,\n>(\n config: TransportConfig<TType>,\n value?: TRpcAttributes,\n): ReturnType<Transport<TType, TRpcAttributes>> {\n return {\n config,\n value,\n }\n}\n","import type {\n BaseRpcRequests,\n Transport,\n TransportConfig,\n} from './createTransport'\nimport { createTransport } from './createTransport'\n\ntype EthereumProvider = { request: BaseRpcRequests['request'] }\n\nexport type CustomTransportConfig = {\n /** The key of the transport. */\n key?: TransportConfig['key']\n /** The name of the transport. */\n name?: TransportConfig['name']\n}\n\nexport type CustomTransport = Transport<'custom', EthereumProvider['request']>\n\n/**\n * @description Creates a custom transport given an EIP-1193 compliant `request` attribute.\n */\nexport function custom<TProvider extends EthereumProvider>(\n /** An Ethereum provider with an EIP-1193 \"request\" attribute. */\n provider: TProvider,\n { key = 'custom', name = 'Custom Provider' }: CustomTransportConfig = {},\n): CustomTransport {\n return () =>\n createTransport({\n key,\n name,\n request: provider.request.bind(provider),\n type: 'custom',\n })\n}\n","import { HttpRequestError, RpcError } from '../../errors'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\nexport type FallbackTransportConfig = {\n /** The key of the Fallback transport. */\n key?: TransportConfig['key']\n /** The name of the Fallback transport. */\n name?: TransportConfig['name']\n}\n\nexport type FallbackTransport = Transport<\n 'fallback',\n { transports: Transport[] }\n>\n\nexport function fallback(\n transports: Transport[],\n { key = 'fallback', name = 'Fallback' }: FallbackTransportConfig = {},\n): FallbackTransport {\n return ({ chain }) =>\n createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const fetch = async (i: number = 0): Promise<any> => {\n const transport = transports[i]({ chain })\n try {\n return await transport.config.request({\n method,\n params,\n } as any)\n } catch (err) {\n if (!(err instanceof RpcError) && i < transports.length - 1)\n return fetch(i + 1)\n throw err\n }\n }\n return fetch()\n },\n type: 'fallback',\n },\n {\n transports: transports.map(\n (fn) => fn({ chain }) as unknown as Transport,\n ),\n },\n )\n}\n","import { UrlRequiredError } from '../../errors'\nimport { rpc } from '../../utils/rpc'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\nexport type HttpTransportConfig = {\n /** The key of the HTTP transport. */\n key?: TransportConfig['key']\n /** The name of the HTTP transport. */\n name?: TransportConfig['name']\n}\n\nexport type HttpTransport = Transport<\n 'http',\n {\n url?: string\n }\n>\n\n/**\n * @description Creates a HTTP transport that connects to a JSON-RPC API.\n */\nexport function http(\n /** URL of the JSON-RPC API. Defaults to the chain's public RPC URL. */\n url?: string,\n { key = 'http', name = 'HTTP JSON-RPC' }: HttpTransportConfig = {},\n): HttpTransport {\n return ({ chain }) => {\n const url_ = url || chain?.rpcUrls.default.http[0]\n if (!url_) throw new UrlRequiredError()\n return createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const { result } = await rpc.http(url_, {\n body: {\n method,\n params,\n },\n })\n return result\n },\n type: 'http',\n },\n {\n url,\n },\n )\n }\n}\n","import WebSocket from 'isomorphic-ws'\nimport { UrlRequiredError } from '../../errors'\nimport type { Hash } from '../../types'\nimport type { RpcResponse } from '../../utils/rpc'\nimport { getSocket, rpc } from '../../utils/rpc'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\ntype WebSocketTransportSubscribeArgs = {\n onData: (data: RpcResponse) => void\n onError?: (error: any) => void\n}\n\ntype WebSocketTransportSubscribeResponse = {\n subscriptionId: Hash\n unsubscribe: () => Promise<RpcResponse<boolean>>\n}\n\ntype WebSocketTransportSubscribe = {\n subscribe(\n args: WebSocketTransportSubscribeArgs & {\n /**\n * @description Add information about compiled contracts\n * @link https://hardhat.org/hardhat-network/docs/reference#hardhat_addcompilationresult\n */\n params: ['newHeads']\n },\n ): Promise<WebSocketTransportSubscribeResponse>\n}\n\nexport type WebSocketTransportConfig = {\n /** The key of the WebSocket transport. */\n key?: TransportConfig['key']\n /** The name of the WebSocket transport. */\n name?: TransportConfig['name']\n}\n\nexport type WebSocketTransport = Transport<\n 'webSocket',\n {\n getSocket(): Promise<WebSocket>\n subscribe: WebSocketTransportSubscribe['subscribe']\n }\n>\n\n/**\n * @description Creates a WebSocket transport that connects to a JSON-RPC API.\n */\nexport function webSocket(\n /** URL of the JSON-RPC API. Defaults to the chain's public RPC URL. */\n url?: string,\n {\n key = 'webSocket',\n name = 'WebSocket JSON-RPC',\n }: WebSocketTransportConfig = {},\n): WebSocketTransport {\n return ({ chain }) => {\n const url_ = url || chain?.rpcUrls.default.webSocket?.[0]\n if (!url_) throw new UrlRequiredError()\n return createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const socket = await getSocket(url_)\n const { result } = await rpc.webSocketAsync(socket, {\n body: { method, params },\n })\n return result\n },\n type: 'webSocket',\n },\n {\n getSocket() {\n return getSocket(url_)\n },\n async subscribe({ params, onData, onError }: any) {\n const socket = await getSocket(url_)\n const { result: subscriptionId } = await new Promise<any>(\n (resolve, reject) =>\n rpc.webSocket(socket, {\n body: {\n method: 'eth_subscribe',\n params,\n },\n onData: (data) => {\n if (typeof data.id === 'number') {\n resolve(data)\n return\n }\n onData(data)\n },\n onError: (error) => {\n reject(error)\n onError?.(error)\n },\n }),\n )\n return {\n subscriptionId,\n async unsubscribe() {\n return new Promise<any>((resolve, reject) =>\n rpc.webSocket(socket, {\n body: {\n method: 'eth_unsubscribe',\n params: [subscriptionId],\n },\n onData: resolve,\n onError: reject,\n }),\n )\n },\n }\n },\n },\n )\n }\n}\n","let size = 256\nlet index = size\nlet buffer: string\n\nexport function uid(length = 11) {\n if (!buffer || index + length > size * 2) {\n buffer = ''\n index = 0\n for (let i = 0; i < size; i++) {\n buffer += ((256 + Math.random() * 256) | 0).toString(16).substring(1)\n }\n }\n return buffer.substring(index, index++ + length)\n}\n","import { Chain } from '../types'\nimport type { Requests } from '../types/eip1193'\nimport { buildRequest } from '../utils/buildRequest'\nimport { uid } from '../utils/uid'\nimport type { BaseRpcRequests, Transport } from './transports/createTransport'\n\nexport type Client<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TRequests extends BaseRpcRequests = Requests,\n> = {\n /** Chain for the client. */\n chain?: TChain\n /** A key for the client. */\n key: string\n /** A name for the client. */\n name: string\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval: number\n /** Request function wrapped with friendly error handling */\n request: TRequests['request']\n /** The RPC transport (http, webSocket, custom, etc) */\n transport: ReturnType<TTransport>['config'] & ReturnType<TTransport>['value']\n /** The type of client. */\n type: string\n /** A unique ID for the client. */\n uid: string\n}\n\nexport type ClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TRequests extends BaseRpcRequests = Requests,\n> = Partial<\n Pick<\n Client<TTransport, TChain, TRequests>,\n 'chain' | 'key' | 'name' | 'pollingInterval' | 'type'\n >\n> & {\n transport: TTransport\n}\n\n/**\n * @description Creates a base RPC client with the given transport.\n *\n * - Intended to be used as a base for other RPC clients.\n * - Has access to _all_ EIP-1474 RPC methods.\n *\n * @example\n * import { mainnet } from 'viem/chains'\n * import { createClient, http } from 'viem/clients'\n * const client = createClient(http({ chain: mainnet }))\n */\nexport function createClient<\n TTransport extends Transport,\n TChain extends Chain,\n TRequests extends BaseRpcRequests,\n>({\n chain,\n key = 'base',\n name = 'Base Client',\n pollingInterval = 4_000,\n transport,\n type = 'base',\n}: ClientConfig<TTransport, TChain, TRequests>): Client<\n TTransport,\n TChain,\n TRequests\n> {\n const { config, value } = transport({ chain })\n return {\n chain,\n key,\n name,\n pollingInterval,\n request: buildRequest(config.request),\n transport: { ...config, ...value },\n type,\n uid: uid(),\n }\n}\n","import type { PublicRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\nexport type PublicClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Pick<\n ClientConfig<TTransport, TChain>,\n 'chain' | 'key' | 'name' | 'pollingInterval' | 'transport'\n>\n\nexport type PublicClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Client<TTransport, TChain, PublicRequests>\n\n/**\n * @description Creates a public client with a given transport.\n *\n * - Only has access to \"public\" EIP-1474 RPC methods (ie. `eth_blockNumber`, etc).\n *\n * @example\n * import { mainnet } from 'viem/chains'\n * import { createPublicClient, http } from 'viem/clients'\n * const client = createPublicClient(http({ chain: mainnet }))\n */\nexport function createPublicClient<\n TTransport extends Transport,\n TChain extends Chain,\n>({\n chain,\n key = 'public',\n name = 'Public Client',\n transport,\n pollingInterval,\n}: PublicClientConfig<TTransport, TChain>): PublicClient<TTransport, TChain> {\n chain\n return createClient({\n chain,\n key,\n name,\n pollingInterval,\n transport,\n type: 'publicClient',\n })\n}\n","import type { TestRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\ntype TestClientModes = 'anvil' | 'hardhat'\n\nexport type TestClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TMode extends TestClientModes = TestClientModes,\n> = {\n chain?: ClientConfig<TTransport, TChain>['chain']\n /** The key of the client. */\n key?: ClientConfig['key']\n /** Mode of the test client. Available: \"anvil\" | \"hardhat\" */\n mode: TMode\n /** The name of the client. */\n name?: ClientConfig['name']\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval?: ClientConfig['pollingInterval']\n transport: ClientConfig<TTransport, TChain>['transport']\n}\n\nexport type TestClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TMode extends TestClientModes = TestClientModes,\n> = Client<TTransport, TChain, TestRequests<TMode>> & {\n mode: TMode\n}\n\n/**\n * @description Creates a test client with a given transport.\n *\n * - Only has access to \"test\" RPC methods (ie. `anvil_setBalance`,\n * `evm_mine`, etc).\n *\n * @example\n * import { createTestClient, http } from 'viem'\n * import { local } from 'viem/chains'\n * const client = createTestClient({ chain: local, mode: 'anvil', transport: http() })\n */\nexport function createTestClient<\n TTransport extends Transport,\n TChain extends Chain,\n TMode extends TestClientModes,\n>({\n chain,\n key = 'test',\n name = 'Test Client',\n mode,\n pollingInterval,\n transport,\n}: TestClientConfig<TTransport, TChain, TMode>): TestClient<\n TTransport,\n TChain,\n TMode\n> {\n return {\n ...createClient({\n chain,\n key,\n name,\n pollingInterval,\n transport,\n type: 'testClient',\n }),\n mode,\n }\n}\n","import type { SignableRequests, WalletRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\nexport type WalletClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = {\n chain?: ClientConfig<TTransport, TChain>['chain']\n /** The key of the Wallet Client. */\n key?: ClientConfig['key']\n /** The name of the Wallet Client. */\n name?: ClientConfig['name']\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval?: ClientConfig['pollingInterval']\n transport: ClientConfig<TTransport, TChain>['transport']\n}\n\nexport type WalletClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Client<TTransport, TChain, SignableRequests & WalletRequests>\n\n/**\n * @description Creates a wallet client with a given transport.\n *\n * - Only has access to \"wallet\" & \"signable\" EIP-1474 RPC methods\n * (ie. `eth_sendTransaction`, `eth_requestAccounts`, etc).\n *\n * @example\n * import { createWalletClient, custom } from 'viem'\n * const client = createWalletClient(\n * custom(window.ethereum)\n * )\n */\nexport function createWalletClient<\n TTransport extends Transport,\n TChain extends Chain,\n>({\n transport,\n key = 'wallet',\n name = 'Wallet Client',\n pollingInterval,\n}: WalletClientConfig<TTransport, TChain>): WalletClient<TTransport, TChain> {\n return createClient({\n key,\n name,\n pollingInterval,\n transport,\n type: 'walletClient',\n })\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/clients/transports/createTransport.ts","../src/clients/transports/custom.ts","../src/clients/transports/fallback.ts","../src/clients/transports/http.ts","../src/clients/transports/webSocket.ts","../src/utils/uid.ts","../src/clients/createClient.ts","../src/clients/createPublicClient.ts","../src/clients/createTestClient.ts","../src/clients/createWalletClient.ts"],"sourcesContent":["import type { Chain } from '../../types'\nimport type { Requests } from '../../types/eip1193'\nimport { buildRequest } from '../../utils'\n\nexport type BaseRpcRequests = {\n request(...args: any): Promise<any>\n}\n\nexport type TransportConfig<\n TType extends string = string,\n TRequests extends BaseRpcRequests['request'] = Requests['request'],\n> = {\n /** The name of the transport. */\n name: string\n /** The key of the transport. */\n key: string\n /** The JSON-RPC request function that matches the EIP-1193 request spec. */\n request: TRequests\n /** The base delay (in ms) between retries. */\n retryDelay?: number\n /** The max number of times to retry. */\n retryCount?: number\n /** The type of the transport. */\n type: TType\n}\n\nexport type Transport<\n TType extends string = string,\n TRpcAttributes = Record<string, any>,\n TRequests extends BaseRpcRequests['request'] = Requests['request'],\n> = <TChain extends Chain = Chain>({\n chain,\n}: {\n chain?: TChain\n retryCount?: TransportConfig['retryCount']\n}) => {\n config: TransportConfig<TType>\n request: TRequests\n value?: TRpcAttributes\n}\n\n/**\n * @description Creates an transport intended to be used with a client.\n */\nexport function createTransport<\n TType extends string = string,\n TRpcAttributes = any,\n>(\n {\n key,\n name,\n request,\n retryCount = 3,\n retryDelay = 150,\n type,\n }: TransportConfig<TType>,\n value?: TRpcAttributes,\n): ReturnType<Transport<TType, TRpcAttributes>> {\n return {\n config: { key, name, request, retryCount, retryDelay, type },\n request: buildRequest(request, { retryCount, retryDelay }),\n value,\n }\n}\n","import type {\n BaseRpcRequests,\n Transport,\n TransportConfig,\n} from './createTransport'\nimport { createTransport } from './createTransport'\n\ntype EthereumProvider = { request: BaseRpcRequests['request'] }\n\nexport type CustomTransportConfig = {\n /** The key of the transport. */\n key?: TransportConfig['key']\n /** The name of the transport. */\n name?: TransportConfig['name']\n /** The max number of times to retry. */\n retryCount?: TransportConfig['retryCount']\n /** The base delay (in ms) between retries. */\n retryDelay?: TransportConfig['retryDelay']\n}\n\nexport type CustomTransport = Transport<'custom', EthereumProvider['request']>\n\n/**\n * @description Creates a custom transport given an EIP-1193 compliant `request` attribute.\n */\nexport function custom<TProvider extends EthereumProvider>(\n /** An Ethereum provider with an EIP-1193 \"request\" attribute. */\n provider: TProvider,\n config: CustomTransportConfig = {},\n): CustomTransport {\n const { key = 'custom', name = 'Custom Provider', retryDelay } = config\n return ({ retryCount: defaultRetryCount }) =>\n createTransport({\n key,\n name,\n request: provider.request.bind(provider),\n retryCount: config.retryCount ?? defaultRetryCount,\n retryDelay,\n type: 'custom',\n })\n}\n","import { isDeterministicError } from '../../utils/buildRequest'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\nexport type FallbackTransportConfig = {\n /** The key of the Fallback transport. */\n key?: TransportConfig['key']\n /** The name of the Fallback transport. */\n name?: TransportConfig['name']\n /** The max number of times to retry. */\n retryCount?: TransportConfig['retryCount']\n /** The base delay (in ms) between retries. */\n retryDelay?: TransportConfig['retryDelay']\n}\n\nexport type FallbackTransport = Transport<\n 'fallback',\n { transports: Transport[] }\n>\n\nexport function fallback(\n transports: Transport[],\n config: FallbackTransportConfig = {},\n): FallbackTransport {\n const { key = 'fallback', name = 'Fallback', retryCount, retryDelay } = config\n return ({ chain }) =>\n createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const fetch = async (i: number = 0): Promise<any> => {\n const transport = transports[i]({ chain, retryCount: 0 })\n try {\n return await transport.request({\n method,\n params,\n } as any)\n } catch (err) {\n // If the error is deterministic, we don't need to fall back.\n // So throw the error.\n if (isDeterministicError(err as Error)) throw err\n\n // If we've reached the end of the fallbacks, throw the error.\n if (i === transports.length - 1) throw err\n\n // Otherwise, try the next fallback.\n return fetch(i + 1)\n }\n }\n return fetch()\n },\n retryCount,\n retryDelay,\n type: 'fallback',\n },\n {\n transports: transports.map(\n (fn) => fn({ chain, retryCount: 0 }) as unknown as Transport,\n ),\n },\n )\n}\n","import { UrlRequiredError } from '../../errors'\nimport { rpc } from '../../utils/rpc'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\nexport type HttpTransportConfig = {\n /** The key of the HTTP transport. */\n key?: TransportConfig['key']\n /** The name of the HTTP transport. */\n name?: TransportConfig['name']\n /** The max number of times to retry. */\n retryCount?: TransportConfig['retryCount']\n /** The base delay (in ms) between retries. */\n retryDelay?: TransportConfig['retryDelay']\n}\n\nexport type HttpTransport = Transport<\n 'http',\n {\n url?: string\n }\n>\n\n/**\n * @description Creates a HTTP transport that connects to a JSON-RPC API.\n */\nexport function http(\n /** URL of the JSON-RPC API. Defaults to the chain's public RPC URL. */\n url?: string,\n config: HttpTransportConfig = {},\n): HttpTransport {\n const { key = 'http', name = 'HTTP JSON-RPC', retryDelay } = config\n return ({ chain, retryCount: defaultRetryCount }) => {\n const retryCount = config.retryCount ?? defaultRetryCount\n const url_ = url || chain?.rpcUrls.default.http[0]\n if (!url_) throw new UrlRequiredError()\n return createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const { result } = await rpc.http(url_, {\n body: {\n method,\n params,\n },\n })\n return result\n },\n retryCount,\n retryDelay,\n type: 'http',\n },\n {\n url,\n },\n )\n }\n}\n","import WebSocket from 'isomorphic-ws'\nimport { UrlRequiredError } from '../../errors'\nimport type { Hash } from '../../types'\nimport type { RpcResponse } from '../../utils/rpc'\nimport { getSocket, rpc } from '../../utils/rpc'\nimport type { Transport, TransportConfig } from './createTransport'\nimport { createTransport } from './createTransport'\n\ntype WebSocketTransportSubscribeArgs = {\n onData: (data: RpcResponse) => void\n onError?: (error: any) => void\n}\n\ntype WebSocketTransportSubscribeResponse = {\n subscriptionId: Hash\n unsubscribe: () => Promise<RpcResponse<boolean>>\n}\n\ntype WebSocketTransportSubscribe = {\n subscribe(\n args: WebSocketTransportSubscribeArgs & {\n /**\n * @description Add information about compiled contracts\n * @link https://hardhat.org/hardhat-network/docs/reference#hardhat_addcompilationresult\n */\n params: ['newHeads']\n },\n ): Promise<WebSocketTransportSubscribeResponse>\n}\n\nexport type WebSocketTransportConfig = {\n /** The key of the WebSocket transport. */\n key?: TransportConfig['key']\n /** The name of the WebSocket transport. */\n name?: TransportConfig['name']\n /** The max number of times to retry. */\n retryCount?: TransportConfig['retryCount']\n /** The base delay (in ms) between retries. */\n retryDelay?: TransportConfig['retryDelay']\n}\n\nexport type WebSocketTransport = Transport<\n 'webSocket',\n {\n getSocket(): Promise<WebSocket>\n subscribe: WebSocketTransportSubscribe['subscribe']\n }\n>\n\n/**\n * @description Creates a WebSocket transport that connects to a JSON-RPC API.\n */\nexport function webSocket(\n /** URL of the JSON-RPC API. Defaults to the chain's public RPC URL. */\n url?: string,\n config: WebSocketTransportConfig = {},\n): WebSocketTransport {\n const { key = 'webSocket', name = 'WebSocket JSON-RPC', retryDelay } = config\n return ({ chain, retryCount: defaultRetryCount }) => {\n const retryCount = config.retryCount ?? defaultRetryCount\n const url_ = url || chain?.rpcUrls.default.webSocket?.[0]\n if (!url_) throw new UrlRequiredError()\n return createTransport(\n {\n key,\n name,\n async request({ method, params }) {\n const socket = await getSocket(url_)\n const { result } = await rpc.webSocketAsync(socket, {\n body: { method, params },\n })\n return result\n },\n retryCount,\n retryDelay,\n type: 'webSocket',\n },\n {\n getSocket() {\n return getSocket(url_)\n },\n async subscribe({ params, onData, onError }: any) {\n const socket = await getSocket(url_)\n const { result: subscriptionId } = await new Promise<any>(\n (resolve, reject) =>\n rpc.webSocket(socket, {\n body: {\n method: 'eth_subscribe',\n params,\n },\n onData: (data) => {\n if (typeof data.id === 'number') {\n resolve(data)\n return\n }\n onData(data)\n },\n onError: (error) => {\n reject(error)\n onError?.(error)\n },\n }),\n )\n return {\n subscriptionId,\n async unsubscribe() {\n return new Promise<any>((resolve, reject) =>\n rpc.webSocket(socket, {\n body: {\n method: 'eth_unsubscribe',\n params: [subscriptionId],\n },\n onData: resolve,\n onError: reject,\n }),\n )\n },\n }\n },\n },\n )\n }\n}\n","let size = 256\nlet index = size\nlet buffer: string\n\nexport function uid(length = 11) {\n if (!buffer || index + length > size * 2) {\n buffer = ''\n index = 0\n for (let i = 0; i < size; i++) {\n buffer += ((256 + Math.random() * 256) | 0).toString(16).substring(1)\n }\n }\n return buffer.substring(index, index++ + length)\n}\n","import { Chain } from '../types'\nimport type { Requests } from '../types/eip1193'\nimport { buildRequest } from '../utils/buildRequest'\nimport { uid } from '../utils/uid'\nimport type { BaseRpcRequests, Transport } from './transports/createTransport'\n\nexport type Client<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TRequests extends BaseRpcRequests = Requests,\n> = {\n /** Chain for the client. */\n chain?: TChain\n /** A key for the client. */\n key: string\n /** A name for the client. */\n name: string\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval: number\n /** Request function wrapped with friendly error handling */\n request: TRequests['request']\n /** The RPC transport (http, webSocket, custom, etc) */\n transport: ReturnType<TTransport>['config'] & ReturnType<TTransport>['value']\n /** The type of client. */\n type: string\n /** A unique ID for the client. */\n uid: string\n}\n\nexport type ClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TRequests extends BaseRpcRequests = Requests,\n> = Partial<\n Pick<\n Client<TTransport, TChain, TRequests>,\n 'chain' | 'key' | 'name' | 'pollingInterval' | 'type'\n >\n> & {\n transport: TTransport\n}\n\n/**\n * @description Creates a base RPC client with the given transport.\n *\n * - Intended to be used as a base for other RPC clients.\n * - Has access to _all_ EIP-1474 RPC methods.\n *\n * @example\n * import { mainnet } from 'viem/chains'\n * import { createClient, http } from 'viem/clients'\n * const client = createClient(http({ chain: mainnet }))\n */\nexport function createClient<\n TTransport extends Transport,\n TChain extends Chain,\n TRequests extends BaseRpcRequests,\n>({\n chain,\n key = 'base',\n name = 'Base Client',\n pollingInterval = 4_000,\n transport,\n type = 'base',\n}: ClientConfig<TTransport, TChain, TRequests>): Client<\n TTransport,\n TChain,\n TRequests\n> {\n const { config, request, value } = transport({ chain })\n return {\n chain,\n key,\n name,\n pollingInterval,\n request,\n transport: { ...config, ...value },\n type,\n uid: uid(),\n }\n}\n","import type { PublicRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\nexport type PublicClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Pick<\n ClientConfig<TTransport, TChain>,\n 'chain' | 'key' | 'name' | 'pollingInterval' | 'transport'\n>\n\nexport type PublicClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Client<TTransport, TChain, PublicRequests>\n\n/**\n * @description Creates a public client with a given transport.\n *\n * - Only has access to \"public\" EIP-1474 RPC methods (ie. `eth_blockNumber`, etc).\n *\n * @example\n * import { mainnet } from 'viem/chains'\n * import { createPublicClient, http } from 'viem/clients'\n * const client = createPublicClient(http({ chain: mainnet }))\n */\nexport function createPublicClient<\n TTransport extends Transport,\n TChain extends Chain,\n>({\n chain,\n key = 'public',\n name = 'Public Client',\n transport,\n pollingInterval,\n}: PublicClientConfig<TTransport, TChain>): PublicClient<TTransport, TChain> {\n chain\n return createClient({\n chain,\n key,\n name,\n pollingInterval,\n transport,\n type: 'publicClient',\n })\n}\n","import type { TestRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\ntype TestClientModes = 'anvil' | 'hardhat'\n\nexport type TestClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TMode extends TestClientModes = TestClientModes,\n> = {\n chain?: ClientConfig<TTransport, TChain>['chain']\n /** The key of the client. */\n key?: ClientConfig['key']\n /** Mode of the test client. Available: \"anvil\" | \"hardhat\" */\n mode: TMode\n /** The name of the client. */\n name?: ClientConfig['name']\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval?: ClientConfig['pollingInterval']\n transport: ClientConfig<TTransport, TChain>['transport']\n}\n\nexport type TestClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n TMode extends TestClientModes = TestClientModes,\n> = Client<TTransport, TChain, TestRequests<TMode>> & {\n mode: TMode\n}\n\n/**\n * @description Creates a test client with a given transport.\n *\n * - Only has access to \"test\" RPC methods (ie. `anvil_setBalance`,\n * `evm_mine`, etc).\n *\n * @example\n * import { createTestClient, http } from 'viem'\n * import { local } from 'viem/chains'\n * const client = createTestClient({ chain: local, mode: 'anvil', transport: http() })\n */\nexport function createTestClient<\n TTransport extends Transport,\n TChain extends Chain,\n TMode extends TestClientModes,\n>({\n chain,\n key = 'test',\n name = 'Test Client',\n mode,\n pollingInterval,\n transport,\n}: TestClientConfig<TTransport, TChain, TMode>): TestClient<\n TTransport,\n TChain,\n TMode\n> {\n return {\n ...createClient({\n chain,\n key,\n name,\n pollingInterval,\n transport,\n type: 'testClient',\n }),\n mode,\n }\n}\n","import type { SignableRequests, WalletRequests } from '../types/eip1193'\nimport type { Transport } from './transports/createTransport'\nimport type { Client, ClientConfig } from './createClient'\nimport { createClient } from './createClient'\nimport { Chain } from '../types'\n\nexport type WalletClientConfig<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = {\n chain?: ClientConfig<TTransport, TChain>['chain']\n /** The key of the Wallet Client. */\n key?: ClientConfig['key']\n /** The name of the Wallet Client. */\n name?: ClientConfig['name']\n /** Frequency (in ms) for polling enabled actions & events. Defaults to 4_000 milliseconds. */\n pollingInterval?: ClientConfig['pollingInterval']\n transport: ClientConfig<TTransport, TChain>['transport']\n}\n\nexport type WalletClient<\n TTransport extends Transport = Transport,\n TChain extends Chain = Chain,\n> = Client<TTransport, TChain, SignableRequests & WalletRequests>\n\n/**\n * @description Creates a wallet client with a given transport.\n *\n * - Only has access to \"wallet\" & \"signable\" EIP-1474 RPC methods\n * (ie. `eth_sendTransaction`, `eth_requestAccounts`, etc).\n *\n * @example\n * import { createWalletClient, custom } from 'viem'\n * const client = createWalletClient(\n * custom(window.ethereum)\n * )\n */\nexport function createWalletClient<\n TTransport extends Transport,\n TChain extends Chain,\n>({\n transport,\n key = 'wallet',\n name = 'Wallet Client',\n pollingInterval,\n}: WalletClientConfig<TTransport, TChain>): WalletClient<TTransport, TChain> {\n return createClient({\n key,\n name,\n pollingInterval,\n transport,\n type: 'walletClient',\n })\n}\n"],"mappings":"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","names":[]}
package/dist/public.d.ts CHANGED
@@ -1,14 +1,14 @@
1
- export { C as CallArgs, a as CallResponse, c as call } from './call-ac509982.js';
2
- import { H as Hex, X as EstimateGasParameters, b as BlockTag, A as Address, a as Hash, C as Chain, F as FeeHistory, L as Log, f as BlockNumber, Y as FormattedTransaction, Z as TransactionFormatter, V as Formatted, W as ExtractFormatter, O as Formatter, p as RpcTransactionReceipt, T as TransactionReceipt, K as TransactionType, x as Transaction } from './chain-f16512e8.js';
3
- import { P as PublicClient } from './createPublicClient-b732194e.js';
4
- import { F as FormattedBlock, B as BlockFormatter, a as FormattedTransactionReceipt, T as TransactionReceiptFormatter } from './transactionReceipt-2a86c7c7.js';
5
- import { E as EventFilterArgs } from './watchEvent-c346c12d.js';
6
- export { G as GetBytecodeArgs, a as GetBytecodeResponse, g as getBytecode, w as watchEvent } from './watchEvent-c346c12d.js';
7
- import { j as EventDefinition } from './contract-9e76e561.js';
8
- import './transactionRequest-c7794f5e.js';
1
+ export { C as CallArgs, a as CallResponse, c as call } from './call-3476b8ee.js';
2
+ import { H as Hex, C as Chain, b as BlockTag, M as Formatter, O as MergeIntersectionProperties, S as Formatted, s as TransactionRequest, A as Address, a as Hash, F as FeeHistory, L as Log, f as BlockNumber, W as FormattedTransaction, X as TransactionFormatter, V as ExtractFormatter, p as RpcTransactionReceipt, T as TransactionReceipt, J as TransactionType, x as Transaction } from './chain-42de87e5.js';
3
+ import { P as PublicClient } from './createPublicClient-fd558574.js';
4
+ import { T as TransactionRequestFormatter } from './transactionRequest-f437b4ba.js';
5
+ import { F as FormattedBlock, B as BlockFormatter, a as FormattedTransactionReceipt, T as TransactionReceiptFormatter } from './transactionReceipt-44dbf122.js';
6
+ import { E as EventFilterArgs } from './watchEvent-569c9976.js';
7
+ export { G as GetBytecodeArgs, a as GetBytecodeResponse, g as getBytecode, w as watchEvent } from './watchEvent-569c9976.js';
8
+ import { j as EventDefinition } from './contract-9dd2f98b.js';
9
9
  import '@wagmi/chains';
10
- import './eip1193-6f9ba163.js';
11
- import './createClient-68ee4bb4.js';
10
+ import './eip1193-617a05ae.js';
11
+ import './createClient-6689596e.js';
12
12
  import 'abitype';
13
13
 
14
14
  type FilterType = 'transaction' | 'block' | 'event';
@@ -23,7 +23,8 @@ declare function createPendingTransactionFilter(client: PublicClient): Promise<C
23
23
  type CreateBlockFilterResponse = Filter<'block'>;
24
24
  declare function createBlockFilter(client: PublicClient): Promise<CreateBlockFilterResponse>;
25
25
 
26
- type EstimateGasArgs = EstimateGasParameters & ({
26
+ type FormattedEstimateGas<TFormatter extends Formatter | undefined = Formatter> = MergeIntersectionProperties<Formatted<TFormatter, TransactionRequest, true>, TransactionRequest>;
27
+ type EstimateGasArgs<TChain extends Chain = Chain> = FormattedEstimateGas<TransactionRequestFormatter<TChain>> & ({
27
28
  /** The balance of the account at a block number. */
28
29
  blockNumber?: bigint;
29
30
  blockTag?: never;
@@ -36,7 +37,7 @@ type EstimateGasResponse = bigint;
36
37
  /**
37
38
  * @description Estimates the gas necessary to complete a transaction without submitting it to the network.
38
39
  */
39
- declare function estimateGas(client: PublicClient, { blockNumber, blockTag, data, from, gas, gasPrice, maxFeePerGas, maxPriorityFeePerGas, to, value, }: EstimateGasArgs): Promise<EstimateGasResponse>;
40
+ declare function estimateGas<TChain extends Chain>(client: PublicClient<any, TChain>, { accessList, blockNumber, blockTag, data, from, gas, gasPrice, maxFeePerGas, maxPriorityFeePerGas, nonce, to, value, ...rest }: EstimateGasArgs): Promise<EstimateGasResponse>;
40
41
 
41
42
  type GetBalanceArgs = {
42
43
  /** The address of the account. */
package/dist/public.js CHANGED
@@ -25,8 +25,8 @@
25
25
 
26
26
 
27
27
 
28
- var _chunkCD2XJOBJjs = require('./chunk-CD2XJOBJ.js');
29
- require('./chunk-THMRUG4D.js');
28
+ var _chunkLINNE4N4js = require('./chunk-LINNE4N4.js');
29
+ require('./chunk-DSQO3E4F.js');
30
30
 
31
31
 
32
32
 
@@ -54,5 +54,5 @@ require('./chunk-THMRUG4D.js');
54
54
 
55
55
 
56
56
 
57
- exports.call = _chunkCD2XJOBJjs.call; exports.createBlockFilter = _chunkCD2XJOBJjs.createBlockFilter; exports.createPendingTransactionFilter = _chunkCD2XJOBJjs.createPendingTransactionFilter; exports.estimateGas = _chunkCD2XJOBJjs.estimateGas; exports.getBalance = _chunkCD2XJOBJjs.getBalance; exports.getBlock = _chunkCD2XJOBJjs.getBlock; exports.getBlockNumber = _chunkCD2XJOBJjs.getBlockNumber; exports.getBlockNumberCache = _chunkCD2XJOBJjs.getBlockNumberCache; exports.getBlockTransactionCount = _chunkCD2XJOBJjs.getBlockTransactionCount; exports.getBytecode = _chunkCD2XJOBJjs.getBytecode; exports.getChainId = _chunkCD2XJOBJjs.getChainId; exports.getFeeHistory = _chunkCD2XJOBJjs.getFeeHistory; exports.getFilterChanges = _chunkCD2XJOBJjs.getFilterChanges; exports.getFilterLogs = _chunkCD2XJOBJjs.getFilterLogs; exports.getGasPrice = _chunkCD2XJOBJjs.getGasPrice; exports.getLogs = _chunkCD2XJOBJjs.getLogs; exports.getTransaction = _chunkCD2XJOBJjs.getTransaction; exports.getTransactionConfirmations = _chunkCD2XJOBJjs.getTransactionConfirmations; exports.getTransactionCount = _chunkCD2XJOBJjs.getTransactionCount; exports.getTransactionReceipt = _chunkCD2XJOBJjs.getTransactionReceipt; exports.uninstallFilter = _chunkCD2XJOBJjs.uninstallFilter; exports.waitForTransactionReceipt = _chunkCD2XJOBJjs.waitForTransactionReceipt; exports.watchBlockNumber = _chunkCD2XJOBJjs.watchBlockNumber; exports.watchBlocks = _chunkCD2XJOBJjs.watchBlocks; exports.watchEvent = _chunkCD2XJOBJjs.watchEvent; exports.watchPendingTransactions = _chunkCD2XJOBJjs.watchPendingTransactions;
57
+ exports.call = _chunkLINNE4N4js.call; exports.createBlockFilter = _chunkLINNE4N4js.createBlockFilter; exports.createPendingTransactionFilter = _chunkLINNE4N4js.createPendingTransactionFilter; exports.estimateGas = _chunkLINNE4N4js.estimateGas; exports.getBalance = _chunkLINNE4N4js.getBalance; exports.getBlock = _chunkLINNE4N4js.getBlock; exports.getBlockNumber = _chunkLINNE4N4js.getBlockNumber; exports.getBlockNumberCache = _chunkLINNE4N4js.getBlockNumberCache; exports.getBlockTransactionCount = _chunkLINNE4N4js.getBlockTransactionCount; exports.getBytecode = _chunkLINNE4N4js.getBytecode; exports.getChainId = _chunkLINNE4N4js.getChainId; exports.getFeeHistory = _chunkLINNE4N4js.getFeeHistory; exports.getFilterChanges = _chunkLINNE4N4js.getFilterChanges; exports.getFilterLogs = _chunkLINNE4N4js.getFilterLogs; exports.getGasPrice = _chunkLINNE4N4js.getGasPrice; exports.getLogs = _chunkLINNE4N4js.getLogs; exports.getTransaction = _chunkLINNE4N4js.getTransaction; exports.getTransactionConfirmations = _chunkLINNE4N4js.getTransactionConfirmations; exports.getTransactionCount = _chunkLINNE4N4js.getTransactionCount; exports.getTransactionReceipt = _chunkLINNE4N4js.getTransactionReceipt; exports.uninstallFilter = _chunkLINNE4N4js.uninstallFilter; exports.waitForTransactionReceipt = _chunkLINNE4N4js.waitForTransactionReceipt; exports.watchBlockNumber = _chunkLINNE4N4js.watchBlockNumber; exports.watchBlocks = _chunkLINNE4N4js.watchBlocks; exports.watchEvent = _chunkLINNE4N4js.watchEvent; exports.watchPendingTransactions = _chunkLINNE4N4js.watchPendingTransactions;
58
58
  //# sourceMappingURL=public.js.map
package/dist/public.mjs CHANGED
@@ -25,8 +25,8 @@ import {
25
25
  watchBlocks,
26
26
  watchEvent,
27
27
  watchPendingTransactions
28
- } from "./chunk-2Y3UZMSP.mjs";
29
- import "./chunk-KSAO4Y4Q.mjs";
28
+ } from "./chunk-QSIX64VZ.mjs";
29
+ import "./chunk-PRG3BBPZ.mjs";
30
30
  export {
31
31
  call,
32
32
  createBlockFilter,
@@ -1,7 +1,7 @@
1
1
  import { Abi } from 'abitype';
2
- import { C as ContractConfig, E as ExtractResultFromAbi } from './contract-9e76e561.js';
3
- import { P as PublicClient } from './createPublicClient-b732194e.js';
4
- import { C as CallArgs } from './call-ac509982.js';
2
+ import { C as ContractConfig, E as ExtractResultFromAbi } from './contract-9dd2f98b.js';
3
+ import { P as PublicClient } from './createPublicClient-fd558574.js';
4
+ import { C as CallArgs } from './call-3476b8ee.js';
5
5
 
6
6
  type ReadContractArgs<TAbi extends Abi | readonly unknown[] = Abi, TFunctionName extends string = string> = Pick<CallArgs, 'blockNumber' | 'blockTag'> & ContractConfig<TAbi, TFunctionName, 'view' | 'pure'>;
7
7
  type ReadContractResponse<TAbi extends Abi | readonly unknown[] = Abi, TFunctionName extends string = string> = ExtractResultFromAbi<TAbi, TFunctionName>;
@@ -1,6 +1,6 @@
1
1
  import { Abi } from 'abitype';
2
- import { A as Address, H as Hex } from './chain-f16512e8.js';
3
- import { D as DecodeErrorResultResponse } from './decodeErrorResult-0b934d23.js';
2
+ import { A as Address, H as Hex } from './chain-42de87e5.js';
3
+ import { D as DecodeErrorResultResponse } from './decodeErrorResult-ac835649.js';
4
4
  import WebSocket from 'isomorphic-ws';
5
5
 
6
6
  type BaseErrorArgs = {
@@ -90,10 +90,8 @@ type RpcResponse<TResult = any, TError = any> = {
90
90
  jsonrpc: `${number}`;
91
91
  id: number;
92
92
  } & (SuccessResult<TResult> | ErrorResult<TError> | Subscription<TResult, TError>);
93
- declare function http(url: string, { body, retryDelay, retryCount, timeout, }: {
93
+ declare function http(url: string, { body, timeout, }: {
94
94
  body: RpcRequest;
95
- retryDelay?: number;
96
- retryCount?: number;
97
95
  timeout?: number;
98
96
  }): Promise<RpcResponse<any, any>>;
99
97
  type Id = string | number;
@@ -1,6 +1,6 @@
1
- import { O as Formatter, S as MergeIntersectionProperties, V as Formatted, s as TransactionRequest, C as Chain, a as Hash } from './chain-f16512e8.js';
2
- import { W as WalletClient } from './createWalletClient-75813d83.js';
3
- import { T as TransactionRequestFormatter } from './transactionRequest-c7794f5e.js';
1
+ import { M as Formatter, O as MergeIntersectionProperties, S as Formatted, s as TransactionRequest, C as Chain, a as Hash } from './chain-42de87e5.js';
2
+ import { W as WalletClient } from './createWalletClient-4df88244.js';
3
+ import { T as TransactionRequestFormatter } from './transactionRequest-f437b4ba.js';
4
4
 
5
5
  type FormattedTransactionRequest<TFormatter extends Formatter | undefined = Formatter> = MergeIntersectionProperties<Formatted<TFormatter, TransactionRequest, true>, TransactionRequest>;
6
6
  type SendTransactionArgs<TChain extends Chain = Chain> = FormattedTransactionRequest<TransactionRequestFormatter<TChain>> & {
package/dist/test.d.ts CHANGED
@@ -1,8 +1,8 @@
1
- import { a as Hash, o as RpcTransaction, A as Address, Q as Quantity, s as TransactionRequest, H as Hex } from './chain-f16512e8.js';
2
- import { T as TestClient } from './createTestClient-dedf321e.js';
1
+ import { a as Hash, o as RpcTransaction, A as Address, Q as Quantity, s as TransactionRequest, H as Hex } from './chain-42de87e5.js';
2
+ import { T as TestClient } from './createTestClient-bc1d9028.js';
3
3
  import '@wagmi/chains';
4
- import './eip1193-6f9ba163.js';
5
- import './createClient-68ee4bb4.js';
4
+ import './eip1193-617a05ae.js';
5
+ import './createClient-6689596e.js';
6
6
 
7
7
  type DropTransactionArgs = {
8
8
  /** The hash of the transaction to drop. */
package/dist/test.js CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
 
4
4
 
5
- var _chunkTHMRUG4Djs = require('./chunk-THMRUG4D.js');
5
+ var _chunkDSQO3E4Fjs = require('./chunk-DSQO3E4F.js');
6
6
 
7
7
  // src/actions/test/dropTransaction.ts
8
8
  async function dropTransaction(client, { hash }) {
@@ -32,8 +32,8 @@ async function getTxpoolStatus(client) {
32
32
  method: "txpool_status"
33
33
  });
34
34
  return {
35
- pending: _chunkTHMRUG4Djs.hexToNumber.call(void 0, pending),
36
- queued: _chunkTHMRUG4Djs.hexToNumber.call(void 0, queued)
35
+ pending: _chunkDSQO3E4Fjs.hexToNumber.call(void 0, pending),
36
+ queued: _chunkDSQO3E4Fjs.hexToNumber.call(void 0, queued)
37
37
  };
38
38
  }
39
39
 
@@ -49,7 +49,7 @@ async function impersonateAccount(client, { address }) {
49
49
  async function increaseTime(client, { seconds }) {
50
50
  return await client.request({
51
51
  method: "evm_increaseTime",
52
- params: [_chunkTHMRUG4Djs.numberToHex.call(void 0, seconds)]
52
+ params: [_chunkDSQO3E4Fjs.numberToHex.call(void 0, seconds)]
53
53
  });
54
54
  }
55
55
 
@@ -64,7 +64,7 @@ async function inspectTxpool(client) {
64
64
  async function mine(client, { blocks, interval }) {
65
65
  return await client.request({
66
66
  method: `${client.mode}_mine`,
67
- params: [_chunkTHMRUG4Djs.numberToHex.call(void 0, blocks), _chunkTHMRUG4Djs.numberToHex.call(void 0, interval || 0)]
67
+ params: [_chunkDSQO3E4Fjs.numberToHex.call(void 0, blocks), _chunkDSQO3E4Fjs.numberToHex.call(void 0, interval || 0)]
68
68
  });
69
69
  }
70
70
 
@@ -93,7 +93,7 @@ async function revert(client, { id }) {
93
93
 
94
94
  // src/actions/test/sendUnsignedTransaction.ts
95
95
  async function sendUnsignedTransaction(client, request) {
96
- const request_ = _chunkTHMRUG4Djs.formatTransactionRequest.call(void 0, request);
96
+ const request_ = _chunkDSQO3E4Fjs.formatTransactionRequest.call(void 0, request);
97
97
  const hash = await client.request({
98
98
  method: "eth_sendUnsignedTransaction",
99
99
  params: [request_]
@@ -113,7 +113,7 @@ async function setAutomine(client, enabled) {
113
113
  async function setBalance(client, { address, value }) {
114
114
  return await client.request({
115
115
  method: `${client.mode}_setBalance`,
116
- params: [address, _chunkTHMRUG4Djs.numberToHex.call(void 0, value)]
116
+ params: [address, _chunkDSQO3E4Fjs.numberToHex.call(void 0, value)]
117
117
  });
118
118
  }
119
119
 
@@ -121,7 +121,7 @@ async function setBalance(client, { address, value }) {
121
121
  async function setBlockGasLimit(client, { gasLimit }) {
122
122
  return await client.request({
123
123
  method: "evm_setBlockGasLimit",
124
- params: [_chunkTHMRUG4Djs.numberToHex.call(void 0, gasLimit)]
124
+ params: [_chunkDSQO3E4Fjs.numberToHex.call(void 0, gasLimit)]
125
125
  });
126
126
  }
127
127
 
@@ -169,7 +169,7 @@ async function setLoggingEnabled(client, enabled) {
169
169
  async function setMinGasPrice(client, { gasPrice }) {
170
170
  return await client.request({
171
171
  method: `${client.mode}_setMinGasPrice`,
172
- params: [_chunkTHMRUG4Djs.numberToHex.call(void 0, gasPrice)]
172
+ params: [_chunkDSQO3E4Fjs.numberToHex.call(void 0, gasPrice)]
173
173
  });
174
174
  }
175
175
 
@@ -177,7 +177,7 @@ async function setMinGasPrice(client, { gasPrice }) {
177
177
  async function setNextBlockBaseFeePerGas(client, { baseFeePerGas }) {
178
178
  return await client.request({
179
179
  method: `${client.mode}_setNextBlockBaseFeePerGas`,
180
- params: [_chunkTHMRUG4Djs.numberToHex.call(void 0, baseFeePerGas)]
180
+ params: [_chunkDSQO3E4Fjs.numberToHex.call(void 0, baseFeePerGas)]
181
181
  });
182
182
  }
183
183
 
@@ -185,7 +185,7 @@ async function setNextBlockBaseFeePerGas(client, { baseFeePerGas }) {
185
185
  async function setNextBlockTimestamp(client, { timestamp }) {
186
186
  return await client.request({
187
187
  method: "evm_setNextBlockTimestamp",
188
- params: [_chunkTHMRUG4Djs.numberToHex.call(void 0, timestamp)]
188
+ params: [_chunkDSQO3E4Fjs.numberToHex.call(void 0, timestamp)]
189
189
  });
190
190
  }
191
191
 
@@ -193,7 +193,7 @@ async function setNextBlockTimestamp(client, { timestamp }) {
193
193
  async function setNonce(client, { address, nonce }) {
194
194
  return await client.request({
195
195
  method: `${client.mode}_setNonce`,
196
- params: [address, _chunkTHMRUG4Djs.numberToHex.call(void 0, nonce)]
196
+ params: [address, _chunkDSQO3E4Fjs.numberToHex.call(void 0, nonce)]
197
197
  });
198
198
  }
199
199
 
@@ -211,7 +211,7 @@ async function setStorageAt(client, { address, index, value }) {
211
211
  method: `${client.mode}_setStorageAt`,
212
212
  params: [
213
213
  address,
214
- typeof index === "number" ? _chunkTHMRUG4Djs.numberToHex.call(void 0, index) : index,
214
+ typeof index === "number" ? _chunkDSQO3E4Fjs.numberToHex.call(void 0, index) : index,
215
215
  value
216
216
  ]
217
217
  });