@aztec/ethereum 0.0.0-test.1 → 0.0.1-commit.0208eb9

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 (285) hide show
  1. package/dest/account.d.ts +2 -0
  2. package/dest/account.d.ts.map +1 -0
  3. package/dest/account.js +4 -0
  4. package/dest/chain.d.ts +1 -1
  5. package/dest/client.d.ts +6 -4
  6. package/dest/client.d.ts.map +1 -1
  7. package/dest/client.js +21 -3
  8. package/dest/config.d.ts +68 -23
  9. package/dest/config.d.ts.map +1 -1
  10. package/dest/config.js +145 -32
  11. package/dest/constants.d.ts +1 -1
  12. package/dest/contracts/empire_base.d.ts +25 -8
  13. package/dest/contracts/empire_base.d.ts.map +1 -1
  14. package/dest/contracts/empire_base.js +75 -2
  15. package/dest/contracts/empire_slashing_proposer.d.ts +67 -0
  16. package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -0
  17. package/dest/contracts/empire_slashing_proposer.js +207 -0
  18. package/dest/contracts/errors.d.ts +7 -0
  19. package/dest/contracts/errors.d.ts.map +1 -0
  20. package/dest/contracts/errors.js +12 -0
  21. package/dest/contracts/fee_asset_handler.d.ts +20 -0
  22. package/dest/contracts/fee_asset_handler.d.ts.map +1 -0
  23. package/dest/contracts/fee_asset_handler.js +59 -0
  24. package/dest/contracts/fee_juice.d.ts +6 -7
  25. package/dest/contracts/fee_juice.d.ts.map +1 -1
  26. package/dest/contracts/fee_juice.js +27 -20
  27. package/dest/contracts/governance.d.ts +45 -32
  28. package/dest/contracts/governance.d.ts.map +1 -1
  29. package/dest/contracts/governance.js +98 -85
  30. package/dest/contracts/governance_proposer.d.ts +17 -13
  31. package/dest/contracts/governance_proposer.d.ts.map +1 -1
  32. package/dest/contracts/governance_proposer.js +432 -26
  33. package/dest/contracts/gse.d.ts +32 -0
  34. package/dest/contracts/gse.d.ts.map +1 -0
  35. package/dest/contracts/gse.js +72 -0
  36. package/dest/contracts/inbox.d.ts +47 -0
  37. package/dest/contracts/inbox.d.ts.map +1 -0
  38. package/dest/contracts/inbox.js +80 -0
  39. package/dest/contracts/index.d.ts +11 -3
  40. package/dest/contracts/index.d.ts.map +1 -1
  41. package/dest/contracts/index.js +10 -2
  42. package/dest/contracts/log.d.ts +13 -0
  43. package/dest/contracts/log.d.ts.map +1 -0
  44. package/dest/contracts/log.js +1 -0
  45. package/dest/contracts/multicall.d.ts +21 -0
  46. package/dest/contracts/multicall.d.ts.map +1 -0
  47. package/dest/contracts/multicall.js +157 -0
  48. package/dest/contracts/outbox.d.ts +41 -0
  49. package/dest/contracts/outbox.d.ts.map +1 -0
  50. package/dest/contracts/outbox.js +86 -0
  51. package/dest/contracts/registry.d.ts +10 -5
  52. package/dest/contracts/registry.d.ts.map +1 -1
  53. package/dest/contracts/registry.js +44 -16
  54. package/dest/contracts/rollup.d.ts +297 -53
  55. package/dest/contracts/rollup.d.ts.map +1 -1
  56. package/dest/contracts/rollup.js +1127 -116
  57. package/dest/contracts/slasher_contract.d.ts +44 -0
  58. package/dest/contracts/slasher_contract.d.ts.map +1 -0
  59. package/dest/contracts/slasher_contract.js +75 -0
  60. package/dest/contracts/tally_slashing_proposer.d.ts +140 -0
  61. package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -0
  62. package/dest/contracts/tally_slashing_proposer.js +320 -0
  63. package/dest/contracts/utils.d.ts +3 -0
  64. package/dest/contracts/utils.d.ts.map +1 -0
  65. package/dest/contracts/utils.js +11 -0
  66. package/dest/deploy_aztec_l1_contracts.d.ts +260 -0
  67. package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
  68. package/dest/deploy_aztec_l1_contracts.js +399 -0
  69. package/dest/deploy_l1_contract.d.ts +68 -0
  70. package/dest/deploy_l1_contract.d.ts.map +1 -0
  71. package/dest/deploy_l1_contract.js +312 -0
  72. package/dest/eth-signer/eth-signer.d.ts +21 -0
  73. package/dest/eth-signer/eth-signer.d.ts.map +1 -0
  74. package/dest/eth-signer/eth-signer.js +5 -0
  75. package/dest/eth-signer/index.d.ts +2 -0
  76. package/dest/eth-signer/index.d.ts.map +1 -0
  77. package/dest/eth-signer/index.js +1 -0
  78. package/dest/forwarder_proxy.d.ts +32 -0
  79. package/dest/forwarder_proxy.d.ts.map +1 -0
  80. package/dest/forwarder_proxy.js +93 -0
  81. package/dest/generated/l1-contracts-defaults.d.ts +30 -0
  82. package/dest/generated/l1-contracts-defaults.d.ts.map +1 -0
  83. package/dest/generated/l1-contracts-defaults.js +30 -0
  84. package/dest/l1_artifacts.d.ts +80735 -0
  85. package/dest/l1_artifacts.d.ts.map +1 -0
  86. package/dest/l1_artifacts.js +166 -0
  87. package/dest/l1_contract_addresses.d.ts +24 -4
  88. package/dest/l1_contract_addresses.d.ts.map +1 -1
  89. package/dest/l1_contract_addresses.js +25 -21
  90. package/dest/l1_reader.d.ts +4 -2
  91. package/dest/l1_reader.d.ts.map +1 -1
  92. package/dest/l1_reader.js +14 -8
  93. package/dest/l1_tx_utils/config.d.ts +59 -0
  94. package/dest/l1_tx_utils/config.d.ts.map +1 -0
  95. package/dest/l1_tx_utils/config.js +96 -0
  96. package/dest/l1_tx_utils/constants.d.ts +12 -0
  97. package/dest/l1_tx_utils/constants.d.ts.map +1 -0
  98. package/dest/l1_tx_utils/constants.js +39 -0
  99. package/dest/l1_tx_utils/factory.d.ts +24 -0
  100. package/dest/l1_tx_utils/factory.d.ts.map +1 -0
  101. package/dest/l1_tx_utils/factory.js +12 -0
  102. package/dest/l1_tx_utils/fee-strategies/index.d.ts +10 -0
  103. package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
  104. package/dest/l1_tx_utils/fee-strategies/index.js +12 -0
  105. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +8 -0
  106. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
  107. package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +129 -0
  108. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +23 -0
  109. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
  110. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +191 -0
  111. package/dest/l1_tx_utils/fee-strategies/types.d.ts +51 -0
  112. package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
  113. package/dest/l1_tx_utils/fee-strategies/types.js +3 -0
  114. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
  115. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
  116. package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +48 -0
  117. package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
  118. package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
  119. package/dest/l1_tx_utils/index-blobs.js +2 -0
  120. package/dest/l1_tx_utils/index.d.ts +12 -0
  121. package/dest/l1_tx_utils/index.d.ts.map +1 -0
  122. package/dest/l1_tx_utils/index.js +12 -0
  123. package/dest/l1_tx_utils/interfaces.d.ts +76 -0
  124. package/dest/l1_tx_utils/interfaces.d.ts.map +1 -0
  125. package/dest/l1_tx_utils/interfaces.js +4 -0
  126. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
  127. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
  128. package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
  129. package/dest/l1_tx_utils/l1_tx_utils.d.ts +94 -0
  130. package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -0
  131. package/dest/l1_tx_utils/l1_tx_utils.js +623 -0
  132. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +26 -0
  133. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +1 -0
  134. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.js +26 -0
  135. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +83 -0
  136. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -0
  137. package/dest/l1_tx_utils/readonly_l1_tx_utils.js +323 -0
  138. package/dest/l1_tx_utils/signer.d.ts +4 -0
  139. package/dest/l1_tx_utils/signer.d.ts.map +1 -0
  140. package/dest/l1_tx_utils/signer.js +16 -0
  141. package/dest/l1_tx_utils/types.d.ts +67 -0
  142. package/dest/l1_tx_utils/types.d.ts.map +1 -0
  143. package/dest/l1_tx_utils/types.js +26 -0
  144. package/dest/l1_tx_utils/utils.d.ts +4 -0
  145. package/dest/l1_tx_utils/utils.d.ts.map +1 -0
  146. package/dest/l1_tx_utils/utils.js +14 -0
  147. package/dest/l1_types.d.ts +6 -0
  148. package/dest/l1_types.d.ts.map +1 -0
  149. package/dest/l1_types.js +1 -0
  150. package/dest/publisher_manager.d.ts +16 -0
  151. package/dest/publisher_manager.d.ts.map +1 -0
  152. package/dest/publisher_manager.js +88 -0
  153. package/dest/queries.d.ts +5 -3
  154. package/dest/queries.d.ts.map +1 -1
  155. package/dest/queries.js +61 -12
  156. package/dest/test/chain_monitor.d.ts +75 -0
  157. package/dest/test/chain_monitor.d.ts.map +1 -0
  158. package/dest/test/chain_monitor.js +213 -0
  159. package/dest/test/delayed_tx_utils.d.ts +8 -3
  160. package/dest/test/delayed_tx_utils.d.ts.map +1 -1
  161. package/dest/test/delayed_tx_utils.js +13 -6
  162. package/dest/test/eth_cheat_codes.d.ts +229 -0
  163. package/dest/test/eth_cheat_codes.d.ts.map +1 -0
  164. package/dest/test/eth_cheat_codes.js +560 -0
  165. package/dest/test/eth_cheat_codes_with_state.d.ts +2 -2
  166. package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
  167. package/dest/test/eth_cheat_codes_with_state.js +1 -1
  168. package/dest/test/index.d.ts +4 -1
  169. package/dest/test/index.d.ts.map +1 -1
  170. package/dest/test/index.js +3 -0
  171. package/dest/test/rollup_cheat_codes.d.ts +90 -0
  172. package/dest/test/rollup_cheat_codes.d.ts.map +1 -0
  173. package/dest/test/rollup_cheat_codes.js +292 -0
  174. package/dest/test/start_anvil.d.ts +9 -1
  175. package/dest/test/start_anvil.d.ts.map +1 -1
  176. package/dest/test/start_anvil.js +16 -7
  177. package/dest/test/tx_delayer.d.ts +18 -7
  178. package/dest/test/tx_delayer.d.ts.map +1 -1
  179. package/dest/test/tx_delayer.js +97 -20
  180. package/dest/test/upgrade_utils.d.ts +6 -5
  181. package/dest/test/upgrade_utils.d.ts.map +1 -1
  182. package/dest/test/upgrade_utils.js +23 -16
  183. package/dest/types.d.ts +62 -8
  184. package/dest/types.d.ts.map +1 -1
  185. package/dest/types.js +3 -1
  186. package/dest/utils.d.ts +17 -3
  187. package/dest/utils.d.ts.map +1 -1
  188. package/dest/utils.js +107 -88
  189. package/dest/zkPassportVerifierAddress.d.ts +15 -0
  190. package/dest/zkPassportVerifierAddress.d.ts.map +1 -0
  191. package/dest/zkPassportVerifierAddress.js +11 -0
  192. package/package.json +51 -23
  193. package/src/account.ts +5 -0
  194. package/src/client.ts +43 -5
  195. package/src/config.ts +207 -41
  196. package/src/contracts/README.md +157 -0
  197. package/src/contracts/empire_base.ts +77 -7
  198. package/src/contracts/empire_slashing_proposer.ts +259 -0
  199. package/src/contracts/errors.ts +13 -0
  200. package/src/contracts/fee_asset_handler.ts +66 -0
  201. package/src/contracts/fee_juice.ts +29 -15
  202. package/src/contracts/governance.ts +90 -78
  203. package/src/contracts/governance_proposer.ts +75 -25
  204. package/src/contracts/gse.ts +88 -0
  205. package/src/contracts/inbox.ts +115 -0
  206. package/src/contracts/index.ts +10 -2
  207. package/src/contracts/log.ts +13 -0
  208. package/src/contracts/multicall.ts +158 -0
  209. package/src/contracts/outbox.ts +98 -0
  210. package/src/contracts/registry.ts +51 -26
  211. package/src/contracts/rollup.ts +879 -89
  212. package/src/contracts/slasher_contract.ts +89 -0
  213. package/src/contracts/tally_slashing_proposer.ts +322 -0
  214. package/src/contracts/utils.ts +14 -0
  215. package/src/deploy_aztec_l1_contracts.ts +623 -0
  216. package/src/deploy_l1_contract.ts +362 -0
  217. package/src/eth-signer/eth-signer.ts +25 -0
  218. package/src/eth-signer/index.ts +1 -0
  219. package/src/forwarder_proxy.ts +108 -0
  220. package/src/generated/l1-contracts-defaults.ts +32 -0
  221. package/src/l1_artifacts.ts +254 -0
  222. package/src/l1_contract_addresses.ts +49 -34
  223. package/src/l1_reader.ts +17 -9
  224. package/src/l1_tx_utils/README.md +177 -0
  225. package/src/l1_tx_utils/config.ts +161 -0
  226. package/src/l1_tx_utils/constants.ts +29 -0
  227. package/src/l1_tx_utils/factory.ts +64 -0
  228. package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
  229. package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +163 -0
  230. package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +245 -0
  231. package/src/l1_tx_utils/fee-strategies/types.ts +56 -0
  232. package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +119 -0
  233. package/src/l1_tx_utils/index-blobs.ts +2 -0
  234. package/src/l1_tx_utils/index.ts +14 -0
  235. package/src/l1_tx_utils/interfaces.ts +86 -0
  236. package/src/l1_tx_utils/l1_fee_analyzer.ts +803 -0
  237. package/src/l1_tx_utils/l1_tx_utils.ts +738 -0
  238. package/src/l1_tx_utils/l1_tx_utils_with_blobs.ts +77 -0
  239. package/src/l1_tx_utils/readonly_l1_tx_utils.ts +419 -0
  240. package/src/l1_tx_utils/signer.ts +28 -0
  241. package/src/l1_tx_utils/types.ts +85 -0
  242. package/src/l1_tx_utils/utils.ts +16 -0
  243. package/src/l1_types.ts +6 -0
  244. package/src/publisher_manager.ts +108 -0
  245. package/src/queries.ts +82 -16
  246. package/src/test/chain_monitor.ts +245 -0
  247. package/src/test/delayed_tx_utils.ts +34 -6
  248. package/src/test/eth_cheat_codes.ts +588 -0
  249. package/src/test/eth_cheat_codes_with_state.ts +1 -1
  250. package/src/test/index.ts +3 -0
  251. package/src/test/rollup_cheat_codes.ts +330 -0
  252. package/src/test/start_anvil.ts +24 -5
  253. package/src/test/tx_delayer.ts +130 -27
  254. package/src/test/upgrade_utils.ts +30 -21
  255. package/src/types.ts +71 -7
  256. package/src/utils.ts +133 -92
  257. package/src/zkPassportVerifierAddress.ts +15 -0
  258. package/dest/contracts/forwarder.d.ts +0 -24
  259. package/dest/contracts/forwarder.d.ts.map +0 -1
  260. package/dest/contracts/forwarder.js +0 -101
  261. package/dest/contracts/slashing_proposer.d.ts +0 -21
  262. package/dest/contracts/slashing_proposer.d.ts.map +0 -1
  263. package/dest/contracts/slashing_proposer.js +0 -47
  264. package/dest/deploy_l1_contracts.d.ts +0 -21210
  265. package/dest/deploy_l1_contracts.d.ts.map +0 -1
  266. package/dest/deploy_l1_contracts.js +0 -687
  267. package/dest/eth_cheat_codes.d.ts +0 -147
  268. package/dest/eth_cheat_codes.d.ts.map +0 -1
  269. package/dest/eth_cheat_codes.js +0 -303
  270. package/dest/index.d.ts +0 -14
  271. package/dest/index.d.ts.map +0 -1
  272. package/dest/index.js +0 -13
  273. package/dest/l1_tx_utils.d.ts +0 -192
  274. package/dest/l1_tx_utils.d.ts.map +0 -1
  275. package/dest/l1_tx_utils.js +0 -641
  276. package/dest/l1_tx_utils_with_blobs.d.ts +0 -12
  277. package/dest/l1_tx_utils_with_blobs.d.ts.map +0 -1
  278. package/dest/l1_tx_utils_with_blobs.js +0 -64
  279. package/src/contracts/forwarder.ts +0 -132
  280. package/src/contracts/slashing_proposer.ts +0 -51
  281. package/src/deploy_l1_contracts.ts +0 -948
  282. package/src/eth_cheat_codes.ts +0 -314
  283. package/src/index.ts +0 -13
  284. package/src/l1_tx_utils.ts +0 -847
  285. package/src/l1_tx_utils_with_blobs.ts +0 -86
@@ -0,0 +1,44 @@
1
+ import { EthAddress } from '@aztec/foundation/eth-address';
2
+ import type { ViemClient } from '../types.js';
3
+ /**
4
+ * Typescript wrapper around the Slasher contract.
5
+ */
6
+ export declare class SlasherContract {
7
+ private readonly client;
8
+ private readonly address;
9
+ private readonly log;
10
+ private contract;
11
+ constructor(client: ViemClient, address: EthAddress, log?: import("@aztec/foundation/log").Logger);
12
+ /**
13
+ * Checks if a slash payload is vetoed.
14
+ * @param payloadAddress - The address of the payload to check
15
+ * @returns True if the payload is vetoed, false otherwise
16
+ */
17
+ isPayloadVetoed(payloadAddress: EthAddress): Promise<boolean>;
18
+ /**
19
+ * Checks if slashing is currently enabled. Slashing can be disabled by the vetoer.
20
+ * @returns True if slashing is enabled, false otherwise
21
+ */
22
+ isSlashingEnabled(): Promise<boolean>;
23
+ /**
24
+ * Gets the current vetoer address.
25
+ * @returns The vetoer address
26
+ */
27
+ getVetoer(): Promise<EthAddress>;
28
+ /**
29
+ * Gets the disable duration by the vetoer.
30
+ * @returns The disable duration in seconds
31
+ */
32
+ getSlashingDisableDuration(): Promise<number>;
33
+ /**
34
+ * Gets the current governance address.
35
+ * @returns The governance address
36
+ */
37
+ getGovernance(): Promise<EthAddress>;
38
+ /**
39
+ * Gets the current proposer address.
40
+ * @returns The proposer address
41
+ */
42
+ getProposer(): Promise<EthAddress>;
43
+ }
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xhc2hlcl9jb250cmFjdC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyYWN0cy9zbGFzaGVyX2NvbnRyYWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQU0zRCxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFOUM7O0dBRUc7QUFDSCxxQkFBYSxlQUFlO0lBSXhCLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTTtJQUN2QixPQUFPLENBQUMsUUFBUSxDQUFDLE9BQU87SUFDeEIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHO0lBTHRCLE9BQU8sQ0FBQyxRQUFRLENBQXVEO0lBRXZFLFlBQ21CLE1BQU0sRUFBRSxVQUFVLEVBQ2xCLE9BQU8sRUFBRSxVQUFVLEVBQ25CLEdBQUcseUNBQW1DLEVBT3hEO0lBRUQ7Ozs7T0FJRztJQUNVLGVBQWUsQ0FBQyxjQUFjLEVBQUUsVUFBVSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FPekU7SUFFRDs7O09BR0c7SUFDVSxpQkFBaUIsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLENBT2pEO0lBRUQ7OztPQUdHO0lBQ1UsU0FBUyxJQUFJLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FHNUM7SUFFRDs7O09BR0c7SUFDVSwwQkFBMEIsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLENBR3pEO0lBRUQ7OztPQUdHO0lBQ1UsYUFBYSxJQUFJLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FHaEQ7SUFFRDs7O09BR0c7SUFDVSxXQUFXLElBQUksT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUc5QztDQUNGIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slasher_contract.d.ts","sourceRoot":"","sources":["../../src/contracts/slasher_contract.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAM3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAE9C;;GAEG;AACH,qBAAa,eAAe;IAIxB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,GAAG;IALtB,OAAO,CAAC,QAAQ,CAAuD;IAEvE,YACmB,MAAM,EAAE,UAAU,EAClB,OAAO,EAAE,UAAU,EACnB,GAAG,yCAAmC,EAOxD;IAED;;;;OAIG;IACU,eAAe,CAAC,cAAc,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,CAOzE;IAED;;;OAGG;IACU,iBAAiB,IAAI,OAAO,CAAC,OAAO,CAAC,CAOjD;IAED;;;OAGG;IACU,SAAS,IAAI,OAAO,CAAC,UAAU,CAAC,CAG5C;IAED;;;OAGG;IACU,0BAA0B,IAAI,OAAO,CAAC,MAAM,CAAC,CAGzD;IAED;;;OAGG;IACU,aAAa,IAAI,OAAO,CAAC,UAAU,CAAC,CAGhD;IAED;;;OAGG;IACU,WAAW,IAAI,OAAO,CAAC,UAAU,CAAC,CAG9C;CACF"}
@@ -0,0 +1,75 @@
1
+ import { EthAddress } from '@aztec/foundation/eth-address';
2
+ import { createLogger } from '@aztec/foundation/log';
3
+ import { SlasherAbi } from '@aztec/l1-artifacts/SlasherAbi';
4
+ import { getContract } from 'viem';
5
+ /**
6
+ * Typescript wrapper around the Slasher contract.
7
+ */ export class SlasherContract {
8
+ client;
9
+ address;
10
+ log;
11
+ contract;
12
+ constructor(client, address, log = createLogger('slasher-contract')){
13
+ this.client = client;
14
+ this.address = address;
15
+ this.log = log;
16
+ this.contract = getContract({
17
+ address: this.address.toString(),
18
+ abi: SlasherAbi,
19
+ client: this.client
20
+ });
21
+ }
22
+ /**
23
+ * Checks if a slash payload is vetoed.
24
+ * @param payloadAddress - The address of the payload to check
25
+ * @returns True if the payload is vetoed, false otherwise
26
+ */ async isPayloadVetoed(payloadAddress) {
27
+ try {
28
+ return await this.contract.read.vetoedPayloads([
29
+ payloadAddress.toString()
30
+ ]);
31
+ } catch (error) {
32
+ this.log.error(`Error checking if payload ${payloadAddress} is vetoed`, error);
33
+ throw error;
34
+ }
35
+ }
36
+ /**
37
+ * Checks if slashing is currently enabled. Slashing can be disabled by the vetoer.
38
+ * @returns True if slashing is enabled, false otherwise
39
+ */ async isSlashingEnabled() {
40
+ try {
41
+ return await this.contract.read.isSlashingEnabled();
42
+ } catch (error) {
43
+ this.log.error(`Error checking if slashing is enabled`, error);
44
+ throw error;
45
+ }
46
+ }
47
+ /**
48
+ * Gets the current vetoer address.
49
+ * @returns The vetoer address
50
+ */ async getVetoer() {
51
+ const vetoer = await this.contract.read.VETOER();
52
+ return EthAddress.fromString(vetoer);
53
+ }
54
+ /**
55
+ * Gets the disable duration by the vetoer.
56
+ * @returns The disable duration in seconds
57
+ */ async getSlashingDisableDuration() {
58
+ const duration = await this.contract.read.SLASHING_DISABLE_DURATION();
59
+ return Number(duration);
60
+ }
61
+ /**
62
+ * Gets the current governance address.
63
+ * @returns The governance address
64
+ */ async getGovernance() {
65
+ const governance = await this.contract.read.GOVERNANCE();
66
+ return EthAddress.fromString(governance);
67
+ }
68
+ /**
69
+ * Gets the current proposer address.
70
+ * @returns The proposer address
71
+ */ async getProposer() {
72
+ const proposer = await this.contract.read.PROPOSER();
73
+ return EthAddress.fromString(proposer);
74
+ }
75
+ }
@@ -0,0 +1,140 @@
1
+ import type { L1TxRequest } from '@aztec/ethereum/l1-tx-utils';
2
+ import type { ViemClient } from '@aztec/ethereum/types';
3
+ import { SlotNumber } from '@aztec/foundation/branded-types';
4
+ import { Buffer32 } from '@aztec/foundation/buffer';
5
+ import { EthAddress } from '@aztec/foundation/eth-address';
6
+ import { type Hex, type Log, type TypedDataDefinition } from 'viem';
7
+ /**
8
+ * Wrapper around the TallySlashingProposer contract that provides
9
+ * a TypeScript interface for interacting with the consensus-based slashing system.
10
+ */
11
+ export declare class TallySlashingProposerContract {
12
+ readonly client: ViemClient;
13
+ private readonly contract;
14
+ readonly type: "tally";
15
+ constructor(client: ViemClient, address: Hex | EthAddress);
16
+ get address(): EthAddress;
17
+ getQuorumSize(): Promise<bigint>;
18
+ getRoundSize(): Promise<bigint>;
19
+ getCommitteeSize(): Promise<bigint>;
20
+ getRoundSizeInEpochs(): Promise<bigint>;
21
+ getLifetimeInRounds(): Promise<bigint>;
22
+ getExecutionDelayInRounds(): Promise<bigint>;
23
+ getSlashingAmounts(): Promise<[bigint, bigint, bigint]>;
24
+ getSlashOffsetInRounds(): Promise<bigint>;
25
+ getCurrentRound(): Promise<bigint>;
26
+ /**
27
+ * Get round information
28
+ * @param round - The round number to query
29
+ * @returns Round status information
30
+ */
31
+ getRound(round: bigint): Promise<{
32
+ isExecuted: boolean;
33
+ voteCount: bigint;
34
+ }>;
35
+ /**
36
+ * Check if a round is ready to execute at a given slot
37
+ * @param round - The round number to check
38
+ * @param slot - The slot number to check at
39
+ * @returns Whether the round is ready to execute
40
+ */
41
+ isRoundReadyToExecute(round: bigint, slot: SlotNumber): Promise<boolean>;
42
+ /** Returns the slash actions and payload address for a given round (zero if no slash actions) */
43
+ getPayload(round: bigint): Promise<{
44
+ actions: {
45
+ slashAmount: bigint;
46
+ validator: EthAddress;
47
+ }[];
48
+ address: EthAddress;
49
+ }>;
50
+ /** Returns the slash actions to be executed for a given round based on votes */
51
+ getTally(round: bigint): Promise<{
52
+ actions: {
53
+ slashAmount: bigint;
54
+ validator: EthAddress;
55
+ }[];
56
+ committees: EthAddress[][];
57
+ }>;
58
+ private mapSlashActions;
59
+ /** Tries to extract a VoteCast event from the given logs. */
60
+ tryExtractVoteCastEvent(logs: Log[]): {
61
+ eventName: "VoteCast";
62
+ args: {
63
+ proposer: `0x${string}`;
64
+ round: bigint;
65
+ slot: bigint;
66
+ };
67
+ } | undefined;
68
+ /** Tries to extract a RoundExecuted event from the given logs. */
69
+ tryExtractRoundExecutedEvent(logs: Log[]): {
70
+ eventName: "RoundExecuted";
71
+ args: {
72
+ round: bigint;
73
+ slashCount: bigint;
74
+ };
75
+ } | undefined;
76
+ /**
77
+ * Create a transaction to vote for slashing offenses
78
+ * @param votes - The encoded votes for slashing
79
+ * @param slot - The slot number for the vote
80
+ * @param signer - The signer to produce the signature
81
+ * @returns L1 transaction request
82
+ */
83
+ buildVoteRequestFromSigner(votes: Hex, slot: SlotNumber, signer: (msg: TypedDataDefinition) => Promise<Hex>): Promise<L1TxRequest>;
84
+ /** Returns the typed data definition to EIP712-sign for voting */
85
+ buildVoteTypedData(votes: Hex, slot: SlotNumber): TypedDataDefinition;
86
+ /** Gets the digest to sign for voting directly from the contract */
87
+ getVoteDataDigest(votes: Hex, slot: SlotNumber): Promise<Buffer32>;
88
+ /**
89
+ * Create a transaction to vote for slashing offenses
90
+ * @param votes - The encoded votes for slashing
91
+ * @param signature - The signature from the current proposer
92
+ * @returns L1 transaction request
93
+ */
94
+ buildVoteRequestWithSignature(votes: Hex, signature: {
95
+ v: number;
96
+ r: Hex;
97
+ s: Hex;
98
+ }): L1TxRequest;
99
+ /**
100
+ * Create a transaction to execute a slashing round
101
+ * @param round - The round number to execute
102
+ * @param committees - The committees for each epoch in the round
103
+ * @returns L1 transaction request
104
+ */
105
+ buildExecuteRoundRequest(round: bigint, committees: EthAddress[][]): L1TxRequest;
106
+ /** Returns the last vote emitted for a given round */
107
+ getLastVote(round: bigint): Promise<{
108
+ validator: EthAddress;
109
+ slashAmount: bigint;
110
+ }[]>;
111
+ /**
112
+ * Listen for VoteCast events
113
+ * @param callback - Callback function to handle vote cast events
114
+ * @returns Unwatch function
115
+ */
116
+ listenToVoteCast(callback: (args: {
117
+ round: bigint;
118
+ proposer: string;
119
+ }) => void): () => void;
120
+ /**
121
+ * Listen for RoundExecuted events
122
+ * @param callback - Callback function to handle round executed events
123
+ * @returns Unwatch function
124
+ */
125
+ listenToRoundExecuted(callback: (args: {
126
+ round: bigint;
127
+ slashCount: bigint;
128
+ l1BlockHash: Hex;
129
+ }) => void): () => void;
130
+ }
131
+ /**
132
+ * Decodes a Buffer containing slash votes back into an array of numbers.
133
+ * Each vote is represented as a 2-bit value (0, 1, 2, or 3) representing slashing units.
134
+ * @dev This should live in stdlib next to encodeSlashConsensusVotes but is here since we
135
+ * do not have a dependency to stdlib from the ethereum package. We need a larger refactor to fix this.
136
+ * @param buffer - The Buffer containing encoded slash votes
137
+ * @returns An array of numbers representing the slash votes
138
+ */
139
+ export declare function decodeSlashConsensusVotes(buffer: Buffer): number[];
140
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFsbHlfc2xhc2hpbmdfcHJvcG9zZXIuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cmFjdHMvdGFsbHlfc2xhc2hpbmdfcHJvcG9zZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFeEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzdELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFNM0QsT0FBTyxFQUVMLEtBQUssR0FBRyxFQUNSLEtBQUssR0FBRyxFQUNSLEtBQUssbUJBQW1CLEVBR3pCLE1BQU0sTUFBTSxDQUFDO0FBRWQ7OztHQUdHO0FBQ0gscUJBQWEsNkJBQTZCO2FBTXRCLE1BQU0sRUFBRSxVQUFVO0lBTHBDLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFxRTtJQUU5RixTQUFnQixJQUFJLFVBQW9CO0lBRXhDLFlBQ2tCLE1BQU0sRUFBRSxVQUFVLEVBQ2xDLE9BQU8sRUFBRSxHQUFHLEdBQUcsVUFBVSxFQU8xQjtJQUVELElBQVcsT0FBTyxlQUVqQjtJQUVNLGFBQWEsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLENBRXRDO0lBRU0sWUFBWSxJQUFJLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FFckM7SUFFTSxnQkFBZ0IsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLENBRXpDO0lBRU0sb0JBQW9CLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUU3QztJQUVNLG1CQUFtQixJQUFJLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FFNUM7SUFFTSx5QkFBeUIsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLENB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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tally_slashing_proposer.d.ts","sourceRoot":"","sources":["../../src/contracts/tally_slashing_proposer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,320 @@
1
+ import { mergeAbis, tryExtractEvent } from '@aztec/ethereum/utils';
2
+ import { Buffer32 } from '@aztec/foundation/buffer';
3
+ import { EthAddress } from '@aztec/foundation/eth-address';
4
+ import { Signature } from '@aztec/foundation/eth-signature';
5
+ import { hexToBuffer } from '@aztec/foundation/string';
6
+ import { SlasherAbi } from '@aztec/l1-artifacts/SlasherAbi';
7
+ import { TallySlashingProposerAbi } from '@aztec/l1-artifacts/TallySlashingProposerAbi';
8
+ import { encodeFunctionData, getContract } from 'viem';
9
+ /**
10
+ * Wrapper around the TallySlashingProposer contract that provides
11
+ * a TypeScript interface for interacting with the consensus-based slashing system.
12
+ */ export class TallySlashingProposerContract {
13
+ client;
14
+ contract;
15
+ type;
16
+ constructor(client, address){
17
+ this.client = client;
18
+ this.type = 'tally';
19
+ this.contract = getContract({
20
+ address: typeof address === 'string' ? address : address.toString(),
21
+ abi: TallySlashingProposerAbi,
22
+ client
23
+ });
24
+ }
25
+ get address() {
26
+ return EthAddress.fromString(this.contract.address);
27
+ }
28
+ getQuorumSize() {
29
+ return this.contract.read.QUORUM();
30
+ }
31
+ getRoundSize() {
32
+ return this.contract.read.ROUND_SIZE();
33
+ }
34
+ getCommitteeSize() {
35
+ return this.contract.read.COMMITTEE_SIZE();
36
+ }
37
+ getRoundSizeInEpochs() {
38
+ return this.contract.read.ROUND_SIZE_IN_EPOCHS();
39
+ }
40
+ getLifetimeInRounds() {
41
+ return this.contract.read.LIFETIME_IN_ROUNDS();
42
+ }
43
+ getExecutionDelayInRounds() {
44
+ return this.contract.read.EXECUTION_DELAY_IN_ROUNDS();
45
+ }
46
+ getSlashingAmounts() {
47
+ return Promise.all([
48
+ this.contract.read.SLASH_AMOUNT_SMALL(),
49
+ this.contract.read.SLASH_AMOUNT_MEDIUM(),
50
+ this.contract.read.SLASH_AMOUNT_LARGE()
51
+ ]);
52
+ }
53
+ getSlashOffsetInRounds() {
54
+ return this.contract.read.SLASH_OFFSET_IN_ROUNDS();
55
+ }
56
+ getCurrentRound() {
57
+ return this.contract.read.getCurrentRound();
58
+ }
59
+ /**
60
+ * Get round information
61
+ * @param round - The round number to query
62
+ * @returns Round status information
63
+ */ async getRound(round) {
64
+ const [isExecuted, voteCount] = await this.contract.read.getRound([
65
+ round
66
+ ]);
67
+ return {
68
+ isExecuted,
69
+ voteCount
70
+ };
71
+ }
72
+ /**
73
+ * Check if a round is ready to execute at a given slot
74
+ * @param round - The round number to check
75
+ * @param slot - The slot number to check at
76
+ * @returns Whether the round is ready to execute
77
+ */ async isRoundReadyToExecute(round, slot) {
78
+ return await this.contract.read.isRoundReadyToExecute([
79
+ round,
80
+ BigInt(slot)
81
+ ]);
82
+ }
83
+ /** Returns the slash actions and payload address for a given round (zero if no slash actions) */ async getPayload(round) {
84
+ const { result: committees } = await this.contract.simulate.getSlashTargetCommittees([
85
+ round
86
+ ]);
87
+ const tally = await this.contract.read.getTally([
88
+ round,
89
+ committees
90
+ ]);
91
+ const address = await this.contract.read.getPayloadAddress([
92
+ round,
93
+ tally
94
+ ]);
95
+ const actions = this.mapSlashActions(tally);
96
+ return {
97
+ actions,
98
+ address: EthAddress.fromString(address)
99
+ };
100
+ }
101
+ /** Returns the slash actions to be executed for a given round based on votes */ async getTally(round) {
102
+ const { result: committees } = await this.contract.simulate.getSlashTargetCommittees([
103
+ round
104
+ ]);
105
+ const tally = await this.contract.read.getTally([
106
+ round,
107
+ committees
108
+ ]);
109
+ return {
110
+ actions: this.mapSlashActions(tally),
111
+ committees: committees.map((c)=>c.map(EthAddress.fromString))
112
+ };
113
+ }
114
+ mapSlashActions(actions) {
115
+ return actions.map(({ validator, slashAmount })=>({
116
+ validator: EthAddress.fromString(validator),
117
+ slashAmount
118
+ }));
119
+ }
120
+ /** Tries to extract a VoteCast event from the given logs. */ tryExtractVoteCastEvent(logs) {
121
+ return tryExtractEvent(logs, this.address.toString(), TallySlashingProposerAbi, 'VoteCast');
122
+ }
123
+ /** Tries to extract a RoundExecuted event from the given logs. */ tryExtractRoundExecutedEvent(logs) {
124
+ return tryExtractEvent(logs, this.address.toString(), TallySlashingProposerAbi, 'RoundExecuted');
125
+ }
126
+ /**
127
+ * Create a transaction to vote for slashing offenses
128
+ * @param votes - The encoded votes for slashing
129
+ * @param slot - The slot number for the vote
130
+ * @param signer - The signer to produce the signature
131
+ * @returns L1 transaction request
132
+ */ async buildVoteRequestFromSigner(votes, slot, signer) {
133
+ const typedData = this.buildVoteTypedData(votes, slot);
134
+ const signature = Signature.fromString(await signer(typedData));
135
+ return {
136
+ to: this.contract.address,
137
+ abi: TallySlashingProposerAbi,
138
+ data: encodeFunctionData({
139
+ abi: TallySlashingProposerAbi,
140
+ functionName: 'vote',
141
+ args: [
142
+ votes,
143
+ signature.toViemSignature()
144
+ ]
145
+ })
146
+ };
147
+ }
148
+ /** Returns the typed data definition to EIP712-sign for voting */ buildVoteTypedData(votes, slot) {
149
+ const domain = {
150
+ name: 'TallySlashingProposer',
151
+ version: '1',
152
+ chainId: this.client.chain.id,
153
+ verifyingContract: this.contract.address
154
+ };
155
+ const types = {
156
+ EIP712Domain: [
157
+ {
158
+ name: 'name',
159
+ type: 'string'
160
+ },
161
+ {
162
+ name: 'version',
163
+ type: 'string'
164
+ },
165
+ {
166
+ name: 'chainId',
167
+ type: 'uint256'
168
+ },
169
+ {
170
+ name: 'verifyingContract',
171
+ type: 'address'
172
+ }
173
+ ],
174
+ Vote: [
175
+ {
176
+ name: 'votes',
177
+ type: 'bytes'
178
+ },
179
+ {
180
+ name: 'slot',
181
+ type: 'uint256'
182
+ }
183
+ ]
184
+ };
185
+ return {
186
+ domain,
187
+ types,
188
+ primaryType: 'Vote',
189
+ message: {
190
+ votes,
191
+ slot: BigInt(slot)
192
+ }
193
+ };
194
+ }
195
+ /** Gets the digest to sign for voting directly from the contract */ async getVoteDataDigest(votes, slot) {
196
+ return Buffer32.fromString(await this.contract.read.getVoteSignatureDigest([
197
+ votes,
198
+ BigInt(slot)
199
+ ]));
200
+ }
201
+ /**
202
+ * Create a transaction to vote for slashing offenses
203
+ * @param votes - The encoded votes for slashing
204
+ * @param signature - The signature from the current proposer
205
+ * @returns L1 transaction request
206
+ */ buildVoteRequestWithSignature(votes, signature) {
207
+ return {
208
+ to: this.contract.address,
209
+ abi: TallySlashingProposerAbi,
210
+ data: encodeFunctionData({
211
+ abi: TallySlashingProposerAbi,
212
+ functionName: 'vote',
213
+ args: [
214
+ votes,
215
+ signature
216
+ ]
217
+ })
218
+ };
219
+ }
220
+ /**
221
+ * Create a transaction to execute a slashing round
222
+ * @param round - The round number to execute
223
+ * @param committees - The committees for each epoch in the round
224
+ * @returns L1 transaction request
225
+ */ buildExecuteRoundRequest(round, committees) {
226
+ return {
227
+ to: this.contract.address,
228
+ abi: mergeAbis([
229
+ TallySlashingProposerAbi,
230
+ SlasherAbi
231
+ ]),
232
+ data: encodeFunctionData({
233
+ abi: TallySlashingProposerAbi,
234
+ functionName: 'executeRound',
235
+ args: [
236
+ round,
237
+ committees.map((c)=>c.map((addr)=>addr.toString()))
238
+ ]
239
+ })
240
+ };
241
+ }
242
+ /** Returns the last vote emitted for a given round */ async getLastVote(round) {
243
+ const { voteCount } = await this.getRound(round);
244
+ const validators = (await this.contract.simulate.getSlashTargetCommittees([
245
+ round
246
+ ])).result.flat();
247
+ const vote = await this.contract.read.getVotes([
248
+ round,
249
+ voteCount - 1n
250
+ ]);
251
+ const decoded = decodeSlashConsensusVotes(hexToBuffer(vote));
252
+ const slashAmounts = await this.getSlashingAmounts();
253
+ return decoded.map((units, i)=>({
254
+ validator: EthAddress.fromString(validators[i]),
255
+ slashAmount: slashAmounts[units - 1] ?? 0n
256
+ })).filter((v)=>v.slashAmount > 0n);
257
+ }
258
+ /**
259
+ * Listen for VoteCast events
260
+ * @param callback - Callback function to handle vote cast events
261
+ * @returns Unwatch function
262
+ */ listenToVoteCast(callback) {
263
+ return this.contract.watchEvent.VoteCast({}, {
264
+ onLogs: (logs)=>{
265
+ for (const log of logs){
266
+ const { round, proposer } = log.args;
267
+ if (round !== undefined && proposer) {
268
+ callback({
269
+ round,
270
+ proposer
271
+ });
272
+ }
273
+ }
274
+ }
275
+ });
276
+ }
277
+ /**
278
+ * Listen for RoundExecuted events
279
+ * @param callback - Callback function to handle round executed events
280
+ * @returns Unwatch function
281
+ */ listenToRoundExecuted(callback) {
282
+ return this.contract.watchEvent.RoundExecuted({}, {
283
+ onLogs: (logs)=>{
284
+ for (const log of logs){
285
+ const { round, slashCount } = log.args;
286
+ if (round !== undefined && slashCount !== undefined) {
287
+ callback({
288
+ round,
289
+ slashCount,
290
+ l1BlockHash: log.blockHash
291
+ });
292
+ }
293
+ }
294
+ }
295
+ });
296
+ }
297
+ }
298
+ /**
299
+ * Decodes a Buffer containing slash votes back into an array of numbers.
300
+ * Each vote is represented as a 2-bit value (0, 1, 2, or 3) representing slashing units.
301
+ * @dev This should live in stdlib next to encodeSlashConsensusVotes but is here since we
302
+ * do not have a dependency to stdlib from the ethereum package. We need a larger refactor to fix this.
303
+ * @param buffer - The Buffer containing encoded slash votes
304
+ * @returns An array of numbers representing the slash votes
305
+ */ export function decodeSlashConsensusVotes(buffer) {
306
+ const votes = [];
307
+ for(let i = 0; i < buffer.length; i++){
308
+ const voteByte = buffer.readUInt8(i);
309
+ // Decode votes from Solidity's bit order (LSB to MSB)
310
+ // Bits 0-1: validator at index i*4
311
+ // Bits 2-3: validator at index i*4+1
312
+ // Bits 4-5: validator at index i*4+2
313
+ // Bits 6-7: validator at index i*4+3
314
+ votes.push(voteByte >> 0 & 0x03);
315
+ votes.push(voteByte >> 2 & 0x03);
316
+ votes.push(voteByte >> 4 & 0x03);
317
+ votes.push(voteByte >> 6 & 0x03);
318
+ }
319
+ return votes;
320
+ }
@@ -0,0 +1,3 @@
1
+ import type { ViemClient } from '../types.js';
2
+ export declare function checkBlockTag(block: bigint | undefined, publicClient: ViemClient): Promise<void>;
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cmFjdHMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBSzlDLHdCQUFzQixhQUFhLENBQUMsS0FBSyxFQUFFLE1BQU0sR0FBRyxTQUFTLEVBQUUsWUFBWSxFQUFFLFVBQVUsaUJBUXRGIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/contracts/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAK9C,wBAAsB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,EAAE,YAAY,EAAE,UAAU,iBAQtF"}
@@ -0,0 +1,11 @@
1
+ import { BlockTagTooOldError } from './errors.js';
2
+ const L1_NON_ARCHIVE_BLOCK_HISTORY_LENGTH = 128n;
3
+ export async function checkBlockTag(block, publicClient) {
4
+ if (block === undefined) {
5
+ return;
6
+ }
7
+ const latestBlock = await publicClient.getBlockNumber();
8
+ if (block < latestBlock - L1_NON_ARCHIVE_BLOCK_HISTORY_LENGTH) {
9
+ throw new BlockTagTooOldError(block, latestBlock);
10
+ }
11
+ }