@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
@@ -1,19 +1,514 @@
1
- function _ts_decorate(decorators, target, key, desc) {
2
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
- else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1
+ function applyDecs2203RFactory() {
2
+ function createAddInitializerMethod(initializers, decoratorFinishedRef) {
3
+ return function addInitializer(initializer) {
4
+ assertNotFinished(decoratorFinishedRef, "addInitializer");
5
+ assertCallable(initializer, "An initializer");
6
+ initializers.push(initializer);
7
+ };
8
+ }
9
+ function memberDec(dec, name, desc, initializers, kind, isStatic, isPrivate, metadata, value) {
10
+ var kindStr;
11
+ switch(kind){
12
+ case 1:
13
+ kindStr = "accessor";
14
+ break;
15
+ case 2:
16
+ kindStr = "method";
17
+ break;
18
+ case 3:
19
+ kindStr = "getter";
20
+ break;
21
+ case 4:
22
+ kindStr = "setter";
23
+ break;
24
+ default:
25
+ kindStr = "field";
26
+ }
27
+ var ctx = {
28
+ kind: kindStr,
29
+ name: isPrivate ? "#" + name : name,
30
+ static: isStatic,
31
+ private: isPrivate,
32
+ metadata: metadata
33
+ };
34
+ var decoratorFinishedRef = {
35
+ v: false
36
+ };
37
+ ctx.addInitializer = createAddInitializerMethod(initializers, decoratorFinishedRef);
38
+ var get, set;
39
+ if (kind === 0) {
40
+ if (isPrivate) {
41
+ get = desc.get;
42
+ set = desc.set;
43
+ } else {
44
+ get = function() {
45
+ return this[name];
46
+ };
47
+ set = function(v) {
48
+ this[name] = v;
49
+ };
50
+ }
51
+ } else if (kind === 2) {
52
+ get = function() {
53
+ return desc.value;
54
+ };
55
+ } else {
56
+ if (kind === 1 || kind === 3) {
57
+ get = function() {
58
+ return desc.get.call(this);
59
+ };
60
+ }
61
+ if (kind === 1 || kind === 4) {
62
+ set = function(v) {
63
+ desc.set.call(this, v);
64
+ };
65
+ }
66
+ }
67
+ ctx.access = get && set ? {
68
+ get: get,
69
+ set: set
70
+ } : get ? {
71
+ get: get
72
+ } : {
73
+ set: set
74
+ };
75
+ try {
76
+ return dec(value, ctx);
77
+ } finally{
78
+ decoratorFinishedRef.v = true;
79
+ }
80
+ }
81
+ function assertNotFinished(decoratorFinishedRef, fnName) {
82
+ if (decoratorFinishedRef.v) {
83
+ throw new Error("attempted to call " + fnName + " after decoration was finished");
84
+ }
85
+ }
86
+ function assertCallable(fn, hint) {
87
+ if (typeof fn !== "function") {
88
+ throw new TypeError(hint + " must be a function");
89
+ }
90
+ }
91
+ function assertValidReturnValue(kind, value) {
92
+ var type = typeof value;
93
+ if (kind === 1) {
94
+ if (type !== "object" || value === null) {
95
+ throw new TypeError("accessor decorators must return an object with get, set, or init properties or void 0");
96
+ }
97
+ if (value.get !== undefined) {
98
+ assertCallable(value.get, "accessor.get");
99
+ }
100
+ if (value.set !== undefined) {
101
+ assertCallable(value.set, "accessor.set");
102
+ }
103
+ if (value.init !== undefined) {
104
+ assertCallable(value.init, "accessor.init");
105
+ }
106
+ } else if (type !== "function") {
107
+ var hint;
108
+ if (kind === 0) {
109
+ hint = "field";
110
+ } else if (kind === 10) {
111
+ hint = "class";
112
+ } else {
113
+ hint = "method";
114
+ }
115
+ throw new TypeError(hint + " decorators must return a function or void 0");
116
+ }
117
+ }
118
+ function applyMemberDec(ret, base, decInfo, name, kind, isStatic, isPrivate, initializers, metadata) {
119
+ var decs = decInfo[0];
120
+ var desc, init, value;
121
+ if (isPrivate) {
122
+ if (kind === 0 || kind === 1) {
123
+ desc = {
124
+ get: decInfo[3],
125
+ set: decInfo[4]
126
+ };
127
+ } else if (kind === 3) {
128
+ desc = {
129
+ get: decInfo[3]
130
+ };
131
+ } else if (kind === 4) {
132
+ desc = {
133
+ set: decInfo[3]
134
+ };
135
+ } else {
136
+ desc = {
137
+ value: decInfo[3]
138
+ };
139
+ }
140
+ } else if (kind !== 0) {
141
+ desc = Object.getOwnPropertyDescriptor(base, name);
142
+ }
143
+ if (kind === 1) {
144
+ value = {
145
+ get: desc.get,
146
+ set: desc.set
147
+ };
148
+ } else if (kind === 2) {
149
+ value = desc.value;
150
+ } else if (kind === 3) {
151
+ value = desc.get;
152
+ } else if (kind === 4) {
153
+ value = desc.set;
154
+ }
155
+ var newValue, get, set;
156
+ if (typeof decs === "function") {
157
+ newValue = memberDec(decs, name, desc, initializers, kind, isStatic, isPrivate, metadata, value);
158
+ if (newValue !== void 0) {
159
+ assertValidReturnValue(kind, newValue);
160
+ if (kind === 0) {
161
+ init = newValue;
162
+ } else if (kind === 1) {
163
+ init = newValue.init;
164
+ get = newValue.get || value.get;
165
+ set = newValue.set || value.set;
166
+ value = {
167
+ get: get,
168
+ set: set
169
+ };
170
+ } else {
171
+ value = newValue;
172
+ }
173
+ }
174
+ } else {
175
+ for(var i = decs.length - 1; i >= 0; i--){
176
+ var dec = decs[i];
177
+ newValue = memberDec(dec, name, desc, initializers, kind, isStatic, isPrivate, metadata, value);
178
+ if (newValue !== void 0) {
179
+ assertValidReturnValue(kind, newValue);
180
+ var newInit;
181
+ if (kind === 0) {
182
+ newInit = newValue;
183
+ } else if (kind === 1) {
184
+ newInit = newValue.init;
185
+ get = newValue.get || value.get;
186
+ set = newValue.set || value.set;
187
+ value = {
188
+ get: get,
189
+ set: set
190
+ };
191
+ } else {
192
+ value = newValue;
193
+ }
194
+ if (newInit !== void 0) {
195
+ if (init === void 0) {
196
+ init = newInit;
197
+ } else if (typeof init === "function") {
198
+ init = [
199
+ init,
200
+ newInit
201
+ ];
202
+ } else {
203
+ init.push(newInit);
204
+ }
205
+ }
206
+ }
207
+ }
208
+ }
209
+ if (kind === 0 || kind === 1) {
210
+ if (init === void 0) {
211
+ init = function(instance, init) {
212
+ return init;
213
+ };
214
+ } else if (typeof init !== "function") {
215
+ var ownInitializers = init;
216
+ init = function(instance, init) {
217
+ var value = init;
218
+ for(var i = 0; i < ownInitializers.length; i++){
219
+ value = ownInitializers[i].call(instance, value);
220
+ }
221
+ return value;
222
+ };
223
+ } else {
224
+ var originalInitializer = init;
225
+ init = function(instance, init) {
226
+ return originalInitializer.call(instance, init);
227
+ };
228
+ }
229
+ ret.push(init);
230
+ }
231
+ if (kind !== 0) {
232
+ if (kind === 1) {
233
+ desc.get = value.get;
234
+ desc.set = value.set;
235
+ } else if (kind === 2) {
236
+ desc.value = value;
237
+ } else if (kind === 3) {
238
+ desc.get = value;
239
+ } else if (kind === 4) {
240
+ desc.set = value;
241
+ }
242
+ if (isPrivate) {
243
+ if (kind === 1) {
244
+ ret.push(function(instance, args) {
245
+ return value.get.call(instance, args);
246
+ });
247
+ ret.push(function(instance, args) {
248
+ return value.set.call(instance, args);
249
+ });
250
+ } else if (kind === 2) {
251
+ ret.push(value);
252
+ } else {
253
+ ret.push(function(instance, args) {
254
+ return value.call(instance, args);
255
+ });
256
+ }
257
+ } else {
258
+ Object.defineProperty(base, name, desc);
259
+ }
260
+ }
261
+ }
262
+ function applyMemberDecs(Class, decInfos, metadata) {
263
+ var ret = [];
264
+ var protoInitializers;
265
+ var staticInitializers;
266
+ var existingProtoNonFields = new Map();
267
+ var existingStaticNonFields = new Map();
268
+ for(var i = 0; i < decInfos.length; i++){
269
+ var decInfo = decInfos[i];
270
+ if (!Array.isArray(decInfo)) continue;
271
+ var kind = decInfo[1];
272
+ var name = decInfo[2];
273
+ var isPrivate = decInfo.length > 3;
274
+ var isStatic = kind >= 5;
275
+ var base;
276
+ var initializers;
277
+ if (isStatic) {
278
+ base = Class;
279
+ kind = kind - 5;
280
+ staticInitializers = staticInitializers || [];
281
+ initializers = staticInitializers;
282
+ } else {
283
+ base = Class.prototype;
284
+ protoInitializers = protoInitializers || [];
285
+ initializers = protoInitializers;
286
+ }
287
+ if (kind !== 0 && !isPrivate) {
288
+ var existingNonFields = isStatic ? existingStaticNonFields : existingProtoNonFields;
289
+ var existingKind = existingNonFields.get(name) || 0;
290
+ if (existingKind === true || existingKind === 3 && kind !== 4 || existingKind === 4 && kind !== 3) {
291
+ throw new Error("Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: " + name);
292
+ } else if (!existingKind && kind > 2) {
293
+ existingNonFields.set(name, kind);
294
+ } else {
295
+ existingNonFields.set(name, true);
296
+ }
297
+ }
298
+ applyMemberDec(ret, base, decInfo, name, kind, isStatic, isPrivate, initializers, metadata);
299
+ }
300
+ pushInitializers(ret, protoInitializers);
301
+ pushInitializers(ret, staticInitializers);
302
+ return ret;
303
+ }
304
+ function pushInitializers(ret, initializers) {
305
+ if (initializers) {
306
+ ret.push(function(instance) {
307
+ for(var i = 0; i < initializers.length; i++){
308
+ initializers[i].call(instance);
309
+ }
310
+ return instance;
311
+ });
312
+ }
313
+ }
314
+ function applyClassDecs(targetClass, classDecs, metadata) {
315
+ if (classDecs.length > 0) {
316
+ var initializers = [];
317
+ var newClass = targetClass;
318
+ var name = targetClass.name;
319
+ for(var i = classDecs.length - 1; i >= 0; i--){
320
+ var decoratorFinishedRef = {
321
+ v: false
322
+ };
323
+ try {
324
+ var nextNewClass = classDecs[i](newClass, {
325
+ kind: "class",
326
+ name: name,
327
+ addInitializer: createAddInitializerMethod(initializers, decoratorFinishedRef),
328
+ metadata
329
+ });
330
+ } finally{
331
+ decoratorFinishedRef.v = true;
332
+ }
333
+ if (nextNewClass !== undefined) {
334
+ assertValidReturnValue(10, nextNewClass);
335
+ newClass = nextNewClass;
336
+ }
337
+ }
338
+ return [
339
+ defineMetadata(newClass, metadata),
340
+ function() {
341
+ for(var i = 0; i < initializers.length; i++){
342
+ initializers[i].call(newClass);
343
+ }
344
+ }
345
+ ];
346
+ }
347
+ }
348
+ function defineMetadata(Class, metadata) {
349
+ return Object.defineProperty(Class, Symbol.metadata || Symbol.for("Symbol.metadata"), {
350
+ configurable: true,
351
+ enumerable: true,
352
+ value: metadata
353
+ });
354
+ }
355
+ return function applyDecs2203R(targetClass, memberDecs, classDecs, parentClass) {
356
+ if (parentClass !== void 0) {
357
+ var parentMetadata = parentClass[Symbol.metadata || Symbol.for("Symbol.metadata")];
358
+ }
359
+ var metadata = Object.create(parentMetadata === void 0 ? null : parentMetadata);
360
+ var e = applyMemberDecs(targetClass, memberDecs, metadata);
361
+ if (!classDecs.length) defineMetadata(targetClass, metadata);
362
+ return {
363
+ e: e,
364
+ get c () {
365
+ return applyClassDecs(targetClass, classDecs, metadata);
366
+ }
367
+ };
368
+ };
369
+ }
370
+ function _apply_decs_2203_r(targetClass, memberDecs, classDecs, parentClass) {
371
+ return (_apply_decs_2203_r = applyDecs2203RFactory())(targetClass, memberDecs, classDecs, parentClass);
6
372
  }
373
+ var _initProto;
374
+ import { CheckpointNumber, EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
375
+ import { Buffer32 } from '@aztec/foundation/buffer';
376
+ import { Fr } from '@aztec/foundation/curves/bn254';
7
377
  import { memoize } from '@aztec/foundation/decorators';
8
378
  import { EthAddress } from '@aztec/foundation/eth-address';
9
- import { RollupAbi, RollupStorage, SlasherAbi } from '@aztec/l1-artifacts';
10
- import { getAddress, getContract } from 'viem';
379
+ import { makeBackoff, retry } from '@aztec/foundation/retry';
380
+ import { EscapeHatchAbi } from '@aztec/l1-artifacts/EscapeHatchAbi';
381
+ import { RollupAbi } from '@aztec/l1-artifacts/RollupAbi';
382
+ import { RollupStorage } from '@aztec/l1-artifacts/RollupStorage';
383
+ import chunk from 'lodash.chunk';
384
+ import { encodeFunctionData, getContract, hexToBigInt, keccak256 } from 'viem';
11
385
  import { getPublicClient } from '../client.js';
12
386
  import { formatViemError } from '../utils.js';
13
- import { SlashingProposerContract } from './slashing_proposer.js';
387
+ import { EmpireSlashingProposerContract } from './empire_slashing_proposer.js';
388
+ import { GSEContract } from './gse.js';
389
+ import { SlasherContract } from './slasher_contract.js';
390
+ import { TallySlashingProposerContract } from './tally_slashing_proposer.js';
391
+ import { checkBlockTag } from './utils.js';
392
+ export var SlashingProposerType = /*#__PURE__*/ function(SlashingProposerType) {
393
+ SlashingProposerType[SlashingProposerType["None"] = 0] = "None";
394
+ SlashingProposerType[SlashingProposerType["Tally"] = 1] = "Tally";
395
+ SlashingProposerType[SlashingProposerType["Empire"] = 2] = "Empire";
396
+ return SlashingProposerType;
397
+ }({});
398
+ /**
399
+ * Status of a validator/attester in the staking system.
400
+ * Matches the Status enum in StakingLib.sol
401
+ */ export var AttesterStatus = /*#__PURE__*/ function(AttesterStatus) {
402
+ AttesterStatus[AttesterStatus["NONE"] = 0] = "NONE";
403
+ AttesterStatus[AttesterStatus["VALIDATING"] = 1] = "VALIDATING";
404
+ AttesterStatus[AttesterStatus["ZOMBIE"] = 2] = "ZOMBIE";
405
+ AttesterStatus[AttesterStatus["EXITING"] = 3] = "EXITING";
406
+ return AttesterStatus;
407
+ }({});
14
408
  export class RollupContract {
15
409
  client;
410
+ static{
411
+ ({ e: [_initProto] } = _apply_decs_2203_r(this, [
412
+ [
413
+ memoize,
414
+ 2,
415
+ "getL1StartBlock"
416
+ ],
417
+ [
418
+ memoize,
419
+ 2,
420
+ "getL1GenesisTime"
421
+ ],
422
+ [
423
+ memoize,
424
+ 2,
425
+ "getProofSubmissionEpochs"
426
+ ],
427
+ [
428
+ memoize,
429
+ 2,
430
+ "getEpochDuration"
431
+ ],
432
+ [
433
+ memoize,
434
+ 2,
435
+ "getSlotDuration"
436
+ ],
437
+ [
438
+ memoize,
439
+ 2,
440
+ "getTargetCommitteeSize"
441
+ ],
442
+ [
443
+ memoize,
444
+ 2,
445
+ "getEjectionThreshold"
446
+ ],
447
+ [
448
+ memoize,
449
+ 2,
450
+ "getLocalEjectionThreshold"
451
+ ],
452
+ [
453
+ memoize,
454
+ 2,
455
+ "getLagInEpochsForValidatorSet"
456
+ ],
457
+ [
458
+ memoize,
459
+ 2,
460
+ "getLagInEpochsForRandao"
461
+ ],
462
+ [
463
+ memoize,
464
+ 2,
465
+ "getActivationThreshold"
466
+ ],
467
+ [
468
+ memoize,
469
+ 2,
470
+ "getExitDelay"
471
+ ],
472
+ [
473
+ memoize,
474
+ 2,
475
+ "getManaTarget"
476
+ ],
477
+ [
478
+ memoize,
479
+ 2,
480
+ "getProvingCostPerMana"
481
+ ],
482
+ [
483
+ memoize,
484
+ 2,
485
+ "getProvingCostPerManaInFeeAsset"
486
+ ],
487
+ [
488
+ memoize,
489
+ 2,
490
+ "getManaLimit"
491
+ ],
492
+ [
493
+ memoize,
494
+ 2,
495
+ "getVersion"
496
+ ],
497
+ [
498
+ memoize,
499
+ 2,
500
+ "getGenesisArchiveTreeRoot"
501
+ ],
502
+ [
503
+ memoize,
504
+ 2,
505
+ "getRollupConstants"
506
+ ]
507
+ ], []));
508
+ }
16
509
  rollup;
510
+ static cachedStfStorageSlot;
511
+ cachedEscapeHatch;
17
512
  static get checkBlobStorageSlot() {
18
513
  const asString = RollupStorage.find((storage)=>storage.label === 'checkBlob')?.slot;
19
514
  if (asString === undefined) {
@@ -21,9 +516,12 @@ export class RollupContract {
21
516
  }
22
517
  return BigInt(asString);
23
518
  }
519
+ static get stfStorageSlot() {
520
+ return RollupContract.cachedStfStorageSlot ??= keccak256(Buffer.from('aztec.stf.storage', 'utf-8'));
521
+ }
24
522
  static getFromL1ContractsValues(deployL1ContractsValues) {
25
- const { publicClient, l1ContractAddresses: { rollupAddress } } = deployL1ContractsValues;
26
- return new RollupContract(publicClient, rollupAddress.toString());
523
+ const { l1Client, l1ContractAddresses: { rollupAddress } } = deployL1ContractsValues;
524
+ return new RollupContract(l1Client, rollupAddress.toString());
27
525
  }
28
526
  static getFromConfig(config) {
29
527
  const client = getPublicClient(config);
@@ -32,6 +530,7 @@ export class RollupContract {
32
530
  }
33
531
  constructor(client, address){
34
532
  this.client = client;
533
+ _initProto(this);
35
534
  if (address instanceof EthAddress) {
36
535
  address = address.toString();
37
536
  }
@@ -41,18 +540,49 @@ export class RollupContract {
41
540
  client
42
541
  });
43
542
  }
543
+ async getGSE() {
544
+ return EthAddress.fromString(await this.rollup.read.getGSE());
545
+ }
44
546
  get address() {
45
547
  return this.rollup.address;
46
548
  }
549
+ getContract() {
550
+ return this.rollup;
551
+ }
47
552
  async getSlashingProposer() {
48
- const slasherAddress = await this.rollup.read.getSlasher();
49
- const slasher = getContract({
50
- address: slasherAddress,
51
- abi: SlasherAbi,
553
+ const slasher = await this.getSlasherContract();
554
+ if (!slasher) {
555
+ return undefined;
556
+ }
557
+ const proposerAddress = await slasher.getProposer();
558
+ const proposerAbi = [
559
+ {
560
+ type: 'function',
561
+ name: 'SLASHING_PROPOSER_TYPE',
562
+ inputs: [],
563
+ outputs: [
564
+ {
565
+ name: '',
566
+ type: 'uint8',
567
+ internalType: 'enum SlasherFlavor'
568
+ }
569
+ ],
570
+ stateMutability: 'view'
571
+ }
572
+ ];
573
+ const proposer = getContract({
574
+ address: proposerAddress.toString(),
575
+ abi: proposerAbi,
52
576
  client: this.client
53
577
  });
54
- const proposerAddress = await slasher.read.PROPOSER();
55
- return new SlashingProposerContract(this.client, proposerAddress);
578
+ const proposerType = await proposer.read.SLASHING_PROPOSER_TYPE();
579
+ if (proposerType === 1..valueOf()) {
580
+ return new TallySlashingProposerContract(this.client, proposerAddress);
581
+ } else if (proposerType === 2..valueOf()) {
582
+ return new EmpireSlashingProposerContract(this.client, proposerAddress);
583
+ } else {
584
+ throw new Error(`Unknown slashing proposer type: ${proposerType}`);
585
+ }
56
586
  }
57
587
  getL1StartBlock() {
58
588
  return this.rollup.read.L1_BLOCK_AT_GENESIS();
@@ -60,90 +590,305 @@ export class RollupContract {
60
590
  getL1GenesisTime() {
61
591
  return this.rollup.read.getGenesisTime();
62
592
  }
63
- getProofSubmissionWindow() {
64
- return this.rollup.read.getProofSubmissionWindow();
593
+ async getProofSubmissionEpochs() {
594
+ return Number(await this.rollup.read.getProofSubmissionEpochs());
595
+ }
596
+ async getEpochDuration() {
597
+ return Number(await this.rollup.read.getEpochDuration());
598
+ }
599
+ async getSlotDuration() {
600
+ return Number(await this.rollup.read.getSlotDuration());
65
601
  }
66
- getEpochDuration() {
67
- return this.rollup.read.getEpochDuration();
602
+ async getTargetCommitteeSize() {
603
+ return Number(await this.rollup.read.getTargetCommitteeSize());
68
604
  }
69
- getSlotDuration() {
70
- return this.rollup.read.getSlotDuration();
605
+ getEjectionThreshold() {
606
+ return this.rollup.read.getEjectionThreshold();
71
607
  }
72
- getTargetCommitteeSize() {
73
- return this.rollup.read.getTargetCommitteeSize();
608
+ getLocalEjectionThreshold() {
609
+ return this.rollup.read.getLocalEjectionThreshold();
74
610
  }
75
- getMinimumStake() {
76
- return this.rollup.read.getMinimumStake();
611
+ async getLagInEpochsForValidatorSet() {
612
+ return Number(await this.rollup.read.getLagInEpochsForValidatorSet());
613
+ }
614
+ async getLagInEpochsForRandao() {
615
+ return Number(await this.rollup.read.getLagInEpochsForRandao());
616
+ }
617
+ getActivationThreshold() {
618
+ return this.rollup.read.getActivationThreshold();
619
+ }
620
+ async getExitDelay() {
621
+ return Number(await this.rollup.read.getExitDelay());
622
+ }
623
+ getManaTarget() {
624
+ return this.rollup.read.getManaTarget();
625
+ }
626
+ getProvingCostPerMana() {
627
+ return this.rollup.read.getProvingCostPerManaInEth();
628
+ }
629
+ getProvingCostPerManaInFeeAsset() {
630
+ return this.rollup.read.getProvingCostPerManaInFeeAsset();
631
+ }
632
+ getManaLimit() {
633
+ return this.rollup.read.getManaLimit();
634
+ }
635
+ getVersion() {
636
+ return this.rollup.read.getVersion();
637
+ }
638
+ async getGenesisArchiveTreeRoot() {
639
+ return Fr.fromString(await this.rollup.read.archiveAt([
640
+ 0n
641
+ ]));
642
+ }
643
+ /**
644
+ * Returns rollup constants used for epoch queries.
645
+ * Return type is `L1RollupConstants` which is defined in stdlib,
646
+ * so we cant reference it until we move this contract to that package.
647
+ */ async getRollupConstants() {
648
+ const [l1StartBlock, l1GenesisTime, slotDuration, epochDuration, proofSubmissionEpochs] = await Promise.all([
649
+ this.getL1StartBlock(),
650
+ this.getL1GenesisTime(),
651
+ this.getSlotDuration(),
652
+ this.getEpochDuration(),
653
+ this.getProofSubmissionEpochs()
654
+ ]);
655
+ return {
656
+ l1StartBlock,
657
+ l1GenesisTime,
658
+ slotDuration,
659
+ epochDuration: Number(epochDuration),
660
+ proofSubmissionEpochs: Number(proofSubmissionEpochs)
661
+ };
662
+ }
663
+ async getSlasherAddress() {
664
+ return EthAddress.fromString(await this.rollup.read.getSlasher());
665
+ }
666
+ /**
667
+ * Returns the configured escape hatch contract address, or zero if disabled.
668
+ */ async getEscapeHatchAddress() {
669
+ return EthAddress.fromString(await this.rollup.read.getEscapeHatch());
670
+ }
671
+ async getEscapeHatchContract() {
672
+ const escapeHatchAddress = await this.getEscapeHatchAddress();
673
+ if (escapeHatchAddress.isZero()) {
674
+ return undefined;
675
+ }
676
+ // Cache the viem contract wrapper since it will be used frequently.
677
+ if (!this.cachedEscapeHatch || !this.cachedEscapeHatch.address.equals(escapeHatchAddress)) {
678
+ this.cachedEscapeHatch = {
679
+ address: escapeHatchAddress,
680
+ contract: getContract({
681
+ address: escapeHatchAddress.toString(),
682
+ abi: EscapeHatchAbi,
683
+ client: this.client
684
+ })
685
+ };
686
+ }
687
+ return this.cachedEscapeHatch.contract;
688
+ }
689
+ /**
690
+ * Returns whether the escape hatch is open for the given epoch.
691
+ * If escape hatch is not configured, returns false.
692
+ *
693
+ * This function is intentionally defensive: any failure to query the escape hatch
694
+ * (RPC issues, transient errors, etc.) is treated as "closed" to avoid callers
695
+ * needing to sprinkle try/catch everywhere.
696
+ */ async isEscapeHatchOpen(epoch) {
697
+ try {
698
+ const escapeHatch = await this.getEscapeHatchContract();
699
+ if (!escapeHatch) {
700
+ return false;
701
+ }
702
+ const [isOpen] = await escapeHatch.read.isHatchOpen([
703
+ BigInt(epoch)
704
+ ]);
705
+ return isOpen;
706
+ } catch {
707
+ return false;
708
+ }
709
+ }
710
+ /**
711
+ * Returns a SlasherContract instance for interacting with the slasher contract.
712
+ */ async getSlasherContract() {
713
+ const slasherAddress = await this.getSlasherAddress();
714
+ if (slasherAddress.isZero()) {
715
+ return undefined;
716
+ }
717
+ return new SlasherContract(this.client, slasherAddress);
718
+ }
719
+ async getOwner() {
720
+ return EthAddress.fromString(await this.rollup.read.owner());
721
+ }
722
+ async getActiveAttesterCount() {
723
+ return Number(await this.rollup.read.getActiveAttesterCount());
77
724
  }
78
725
  async getSlashingProposerAddress() {
79
- const slasherAddress = await this.rollup.read.getSlasher();
80
- const slasher = getContract({
81
- address: getAddress(slasherAddress.toString()),
82
- abi: SlasherAbi,
83
- client: this.client
84
- });
85
- return EthAddress.fromString(await slasher.read.PROPOSER());
726
+ const slasher = await this.getSlasherContract();
727
+ if (!slasher) {
728
+ return EthAddress.ZERO;
729
+ }
730
+ return await slasher.getProposer();
731
+ }
732
+ getCheckpointReward() {
733
+ return this.rollup.read.getCheckpointReward();
86
734
  }
87
- getBlockNumber() {
88
- return this.rollup.read.getPendingBlockNumber();
735
+ async getCheckpointNumber() {
736
+ return CheckpointNumber.fromBigInt(await this.rollup.read.getPendingCheckpointNumber());
89
737
  }
90
- getProvenBlockNumber() {
91
- return this.rollup.read.getProvenBlockNumber();
738
+ async getProvenCheckpointNumber() {
739
+ return CheckpointNumber.fromBigInt(await this.rollup.read.getProvenCheckpointNumber());
92
740
  }
93
- getSlotNumber() {
94
- return this.rollup.read.getCurrentSlot();
741
+ async getSlotNumber() {
742
+ return SlotNumber.fromBigInt(await this.rollup.read.getCurrentSlot());
95
743
  }
96
- getCommitteeAt(timestamp) {
97
- return this.rollup.read.getCommitteeAt([
744
+ async getL1FeesAt(timestamp) {
745
+ const result = await this.rollup.read.getL1FeesAt([
98
746
  timestamp
99
747
  ]);
748
+ return {
749
+ baseFee: result.baseFee,
750
+ blobFee: result.blobFee
751
+ };
752
+ }
753
+ getEthPerFeeAsset() {
754
+ return this.rollup.read.getEthPerFeeAsset();
755
+ }
756
+ async getCommitteeAt(timestamp) {
757
+ const { result } = await this.client.simulateContract({
758
+ address: this.address,
759
+ abi: RollupAbi,
760
+ functionName: 'getCommitteeAt',
761
+ args: [
762
+ timestamp
763
+ ]
764
+ }).catch((e)=>{
765
+ if (e instanceof Error && e.message.includes('ValidatorSelection__InsufficientValidatorSetSize')) {
766
+ return {
767
+ result: undefined
768
+ };
769
+ }
770
+ throw e;
771
+ });
772
+ return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
100
773
  }
101
- getSampleSeedAt(timestamp) {
102
- return this.rollup.read.getSampleSeedAt([
774
+ async getSampleSeedAt(timestamp) {
775
+ return Buffer32.fromBigInt(await this.rollup.read.getSampleSeedAt([
103
776
  timestamp
104
- ]);
777
+ ]));
105
778
  }
106
- getCurrentSampleSeed() {
107
- return this.rollup.read.getCurrentSampleSeed();
779
+ async getCurrentSampleSeed() {
780
+ return Buffer32.fromBigInt(await this.rollup.read.getCurrentSampleSeed());
108
781
  }
109
- getCurrentEpochCommittee() {
110
- return this.rollup.read.getCurrentEpochCommittee();
782
+ async getCurrentEpoch() {
783
+ return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
111
784
  }
112
- getCurrentProposer() {
113
- return this.rollup.read.getCurrentProposer();
785
+ async getCurrentEpochCommittee() {
786
+ const { result } = await this.client.simulateContract({
787
+ address: this.address,
788
+ abi: RollupAbi,
789
+ functionName: 'getCurrentEpochCommittee',
790
+ args: []
791
+ }).catch((e)=>{
792
+ if (e instanceof Error && e.message.includes('ValidatorSelection__InsufficientValidatorSetSize')) {
793
+ return {
794
+ result: undefined
795
+ };
796
+ }
797
+ throw e;
798
+ });
799
+ return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
114
800
  }
115
- getProposerAt(timestamp) {
116
- return this.rollup.read.getProposerAt([
117
- timestamp
118
- ]);
801
+ async getCurrentProposer() {
802
+ const { result } = await this.client.simulateContract({
803
+ address: this.address,
804
+ abi: RollupAbi,
805
+ functionName: 'getCurrentProposer',
806
+ args: []
807
+ });
808
+ return EthAddress.fromString(result);
809
+ }
810
+ async getProposerAt(timestamp) {
811
+ const { result } = await this.client.simulateContract({
812
+ address: this.address,
813
+ abi: RollupAbi,
814
+ functionName: 'getProposerAt',
815
+ args: [
816
+ timestamp
817
+ ]
818
+ });
819
+ return EthAddress.fromString(result);
119
820
  }
120
- getBlock(blockNumber) {
121
- return this.rollup.read.getBlock([
122
- blockNumber
821
+ async getCheckpoint(checkpointNumber) {
822
+ const result = await this.rollup.read.getCheckpoint([
823
+ BigInt(checkpointNumber)
123
824
  ]);
825
+ return {
826
+ archive: Fr.fromString(result.archive),
827
+ headerHash: Buffer32.fromString(result.headerHash),
828
+ blobCommitmentsHash: Buffer32.fromString(result.blobCommitmentsHash),
829
+ attestationsHash: Buffer32.fromString(result.attestationsHash),
830
+ payloadDigest: Buffer32.fromString(result.payloadDigest),
831
+ slotNumber: SlotNumber.fromBigInt(result.slotNumber),
832
+ feeHeader: {
833
+ excessMana: result.feeHeader.excessMana,
834
+ manaUsed: result.feeHeader.manaUsed,
835
+ ethPerFeeAsset: result.feeHeader.ethPerFeeAsset,
836
+ congestionCost: result.feeHeader.congestionCost,
837
+ proverCost: result.feeHeader.proverCost
838
+ }
839
+ };
840
+ }
841
+ /** Returns the pending checkpoint from the rollup contract */ getPendingCheckpoint() {
842
+ // We retry because of race conditions during prunes: we may get a pending checkpoint number which is immediately
843
+ // reorged out due to a prune happening, causing the subsequent getCheckpoint call to fail. So we try again in that case.
844
+ return retry(async ()=>{
845
+ const pendingCheckpointNumber = await this.getCheckpointNumber();
846
+ const pendingCheckpoint = await this.getCheckpoint(pendingCheckpointNumber);
847
+ return pendingCheckpoint;
848
+ }, 'getting pending checkpoint', makeBackoff([
849
+ 0.5,
850
+ 0.5,
851
+ 0.5
852
+ ]));
124
853
  }
125
- getTips() {
126
- return this.rollup.read.getTips();
854
+ async getTips() {
855
+ const { pending, proven } = await this.rollup.read.getTips();
856
+ return {
857
+ pending: CheckpointNumber.fromBigInt(pending),
858
+ proven: CheckpointNumber.fromBigInt(proven)
859
+ };
127
860
  }
128
861
  getTimestampForSlot(slot) {
129
862
  return this.rollup.read.getTimestampForSlot([
130
- slot
863
+ BigInt(slot)
131
864
  ]);
132
865
  }
133
- async getEpochNumber(blockNumber) {
134
- blockNumber ??= await this.getBlockNumber();
135
- return this.rollup.read.getEpochForBlock([
136
- BigInt(blockNumber)
137
- ]);
866
+ async getEntryQueueLength() {
867
+ return Number(await this.rollup.read.getEntryQueueLength());
868
+ }
869
+ async getAvailableValidatorFlushes() {
870
+ return Number(await this.rollup.read.getAvailableValidatorFlushes());
871
+ }
872
+ async getNextFlushableEpoch() {
873
+ return EpochNumber.fromBigInt(await this.rollup.read.getNextFlushableEpoch());
874
+ }
875
+ async getCurrentEpochNumber() {
876
+ return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
877
+ }
878
+ async getEpochNumberForCheckpoint(checkpointNumber) {
879
+ return EpochNumber.fromBigInt(await this.rollup.read.getEpochForCheckpoint([
880
+ BigInt(checkpointNumber)
881
+ ]));
138
882
  }
139
883
  async getRollupAddresses() {
140
- const [inboxAddress, outboxAddress, feeJuicePortalAddress, rewardDistributorAddress, feeJuiceAddress, stakingAssetAddress] = (await Promise.all([
884
+ const [inboxAddress, outboxAddress, feeJuicePortalAddress, rewardDistributorAddress, feeJuiceAddress, stakingAssetAddress, gseAddress] = (await Promise.all([
141
885
  this.rollup.read.getInbox(),
142
886
  this.rollup.read.getOutbox(),
143
887
  this.rollup.read.getFeeAssetPortal(),
144
888
  this.rollup.read.getRewardDistributor(),
145
889
  this.rollup.read.getFeeAsset(),
146
- this.rollup.read.getStakingAsset()
890
+ this.rollup.read.getStakingAsset(),
891
+ this.rollup.read.getGSE()
147
892
  ])).map(EthAddress.fromString);
148
893
  return {
149
894
  rollupAddress: EthAddress.fromString(this.address),
@@ -152,20 +897,29 @@ export class RollupContract {
152
897
  feeJuicePortalAddress,
153
898
  feeJuiceAddress,
154
899
  stakingAssetAddress,
155
- rewardDistributorAddress
900
+ rewardDistributorAddress,
901
+ gseAddress
156
902
  };
157
903
  }
904
+ async getFeeJuicePortal() {
905
+ return EthAddress.fromString(await this.rollup.read.getFeeAssetPortal());
906
+ }
158
907
  async getEpochNumberForSlotNumber(slotNumber) {
159
- return await this.rollup.read.getEpochAtSlot([
160
- slotNumber
161
- ]);
908
+ return EpochNumber.fromBigInt(await this.rollup.read.getEpochAtSlot([
909
+ BigInt(slotNumber)
910
+ ]));
162
911
  }
163
- getEpochProofPublicInputs(args) {
164
- return this.rollup.read.getEpochProofPublicInputs(args);
912
+ async getEpochProofPublicInputs(args) {
913
+ const result = await this.rollup.read.getEpochProofPublicInputs(args);
914
+ return result.map(Fr.fromString);
165
915
  }
166
916
  async validateHeader(args, account) {
167
917
  try {
168
- await this.rollup.read.validateHeader(args, {
918
+ await this.client.simulateContract({
919
+ address: this.address,
920
+ abi: RollupAbi,
921
+ functionName: 'validateHeaderWithAttestations',
922
+ args,
169
923
  account
170
924
  });
171
925
  } catch (error) {
@@ -178,57 +932,314 @@ export class RollupContract {
178
932
  * @dev Throws if unable to propose
179
933
  *
180
934
  * @param archive - The archive that we expect to be current state
181
- * @return [slot, blockNumber] - If you can propose, the L2 slot number and L2 block number of the next Ethereum block,
935
+ * @return [slot, checkpointNumber, timeOfNextL1Slot] - If you can propose, the L2 slot number, checkpoint number and
936
+ * timestamp of the next L1 block
182
937
  * @throws otherwise
183
- */ async canProposeAtNextEthBlock(archive, account, slotDuration) {
184
- if (typeof slotDuration === 'number') {
185
- slotDuration = BigInt(slotDuration);
186
- }
187
- const timeOfNextL1Slot = (await this.client.getBlock()).timestamp + slotDuration;
938
+ */ async canProposeAtNextEthBlock(archive, account, slotDuration, opts = {}) {
939
+ const latestBlock = await this.client.getBlock();
940
+ const timeOfNextL1Slot = latestBlock.timestamp + BigInt(slotDuration);
941
+ const who = typeof account === 'string' ? account : account.address;
188
942
  try {
189
- const [slot, blockNumber] = await this.rollup.read.canProposeAtTime([
190
- timeOfNextL1Slot,
191
- `0x${archive.toString('hex')}`
192
- ], {
193
- account
943
+ const { result: [slot, checkpointNumber] } = await this.client.simulateContract({
944
+ address: this.address,
945
+ abi: RollupAbi,
946
+ functionName: 'canProposeAtTime',
947
+ args: [
948
+ timeOfNextL1Slot,
949
+ `0x${archive.toString('hex')}`,
950
+ who
951
+ ],
952
+ account,
953
+ stateOverride: await this.makePendingCheckpointNumberOverride(opts.forcePendingCheckpointNumber)
194
954
  });
195
- return [
196
- slot,
197
- blockNumber
198
- ];
955
+ return {
956
+ slot: SlotNumber.fromBigInt(slot),
957
+ checkpointNumber: CheckpointNumber.fromBigInt(checkpointNumber),
958
+ timeOfNextL1Slot
959
+ };
199
960
  } catch (err) {
200
961
  throw formatViemError(err);
201
962
  }
202
963
  }
203
- /** Calls getHasSubmitted directly. Returns whether the given prover has submitted a proof with the given length for the given epoch. */ getHasSubmittedProof(epochNumber, numberOfBlocksInEpoch, prover) {
964
+ /**
965
+ * Returns a state override that sets the pending checkpoint number to the specified value. Useful for simulations.
966
+ * Requires querying the current state of the contract to get the current proven checkpoint number, as they are both
967
+ * stored in the same slot. If the argument is undefined, it returns an empty override.
968
+ */ async makePendingCheckpointNumberOverride(forcePendingCheckpointNumber) {
969
+ if (forcePendingCheckpointNumber === undefined) {
970
+ return [];
971
+ }
972
+ const slot = RollupContract.stfStorageSlot;
973
+ const currentValue = await this.client.getStorageAt({
974
+ address: this.address,
975
+ slot
976
+ });
977
+ const currentProvenCheckpointNumber = currentValue ? hexToBigInt(currentValue) & (1n << 128n) - 1n : 0n;
978
+ const newValue = BigInt(forcePendingCheckpointNumber) << 128n | currentProvenCheckpointNumber;
979
+ return [
980
+ {
981
+ address: this.address,
982
+ stateDiff: [
983
+ {
984
+ slot,
985
+ value: `0x${newValue.toString(16).padStart(64, '0')}`
986
+ }
987
+ ]
988
+ }
989
+ ];
990
+ }
991
+ /** Creates a request to Rollup#invalidateBadAttestation to be simulated or sent */ buildInvalidateBadAttestationRequest(checkpointNumber, attestationsAndSigners, committee, invalidIndex) {
992
+ return {
993
+ to: this.address,
994
+ abi: RollupAbi,
995
+ data: encodeFunctionData({
996
+ abi: RollupAbi,
997
+ functionName: 'invalidateBadAttestation',
998
+ args: [
999
+ BigInt(checkpointNumber),
1000
+ attestationsAndSigners,
1001
+ committee.map((addr)=>addr.toString()),
1002
+ BigInt(invalidIndex)
1003
+ ]
1004
+ })
1005
+ };
1006
+ }
1007
+ /** Creates a request to Rollup#invalidateInsufficientAttestations to be simulated or sent */ buildInvalidateInsufficientAttestationsRequest(checkpointNumber, attestationsAndSigners, committee) {
1008
+ return {
1009
+ to: this.address,
1010
+ abi: RollupAbi,
1011
+ data: encodeFunctionData({
1012
+ abi: RollupAbi,
1013
+ functionName: 'invalidateInsufficientAttestations',
1014
+ args: [
1015
+ BigInt(checkpointNumber),
1016
+ attestationsAndSigners,
1017
+ committee.map((addr)=>addr.toString())
1018
+ ]
1019
+ })
1020
+ };
1021
+ }
1022
+ /** Calls getHasSubmitted directly. Returns whether the given prover has submitted a proof with the given length for the given epoch. */ getHasSubmittedProof(epochNumber, numberOfCheckpointsInEpoch, prover) {
1023
+ if (prover instanceof EthAddress) {
1024
+ prover = prover.toString();
1025
+ }
204
1026
  return this.rollup.read.getHasSubmitted([
205
1027
  BigInt(epochNumber),
206
- BigInt(numberOfBlocksInEpoch),
207
- prover.toString()
1028
+ BigInt(numberOfCheckpointsInEpoch),
1029
+ prover
1030
+ ]);
1031
+ }
1032
+ getManaMinFeeAt(timestamp, inFeeAsset) {
1033
+ return this.rollup.read.getManaMinFeeAt([
1034
+ timestamp,
1035
+ inFeeAsset
1036
+ ]);
1037
+ }
1038
+ async getSlotAt(timestamp) {
1039
+ return SlotNumber.fromBigInt(await this.rollup.read.getSlotAt([
1040
+ timestamp
1041
+ ]));
1042
+ }
1043
+ async status(checkpointNumber, options) {
1044
+ await checkBlockTag(options?.blockNumber, this.client);
1045
+ const result = await this.rollup.read.status([
1046
+ BigInt(checkpointNumber)
1047
+ ], options);
1048
+ return {
1049
+ provenCheckpointNumber: CheckpointNumber.fromBigInt(result[0]),
1050
+ provenArchive: Fr.fromString(result[1]),
1051
+ pendingCheckpointNumber: CheckpointNumber.fromBigInt(result[2]),
1052
+ pendingArchive: Fr.fromString(result[3]),
1053
+ archiveOfMyCheckpoint: Fr.fromString(result[4])
1054
+ };
1055
+ }
1056
+ async canPruneAtTime(timestamp, options) {
1057
+ await checkBlockTag(options?.blockNumber, this.client);
1058
+ return this.rollup.read.canPruneAtTime([
1059
+ timestamp
1060
+ ], options);
1061
+ }
1062
+ async archive() {
1063
+ return Fr.fromString(await this.rollup.read.archive());
1064
+ }
1065
+ async archiveAt(checkpointNumber) {
1066
+ return Fr.fromString(await this.rollup.read.archiveAt([
1067
+ BigInt(checkpointNumber)
1068
+ ]));
1069
+ }
1070
+ getSequencerRewards(address) {
1071
+ if (address instanceof EthAddress) {
1072
+ address = address.toString();
1073
+ }
1074
+ return this.rollup.read.getSequencerRewards([
1075
+ address
1076
+ ]);
1077
+ }
1078
+ getSpecificProverRewardsForEpoch(epoch, prover) {
1079
+ if (prover instanceof EthAddress) {
1080
+ prover = prover.toString();
1081
+ }
1082
+ return this.rollup.read.getSpecificProverRewardsForEpoch([
1083
+ epoch,
1084
+ prover
1085
+ ]);
1086
+ }
1087
+ async getAttesters() {
1088
+ const attesterSize = await this.getActiveAttesterCount();
1089
+ const gse = new GSEContract(this.client, await this.getGSE());
1090
+ const ts = (await this.client.getBlock()).timestamp;
1091
+ const indices = Array.from({
1092
+ length: attesterSize
1093
+ }, (_, i)=>BigInt(i));
1094
+ const chunks = chunk(indices, 1000);
1095
+ const results = await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)));
1096
+ return results.flat().map((addr)=>EthAddress.fromString(addr));
1097
+ }
1098
+ async getAttesterView(address) {
1099
+ if (address instanceof EthAddress) {
1100
+ address = address.toString();
1101
+ }
1102
+ const result = await this.rollup.read.getAttesterView([
1103
+ address
1104
+ ]);
1105
+ return {
1106
+ status: result.status,
1107
+ effectiveBalance: result.effectiveBalance,
1108
+ exit: {
1109
+ withdrawalId: result.exit.withdrawalId,
1110
+ amount: result.exit.amount,
1111
+ exitableAt: result.exit.exitableAt,
1112
+ recipientOrWithdrawer: EthAddress.fromString(result.exit.recipientOrWithdrawer),
1113
+ isRecipient: result.exit.isRecipient,
1114
+ exists: result.exit.exists
1115
+ },
1116
+ config: {
1117
+ publicKey: {
1118
+ x: result.config.publicKey.x,
1119
+ y: result.config.publicKey.y
1120
+ },
1121
+ withdrawer: EthAddress.fromString(result.config.withdrawer)
1122
+ }
1123
+ };
1124
+ }
1125
+ async getStatus(address) {
1126
+ if (address instanceof EthAddress) {
1127
+ address = address.toString();
1128
+ }
1129
+ return await this.rollup.read.getStatus([
1130
+ address
208
1131
  ]);
209
1132
  }
1133
+ async getBlobCommitmentsHash(checkpointNumber) {
1134
+ return Buffer32.fromString(await this.rollup.read.getBlobCommitmentsHash([
1135
+ BigInt(checkpointNumber)
1136
+ ]));
1137
+ }
1138
+ async getCurrentBlobCommitmentsHash() {
1139
+ return Buffer32.fromString(await this.rollup.read.getCurrentBlobCommitmentsHash());
1140
+ }
1141
+ async getStakingAsset() {
1142
+ return EthAddress.fromString(await this.rollup.read.getStakingAsset());
1143
+ }
1144
+ async getRewardConfig() {
1145
+ const result = await this.rollup.read.getRewardConfig();
1146
+ return {
1147
+ rewardDistributor: EthAddress.fromString(result.rewardDistributor),
1148
+ sequencerBps: BigInt(result.sequencerBps),
1149
+ booster: EthAddress.fromString(result.booster),
1150
+ checkpointReward: result.checkpointReward
1151
+ };
1152
+ }
1153
+ setupEpoch(l1TxUtils) {
1154
+ return l1TxUtils.sendAndMonitorTransaction({
1155
+ to: this.address,
1156
+ abi: RollupAbi,
1157
+ data: encodeFunctionData({
1158
+ abi: RollupAbi,
1159
+ functionName: 'setupEpoch',
1160
+ args: []
1161
+ })
1162
+ });
1163
+ }
1164
+ vote(l1TxUtils, proposalId) {
1165
+ return l1TxUtils.sendAndMonitorTransaction({
1166
+ to: this.address,
1167
+ abi: RollupAbi,
1168
+ data: encodeFunctionData({
1169
+ abi: RollupAbi,
1170
+ functionName: 'vote',
1171
+ args: [
1172
+ proposalId
1173
+ ]
1174
+ })
1175
+ });
1176
+ }
1177
+ listenToSlasherChanged(callback) {
1178
+ return this.rollup.watchEvent.SlasherUpdated({}, {
1179
+ onLogs: (logs)=>{
1180
+ for (const log of logs){
1181
+ const args = log.args;
1182
+ if (args.oldSlasher && args.newSlasher) {
1183
+ callback(args);
1184
+ }
1185
+ }
1186
+ }
1187
+ });
1188
+ }
1189
+ listenToCheckpointInvalidated(callback) {
1190
+ return this.rollup.watchEvent.CheckpointInvalidated({}, {
1191
+ onLogs: (logs)=>{
1192
+ for (const log of logs){
1193
+ const args = log.args;
1194
+ if (args.checkpointNumber !== undefined) {
1195
+ callback({
1196
+ checkpointNumber: CheckpointNumber.fromBigInt(args.checkpointNumber)
1197
+ });
1198
+ }
1199
+ }
1200
+ }
1201
+ });
1202
+ }
1203
+ async getSlashEvents(l1BlockHash) {
1204
+ const events = await this.rollup.getEvents.Slashed({}, {
1205
+ blockHash: l1BlockHash,
1206
+ strict: true
1207
+ });
1208
+ return events.map((event)=>({
1209
+ amount: event.args.amount,
1210
+ attester: EthAddress.fromString(event.args.attester)
1211
+ }));
1212
+ }
1213
+ listenToSlash(callback) {
1214
+ return this.rollup.watchEvent.Slashed({}, {
1215
+ strict: true,
1216
+ onLogs: (logs)=>{
1217
+ for (const log of logs){
1218
+ const args = log.args;
1219
+ callback({
1220
+ amount: args.amount,
1221
+ attester: EthAddress.fromString(args.attester)
1222
+ });
1223
+ }
1224
+ }
1225
+ });
1226
+ }
1227
+ /** Fetches CheckpointProposed events within the given block range. */ async getCheckpointProposedEvents(fromBlock, toBlock) {
1228
+ const logs = await this.rollup.getEvents.CheckpointProposed({}, {
1229
+ fromBlock,
1230
+ toBlock
1231
+ });
1232
+ return logs.filter((log)=>log.blockNumber >= fromBlock && log.blockNumber <= toBlock).map((log)=>({
1233
+ l1BlockNumber: log.blockNumber,
1234
+ l1BlockHash: Buffer32.fromString(log.blockHash),
1235
+ l1TransactionHash: log.transactionHash,
1236
+ args: {
1237
+ checkpointNumber: CheckpointNumber.fromBigInt(log.args.checkpointNumber),
1238
+ archive: Fr.fromString(log.args.archive),
1239
+ versionedBlobHashes: log.args.versionedBlobHashes.map((h)=>Buffer.from(h.slice(2), 'hex')),
1240
+ attestationsHash: log.args.attestationsHash ? Buffer32.fromString(log.args.attestationsHash) : undefined,
1241
+ payloadDigest: log.args.payloadDigest ? Buffer32.fromString(log.args.payloadDigest) : undefined
1242
+ }
1243
+ }));
1244
+ }
210
1245
  }
211
- _ts_decorate([
212
- memoize
213
- ], RollupContract.prototype, "getSlashingProposer", null);
214
- _ts_decorate([
215
- memoize
216
- ], RollupContract.prototype, "getL1StartBlock", null);
217
- _ts_decorate([
218
- memoize
219
- ], RollupContract.prototype, "getL1GenesisTime", null);
220
- _ts_decorate([
221
- memoize
222
- ], RollupContract.prototype, "getProofSubmissionWindow", null);
223
- _ts_decorate([
224
- memoize
225
- ], RollupContract.prototype, "getEpochDuration", null);
226
- _ts_decorate([
227
- memoize
228
- ], RollupContract.prototype, "getSlotDuration", null);
229
- _ts_decorate([
230
- memoize
231
- ], RollupContract.prototype, "getTargetCommitteeSize", null);
232
- _ts_decorate([
233
- memoize
234
- ], RollupContract.prototype, "getMinimumStake", null);