viem 2.0.0-beta.9 → 2.0.0-rc.0

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 (457) hide show
  1. package/CHANGELOG.md +44 -0
  2. package/README.md +9 -3
  3. package/_cjs/actions/ens/getEnsName.js +4 -2
  4. package/_cjs/actions/ens/getEnsName.js.map +1 -1
  5. package/_cjs/actions/index.js +16 -2
  6. package/_cjs/actions/index.js.map +1 -1
  7. package/_cjs/actions/wallet/prepareTransactionRequest.js.map +1 -1
  8. package/_cjs/chains/definitions/arbitrumSepolia.js +4 -0
  9. package/_cjs/chains/definitions/arbitrumSepolia.js.map +1 -1
  10. package/_cjs/chains/definitions/base.js +5 -0
  11. package/_cjs/chains/definitions/base.js.map +1 -1
  12. package/_cjs/chains/definitions/baseGoerli.js +5 -0
  13. package/_cjs/chains/definitions/baseGoerli.js.map +1 -1
  14. package/_cjs/chains/definitions/baseSepolia.js +5 -0
  15. package/_cjs/chains/definitions/baseSepolia.js.map +1 -1
  16. package/_cjs/chains/definitions/fantomSonicTestnet.js +26 -0
  17. package/_cjs/chains/definitions/fantomSonicTestnet.js.map +1 -0
  18. package/_cjs/chains/definitions/optimism.js +5 -0
  19. package/_cjs/chains/definitions/optimism.js.map +1 -1
  20. package/_cjs/chains/definitions/optimismGoerli.js +5 -0
  21. package/_cjs/chains/definitions/optimismGoerli.js.map +1 -1
  22. package/_cjs/chains/definitions/optimismSepolia.js +5 -0
  23. package/_cjs/chains/definitions/optimismSepolia.js.map +1 -1
  24. package/_cjs/chains/definitions/pgn.js +12 -0
  25. package/_cjs/chains/definitions/pgn.js.map +1 -1
  26. package/_cjs/chains/definitions/pgnTestnet.js +7 -0
  27. package/_cjs/chains/definitions/pgnTestnet.js.map +1 -1
  28. package/_cjs/chains/definitions/zilliqa.js +26 -0
  29. package/_cjs/chains/definitions/zilliqa.js.map +1 -0
  30. package/_cjs/chains/definitions/zilliqaTestnet.js +26 -0
  31. package/_cjs/chains/definitions/zilliqaTestnet.js.map +1 -0
  32. package/_cjs/chains/definitions/zkSyncSepoliaTestnet.js +35 -0
  33. package/_cjs/chains/definitions/zkSyncSepoliaTestnet.js.map +1 -0
  34. package/_cjs/chains/definitions/zkSyncTestnet.js +4 -0
  35. package/_cjs/chains/definitions/zkSyncTestnet.js.map +1 -1
  36. package/_cjs/chains/definitions/zora.js +5 -0
  37. package/_cjs/chains/definitions/zora.js.map +1 -1
  38. package/_cjs/chains/definitions/zoraSepolia.js +5 -0
  39. package/_cjs/chains/definitions/zoraSepolia.js.map +1 -1
  40. package/_cjs/chains/index.js +12 -4
  41. package/_cjs/chains/index.js.map +1 -1
  42. package/_cjs/chains/opStack/abis.js +366 -1
  43. package/_cjs/chains/opStack/abis.js.map +1 -1
  44. package/_cjs/chains/opStack/actions/buildDepositTransaction.js +1 -1
  45. package/_cjs/chains/opStack/actions/buildDepositTransaction.js.map +1 -1
  46. package/_cjs/chains/opStack/actions/buildInitiateWithdrawal.js +29 -0
  47. package/_cjs/chains/opStack/actions/buildInitiateWithdrawal.js.map +1 -0
  48. package/_cjs/chains/opStack/actions/buildProveWithdrawal.js +39 -0
  49. package/_cjs/chains/opStack/actions/buildProveWithdrawal.js.map +1 -0
  50. package/_cjs/chains/opStack/actions/depositTransaction.js +11 -6
  51. package/_cjs/chains/opStack/actions/depositTransaction.js.map +1 -1
  52. package/_cjs/chains/opStack/actions/estimateDepositTransactionGas.js +37 -0
  53. package/_cjs/chains/opStack/actions/estimateDepositTransactionGas.js.map +1 -0
  54. package/_cjs/chains/opStack/actions/estimateFinalizeWithdrawalGas.js +29 -0
  55. package/_cjs/chains/opStack/actions/estimateFinalizeWithdrawalGas.js.map +1 -0
  56. package/_cjs/chains/opStack/actions/estimateInitiateWithdrawalGas.js +24 -0
  57. package/_cjs/chains/opStack/actions/estimateInitiateWithdrawalGas.js.map +1 -0
  58. package/_cjs/chains/opStack/actions/estimateProveWithdrawalGas.js +29 -0
  59. package/_cjs/chains/opStack/actions/estimateProveWithdrawalGas.js.map +1 -0
  60. package/_cjs/chains/opStack/actions/finalizeWithdrawal.js +33 -0
  61. package/_cjs/chains/opStack/actions/finalizeWithdrawal.js.map +1 -0
  62. package/_cjs/chains/opStack/actions/getL2Output.js +30 -0
  63. package/_cjs/chains/opStack/actions/getL2Output.js.map +1 -0
  64. package/_cjs/chains/opStack/actions/getTimeToFinalize.js +46 -0
  65. package/_cjs/chains/opStack/actions/getTimeToFinalize.js.map +1 -0
  66. package/_cjs/chains/opStack/actions/getTimeToNextL2Output.js +63 -0
  67. package/_cjs/chains/opStack/actions/getTimeToNextL2Output.js.map +1 -0
  68. package/_cjs/chains/opStack/actions/getTimeToProve.js +13 -0
  69. package/_cjs/chains/opStack/actions/getTimeToProve.js.map +1 -0
  70. package/_cjs/chains/opStack/actions/getWithdrawalStatus.js +71 -0
  71. package/_cjs/chains/opStack/actions/getWithdrawalStatus.js.map +1 -0
  72. package/_cjs/chains/opStack/actions/initiateWithdrawal.js +28 -0
  73. package/_cjs/chains/opStack/actions/initiateWithdrawal.js.map +1 -0
  74. package/_cjs/chains/opStack/actions/proveWithdrawal.js +33 -0
  75. package/_cjs/chains/opStack/actions/proveWithdrawal.js.map +1 -0
  76. package/_cjs/chains/opStack/actions/waitForNextL2Output.js +32 -0
  77. package/_cjs/chains/opStack/actions/waitForNextL2Output.js.map +1 -0
  78. package/_cjs/chains/opStack/actions/waitToFinalize.js +11 -0
  79. package/_cjs/chains/opStack/actions/waitToFinalize.js.map +1 -0
  80. package/_cjs/chains/opStack/actions/waitToProve.js +21 -0
  81. package/_cjs/chains/opStack/actions/waitToProve.js.map +1 -0
  82. package/_cjs/chains/opStack/chains.js +5 -1
  83. package/_cjs/chains/opStack/chains.js.map +1 -1
  84. package/_cjs/chains/opStack/decorators/publicL1.js +35 -0
  85. package/_cjs/chains/opStack/decorators/publicL1.js.map +1 -0
  86. package/_cjs/chains/opStack/decorators/publicL2.js +5 -1
  87. package/_cjs/chains/opStack/decorators/publicL2.js.map +1 -1
  88. package/_cjs/chains/opStack/decorators/walletL1.js +4 -0
  89. package/_cjs/chains/opStack/decorators/walletL1.js.map +1 -1
  90. package/_cjs/chains/opStack/decorators/walletL2.js +13 -0
  91. package/_cjs/chains/opStack/decorators/walletL2.js.map +1 -0
  92. package/_cjs/chains/opStack/errors/withdrawal.js +17 -0
  93. package/_cjs/chains/opStack/errors/withdrawal.js.map +1 -0
  94. package/_cjs/chains/opStack/index.js +43 -15
  95. package/_cjs/chains/opStack/index.js.map +1 -1
  96. package/_cjs/chains/opStack/types/deposit.js +3 -0
  97. package/_cjs/chains/opStack/types/deposit.js.map +1 -0
  98. package/_cjs/chains/opStack/types/withdrawal.js +3 -0
  99. package/_cjs/chains/opStack/types/withdrawal.js.map +1 -0
  100. package/_cjs/chains/opStack/utils/extractWithdrawalMessageLogs.js +14 -0
  101. package/_cjs/chains/opStack/utils/extractWithdrawalMessageLogs.js.map +1 -0
  102. package/_cjs/chains/opStack/utils/getL2TransactionHash.js +2 -2
  103. package/_cjs/chains/opStack/utils/getL2TransactionHash.js.map +1 -1
  104. package/_cjs/chains/opStack/utils/getWithdrawalHashStorageSlot.js +11 -0
  105. package/_cjs/chains/opStack/utils/getWithdrawalHashStorageSlot.js.map +1 -0
  106. package/_cjs/chains/opStack/utils/getWithdrawals.js +10 -0
  107. package/_cjs/chains/opStack/utils/getWithdrawals.js.map +1 -0
  108. package/_cjs/chains/opStack/utils/{fromOpaqueData.js → opaqueDataToDepositData.js} +4 -4
  109. package/_cjs/chains/opStack/utils/opaqueDataToDepositData.js.map +1 -0
  110. package/_cjs/errors/abi.js +21 -1
  111. package/_cjs/errors/abi.js.map +1 -1
  112. package/_cjs/errors/version.js +1 -1
  113. package/_cjs/errors/version.js.map +1 -1
  114. package/_cjs/index.js +10 -2
  115. package/_cjs/index.js.map +1 -1
  116. package/_cjs/utils/abi/getAbiItem.js +46 -3
  117. package/_cjs/utils/abi/getAbiItem.js.map +1 -1
  118. package/_cjs/utils/hash/ripemd160.js +16 -0
  119. package/_cjs/utils/hash/ripemd160.js.map +1 -0
  120. package/_cjs/utils/hash/sha256.js +16 -0
  121. package/_cjs/utils/hash/sha256.js.map +1 -0
  122. package/_cjs/utils/index.js +5 -1
  123. package/_cjs/utils/index.js.map +1 -1
  124. package/_esm/actions/ens/getEnsName.js +4 -2
  125. package/_esm/actions/ens/getEnsName.js.map +1 -1
  126. package/_esm/actions/index.js +7 -0
  127. package/_esm/actions/index.js.map +1 -1
  128. package/_esm/actions/wallet/prepareTransactionRequest.js.map +1 -1
  129. package/_esm/chains/definitions/arbitrumSepolia.js +4 -0
  130. package/_esm/chains/definitions/arbitrumSepolia.js.map +1 -1
  131. package/_esm/chains/definitions/base.js +5 -0
  132. package/_esm/chains/definitions/base.js.map +1 -1
  133. package/_esm/chains/definitions/baseGoerli.js +5 -0
  134. package/_esm/chains/definitions/baseGoerli.js.map +1 -1
  135. package/_esm/chains/definitions/baseSepolia.js +5 -0
  136. package/_esm/chains/definitions/baseSepolia.js.map +1 -1
  137. package/_esm/chains/definitions/fantomSonicTestnet.js +23 -0
  138. package/_esm/chains/definitions/fantomSonicTestnet.js.map +1 -0
  139. package/_esm/chains/definitions/optimism.js +5 -0
  140. package/_esm/chains/definitions/optimism.js.map +1 -1
  141. package/_esm/chains/definitions/optimismGoerli.js +5 -0
  142. package/_esm/chains/definitions/optimismGoerli.js.map +1 -1
  143. package/_esm/chains/definitions/optimismSepolia.js +5 -0
  144. package/_esm/chains/definitions/optimismSepolia.js.map +1 -1
  145. package/_esm/chains/definitions/pgn.js +12 -0
  146. package/_esm/chains/definitions/pgn.js.map +1 -1
  147. package/_esm/chains/definitions/pgnTestnet.js +7 -0
  148. package/_esm/chains/definitions/pgnTestnet.js.map +1 -1
  149. package/_esm/chains/definitions/zilliqa.js +23 -0
  150. package/_esm/chains/definitions/zilliqa.js.map +1 -0
  151. package/_esm/chains/definitions/zilliqaTestnet.js +23 -0
  152. package/_esm/chains/definitions/zilliqaTestnet.js.map +1 -0
  153. package/_esm/chains/definitions/zkSyncSepoliaTestnet.js +32 -0
  154. package/_esm/chains/definitions/zkSyncSepoliaTestnet.js.map +1 -0
  155. package/_esm/chains/definitions/zkSyncTestnet.js +5 -0
  156. package/_esm/chains/definitions/zkSyncTestnet.js.map +1 -1
  157. package/_esm/chains/definitions/zora.js +5 -0
  158. package/_esm/chains/definitions/zora.js.map +1 -1
  159. package/_esm/chains/definitions/zoraSepolia.js +5 -0
  160. package/_esm/chains/definitions/zoraSepolia.js.map +1 -1
  161. package/_esm/chains/index.js +4 -0
  162. package/_esm/chains/index.js.map +1 -1
  163. package/_esm/chains/opStack/abis.js +365 -0
  164. package/_esm/chains/opStack/abis.js.map +1 -1
  165. package/_esm/chains/opStack/actions/buildDepositTransaction.js +2 -2
  166. package/_esm/chains/opStack/actions/buildDepositTransaction.js.map +1 -1
  167. package/_esm/chains/opStack/actions/buildInitiateWithdrawal.js +50 -0
  168. package/_esm/chains/opStack/actions/buildInitiateWithdrawal.js.map +1 -0
  169. package/_esm/chains/opStack/actions/buildProveWithdrawal.js +59 -0
  170. package/_esm/chains/opStack/actions/buildProveWithdrawal.js.map +1 -0
  171. package/_esm/chains/opStack/actions/depositTransaction.js +17 -14
  172. package/_esm/chains/opStack/actions/depositTransaction.js.map +1 -1
  173. package/_esm/chains/opStack/actions/estimateDepositTransactionGas.js +62 -0
  174. package/_esm/chains/opStack/actions/estimateDepositTransactionGas.js.map +1 -0
  175. package/_esm/chains/opStack/actions/estimateFinalizeWithdrawalGas.js +50 -0
  176. package/_esm/chains/opStack/actions/estimateFinalizeWithdrawalGas.js.map +1 -0
  177. package/_esm/chains/opStack/actions/estimateInitiateWithdrawalGas.js +48 -0
  178. package/_esm/chains/opStack/actions/estimateInitiateWithdrawalGas.js.map +1 -0
  179. package/_esm/chains/opStack/actions/estimateProveWithdrawalGas.js +53 -0
  180. package/_esm/chains/opStack/actions/estimateProveWithdrawalGas.js.map +1 -0
  181. package/_esm/chains/opStack/actions/finalizeWithdrawal.js +53 -0
  182. package/_esm/chains/opStack/actions/finalizeWithdrawal.js.map +1 -0
  183. package/_esm/chains/opStack/actions/getL2Output.js +50 -0
  184. package/_esm/chains/opStack/actions/getL2Output.js.map +1 -0
  185. package/_esm/chains/opStack/actions/getTimeToFinalize.js +77 -0
  186. package/_esm/chains/opStack/actions/getTimeToFinalize.js.map +1 -0
  187. package/_esm/chains/opStack/actions/getTimeToNextL2Output.js +91 -0
  188. package/_esm/chains/opStack/actions/getTimeToNextL2Output.js.map +1 -0
  189. package/_esm/chains/opStack/actions/getTimeToProve.js +39 -0
  190. package/_esm/chains/opStack/actions/getTimeToProve.js.map +1 -0
  191. package/_esm/chains/opStack/actions/getWithdrawalStatus.js +99 -0
  192. package/_esm/chains/opStack/actions/getWithdrawalStatus.js.map +1 -0
  193. package/_esm/chains/opStack/actions/initiateWithdrawal.js +76 -0
  194. package/_esm/chains/opStack/actions/initiateWithdrawal.js.map +1 -0
  195. package/_esm/chains/opStack/actions/proveWithdrawal.js +57 -0
  196. package/_esm/chains/opStack/actions/proveWithdrawal.js.map +1 -0
  197. package/_esm/chains/opStack/actions/waitForNextL2Output.js +58 -0
  198. package/_esm/chains/opStack/actions/waitForNextL2Output.js.map +1 -0
  199. package/_esm/chains/opStack/actions/waitToFinalize.js +41 -0
  200. package/_esm/chains/opStack/actions/waitToFinalize.js.map +1 -0
  201. package/_esm/chains/opStack/actions/waitToProve.js +47 -0
  202. package/_esm/chains/opStack/actions/waitToProve.js.map +1 -0
  203. package/_esm/chains/opStack/chains.js +2 -0
  204. package/_esm/chains/opStack/chains.js.map +1 -1
  205. package/_esm/chains/opStack/decorators/publicL1.js +31 -0
  206. package/_esm/chains/opStack/decorators/publicL1.js.map +1 -0
  207. package/_esm/chains/opStack/decorators/publicL2.js +5 -1
  208. package/_esm/chains/opStack/decorators/publicL2.js.map +1 -1
  209. package/_esm/chains/opStack/decorators/walletL1.js +4 -0
  210. package/_esm/chains/opStack/decorators/walletL1.js.map +1 -1
  211. package/_esm/chains/opStack/decorators/walletL2.js +9 -0
  212. package/_esm/chains/opStack/decorators/walletL2.js.map +1 -0
  213. package/_esm/chains/opStack/errors/withdrawal.js +13 -0
  214. package/_esm/chains/opStack/errors/withdrawal.js.map +1 -0
  215. package/_esm/chains/opStack/index.js +21 -3
  216. package/_esm/chains/opStack/index.js.map +1 -1
  217. package/_esm/chains/opStack/types/deposit.js +2 -0
  218. package/_esm/chains/opStack/types/deposit.js.map +1 -0
  219. package/_esm/chains/opStack/types/withdrawal.js +2 -0
  220. package/_esm/chains/opStack/types/withdrawal.js.map +1 -0
  221. package/_esm/chains/opStack/utils/extractWithdrawalMessageLogs.js +10 -0
  222. package/_esm/chains/opStack/utils/extractWithdrawalMessageLogs.js.map +1 -0
  223. package/_esm/chains/opStack/utils/getL2TransactionHash.js +2 -2
  224. package/_esm/chains/opStack/utils/getL2TransactionHash.js.map +1 -1
  225. package/_esm/chains/opStack/utils/getWithdrawalHashStorageSlot.js +7 -0
  226. package/_esm/chains/opStack/utils/getWithdrawalHashStorageSlot.js.map +1 -0
  227. package/_esm/chains/opStack/utils/getWithdrawals.js +6 -0
  228. package/_esm/chains/opStack/utils/getWithdrawals.js.map +1 -0
  229. package/_esm/chains/opStack/utils/{fromOpaqueData.js → opaqueDataToDepositData.js} +2 -2
  230. package/_esm/chains/opStack/utils/opaqueDataToDepositData.js.map +1 -0
  231. package/_esm/errors/abi.js +19 -0
  232. package/_esm/errors/abi.js.map +1 -1
  233. package/_esm/errors/version.js +1 -1
  234. package/_esm/errors/version.js.map +1 -1
  235. package/_esm/index.js +4 -0
  236. package/_esm/index.js.map +1 -1
  237. package/_esm/utils/abi/getAbiItem.js +46 -2
  238. package/_esm/utils/abi/getAbiItem.js.map +1 -1
  239. package/_esm/utils/hash/ripemd160.js +12 -0
  240. package/_esm/utils/hash/ripemd160.js.map +1 -0
  241. package/_esm/utils/hash/sha256.js +12 -0
  242. package/_esm/utils/hash/sha256.js.map +1 -0
  243. package/_esm/utils/index.js +2 -0
  244. package/_esm/utils/index.js.map +1 -1
  245. package/_types/actions/ens/getEnsName.d.ts.map +1 -1
  246. package/_types/actions/index.d.ts +7 -0
  247. package/_types/actions/index.d.ts.map +1 -1
  248. package/_types/actions/wallet/prepareTransactionRequest.d.ts +5 -5
  249. package/_types/actions/wallet/prepareTransactionRequest.d.ts.map +1 -1
  250. package/_types/chains/celo/chainConfig.d.ts +180 -180
  251. package/_types/chains/celo/formatters.d.ts +180 -180
  252. package/_types/chains/definitions/arbitrumSepolia.d.ts +4 -0
  253. package/_types/chains/definitions/arbitrumSepolia.d.ts.map +1 -1
  254. package/_types/chains/definitions/base.d.ts +142 -137
  255. package/_types/chains/definitions/base.d.ts.map +1 -1
  256. package/_types/chains/definitions/baseGoerli.d.ts +142 -137
  257. package/_types/chains/definitions/baseGoerli.d.ts.map +1 -1
  258. package/_types/chains/definitions/baseSepolia.d.ts +142 -137
  259. package/_types/chains/definitions/baseSepolia.d.ts.map +1 -1
  260. package/_types/chains/definitions/celo.d.ts +180 -180
  261. package/_types/chains/definitions/celoAlfajores.d.ts +180 -180
  262. package/_types/chains/definitions/celoCannoli.d.ts +180 -180
  263. package/_types/chains/definitions/fantomSonicTestnet.d.ts +38 -0
  264. package/_types/chains/definitions/fantomSonicTestnet.d.ts.map +1 -0
  265. package/_types/chains/definitions/optimism.d.ts +142 -137
  266. package/_types/chains/definitions/optimism.d.ts.map +1 -1
  267. package/_types/chains/definitions/optimismGoerli.d.ts +142 -137
  268. package/_types/chains/definitions/optimismGoerli.d.ts.map +1 -1
  269. package/_types/chains/definitions/optimismSepolia.d.ts +142 -137
  270. package/_types/chains/definitions/optimismSepolia.d.ts.map +1 -1
  271. package/_types/chains/definitions/pgn.d.ts +147 -137
  272. package/_types/chains/definitions/pgn.d.ts.map +1 -1
  273. package/_types/chains/definitions/pgnTestnet.d.ts +142 -137
  274. package/_types/chains/definitions/pgnTestnet.d.ts.map +1 -1
  275. package/_types/chains/definitions/zilliqa.d.ts +38 -0
  276. package/_types/chains/definitions/zilliqa.d.ts.map +1 -0
  277. package/_types/chains/definitions/zilliqaTestnet.d.ts +38 -0
  278. package/_types/chains/definitions/zilliqaTestnet.d.ts.map +1 -0
  279. package/_types/chains/definitions/zkSync.d.ts +24 -24
  280. package/_types/chains/definitions/zkSyncSepoliaTestnet.d.ts +533 -0
  281. package/_types/chains/definitions/zkSyncSepoliaTestnet.d.ts.map +1 -0
  282. package/_types/chains/definitions/zkSyncTestnet.d.ts +29 -24
  283. package/_types/chains/definitions/zkSyncTestnet.d.ts.map +1 -1
  284. package/_types/chains/definitions/zora.d.ts +142 -137
  285. package/_types/chains/definitions/zora.d.ts.map +1 -1
  286. package/_types/chains/definitions/zoraSepolia.d.ts +142 -137
  287. package/_types/chains/definitions/zoraSepolia.d.ts.map +1 -1
  288. package/_types/chains/definitions/zoraTestnet.d.ts +137 -137
  289. package/_types/chains/index.d.ts +5 -1
  290. package/_types/chains/index.d.ts.map +1 -1
  291. package/_types/chains/opStack/abis.d.ts +457 -0
  292. package/_types/chains/opStack/abis.d.ts.map +1 -1
  293. package/_types/chains/opStack/actions/buildDepositTransaction.d.ts +5 -3
  294. package/_types/chains/opStack/actions/buildDepositTransaction.d.ts.map +1 -1
  295. package/_types/chains/opStack/actions/buildInitiateWithdrawal.d.ts +50 -0
  296. package/_types/chains/opStack/actions/buildInitiateWithdrawal.d.ts.map +1 -0
  297. package/_types/chains/opStack/actions/buildProveWithdrawal.d.ts +48 -0
  298. package/_types/chains/opStack/actions/buildProveWithdrawal.d.ts.map +1 -0
  299. package/_types/chains/opStack/actions/depositTransaction.d.ts +18 -34
  300. package/_types/chains/opStack/actions/depositTransaction.d.ts.map +1 -1
  301. package/_types/chains/opStack/actions/estimateDepositTransactionGas.d.ts +50 -0
  302. package/_types/chains/opStack/actions/estimateDepositTransactionGas.d.ts.map +1 -0
  303. package/_types/chains/opStack/actions/estimateFinalizeWithdrawalGas.d.ts +45 -0
  304. package/_types/chains/opStack/actions/estimateFinalizeWithdrawalGas.d.ts.map +1 -0
  305. package/_types/chains/opStack/actions/estimateInitiateWithdrawalGas.d.ts +51 -0
  306. package/_types/chains/opStack/actions/estimateInitiateWithdrawalGas.d.ts.map +1 -0
  307. package/_types/chains/opStack/actions/estimateProveWithdrawalGas.d.ts +63 -0
  308. package/_types/chains/opStack/actions/estimateProveWithdrawalGas.d.ts.map +1 -0
  309. package/_types/chains/opStack/actions/finalizeWithdrawal.d.ts +49 -0
  310. package/_types/chains/opStack/actions/finalizeWithdrawal.d.ts.map +1 -0
  311. package/_types/chains/opStack/actions/getL2Output.d.ts +44 -0
  312. package/_types/chains/opStack/actions/getL2Output.d.ts.map +1 -0
  313. package/_types/chains/opStack/actions/getTimeToFinalize.d.ts +57 -0
  314. package/_types/chains/opStack/actions/getTimeToFinalize.d.ts.map +1 -0
  315. package/_types/chains/opStack/actions/getTimeToNextL2Output.d.ts +61 -0
  316. package/_types/chains/opStack/actions/getTimeToNextL2Output.d.ts.map +1 -0
  317. package/_types/chains/opStack/actions/getTimeToProve.d.ts +50 -0
  318. package/_types/chains/opStack/actions/getTimeToProve.d.ts.map +1 -0
  319. package/_types/chains/opStack/actions/getWithdrawalStatus.d.ts +48 -0
  320. package/_types/chains/opStack/actions/getWithdrawalStatus.d.ts.map +1 -0
  321. package/_types/chains/opStack/actions/initiateWithdrawal.d.ts +77 -0
  322. package/_types/chains/opStack/actions/initiateWithdrawal.d.ts.map +1 -0
  323. package/_types/chains/opStack/actions/proveWithdrawal.d.ts +67 -0
  324. package/_types/chains/opStack/actions/proveWithdrawal.d.ts.map +1 -0
  325. package/_types/chains/opStack/actions/waitForNextL2Output.d.ts +55 -0
  326. package/_types/chains/opStack/actions/waitForNextL2Output.d.ts.map +1 -0
  327. package/_types/chains/opStack/actions/waitToFinalize.d.ts +45 -0
  328. package/_types/chains/opStack/actions/waitToFinalize.d.ts.map +1 -0
  329. package/_types/chains/opStack/actions/waitToProve.d.ts +55 -0
  330. package/_types/chains/opStack/actions/waitToProve.d.ts.map +1 -0
  331. package/_types/chains/opStack/chainConfig.d.ts +136 -136
  332. package/_types/chains/opStack/chains.d.ts +2 -0
  333. package/_types/chains/opStack/chains.d.ts.map +1 -1
  334. package/_types/chains/opStack/decorators/publicL1.d.ts +386 -0
  335. package/_types/chains/opStack/decorators/publicL1.d.ts.map +1 -0
  336. package/_types/chains/opStack/decorators/publicL2.d.ts +82 -26
  337. package/_types/chains/opStack/decorators/publicL2.d.ts.map +1 -1
  338. package/_types/chains/opStack/decorators/walletL1.d.ts +57 -2
  339. package/_types/chains/opStack/decorators/walletL1.d.ts.map +1 -1
  340. package/_types/chains/opStack/decorators/walletL2.d.ts +62 -0
  341. package/_types/chains/opStack/decorators/walletL2.d.ts.map +1 -0
  342. package/_types/chains/opStack/errors/withdrawal.d.ts +12 -0
  343. package/_types/chains/opStack/errors/withdrawal.d.ts.map +1 -0
  344. package/_types/chains/opStack/formatters.d.ts +136 -136
  345. package/_types/chains/opStack/index.d.ts +21 -3
  346. package/_types/chains/opStack/index.d.ts.map +1 -1
  347. package/_types/chains/opStack/types/deposit.d.ts +25 -0
  348. package/_types/chains/opStack/types/deposit.d.ts.map +1 -0
  349. package/_types/chains/opStack/types/withdrawal.d.ts +22 -0
  350. package/_types/chains/opStack/types/withdrawal.d.ts.map +1 -0
  351. package/_types/chains/opStack/utils/extractWithdrawalMessageLogs.d.ts +137 -0
  352. package/_types/chains/opStack/utils/extractWithdrawalMessageLogs.d.ts.map +1 -0
  353. package/_types/chains/opStack/utils/getWithdrawalHashStorageSlot.d.ts +11 -0
  354. package/_types/chains/opStack/utils/getWithdrawalHashStorageSlot.d.ts.map +1 -0
  355. package/_types/chains/opStack/utils/getWithdrawals.d.ts +12 -0
  356. package/_types/chains/opStack/utils/getWithdrawals.d.ts.map +1 -0
  357. package/_types/chains/opStack/utils/opaqueDataToDepositData.d.ts +15 -0
  358. package/_types/chains/opStack/utils/opaqueDataToDepositData.d.ts.map +1 -0
  359. package/_types/chains/zksync/chainConfig.d.ts +24 -24
  360. package/_types/chains/zksync/formatters.d.ts +24 -24
  361. package/_types/clients/decorators/public.d.ts +2 -2
  362. package/_types/clients/decorators/public.d.ts.map +1 -1
  363. package/_types/clients/decorators/wallet.d.ts +2 -2
  364. package/_types/clients/decorators/wallet.d.ts.map +1 -1
  365. package/_types/errors/abi.d.ts +14 -1
  366. package/_types/errors/abi.d.ts.map +1 -1
  367. package/_types/errors/version.d.ts +1 -1
  368. package/_types/errors/version.d.ts.map +1 -1
  369. package/_types/index.d.ts +15 -1
  370. package/_types/index.d.ts.map +1 -1
  371. package/_types/types/account.d.ts +1 -1
  372. package/_types/types/account.d.ts.map +1 -1
  373. package/_types/types/eip1193.d.ts +12 -0
  374. package/_types/types/eip1193.d.ts.map +1 -1
  375. package/_types/utils/abi/getAbiItem.d.ts +2 -1
  376. package/_types/utils/abi/getAbiItem.d.ts.map +1 -1
  377. package/_types/utils/formatters/transaction.d.ts +1 -1
  378. package/_types/utils/formatters/transactionRequest.d.ts +1 -1
  379. package/_types/utils/hash/ripemd160.d.ts +11 -0
  380. package/_types/utils/hash/ripemd160.d.ts.map +1 -0
  381. package/_types/utils/hash/sha256.d.ts +11 -0
  382. package/_types/utils/hash/sha256.d.ts.map +1 -0
  383. package/_types/utils/index.d.ts +2 -0
  384. package/_types/utils/index.d.ts.map +1 -1
  385. package/actions/ens/getEnsName.ts +3 -2
  386. package/actions/index.ts +31 -0
  387. package/actions/wallet/prepareTransactionRequest.ts +16 -9
  388. package/chains/definitions/arbitrumSepolia.ts +4 -0
  389. package/chains/definitions/base.ts +5 -0
  390. package/chains/definitions/baseGoerli.ts +5 -0
  391. package/chains/definitions/baseSepolia.ts +5 -0
  392. package/chains/definitions/fantomSonicTestnet.ts +23 -0
  393. package/chains/definitions/optimism.ts +5 -0
  394. package/chains/definitions/optimismGoerli.ts +5 -0
  395. package/chains/definitions/optimismSepolia.ts +5 -0
  396. package/chains/definitions/pgn.ts +13 -0
  397. package/chains/definitions/pgnTestnet.ts +8 -0
  398. package/chains/definitions/zilliqa.ts +23 -0
  399. package/chains/definitions/zilliqaTestnet.ts +23 -0
  400. package/chains/definitions/zkSyncSepoliaTestnet.ts +32 -0
  401. package/chains/definitions/zkSyncTestnet.ts +5 -0
  402. package/chains/definitions/zora.ts +5 -0
  403. package/chains/definitions/zoraSepolia.ts +5 -0
  404. package/chains/index.ts +9 -0
  405. package/chains/opStack/abis.ts +367 -0
  406. package/chains/opStack/actions/buildDepositTransaction.ts +11 -6
  407. package/chains/opStack/actions/buildInitiateWithdrawal.ts +118 -0
  408. package/chains/opStack/actions/buildProveWithdrawal.ts +149 -0
  409. package/chains/opStack/actions/depositTransaction.ts +50 -44
  410. package/chains/opStack/actions/estimateDepositTransactionGas.ts +138 -0
  411. package/chains/opStack/actions/estimateFinalizeWithdrawalGas.ts +118 -0
  412. package/chains/opStack/actions/estimateInitiateWithdrawalGas.ts +118 -0
  413. package/chains/opStack/actions/estimateProveWithdrawalGas.ts +139 -0
  414. package/chains/opStack/actions/finalizeWithdrawal.ts +130 -0
  415. package/chains/opStack/actions/getL2Output.ts +89 -0
  416. package/chains/opStack/actions/getTimeToFinalize.ts +122 -0
  417. package/chains/opStack/actions/getTimeToNextL2Output.ts +162 -0
  418. package/chains/opStack/actions/getTimeToProve.ts +79 -0
  419. package/chains/opStack/actions/getWithdrawalStatus.ts +152 -0
  420. package/chains/opStack/actions/initiateWithdrawal.ts +153 -0
  421. package/chains/opStack/actions/proveWithdrawal.ts +151 -0
  422. package/chains/opStack/actions/waitForNextL2Output.ts +111 -0
  423. package/chains/opStack/actions/waitToFinalize.ts +64 -0
  424. package/chains/opStack/actions/waitToProve.ts +99 -0
  425. package/chains/opStack/chains.ts +2 -0
  426. package/chains/opStack/decorators/publicL1.ts +514 -0
  427. package/chains/opStack/decorators/publicL2.ts +129 -37
  428. package/chains/opStack/decorators/walletL1.ts +71 -2
  429. package/chains/opStack/decorators/walletL2.ts +84 -0
  430. package/chains/opStack/errors/withdrawal.ts +15 -0
  431. package/chains/opStack/index.ts +112 -21
  432. package/chains/opStack/types/deposit.ts +28 -0
  433. package/chains/opStack/types/withdrawal.ts +23 -0
  434. package/chains/opStack/utils/extractWithdrawalMessageLogs.ts +36 -0
  435. package/chains/opStack/utils/getL2TransactionHash.ts +2 -2
  436. package/chains/opStack/utils/getWithdrawalHashStorageSlot.ts +29 -0
  437. package/chains/opStack/utils/getWithdrawals.ts +25 -0
  438. package/chains/opStack/utils/{fromOpaqueData.ts → opaqueDataToDepositData.ts} +9 -4
  439. package/clients/decorators/public.ts +2 -2
  440. package/clients/decorators/wallet.ts +2 -2
  441. package/errors/abi.ts +22 -1
  442. package/errors/version.ts +1 -1
  443. package/index.ts +40 -0
  444. package/package.json +1 -1
  445. package/types/account.ts +1 -1
  446. package/types/eip1193.ts +12 -0
  447. package/utils/abi/getAbiItem.ts +71 -2
  448. package/utils/hash/ripemd160.ts +31 -0
  449. package/utils/hash/sha256.ts +31 -0
  450. package/utils/index.ts +2 -0
  451. package/_cjs/chains/opStack/utils/fromOpaqueData.js.map +0 -1
  452. package/_esm/chains/opStack/utils/fromOpaqueData.js.map +0 -1
  453. package/_types/chains/opStack/utils/fromOpaqueData.d.ts +0 -15
  454. package/_types/chains/opStack/utils/fromOpaqueData.d.ts.map +0 -1
  455. package/chains/celo/package.json +0 -6
  456. package/chains/opStack/package.json +0 -6
  457. package/chains/zksync/package.json +0 -6
@@ -0,0 +1,122 @@
1
+ import {
2
+ type MulticallErrorType,
3
+ multicall,
4
+ } from '../../../actions/public/multicall.js'
5
+ import type { Client } from '../../../clients/createClient.js'
6
+ import type { Transport } from '../../../clients/transports/createTransport.js'
7
+ import type { ErrorType } from '../../../errors/utils.js'
8
+ import type { Account } from '../../../types/account.js'
9
+ import type {
10
+ Chain,
11
+ DeriveChain,
12
+ GetChainParameter,
13
+ } from '../../../types/chain.js'
14
+ import type { Hash } from '../../../types/misc.js'
15
+ import { l2OutputOracleAbi, portalAbi } from '../abis.js'
16
+ import type { GetContractAddressParameter } from '../types/contract.js'
17
+
18
+ export type GetTimeToFinalizeParameters<
19
+ chain extends Chain | undefined = Chain | undefined,
20
+ chainOverride extends Chain | undefined = Chain | undefined,
21
+ _derivedChain extends Chain | undefined = DeriveChain<chain, chainOverride>,
22
+ > = GetChainParameter<chain, chainOverride> &
23
+ GetContractAddressParameter<_derivedChain, 'l2OutputOracle' | 'portal'> & {
24
+ withdrawalHash: Hash
25
+ }
26
+ export type GetTimeToFinalizeReturnType = {
27
+ /** The finalization period (in seconds). */
28
+ period: number
29
+ /** Seconds until the withdrawal can be finalized. */
30
+ seconds: number
31
+ /** Timestamp of when the withdrawal can be finalized. */
32
+ timestamp: number
33
+ }
34
+ export type GetTimeToFinalizeErrorType = MulticallErrorType | ErrorType
35
+
36
+ const buffer = 10
37
+
38
+ /**
39
+ * Returns the time until the withdrawal transaction can be finalized. Used for the [Withdrawal](/op-stack/guides/withdrawals.html) flow.
40
+ *
41
+ * - Docs: https://viem.sh/op-stack/actions/getTimeToFinalize.html
42
+ *
43
+ * @param client - Client to use
44
+ * @param parameters - {@link GetTimeToFinalizeParameters}
45
+ * @returns Time until finalize. {@link GetTimeToFinalizeReturnType}
46
+ *
47
+ * @example
48
+ * import { createPublicClient, http } from 'viem'
49
+ * import { getBlockNumber } from 'viem/actions'
50
+ * import { mainnet, optimism } from 'viem/chains'
51
+ * import { getTimeToFinalize } from 'viem/op-stack'
52
+ *
53
+ * const publicClientL1 = createPublicClient({
54
+ * chain: mainnet,
55
+ * transport: http(),
56
+ * })
57
+ * const publicClientL2 = createPublicClient({
58
+ * chain: optimism,
59
+ * transport: http(),
60
+ * })
61
+ *
62
+ * const receipt = await getTransactionReceipt(publicClientL2, {
63
+ * hash: '0x9a2f4283636ddeb9ac32382961b22c177c9e86dd3b283735c154f897b1a7ff4a',
64
+ * })
65
+ *
66
+ * const [withdrawal] = getWithdrawals(receipt)
67
+ *
68
+ * const { seconds } = await getTimeToFinalize(publicClientL1, {
69
+ * withdrawalHash: withdrawal.withdrawalHash,
70
+ * targetChain: optimism
71
+ * })
72
+ */
73
+ export async function getTimeToFinalize<
74
+ chain extends Chain | undefined,
75
+ account extends Account | undefined,
76
+ chainOverride extends Chain | undefined = undefined,
77
+ >(
78
+ client: Client<Transport, chain, account>,
79
+ parameters: GetTimeToFinalizeParameters<chain, chainOverride>,
80
+ ): Promise<GetTimeToFinalizeReturnType> {
81
+ const { chain = client.chain, withdrawalHash, targetChain } = parameters
82
+
83
+ const l2OutputOracleAddress = (() => {
84
+ if (parameters.l2OutputOracleAddress)
85
+ return parameters.l2OutputOracleAddress
86
+ if (chain) return targetChain!.contracts.l2OutputOracle[chain.id].address
87
+ return Object.values(targetChain!.contracts.l2OutputOracle)[0].address
88
+ })()
89
+ const portalAddress = (() => {
90
+ if (parameters.portalAddress) return parameters.portalAddress
91
+ if (chain) return targetChain!.contracts.portal[chain.id].address
92
+ return Object.values(targetChain!.contracts.portal)[0].address
93
+ })()
94
+
95
+ const [[_outputRoot, proveTimestamp, _l2OutputIndex], period] =
96
+ await multicall(client, {
97
+ allowFailure: false,
98
+ contracts: [
99
+ {
100
+ abi: portalAbi,
101
+ address: portalAddress,
102
+ functionName: 'provenWithdrawals',
103
+ args: [withdrawalHash],
104
+ },
105
+ {
106
+ abi: l2OutputOracleAbi,
107
+ address: l2OutputOracleAddress,
108
+ functionName: 'FINALIZATION_PERIOD_SECONDS',
109
+ },
110
+ ],
111
+ })
112
+
113
+ const secondsSinceProven = Date.now() / 1000 - Number(proveTimestamp)
114
+ const secondsToFinalize = Number(period) - secondsSinceProven
115
+
116
+ const seconds = Math.floor(
117
+ secondsToFinalize < 0 ? 0 : secondsToFinalize + buffer,
118
+ )
119
+ const timestamp = Date.now() + seconds * 1000
120
+
121
+ return { period: Number(period), seconds, timestamp }
122
+ }
@@ -0,0 +1,162 @@
1
+ import {
2
+ type MulticallErrorType,
3
+ multicall,
4
+ } from '../../../actions/public/multicall.js'
5
+ import {
6
+ type ReadContractErrorType,
7
+ readContract,
8
+ } from '../../../actions/public/readContract.js'
9
+ import type { Client } from '../../../clients/createClient.js'
10
+ import type { Transport } from '../../../clients/transports/createTransport.js'
11
+ import type { ErrorType } from '../../../errors/utils.js'
12
+ import type { Account } from '../../../types/account.js'
13
+ import type {
14
+ Chain,
15
+ DeriveChain,
16
+ GetChainParameter,
17
+ } from '../../../types/chain.js'
18
+ import { l2OutputOracleAbi } from '../abis.js'
19
+ import type { GetContractAddressParameter } from '../types/contract.js'
20
+
21
+ export type GetTimeToNextL2OutputParameters<
22
+ chain extends Chain | undefined = Chain | undefined,
23
+ chainOverride extends Chain | undefined = Chain | undefined,
24
+ _derivedChain extends Chain | undefined = DeriveChain<chain, chainOverride>,
25
+ > = GetChainParameter<chain, chainOverride> &
26
+ GetContractAddressParameter<_derivedChain, 'l2OutputOracle'> & {
27
+ /**
28
+ * The buffer to account for discrepencies between non-deterministic time intervals.
29
+ * @default 1.1
30
+ */
31
+ intervalBuffer?: number
32
+ l2BlockNumber: bigint
33
+ }
34
+ export type GetTimeToNextL2OutputReturnType = {
35
+ /** The interval (in seconds) between L2 outputs. */
36
+ interval: number
37
+ /**
38
+ * Seconds until the next L2 output.
39
+ * `0` if the next L2 output has already been submitted.
40
+ */
41
+ seconds: number
42
+ /**
43
+ * Estimated timestamp of the next L2 output.
44
+ * `undefined` if the next L2 output has already been submitted.
45
+ */
46
+ timestamp?: number
47
+ }
48
+ export type GetTimeToNextL2OutputErrorType =
49
+ | MulticallErrorType
50
+ | ReadContractErrorType
51
+ | ErrorType
52
+
53
+ /**
54
+ * Returns the time until the next L2 output (after the provided block number) is submitted. Used for the [Withdrawal](/op-stack/guides/withdrawals.html) flow.
55
+ *
56
+ * - Docs: https://viem.sh/op-stack/actions/getTimeToNextL2Output.html
57
+ *
58
+ * @param client - Client to use
59
+ * @param parameters - {@link GetTimeToNextL2OutputParameters}
60
+ * @returns The L2 transaction hash. {@link GetTimeToNextL2OutputReturnType}
61
+ *
62
+ * @example
63
+ * import { createPublicClient, http } from 'viem'
64
+ * import { getBlockNumber } from 'viem/actions'
65
+ * import { mainnet, optimism } from 'viem/chains'
66
+ * import { getTimeToNextL2Output } from 'viem/op-stack'
67
+ *
68
+ * const publicClientL1 = createPublicClient({
69
+ * chain: mainnet,
70
+ * transport: http(),
71
+ * })
72
+ * const publicClientL2 = createPublicClient({
73
+ * chain: optimism,
74
+ * transport: http(),
75
+ * })
76
+ *
77
+ * const { seconds } = await getTimeToNextL2Output(publicClientL1, {
78
+ * targetChain: optimism
79
+ * })
80
+ */
81
+ export async function getTimeToNextL2Output<
82
+ chain extends Chain | undefined,
83
+ account extends Account | undefined,
84
+ chainOverride extends Chain | undefined = undefined,
85
+ >(
86
+ client: Client<Transport, chain, account>,
87
+ parameters: GetTimeToNextL2OutputParameters<chain, chainOverride>,
88
+ ): Promise<GetTimeToNextL2OutputReturnType> {
89
+ const {
90
+ intervalBuffer = 1.1,
91
+ chain = client.chain,
92
+ l2BlockNumber,
93
+ targetChain,
94
+ } = parameters
95
+
96
+ const l2OutputOracleAddress = (() => {
97
+ if (parameters.l2OutputOracleAddress)
98
+ return parameters.l2OutputOracleAddress
99
+ if (chain) return targetChain!.contracts.l2OutputOracle[chain.id].address
100
+ return Object.values(targetChain!.contracts.l2OutputOracle)[0].address
101
+ })()
102
+
103
+ const [latestOutputIndex, blockTime, blockInterval] = await multicall(
104
+ client,
105
+ {
106
+ allowFailure: false,
107
+ contracts: [
108
+ {
109
+ abi: l2OutputOracleAbi,
110
+ address: l2OutputOracleAddress,
111
+ functionName: 'latestOutputIndex',
112
+ },
113
+ {
114
+ abi: l2OutputOracleAbi,
115
+ address: l2OutputOracleAddress,
116
+ functionName: 'L2_BLOCK_TIME',
117
+ },
118
+ {
119
+ abi: l2OutputOracleAbi,
120
+ address: l2OutputOracleAddress,
121
+ functionName: 'SUBMISSION_INTERVAL',
122
+ },
123
+ ],
124
+ },
125
+ )
126
+ const latestOutput = await readContract(client, {
127
+ abi: l2OutputOracleAbi,
128
+ address: l2OutputOracleAddress,
129
+ functionName: 'getL2Output',
130
+ args: [latestOutputIndex],
131
+ })
132
+ const latestOutputTimestamp = Number(latestOutput.timestamp) * 1000
133
+
134
+ const interval = Number(blockInterval * blockTime)
135
+ const intervalWithBuffer = Math.ceil(interval * intervalBuffer)
136
+
137
+ const now = Date.now()
138
+
139
+ const seconds = (() => {
140
+ // If the current timestamp is lesser than the latest L2 output timestamp,
141
+ // then we assume that the L2 output has already been submitted.
142
+ if (now < latestOutputTimestamp) return 0
143
+
144
+ // If the latest L2 output block is newer than the provided L2 block number,
145
+ // then we assume that the L2 output has already been submitted.
146
+ if (latestOutput.l2BlockNumber > l2BlockNumber) return 0
147
+
148
+ const elapsedBlocks = Number(l2BlockNumber - latestOutput.l2BlockNumber)
149
+
150
+ const elapsed = Math.ceil((now - latestOutputTimestamp) / 1000)
151
+ const secondsToNextOutput =
152
+ intervalWithBuffer - (elapsed % intervalWithBuffer)
153
+ return elapsedBlocks < blockInterval
154
+ ? secondsToNextOutput
155
+ : Math.floor(elapsedBlocks / Number(blockInterval)) * intervalWithBuffer +
156
+ secondsToNextOutput
157
+ })()
158
+
159
+ const timestamp = seconds > 0 ? now + seconds * 1000 : undefined
160
+
161
+ return { interval, seconds, timestamp }
162
+ }
@@ -0,0 +1,79 @@
1
+ import type { Client } from '../../../clients/createClient.js'
2
+ import type { Transport } from '../../../clients/transports/createTransport.js'
3
+ import type { ErrorType } from '../../../errors/utils.js'
4
+ import type { Account } from '../../../types/account.js'
5
+ import type {
6
+ Chain,
7
+ DeriveChain,
8
+ GetChainParameter,
9
+ } from '../../../types/chain.js'
10
+ import type { TransactionReceipt } from '../../../types/transaction.js'
11
+ import type { GetContractAddressParameter } from '../types/contract.js'
12
+ import {
13
+ type GetTimeToNextL2OutputErrorType,
14
+ type GetTimeToNextL2OutputParameters,
15
+ type GetTimeToNextL2OutputReturnType,
16
+ getTimeToNextL2Output,
17
+ } from './getTimeToNextL2Output.js'
18
+
19
+ export type GetTimeToProveParameters<
20
+ chain extends Chain | undefined = Chain | undefined,
21
+ chainOverride extends Chain | undefined = Chain | undefined,
22
+ _derivedChain extends Chain | undefined = DeriveChain<chain, chainOverride>,
23
+ > = GetChainParameter<chain, chainOverride> &
24
+ GetContractAddressParameter<_derivedChain, 'l2OutputOracle'> & {
25
+ /**
26
+ * The buffer to account for discrepencies between non-deterministic time intervals.
27
+ * @default 1.1
28
+ */
29
+ intervalBuffer?: GetTimeToNextL2OutputParameters['intervalBuffer']
30
+ receipt: TransactionReceipt
31
+ }
32
+ export type GetTimeToProveReturnType = GetTimeToNextL2OutputReturnType
33
+ export type GetTimeToProveErrorType = GetTimeToNextL2OutputErrorType | ErrorType
34
+
35
+ /**
36
+ * Returns the time until the withdrawal transaction is ready to prove. Used for the [Withdrawal](/op-stack/guides/withdrawals.html) flow.
37
+ *
38
+ * - Docs: https://viem.sh/op-stack/actions/getTimeToProve.html
39
+ *
40
+ * @param client - Client to use
41
+ * @param parameters - {@link GetTimeToNextL2OutputParameters}
42
+ * @returns Time until prove step is ready. {@link GetTimeToNextL2OutputReturnType}
43
+ *
44
+ * @example
45
+ * import { createPublicClient, http } from 'viem'
46
+ * import { getBlockNumber } from 'viem/actions'
47
+ * import { mainnet, optimism } from 'viem/chains'
48
+ * import { getTimeToProve } from 'viem/op-stack'
49
+ *
50
+ * const publicClientL1 = createPublicClient({
51
+ * chain: mainnet,
52
+ * transport: http(),
53
+ * })
54
+ * const publicClientL2 = createPublicClient({
55
+ * chain: optimism,
56
+ * transport: http(),
57
+ * })
58
+ *
59
+ * const receipt = await getTransactionReceipt(publicClientL2, { hash: '0x...' })
60
+ * const { period, seconds, timestamp } = await getTimeToProve(publicClientL1, {
61
+ * receipt,
62
+ * targetChain: optimism
63
+ * })
64
+ */
65
+ export async function getTimeToProve<
66
+ chain extends Chain | undefined,
67
+ account extends Account | undefined,
68
+ chainOverride extends Chain | undefined = undefined,
69
+ >(
70
+ client: Client<Transport, chain, account>,
71
+ parameters: GetTimeToProveParameters<chain, chainOverride>,
72
+ ): Promise<GetTimeToProveReturnType> {
73
+ const { receipt } = parameters
74
+
75
+ return getTimeToNextL2Output(client, {
76
+ ...parameters,
77
+ l2BlockNumber: receipt.blockNumber,
78
+ })
79
+ }
@@ -0,0 +1,152 @@
1
+ import {
2
+ type ReadContractErrorType,
3
+ readContract,
4
+ } from '../../../actions/public/readContract.js'
5
+ import type { Client } from '../../../clients/createClient.js'
6
+ import type { Transport } from '../../../clients/transports/createTransport.js'
7
+ import { ContractFunctionRevertedError } from '../../../errors/contract.js'
8
+ import type { ErrorType } from '../../../errors/utils.js'
9
+ import type { Account } from '../../../types/account.js'
10
+ import type {
11
+ Chain,
12
+ DeriveChain,
13
+ GetChainParameter,
14
+ } from '../../../types/chain.js'
15
+ import type { TransactionReceipt } from '../../../types/transaction.js'
16
+ import { portalAbi } from '../abis.js'
17
+ import { ReceiptContainsNoWithdrawalsError } from '../errors/withdrawal.js'
18
+ import type { GetContractAddressParameter } from '../types/contract.js'
19
+ import {
20
+ type GetWithdrawalsErrorType,
21
+ getWithdrawals,
22
+ } from '../utils/getWithdrawals.js'
23
+ import { type GetL2OutputErrorType, getL2Output } from './getL2Output.js'
24
+ import {
25
+ type GetTimeToFinalizeErrorType,
26
+ getTimeToFinalize,
27
+ } from './getTimeToFinalize.js'
28
+
29
+ export type GetWithdrawalStatusParameters<
30
+ chain extends Chain | undefined = Chain | undefined,
31
+ chainOverride extends Chain | undefined = Chain | undefined,
32
+ _derivedChain extends Chain | undefined = DeriveChain<chain, chainOverride>,
33
+ > = GetChainParameter<chain, chainOverride> &
34
+ GetContractAddressParameter<_derivedChain, 'l2OutputOracle' | 'portal'> & {
35
+ receipt: TransactionReceipt
36
+ }
37
+ export type GetWithdrawalStatusReturnType =
38
+ | 'waiting-to-prove'
39
+ | 'ready-to-prove'
40
+ | 'waiting-to-finalize'
41
+ | 'ready-to-finalize'
42
+ | 'finalized'
43
+ export type GetWithdrawalStatusErrorType =
44
+ | GetL2OutputErrorType
45
+ | GetTimeToFinalizeErrorType
46
+ | GetWithdrawalsErrorType
47
+ | ReadContractErrorType
48
+ | ErrorType
49
+
50
+ /**
51
+ * Returns the current status of a withdrawal. Used for the [Withdrawal](/op-stack/guides/withdrawals.html) flow.
52
+ *
53
+ * - Docs: https://viem.sh/op-stack/actions/getWithdrawalStatus.html
54
+ *
55
+ * @param client - Client to use
56
+ * @param parameters - {@link GetWithdrawalStatusParameters}
57
+ * @returns Status of the withdrawal. {@link GetWithdrawalStatusReturnType}
58
+ *
59
+ * @example
60
+ * import { createPublicClient, http } from 'viem'
61
+ * import { getBlockNumber } from 'viem/actions'
62
+ * import { mainnet, optimism } from 'viem/chains'
63
+ * import { getWithdrawalStatus } from 'viem/op-stack'
64
+ *
65
+ * const publicClientL1 = createPublicClient({
66
+ * chain: mainnet,
67
+ * transport: http(),
68
+ * })
69
+ * const publicClientL2 = createPublicClient({
70
+ * chain: optimism,
71
+ * transport: http(),
72
+ * })
73
+ *
74
+ * const receipt = await getTransactionReceipt(publicClientL2, { hash: '0x...' })
75
+ * const status = await getWithdrawalStatus(publicClientL1, {
76
+ * receipt,
77
+ * targetChain: optimism
78
+ * })
79
+ */
80
+ export async function getWithdrawalStatus<
81
+ chain extends Chain | undefined,
82
+ account extends Account | undefined,
83
+ chainOverride extends Chain | undefined = undefined,
84
+ >(
85
+ client: Client<Transport, chain, account>,
86
+ parameters: GetWithdrawalStatusParameters<chain, chainOverride>,
87
+ ): Promise<GetWithdrawalStatusReturnType> {
88
+ const { chain = client.chain, receipt, targetChain } = parameters
89
+
90
+ const portalAddress = (() => {
91
+ if (parameters.portalAddress) return parameters.portalAddress
92
+ if (chain) return targetChain!.contracts.portal[chain.id].address
93
+ return Object.values(targetChain!.contracts.portal)[0].address
94
+ })()
95
+
96
+ const [withdrawal] = getWithdrawals(receipt)
97
+
98
+ if (!withdrawal)
99
+ throw new ReceiptContainsNoWithdrawalsError({
100
+ hash: receipt.transactionHash,
101
+ })
102
+
103
+ const [outputResult, proveResult, finalizedResult, timeToFinalizeResult] =
104
+ await Promise.allSettled([
105
+ getL2Output(client, {
106
+ ...parameters,
107
+ l2BlockNumber: receipt.blockNumber,
108
+ }),
109
+ readContract(client, {
110
+ abi: portalAbi,
111
+ address: portalAddress,
112
+ functionName: 'provenWithdrawals',
113
+ args: [withdrawal.withdrawalHash],
114
+ }),
115
+ readContract(client, {
116
+ abi: portalAbi,
117
+ address: portalAddress,
118
+ functionName: 'finalizedWithdrawals',
119
+ args: [withdrawal.withdrawalHash],
120
+ }),
121
+ getTimeToFinalize(client, {
122
+ ...parameters,
123
+ withdrawalHash: withdrawal.withdrawalHash,
124
+ }),
125
+ ])
126
+
127
+ // If the L2 Output is not processed yet (ie. the actions throws), this means
128
+ // that the withdrawal is not ready to prove.
129
+ if (outputResult.status === 'rejected') {
130
+ const error = outputResult.reason as GetL2OutputErrorType
131
+ if (
132
+ error.cause instanceof ContractFunctionRevertedError &&
133
+ error.cause.data?.args?.[0] ===
134
+ 'L2OutputOracle: cannot get output for a block that has not been proposed'
135
+ )
136
+ return 'waiting-to-prove'
137
+ throw error
138
+ }
139
+ if (proveResult.status === 'rejected') throw proveResult.reason
140
+ if (finalizedResult.status === 'rejected') throw finalizedResult.reason
141
+ if (timeToFinalizeResult.status === 'rejected')
142
+ throw timeToFinalizeResult.reason
143
+
144
+ const [_, proveTimestamp] = proveResult.value
145
+ if (!proveTimestamp) return 'ready-to-prove'
146
+
147
+ const finalized = finalizedResult.value
148
+ if (finalized) return 'finalized'
149
+
150
+ const { seconds } = timeToFinalizeResult.value
151
+ return seconds > 0 ? 'waiting-to-finalize' : 'ready-to-finalize'
152
+ }
@@ -0,0 +1,153 @@
1
+ import type { Address } from 'abitype'
2
+ import {
3
+ type WriteContractErrorType,
4
+ type WriteContractParameters,
5
+ writeContract,
6
+ } from '../../../actions/wallet/writeContract.js'
7
+ import type { Client } from '../../../clients/createClient.js'
8
+ import type { Transport } from '../../../clients/transports/createTransport.js'
9
+ import type { ErrorType } from '../../../errors/utils.js'
10
+ import type { Account, GetAccountParameter } from '../../../types/account.js'
11
+ import type {
12
+ Chain,
13
+ DeriveChain,
14
+ GetChainParameter,
15
+ } from '../../../types/chain.js'
16
+ import type { Hash } from '../../../types/misc.js'
17
+ import type { UnionEvaluate, UnionOmit } from '../../../types/utils.js'
18
+ import type { FormattedTransactionRequest } from '../../../utils/formatters/transactionRequest.js'
19
+ import { l2ToL1MessagePasserAbi } from '../abis.js'
20
+ import { contracts } from '../contracts.js'
21
+ import type { WithdrawalRequest } from '../types/withdrawal.js'
22
+ import {
23
+ type EstimateInitiateWithdrawalGasErrorType,
24
+ type EstimateInitiateWithdrawalGasParameters,
25
+ estimateInitiateWithdrawalGas,
26
+ } from './estimateInitiateWithdrawalGas.js'
27
+
28
+ export type InitiateWithdrawalParameters<
29
+ chain extends Chain | undefined = Chain | undefined,
30
+ account extends Account | undefined = Account | undefined,
31
+ chainOverride extends Chain | undefined = Chain | undefined,
32
+ _derivedChain extends Chain | undefined = DeriveChain<chain, chainOverride>,
33
+ > = UnionEvaluate<
34
+ UnionOmit<
35
+ FormattedTransactionRequest<_derivedChain>,
36
+ | 'accessList'
37
+ | 'data'
38
+ | 'from'
39
+ | 'gas'
40
+ | 'gasPrice'
41
+ | 'to'
42
+ | 'type'
43
+ | 'value'
44
+ >
45
+ > &
46
+ GetAccountParameter<account, Account | Address> &
47
+ GetChainParameter<chain, chainOverride> & {
48
+ /**
49
+ * Gas limit for transaction execution on the L2.
50
+ * `null` to skip gas estimation & defer calculation to signer.
51
+ */
52
+ gas?: bigint | null
53
+ /** Withdrawal request. Supplied to the L2ToL1MessagePasser `initiateWithdrawal` method. */
54
+ request: WithdrawalRequest
55
+ }
56
+ export type InitiateWithdrawalReturnType = Hash
57
+ export type InitiateWithdrawalErrorType =
58
+ | EstimateInitiateWithdrawalGasErrorType
59
+ | WriteContractErrorType
60
+ | ErrorType
61
+
62
+ /**
63
+ * Initiates a [withdrawal](https://community.optimism.io/docs/protocol/withdrawal-flow/#withdrawal-initiating-transaction) on an L2 to the L1.
64
+ *
65
+ * Internally performs a contract write to the [`initiateWithdrawal` function](https://github.com/ethereum-optimism/optimism/blob/283f0aa2e3358ced30ff7cbd4028c0c0c3faa140/packages/contracts-bedrock/src/L2/L2ToL1MessagePasser.sol#L73)
66
+ * on the [Optimism L2ToL1MessagePasser predeploy contract](https://github.com/ethereum-optimism/optimism/blob/283f0aa2e3358ced30ff7cbd4028c0c0c3faa140/packages/contracts-bedrock/src/L2/L2ToL1MessagePasser.sol).
67
+ *
68
+ * - Docs: https://viem.sh/op-stack/actions/initiateWithdrawal.html
69
+ *
70
+ * @param client - Client to use
71
+ * @param parameters - {@link InitiateWithdrawalParameters}
72
+ * @returns The L2 transaction hash. {@link InitiateWithdrawalReturnType}
73
+ *
74
+ * @example
75
+ * import { createWalletClient, custom, parseEther } from 'viem'
76
+ * import { base, mainnet } from 'viem/chains'
77
+ * import { initiateWithdrawal } from 'viem/op-stack'
78
+ *
79
+ * const client = createWalletClient({
80
+ * chain: mainnet,
81
+ * transport: custom(window.ethereum),
82
+ * })
83
+ *
84
+ * const hash = await initiateWithdrawal(client, {
85
+ * account: '0xA0Cf798816D4b9b9866b5330EEa46a18382f251e',
86
+ * args: {
87
+ * gas: 21_000n,
88
+ * to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
89
+ * value: parseEther('1'),
90
+ * },
91
+ * })
92
+ *
93
+ * @example
94
+ * // Account Hoisting
95
+ * import { createWalletClient, http } from 'viem'
96
+ * import { privateKeyToAccount } from 'viem/accounts'
97
+ * import { base, mainnet } from 'viem/chains'
98
+ * import { initiateWithdrawal } from 'viem/op-stack'
99
+ *
100
+ * const client = createWalletClient({
101
+ * account: privateKeyToAccount('0x…'),
102
+ * chain: mainnet,
103
+ * transport: http(),
104
+ * })
105
+ *
106
+ * const hash = await initiateWithdrawal(client, {
107
+ * request: {
108
+ * gas: 21_000n,
109
+ * to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
110
+ * value: parseEther('1'),
111
+ * },
112
+ * })
113
+ */
114
+ export async function initiateWithdrawal<
115
+ chain extends Chain | undefined,
116
+ account extends Account | undefined,
117
+ chainOverride extends Chain | undefined = undefined,
118
+ >(
119
+ client: Client<Transport, chain, account>,
120
+ parameters: InitiateWithdrawalParameters<chain, account, chainOverride>,
121
+ ) {
122
+ const {
123
+ account,
124
+ chain = client.chain,
125
+ gas,
126
+ maxFeePerGas,
127
+ maxPriorityFeePerGas,
128
+ nonce,
129
+ request: { data = '0x', gas: l1Gas, to, value },
130
+ } = parameters
131
+
132
+ const gas_ =
133
+ typeof gas !== 'number' && gas !== null
134
+ ? await estimateInitiateWithdrawalGas(
135
+ client,
136
+ parameters as EstimateInitiateWithdrawalGasParameters,
137
+ )
138
+ : undefined
139
+
140
+ return writeContract(client, {
141
+ account: account!,
142
+ abi: l2ToL1MessagePasserAbi,
143
+ address: contracts.l2ToL1MessagePasser.address,
144
+ chain,
145
+ functionName: 'initiateWithdrawal',
146
+ args: [to, l1Gas, data],
147
+ gas: gas_,
148
+ maxFeePerGas,
149
+ maxPriorityFeePerGas,
150
+ nonce,
151
+ value,
152
+ } satisfies WriteContractParameters as any)
153
+ }