@aztec/ethereum 0.0.1-commit.b655e406 → 0.0.1-commit.bf2612ae

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 (204) hide show
  1. package/dest/account.d.ts +1 -1
  2. package/dest/chain.d.ts +1 -1
  3. package/dest/client.d.ts +1 -1
  4. package/dest/client.js +6 -2
  5. package/dest/config.d.ts +22 -68
  6. package/dest/config.d.ts.map +1 -1
  7. package/dest/config.js +57 -378
  8. package/dest/constants.d.ts +1 -1
  9. package/dest/contracts/empire_base.d.ts +7 -5
  10. package/dest/contracts/empire_base.d.ts.map +1 -1
  11. package/dest/contracts/empire_base.js +1 -1
  12. package/dest/contracts/empire_slashing_proposer.d.ts +6 -4
  13. package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -1
  14. package/dest/contracts/empire_slashing_proposer.js +17 -2
  15. package/dest/contracts/errors.d.ts +1 -1
  16. package/dest/contracts/errors.d.ts.map +1 -1
  17. package/dest/contracts/fee_asset_handler.d.ts +6 -5
  18. package/dest/contracts/fee_asset_handler.d.ts.map +1 -1
  19. package/dest/contracts/fee_asset_handler.js +9 -9
  20. package/dest/contracts/fee_juice.d.ts +1 -1
  21. package/dest/contracts/fee_juice.d.ts.map +1 -1
  22. package/dest/contracts/governance.d.ts +18 -16
  23. package/dest/contracts/governance.d.ts.map +1 -1
  24. package/dest/contracts/governance.js +9 -1
  25. package/dest/contracts/governance_proposer.d.ts +6 -4
  26. package/dest/contracts/governance_proposer.d.ts.map +1 -1
  27. package/dest/contracts/governance_proposer.js +399 -10
  28. package/dest/contracts/gse.d.ts +1 -1
  29. package/dest/contracts/gse.d.ts.map +1 -1
  30. package/dest/contracts/inbox.d.ts +24 -3
  31. package/dest/contracts/inbox.d.ts.map +1 -1
  32. package/dest/contracts/inbox.js +36 -1
  33. package/dest/contracts/index.d.ts +3 -1
  34. package/dest/contracts/index.d.ts.map +1 -1
  35. package/dest/contracts/index.js +2 -0
  36. package/dest/contracts/log.d.ts +13 -0
  37. package/dest/contracts/log.d.ts.map +1 -0
  38. package/dest/contracts/log.js +1 -0
  39. package/dest/contracts/multicall.d.ts +2 -2
  40. package/dest/contracts/multicall.d.ts.map +1 -1
  41. package/dest/contracts/outbox.d.ts +41 -0
  42. package/dest/contracts/outbox.d.ts.map +1 -0
  43. package/dest/contracts/outbox.js +86 -0
  44. package/dest/contracts/registry.d.ts +1 -1
  45. package/dest/contracts/registry.d.ts.map +1 -1
  46. package/dest/contracts/rollup.d.ts +194 -123
  47. package/dest/contracts/rollup.d.ts.map +1 -1
  48. package/dest/contracts/rollup.js +746 -184
  49. package/dest/contracts/slasher_contract.d.ts +1 -1
  50. package/dest/contracts/slasher_contract.d.ts.map +1 -1
  51. package/dest/contracts/tally_slashing_proposer.d.ts +9 -7
  52. package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -1
  53. package/dest/contracts/tally_slashing_proposer.js +4 -4
  54. package/dest/contracts/utils.d.ts +1 -1
  55. package/dest/deploy_aztec_l1_contracts.d.ts +260 -0
  56. package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
  57. package/dest/deploy_aztec_l1_contracts.js +398 -0
  58. package/dest/deploy_l1_contract.d.ts +68 -0
  59. package/dest/deploy_l1_contract.d.ts.map +1 -0
  60. package/dest/deploy_l1_contract.js +312 -0
  61. package/dest/eth-signer/eth-signer.d.ts +1 -1
  62. package/dest/eth-signer/index.d.ts +1 -1
  63. package/dest/forwarder_proxy.d.ts +32 -0
  64. package/dest/forwarder_proxy.d.ts.map +1 -0
  65. package/dest/forwarder_proxy.js +93 -0
  66. package/dest/generated/l1-contracts-defaults.d.ts +30 -0
  67. package/dest/generated/l1-contracts-defaults.d.ts.map +1 -0
  68. package/dest/generated/l1-contracts-defaults.js +30 -0
  69. package/dest/l1_artifacts.d.ts +6597 -2046
  70. package/dest/l1_artifacts.d.ts.map +1 -1
  71. package/dest/l1_contract_addresses.d.ts +3 -3
  72. package/dest/l1_contract_addresses.d.ts.map +1 -1
  73. package/dest/l1_contract_addresses.js +3 -3
  74. package/dest/l1_reader.d.ts +3 -1
  75. package/dest/l1_reader.d.ts.map +1 -1
  76. package/dest/l1_reader.js +6 -0
  77. package/dest/l1_tx_utils/config.d.ts +5 -5
  78. package/dest/l1_tx_utils/config.d.ts.map +1 -1
  79. package/dest/l1_tx_utils/config.js +30 -7
  80. package/dest/l1_tx_utils/constants.d.ts +7 -1
  81. package/dest/l1_tx_utils/constants.d.ts.map +1 -1
  82. package/dest/l1_tx_utils/constants.js +25 -0
  83. package/dest/l1_tx_utils/factory.d.ts +1 -1
  84. package/dest/l1_tx_utils/fee-strategies/index.d.ts +10 -0
  85. package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
  86. package/dest/l1_tx_utils/fee-strategies/index.js +12 -0
  87. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +8 -0
  88. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
  89. package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +129 -0
  90. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +23 -0
  91. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
  92. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +191 -0
  93. package/dest/l1_tx_utils/fee-strategies/types.d.ts +51 -0
  94. package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
  95. package/dest/l1_tx_utils/fee-strategies/types.js +3 -0
  96. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
  97. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
  98. package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +48 -0
  99. package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
  100. package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
  101. package/dest/l1_tx_utils/index-blobs.js +2 -0
  102. package/dest/l1_tx_utils/index.d.ts +3 -1
  103. package/dest/l1_tx_utils/index.d.ts.map +1 -1
  104. package/dest/l1_tx_utils/index.js +2 -0
  105. package/dest/l1_tx_utils/interfaces.d.ts +2 -2
  106. package/dest/l1_tx_utils/interfaces.d.ts.map +1 -1
  107. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
  108. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
  109. package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
  110. package/dest/l1_tx_utils/l1_tx_utils.d.ts +1 -2
  111. package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -1
  112. package/dest/l1_tx_utils/l1_tx_utils.js +17 -4
  113. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +1 -1
  114. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +1 -1
  115. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +19 -30
  116. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -1
  117. package/dest/l1_tx_utils/readonly_l1_tx_utils.js +54 -162
  118. package/dest/l1_tx_utils/signer.d.ts +1 -1
  119. package/dest/l1_tx_utils/types.d.ts +1 -1
  120. package/dest/l1_tx_utils/types.d.ts.map +1 -1
  121. package/dest/l1_tx_utils/utils.d.ts +1 -1
  122. package/dest/l1_types.d.ts +1 -1
  123. package/dest/publisher_manager.d.ts +1 -1
  124. package/dest/publisher_manager.d.ts.map +1 -1
  125. package/dest/queries.d.ts +2 -2
  126. package/dest/queries.d.ts.map +1 -1
  127. package/dest/queries.js +16 -6
  128. package/dest/test/chain_monitor.d.ts +27 -24
  129. package/dest/test/chain_monitor.d.ts.map +1 -1
  130. package/dest/test/chain_monitor.js +33 -36
  131. package/dest/test/delayed_tx_utils.d.ts +1 -1
  132. package/dest/test/delayed_tx_utils.d.ts.map +1 -1
  133. package/dest/test/eth_cheat_codes.d.ts +11 -3
  134. package/dest/test/eth_cheat_codes.d.ts.map +1 -1
  135. package/dest/test/eth_cheat_codes.js +11 -3
  136. package/dest/test/eth_cheat_codes_with_state.d.ts +1 -1
  137. package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
  138. package/dest/test/index.d.ts +1 -1
  139. package/dest/test/rollup_cheat_codes.d.ts +15 -13
  140. package/dest/test/rollup_cheat_codes.d.ts.map +1 -1
  141. package/dest/test/rollup_cheat_codes.js +54 -39
  142. package/dest/test/start_anvil.d.ts +4 -1
  143. package/dest/test/start_anvil.d.ts.map +1 -1
  144. package/dest/test/start_anvil.js +2 -1
  145. package/dest/test/tx_delayer.d.ts +1 -1
  146. package/dest/test/tx_delayer.d.ts.map +1 -1
  147. package/dest/test/tx_delayer.js +4 -3
  148. package/dest/test/upgrade_utils.d.ts +1 -1
  149. package/dest/types.d.ts +57 -2
  150. package/dest/types.d.ts.map +1 -1
  151. package/dest/utils.d.ts +15 -3
  152. package/dest/utils.d.ts.map +1 -1
  153. package/dest/utils.js +18 -0
  154. package/dest/zkPassportVerifierAddress.d.ts +1 -1
  155. package/package.json +34 -14
  156. package/src/client.ts +2 -2
  157. package/src/config.ts +71 -458
  158. package/src/contracts/README.md +157 -0
  159. package/src/contracts/empire_base.ts +6 -5
  160. package/src/contracts/empire_slashing_proposer.ts +16 -5
  161. package/src/contracts/fee_asset_handler.ts +8 -7
  162. package/src/contracts/governance.ts +8 -1
  163. package/src/contracts/governance_proposer.ts +16 -5
  164. package/src/contracts/inbox.ts +55 -3
  165. package/src/contracts/index.ts +2 -0
  166. package/src/contracts/log.ts +13 -0
  167. package/src/contracts/outbox.ts +98 -0
  168. package/src/contracts/rollup.ts +417 -160
  169. package/src/contracts/tally_slashing_proposer.ts +11 -8
  170. package/src/deploy_aztec_l1_contracts.ts +619 -0
  171. package/src/deploy_l1_contract.ts +362 -0
  172. package/src/forwarder_proxy.ts +108 -0
  173. package/src/generated/l1-contracts-defaults.ts +32 -0
  174. package/src/l1_contract_addresses.ts +22 -20
  175. package/src/l1_reader.ts +8 -0
  176. package/src/l1_tx_utils/config.ts +32 -11
  177. package/src/l1_tx_utils/constants.ts +11 -0
  178. package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
  179. package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +163 -0
  180. package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +245 -0
  181. package/src/l1_tx_utils/fee-strategies/types.ts +56 -0
  182. package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +119 -0
  183. package/src/l1_tx_utils/index-blobs.ts +2 -0
  184. package/src/l1_tx_utils/index.ts +2 -0
  185. package/src/l1_tx_utils/interfaces.ts +1 -1
  186. package/src/l1_tx_utils/l1_fee_analyzer.ts +803 -0
  187. package/src/l1_tx_utils/l1_tx_utils.ts +24 -4
  188. package/src/l1_tx_utils/readonly_l1_tx_utils.ts +67 -207
  189. package/src/queries.ts +17 -6
  190. package/src/test/chain_monitor.ts +51 -49
  191. package/src/test/eth_cheat_codes.ts +9 -3
  192. package/src/test/rollup_cheat_codes.ts +54 -43
  193. package/src/test/start_anvil.ts +4 -0
  194. package/src/test/tx_delayer.ts +5 -3
  195. package/src/types.ts +62 -0
  196. package/src/utils.ts +30 -1
  197. package/dest/deploy_l1_contracts.d.ts +0 -226
  198. package/dest/deploy_l1_contracts.d.ts.map +0 -1
  199. package/dest/deploy_l1_contracts.js +0 -1473
  200. package/dest/index.d.ts +0 -18
  201. package/dest/index.d.ts.map +0 -1
  202. package/dest/index.js +0 -17
  203. package/src/deploy_l1_contracts.ts +0 -1849
  204. package/src/index.ts +0 -17
@@ -1,11 +1,383 @@
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';
379
+ import { makeBackoff, retry } from '@aztec/foundation/retry';
380
+ import { EscapeHatchAbi } from '@aztec/l1-artifacts/EscapeHatchAbi';
9
381
  import { RollupAbi } from '@aztec/l1-artifacts/RollupAbi';
10
382
  import { RollupStorage } from '@aztec/l1-artifacts/RollupStorage';
11
383
  import chunk from 'lodash.chunk';
@@ -23,10 +395,120 @@ export var SlashingProposerType = /*#__PURE__*/ function(SlashingProposerType) {
23
395
  SlashingProposerType[SlashingProposerType["Empire"] = 2] = "Empire";
24
396
  return SlashingProposerType;
25
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
+ }({});
26
408
  export class RollupContract {
27
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
+ }
28
509
  rollup;
29
510
  static cachedStfStorageSlot;
511
+ cachedEscapeHatch;
30
512
  static get checkBlobStorageSlot() {
31
513
  const asString = RollupStorage.find((storage)=>storage.label === 'checkBlob')?.slot;
32
514
  if (asString === undefined) {
@@ -48,6 +530,7 @@ export class RollupContract {
48
530
  }
49
531
  constructor(client, address){
50
532
  this.client = client;
533
+ _initProto(this);
51
534
  if (address instanceof EthAddress) {
52
535
  address = address.toString();
53
536
  }
@@ -57,8 +540,8 @@ export class RollupContract {
57
540
  client
58
541
  });
59
542
  }
60
- getGSE() {
61
- return this.rollup.read.getGSE();
543
+ async getGSE() {
544
+ return EthAddress.fromString(await this.rollup.read.getGSE());
62
545
  }
63
546
  get address() {
64
547
  return this.rollup.address;
@@ -107,17 +590,17 @@ export class RollupContract {
107
590
  getL1GenesisTime() {
108
591
  return this.rollup.read.getGenesisTime();
109
592
  }
110
- getProofSubmissionEpochs() {
111
- return this.rollup.read.getProofSubmissionEpochs();
593
+ async getProofSubmissionEpochs() {
594
+ return Number(await this.rollup.read.getProofSubmissionEpochs());
112
595
  }
113
- getEpochDuration() {
114
- return this.rollup.read.getEpochDuration();
596
+ async getEpochDuration() {
597
+ return Number(await this.rollup.read.getEpochDuration());
115
598
  }
116
- getSlotDuration() {
117
- return this.rollup.read.getSlotDuration();
599
+ async getSlotDuration() {
600
+ return Number(await this.rollup.read.getSlotDuration());
118
601
  }
119
- getTargetCommitteeSize() {
120
- return this.rollup.read.getTargetCommitteeSize();
602
+ async getTargetCommitteeSize() {
603
+ return Number(await this.rollup.read.getTargetCommitteeSize());
121
604
  }
122
605
  getEjectionThreshold() {
123
606
  return this.rollup.read.getEjectionThreshold();
@@ -125,14 +608,17 @@ export class RollupContract {
125
608
  getLocalEjectionThreshold() {
126
609
  return this.rollup.read.getLocalEjectionThreshold();
127
610
  }
128
- getLagInEpochs() {
129
- return this.rollup.read.getLagInEpochs();
611
+ async getLagInEpochsForValidatorSet() {
612
+ return Number(await this.rollup.read.getLagInEpochsForValidatorSet());
613
+ }
614
+ async getLagInEpochsForRandao() {
615
+ return Number(await this.rollup.read.getLagInEpochsForRandao());
130
616
  }
131
617
  getActivationThreshold() {
132
618
  return this.rollup.read.getActivationThreshold();
133
619
  }
134
- getExitDelay() {
135
- return this.rollup.read.getExitDelay();
620
+ async getExitDelay() {
621
+ return Number(await this.rollup.read.getExitDelay());
136
622
  }
137
623
  getManaTarget() {
138
624
  return this.rollup.read.getManaTarget();
@@ -150,9 +636,9 @@ export class RollupContract {
150
636
  return this.rollup.read.getVersion();
151
637
  }
152
638
  async getGenesisArchiveTreeRoot() {
153
- return await this.rollup.read.archiveAt([
639
+ return Fr.fromString(await this.rollup.read.archiveAt([
154
640
  0n
155
- ]);
641
+ ]));
156
642
  }
157
643
  /**
158
644
  * Returns rollup constants used for epoch queries.
@@ -169,28 +655,72 @@ export class RollupContract {
169
655
  return {
170
656
  l1StartBlock,
171
657
  l1GenesisTime,
172
- slotDuration: Number(slotDuration),
658
+ slotDuration,
173
659
  epochDuration: Number(epochDuration),
174
660
  proofSubmissionEpochs: Number(proofSubmissionEpochs)
175
661
  };
176
662
  }
177
- getSlasherAddress() {
178
- return this.rollup.read.getSlasher();
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
+ }
179
709
  }
180
710
  /**
181
711
  * Returns a SlasherContract instance for interacting with the slasher contract.
182
712
  */ async getSlasherContract() {
183
- const slasherAddress = EthAddress.fromString(await this.getSlasherAddress());
713
+ const slasherAddress = await this.getSlasherAddress();
184
714
  if (slasherAddress.isZero()) {
185
715
  return undefined;
186
716
  }
187
717
  return new SlasherContract(this.client, slasherAddress);
188
718
  }
189
- getOwner() {
190
- return this.rollup.read.owner();
719
+ async getOwner() {
720
+ return EthAddress.fromString(await this.rollup.read.owner());
191
721
  }
192
- getActiveAttesterCount() {
193
- return this.rollup.read.getActiveAttesterCount();
722
+ async getActiveAttesterCount() {
723
+ return Number(await this.rollup.read.getActiveAttesterCount());
194
724
  }
195
725
  async getSlashingProposerAddress() {
196
726
  const slasher = await this.getSlasherContract();
@@ -199,25 +729,29 @@ export class RollupContract {
199
729
  }
200
730
  return await slasher.getProposer();
201
731
  }
202
- getBlockReward() {
203
- return this.rollup.read.getBlockReward();
732
+ getCheckpointReward() {
733
+ return this.rollup.read.getCheckpointReward();
204
734
  }
205
- getBlockNumber() {
206
- return this.rollup.read.getPendingBlockNumber();
735
+ async getCheckpointNumber() {
736
+ return CheckpointNumber.fromBigInt(await this.rollup.read.getPendingCheckpointNumber());
207
737
  }
208
- getProvenBlockNumber() {
209
- return this.rollup.read.getProvenBlockNumber();
738
+ async getProvenCheckpointNumber() {
739
+ return CheckpointNumber.fromBigInt(await this.rollup.read.getProvenCheckpointNumber());
210
740
  }
211
- getSlotNumber() {
212
- return this.rollup.read.getCurrentSlot();
741
+ async getSlotNumber() {
742
+ return SlotNumber.fromBigInt(await this.rollup.read.getCurrentSlot());
213
743
  }
214
- getL1FeesAt(timestamp) {
215
- return this.rollup.read.getL1FeesAt([
744
+ async getL1FeesAt(timestamp) {
745
+ const result = await this.rollup.read.getL1FeesAt([
216
746
  timestamp
217
747
  ]);
748
+ return {
749
+ baseFee: result.baseFee,
750
+ blobFee: result.blobFee
751
+ };
218
752
  }
219
- getFeeAssetPerEth() {
220
- return this.rollup.read.getFeeAssetPerEth();
753
+ getEthPerFeeAsset() {
754
+ return this.rollup.read.getEthPerFeeAsset();
221
755
  }
222
756
  async getCommitteeAt(timestamp) {
223
757
  const { result } = await this.client.simulateContract({
@@ -235,18 +769,18 @@ export class RollupContract {
235
769
  }
236
770
  throw e;
237
771
  });
238
- return result;
772
+ return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
239
773
  }
240
- getSampleSeedAt(timestamp) {
241
- return this.rollup.read.getSampleSeedAt([
774
+ async getSampleSeedAt(timestamp) {
775
+ return Buffer32.fromBigInt(await this.rollup.read.getSampleSeedAt([
242
776
  timestamp
243
- ]);
777
+ ]));
244
778
  }
245
- getCurrentSampleSeed() {
246
- return this.rollup.read.getCurrentSampleSeed();
779
+ async getCurrentSampleSeed() {
780
+ return Buffer32.fromBigInt(await this.rollup.read.getCurrentSampleSeed());
247
781
  }
248
- getCurrentEpoch() {
249
- return this.rollup.read.getCurrentEpoch();
782
+ async getCurrentEpoch() {
783
+ return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
250
784
  }
251
785
  async getCurrentEpochCommittee() {
252
786
  const { result } = await this.client.simulateContract({
@@ -262,7 +796,7 @@ export class RollupContract {
262
796
  }
263
797
  throw e;
264
798
  });
265
- return result;
799
+ return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
266
800
  }
267
801
  async getCurrentProposer() {
268
802
  const { result } = await this.client.simulateContract({
@@ -271,7 +805,7 @@ export class RollupContract {
271
805
  functionName: 'getCurrentProposer',
272
806
  args: []
273
807
  });
274
- return result;
808
+ return EthAddress.fromString(result);
275
809
  }
276
810
  async getProposerAt(timestamp) {
277
811
  const { result } = await this.client.simulateContract({
@@ -282,37 +816,69 @@ export class RollupContract {
282
816
  timestamp
283
817
  ]
284
818
  });
285
- return result;
819
+ return EthAddress.fromString(result);
286
820
  }
287
- getBlock(blockNumber) {
288
- return this.rollup.read.getBlock([
289
- BigInt(blockNumber)
821
+ async getCheckpoint(checkpointNumber) {
822
+ const result = await this.rollup.read.getCheckpoint([
823
+ BigInt(checkpointNumber)
290
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
+ };
291
840
  }
292
- getTips() {
293
- return this.rollup.read.getTips();
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
+ ]));
853
+ }
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
+ };
294
860
  }
295
861
  getTimestampForSlot(slot) {
296
862
  return this.rollup.read.getTimestampForSlot([
297
- slot
863
+ BigInt(slot)
298
864
  ]);
299
865
  }
300
- getEntryQueueLength() {
301
- return this.rollup.read.getEntryQueueLength();
866
+ async getEntryQueueLength() {
867
+ return Number(await this.rollup.read.getEntryQueueLength());
302
868
  }
303
- getAvailableValidatorFlushes() {
304
- return this.rollup.read.getAvailableValidatorFlushes();
869
+ async getAvailableValidatorFlushes() {
870
+ return Number(await this.rollup.read.getAvailableValidatorFlushes());
305
871
  }
306
- getNextFlushableEpoch() {
307
- return this.rollup.read.getNextFlushableEpoch();
872
+ async getNextFlushableEpoch() {
873
+ return EpochNumber.fromBigInt(await this.rollup.read.getNextFlushableEpoch());
308
874
  }
309
- getCurrentEpochNumber() {
310
- return this.rollup.read.getCurrentEpoch();
875
+ async getCurrentEpochNumber() {
876
+ return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
311
877
  }
312
- getEpochNumberForBlock(blockNumber) {
313
- return this.rollup.read.getEpochForBlock([
314
- BigInt(blockNumber)
315
- ]);
878
+ async getEpochNumberForCheckpoint(checkpointNumber) {
879
+ return EpochNumber.fromBigInt(await this.rollup.read.getEpochForCheckpoint([
880
+ BigInt(checkpointNumber)
881
+ ]));
316
882
  }
317
883
  async getRollupAddresses() {
318
884
  const [inboxAddress, outboxAddress, feeJuicePortalAddress, rewardDistributorAddress, feeJuiceAddress, stakingAssetAddress, gseAddress] = (await Promise.all([
@@ -339,12 +905,13 @@ export class RollupContract {
339
905
  return EthAddress.fromString(await this.rollup.read.getFeeAssetPortal());
340
906
  }
341
907
  async getEpochNumberForSlotNumber(slotNumber) {
342
- return await this.rollup.read.getEpochAtSlot([
343
- slotNumber
344
- ]);
908
+ return EpochNumber.fromBigInt(await this.rollup.read.getEpochAtSlot([
909
+ BigInt(slotNumber)
910
+ ]));
345
911
  }
346
- getEpochProofPublicInputs(args) {
347
- 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);
348
915
  }
349
916
  async validateHeader(args, account) {
350
917
  try {
@@ -365,17 +932,15 @@ export class RollupContract {
365
932
  * @dev Throws if unable to propose
366
933
  *
367
934
  * @param archive - The archive that we expect to be current state
368
- * @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
369
937
  * @throws otherwise
370
938
  */ async canProposeAtNextEthBlock(archive, account, slotDuration, opts = {}) {
371
- if (typeof slotDuration === 'number') {
372
- slotDuration = BigInt(slotDuration);
373
- }
374
939
  const latestBlock = await this.client.getBlock();
375
- const timeOfNextL1Slot = latestBlock.timestamp + slotDuration;
940
+ const timeOfNextL1Slot = latestBlock.timestamp + BigInt(slotDuration);
376
941
  const who = typeof account === 'string' ? account : account.address;
377
942
  try {
378
- const { result: [slot, blockNumber] } = await this.client.simulateContract({
943
+ const { result: [slot, checkpointNumber] } = await this.client.simulateContract({
379
944
  address: this.address,
380
945
  abi: RollupAbi,
381
946
  functionName: 'canProposeAtTime',
@@ -385,11 +950,11 @@ export class RollupContract {
385
950
  who
386
951
  ],
387
952
  account,
388
- stateOverride: await this.makePendingBlockNumberOverride(opts.forcePendingBlockNumber)
953
+ stateOverride: await this.makePendingCheckpointNumberOverride(opts.forcePendingCheckpointNumber)
389
954
  });
390
955
  return {
391
- slot,
392
- blockNumber,
956
+ slot: SlotNumber.fromBigInt(slot),
957
+ checkpointNumber: CheckpointNumber.fromBigInt(checkpointNumber),
393
958
  timeOfNextL1Slot
394
959
  };
395
960
  } catch (err) {
@@ -397,11 +962,11 @@ export class RollupContract {
397
962
  }
398
963
  }
399
964
  /**
400
- * Returns a state override that sets the pending block number to the specified value. Useful for simulations.
401
- * Requires querying the current state of the contract to get the current proven block number, as they are both
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
402
967
  * stored in the same slot. If the argument is undefined, it returns an empty override.
403
- */ async makePendingBlockNumberOverride(forcePendingBlockNumber) {
404
- if (forcePendingBlockNumber === undefined) {
968
+ */ async makePendingCheckpointNumberOverride(forcePendingCheckpointNumber) {
969
+ if (forcePendingCheckpointNumber === undefined) {
405
970
  return [];
406
971
  }
407
972
  const slot = RollupContract.stfStorageSlot;
@@ -409,8 +974,8 @@ export class RollupContract {
409
974
  address: this.address,
410
975
  slot
411
976
  });
412
- const currentProvenBlockNumber = currentValue ? hexToBigInt(currentValue) & (1n << 128n) - 1n : 0n;
413
- const newValue = BigInt(forcePendingBlockNumber) << 128n | currentProvenBlockNumber;
977
+ const currentProvenCheckpointNumber = currentValue ? hexToBigInt(currentValue) & (1n << 128n) - 1n : 0n;
978
+ const newValue = BigInt(forcePendingCheckpointNumber) << 128n | currentProvenCheckpointNumber;
414
979
  return [
415
980
  {
416
981
  address: this.address,
@@ -423,14 +988,14 @@ export class RollupContract {
423
988
  }
424
989
  ];
425
990
  }
426
- /** Creates a request to Rollup#invalidateBadAttestation to be simulated or sent */ buildInvalidateBadAttestationRequest(blockNumber, attestationsAndSigners, committee, invalidIndex) {
991
+ /** Creates a request to Rollup#invalidateBadAttestation to be simulated or sent */ buildInvalidateBadAttestationRequest(checkpointNumber, attestationsAndSigners, committee, invalidIndex) {
427
992
  return {
428
993
  to: this.address,
429
994
  data: encodeFunctionData({
430
995
  abi: RollupAbi,
431
996
  functionName: 'invalidateBadAttestation',
432
997
  args: [
433
- BigInt(blockNumber),
998
+ BigInt(checkpointNumber),
434
999
  attestationsAndSigners,
435
1000
  committee.map((addr)=>addr.toString()),
436
1001
  BigInt(invalidIndex)
@@ -438,46 +1003,53 @@ export class RollupContract {
438
1003
  })
439
1004
  };
440
1005
  }
441
- /** Creates a request to Rollup#invalidateInsufficientAttestations to be simulated or sent */ buildInvalidateInsufficientAttestationsRequest(blockNumber, attestationsAndSigners, committee) {
1006
+ /** Creates a request to Rollup#invalidateInsufficientAttestations to be simulated or sent */ buildInvalidateInsufficientAttestationsRequest(checkpointNumber, attestationsAndSigners, committee) {
442
1007
  return {
443
1008
  to: this.address,
444
1009
  data: encodeFunctionData({
445
1010
  abi: RollupAbi,
446
1011
  functionName: 'invalidateInsufficientAttestations',
447
1012
  args: [
448
- BigInt(blockNumber),
1013
+ BigInt(checkpointNumber),
449
1014
  attestationsAndSigners,
450
1015
  committee.map((addr)=>addr.toString())
451
1016
  ]
452
1017
  })
453
1018
  };
454
1019
  }
455
- /** Calls getHasSubmitted directly. Returns whether the given prover has submitted a proof with the given length for the given epoch. */ getHasSubmittedProof(epochNumber, numberOfBlocksInEpoch, prover) {
1020
+ /** Calls getHasSubmitted directly. Returns whether the given prover has submitted a proof with the given length for the given epoch. */ getHasSubmittedProof(epochNumber, numberOfCheckpointsInEpoch, prover) {
456
1021
  if (prover instanceof EthAddress) {
457
1022
  prover = prover.toString();
458
1023
  }
459
1024
  return this.rollup.read.getHasSubmitted([
460
1025
  BigInt(epochNumber),
461
- BigInt(numberOfBlocksInEpoch),
1026
+ BigInt(numberOfCheckpointsInEpoch),
462
1027
  prover
463
1028
  ]);
464
1029
  }
465
- getManaBaseFeeAt(timestamp, inFeeAsset) {
466
- return this.rollup.read.getManaBaseFeeAt([
1030
+ getManaMinFeeAt(timestamp, inFeeAsset) {
1031
+ return this.rollup.read.getManaMinFeeAt([
467
1032
  timestamp,
468
1033
  inFeeAsset
469
1034
  ]);
470
1035
  }
471
- getSlotAt(timestamp) {
472
- return this.rollup.read.getSlotAt([
1036
+ async getSlotAt(timestamp) {
1037
+ return SlotNumber.fromBigInt(await this.rollup.read.getSlotAt([
473
1038
  timestamp
474
- ]);
1039
+ ]));
475
1040
  }
476
- async status(blockNumber, options) {
1041
+ async status(checkpointNumber, options) {
477
1042
  await checkBlockTag(options?.blockNumber, this.client);
478
- return this.rollup.read.status([
479
- blockNumber
1043
+ const result = await this.rollup.read.status([
1044
+ BigInt(checkpointNumber)
480
1045
  ], options);
1046
+ return {
1047
+ provenCheckpointNumber: CheckpointNumber.fromBigInt(result[0]),
1048
+ provenArchive: Fr.fromString(result[1]),
1049
+ pendingCheckpointNumber: CheckpointNumber.fromBigInt(result[2]),
1050
+ pendingArchive: Fr.fromString(result[3]),
1051
+ archiveOfMyCheckpoint: Fr.fromString(result[4])
1052
+ };
481
1053
  }
482
1054
  async canPruneAtTime(timestamp, options) {
483
1055
  await checkBlockTag(options?.blockNumber, this.client);
@@ -485,13 +1057,13 @@ export class RollupContract {
485
1057
  timestamp
486
1058
  ], options);
487
1059
  }
488
- archive() {
489
- return this.rollup.read.archive();
1060
+ async archive() {
1061
+ return Fr.fromString(await this.rollup.read.archive());
490
1062
  }
491
- archiveAt(blockNumber) {
492
- return this.rollup.read.archiveAt([
493
- blockNumber
494
- ]);
1063
+ async archiveAt(checkpointNumber) {
1064
+ return Fr.fromString(await this.rollup.read.archiveAt([
1065
+ BigInt(checkpointNumber)
1066
+ ]));
495
1067
  }
496
1068
  getSequencerRewards(address) {
497
1069
  if (address instanceof EthAddress) {
@@ -515,40 +1087,66 @@ export class RollupContract {
515
1087
  const gse = new GSEContract(this.client, await this.getGSE());
516
1088
  const ts = (await this.client.getBlock()).timestamp;
517
1089
  const indices = Array.from({
518
- length: Number(attesterSize)
1090
+ length: attesterSize
519
1091
  }, (_, i)=>BigInt(i));
520
1092
  const chunks = chunk(indices, 1000);
521
- return (await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)))).flat();
1093
+ const results = await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)));
1094
+ return results.flat().map((addr)=>EthAddress.fromString(addr));
522
1095
  }
523
- getAttesterView(address) {
1096
+ async getAttesterView(address) {
524
1097
  if (address instanceof EthAddress) {
525
1098
  address = address.toString();
526
1099
  }
527
- return this.rollup.read.getAttesterView([
1100
+ const result = await this.rollup.read.getAttesterView([
528
1101
  address
529
1102
  ]);
1103
+ return {
1104
+ status: result.status,
1105
+ effectiveBalance: result.effectiveBalance,
1106
+ exit: {
1107
+ withdrawalId: result.exit.withdrawalId,
1108
+ amount: result.exit.amount,
1109
+ exitableAt: result.exit.exitableAt,
1110
+ recipientOrWithdrawer: EthAddress.fromString(result.exit.recipientOrWithdrawer),
1111
+ isRecipient: result.exit.isRecipient,
1112
+ exists: result.exit.exists
1113
+ },
1114
+ config: {
1115
+ publicKey: {
1116
+ x: result.config.publicKey.x,
1117
+ y: result.config.publicKey.y
1118
+ },
1119
+ withdrawer: EthAddress.fromString(result.config.withdrawer)
1120
+ }
1121
+ };
530
1122
  }
531
- getStatus(address) {
1123
+ async getStatus(address) {
532
1124
  if (address instanceof EthAddress) {
533
1125
  address = address.toString();
534
1126
  }
535
- return this.rollup.read.getStatus([
1127
+ return await this.rollup.read.getStatus([
536
1128
  address
537
1129
  ]);
538
1130
  }
539
- getBlobCommitmentsHash(blockNumber) {
540
- return this.rollup.read.getBlobCommitmentsHash([
541
- blockNumber
542
- ]);
1131
+ async getBlobCommitmentsHash(checkpointNumber) {
1132
+ return Buffer32.fromString(await this.rollup.read.getBlobCommitmentsHash([
1133
+ BigInt(checkpointNumber)
1134
+ ]));
543
1135
  }
544
- getCurrentBlobCommitmentsHash() {
545
- return this.rollup.read.getCurrentBlobCommitmentsHash();
1136
+ async getCurrentBlobCommitmentsHash() {
1137
+ return Buffer32.fromString(await this.rollup.read.getCurrentBlobCommitmentsHash());
546
1138
  }
547
- getStakingAsset() {
548
- return this.rollup.read.getStakingAsset();
1139
+ async getStakingAsset() {
1140
+ return EthAddress.fromString(await this.rollup.read.getStakingAsset());
549
1141
  }
550
- getRewardConfig() {
551
- return this.rollup.read.getRewardConfig();
1142
+ async getRewardConfig() {
1143
+ const result = await this.rollup.read.getRewardConfig();
1144
+ return {
1145
+ rewardDistributor: EthAddress.fromString(result.rewardDistributor),
1146
+ sequencerBps: BigInt(result.sequencerBps),
1147
+ booster: EthAddress.fromString(result.booster),
1148
+ checkpointReward: result.checkpointReward
1149
+ };
552
1150
  }
553
1151
  setupEpoch(l1TxUtils) {
554
1152
  return l1TxUtils.sendAndMonitorTransaction({
@@ -584,14 +1182,14 @@ export class RollupContract {
584
1182
  }
585
1183
  });
586
1184
  }
587
- listenToBlockInvalidated(callback) {
588
- return this.rollup.watchEvent.BlockInvalidated({}, {
1185
+ listenToCheckpointInvalidated(callback) {
1186
+ return this.rollup.watchEvent.CheckpointInvalidated({}, {
589
1187
  onLogs: (logs)=>{
590
1188
  for (const log of logs){
591
1189
  const args = log.args;
592
- if (args.blockNumber !== undefined) {
1190
+ if (args.checkpointNumber !== undefined) {
593
1191
  callback({
594
- blockNumber: args.blockNumber
1192
+ checkpointNumber: CheckpointNumber.fromBigInt(args.checkpointNumber)
595
1193
  });
596
1194
  }
597
1195
  }
@@ -622,58 +1220,22 @@ export class RollupContract {
622
1220
  }
623
1221
  });
624
1222
  }
1223
+ /** Fetches CheckpointProposed events within the given block range. */ async getCheckpointProposedEvents(fromBlock, toBlock) {
1224
+ const logs = await this.rollup.getEvents.CheckpointProposed({}, {
1225
+ fromBlock,
1226
+ toBlock
1227
+ });
1228
+ return logs.filter((log)=>log.blockNumber >= fromBlock && log.blockNumber <= toBlock).map((log)=>({
1229
+ l1BlockNumber: log.blockNumber,
1230
+ l1BlockHash: Buffer32.fromString(log.blockHash),
1231
+ l1TransactionHash: log.transactionHash,
1232
+ args: {
1233
+ checkpointNumber: CheckpointNumber.fromBigInt(log.args.checkpointNumber),
1234
+ archive: Fr.fromString(log.args.archive),
1235
+ versionedBlobHashes: log.args.versionedBlobHashes.map((h)=>Buffer.from(h.slice(2), 'hex')),
1236
+ attestationsHash: log.args.attestationsHash ? Buffer32.fromString(log.args.attestationsHash) : undefined,
1237
+ payloadDigest: log.args.payloadDigest ? Buffer32.fromString(log.args.payloadDigest) : undefined
1238
+ }
1239
+ }));
1240
+ }
625
1241
  }
626
- _ts_decorate([
627
- memoize
628
- ], RollupContract.prototype, "getL1StartBlock", null);
629
- _ts_decorate([
630
- memoize
631
- ], RollupContract.prototype, "getL1GenesisTime", null);
632
- _ts_decorate([
633
- memoize
634
- ], RollupContract.prototype, "getProofSubmissionEpochs", null);
635
- _ts_decorate([
636
- memoize
637
- ], RollupContract.prototype, "getEpochDuration", null);
638
- _ts_decorate([
639
- memoize
640
- ], RollupContract.prototype, "getSlotDuration", null);
641
- _ts_decorate([
642
- memoize
643
- ], RollupContract.prototype, "getTargetCommitteeSize", null);
644
- _ts_decorate([
645
- memoize
646
- ], RollupContract.prototype, "getEjectionThreshold", null);
647
- _ts_decorate([
648
- memoize
649
- ], RollupContract.prototype, "getLocalEjectionThreshold", null);
650
- _ts_decorate([
651
- memoize
652
- ], RollupContract.prototype, "getLagInEpochs", null);
653
- _ts_decorate([
654
- memoize
655
- ], RollupContract.prototype, "getActivationThreshold", null);
656
- _ts_decorate([
657
- memoize
658
- ], RollupContract.prototype, "getExitDelay", null);
659
- _ts_decorate([
660
- memoize
661
- ], RollupContract.prototype, "getManaTarget", null);
662
- _ts_decorate([
663
- memoize
664
- ], RollupContract.prototype, "getProvingCostPerMana", null);
665
- _ts_decorate([
666
- memoize
667
- ], RollupContract.prototype, "getProvingCostPerManaInFeeAsset", null);
668
- _ts_decorate([
669
- memoize
670
- ], RollupContract.prototype, "getManaLimit", null);
671
- _ts_decorate([
672
- memoize
673
- ], RollupContract.prototype, "getVersion", null);
674
- _ts_decorate([
675
- memoize
676
- ], RollupContract.prototype, "getGenesisArchiveTreeRoot", null);
677
- _ts_decorate([
678
- memoize
679
- ], RollupContract.prototype, "getRollupConstants", null);