@aztec/ethereum 0.0.1-commit.5daedc8 → 0.0.1-commit.6a729f7

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 (175) hide show
  1. package/dest/client.js +6 -2
  2. package/dest/config.d.ts +19 -68
  3. package/dest/config.d.ts.map +1 -1
  4. package/dest/config.js +51 -378
  5. package/dest/contracts/empire_base.d.ts +2 -1
  6. package/dest/contracts/empire_base.d.ts.map +1 -1
  7. package/dest/contracts/empire_slashing_proposer.d.ts +2 -1
  8. package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -1
  9. package/dest/contracts/empire_slashing_proposer.js +22 -15
  10. package/dest/contracts/fee_asset_handler.d.ts +6 -5
  11. package/dest/contracts/fee_asset_handler.d.ts.map +1 -1
  12. package/dest/contracts/fee_asset_handler.js +11 -9
  13. package/dest/contracts/governance.d.ts +3 -1
  14. package/dest/contracts/governance.d.ts.map +1 -1
  15. package/dest/contracts/governance.js +11 -1
  16. package/dest/contracts/governance_proposer.d.ts +2 -1
  17. package/dest/contracts/governance_proposer.d.ts.map +1 -1
  18. package/dest/contracts/governance_proposer.js +395 -9
  19. package/dest/contracts/inbox.d.ts +24 -3
  20. package/dest/contracts/inbox.d.ts.map +1 -1
  21. package/dest/contracts/inbox.js +36 -1
  22. package/dest/contracts/index.d.ts +3 -1
  23. package/dest/contracts/index.d.ts.map +1 -1
  24. package/dest/contracts/index.js +2 -0
  25. package/dest/contracts/log.d.ts +13 -0
  26. package/dest/contracts/log.d.ts.map +1 -0
  27. package/dest/contracts/log.js +1 -0
  28. package/dest/contracts/multicall.d.ts +1 -1
  29. package/dest/contracts/multicall.d.ts.map +1 -1
  30. package/dest/contracts/multicall.js +2 -1
  31. package/dest/contracts/outbox.d.ts +41 -0
  32. package/dest/contracts/outbox.d.ts.map +1 -0
  33. package/dest/contracts/outbox.js +86 -0
  34. package/dest/contracts/rollup.d.ts +176 -96
  35. package/dest/contracts/rollup.d.ts.map +1 -1
  36. package/dest/contracts/rollup.js +702 -141
  37. package/dest/contracts/tally_slashing_proposer.d.ts +3 -2
  38. package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -1
  39. package/dest/contracts/tally_slashing_proposer.js +8 -1
  40. package/dest/deploy_aztec_l1_contracts.d.ts +260 -0
  41. package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
  42. package/dest/deploy_aztec_l1_contracts.js +398 -0
  43. package/dest/deploy_l1_contract.d.ts +68 -0
  44. package/dest/deploy_l1_contract.d.ts.map +1 -0
  45. package/dest/deploy_l1_contract.js +312 -0
  46. package/dest/forwarder_proxy.d.ts +32 -0
  47. package/dest/forwarder_proxy.d.ts.map +1 -0
  48. package/dest/forwarder_proxy.js +93 -0
  49. package/dest/generated/l1-contracts-defaults.d.ts +30 -0
  50. package/dest/generated/l1-contracts-defaults.d.ts.map +1 -0
  51. package/dest/generated/l1-contracts-defaults.js +30 -0
  52. package/dest/l1_artifacts.d.ts +4964 -1573
  53. package/dest/l1_artifacts.d.ts.map +1 -1
  54. package/dest/l1_contract_addresses.d.ts +1 -1
  55. package/dest/l1_contract_addresses.d.ts.map +1 -1
  56. package/dest/l1_contract_addresses.js +3 -3
  57. package/dest/l1_reader.d.ts +3 -1
  58. package/dest/l1_reader.d.ts.map +1 -1
  59. package/dest/l1_reader.js +6 -0
  60. package/dest/l1_tx_utils/config.d.ts +3 -3
  61. package/dest/l1_tx_utils/config.d.ts.map +1 -1
  62. package/dest/l1_tx_utils/config.js +17 -3
  63. package/dest/l1_tx_utils/constants.d.ts +8 -2
  64. package/dest/l1_tx_utils/constants.d.ts.map +1 -1
  65. package/dest/l1_tx_utils/constants.js +27 -2
  66. package/dest/l1_tx_utils/fee-strategies/index.d.ts +10 -0
  67. package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
  68. package/dest/l1_tx_utils/fee-strategies/index.js +12 -0
  69. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +8 -0
  70. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
  71. package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +129 -0
  72. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +23 -0
  73. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
  74. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +191 -0
  75. package/dest/l1_tx_utils/fee-strategies/types.d.ts +51 -0
  76. package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
  77. package/dest/l1_tx_utils/fee-strategies/types.js +3 -0
  78. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
  79. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
  80. package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +48 -0
  81. package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
  82. package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
  83. package/dest/l1_tx_utils/index-blobs.js +2 -0
  84. package/dest/l1_tx_utils/index.d.ts +3 -1
  85. package/dest/l1_tx_utils/index.d.ts.map +1 -1
  86. package/dest/l1_tx_utils/index.js +2 -0
  87. package/dest/l1_tx_utils/interfaces.d.ts +2 -2
  88. package/dest/l1_tx_utils/interfaces.d.ts.map +1 -1
  89. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
  90. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
  91. package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
  92. package/dest/l1_tx_utils/l1_tx_utils.d.ts +1 -1
  93. package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -1
  94. package/dest/l1_tx_utils/l1_tx_utils.js +23 -10
  95. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +4 -15
  96. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -1
  97. package/dest/l1_tx_utils/readonly_l1_tx_utils.js +53 -160
  98. package/dest/publisher_manager.d.ts +3 -2
  99. package/dest/publisher_manager.d.ts.map +1 -1
  100. package/dest/publisher_manager.js +2 -2
  101. package/dest/queries.d.ts +2 -2
  102. package/dest/queries.d.ts.map +1 -1
  103. package/dest/queries.js +12 -4
  104. package/dest/test/chain_monitor.d.ts +15 -13
  105. package/dest/test/chain_monitor.d.ts.map +1 -1
  106. package/dest/test/chain_monitor.js +7 -9
  107. package/dest/test/eth_cheat_codes.d.ts +13 -1
  108. package/dest/test/eth_cheat_codes.d.ts.map +1 -1
  109. package/dest/test/eth_cheat_codes.js +4 -2
  110. package/dest/test/rollup_cheat_codes.d.ts +9 -6
  111. package/dest/test/rollup_cheat_codes.d.ts.map +1 -1
  112. package/dest/test/rollup_cheat_codes.js +32 -6
  113. package/dest/test/start_anvil.d.ts +3 -1
  114. package/dest/test/start_anvil.d.ts.map +1 -1
  115. package/dest/test/start_anvil.js +1 -1
  116. package/dest/test/tx_delayer.d.ts +1 -1
  117. package/dest/test/tx_delayer.d.ts.map +1 -1
  118. package/dest/test/tx_delayer.js +4 -3
  119. package/dest/types.d.ts +57 -2
  120. package/dest/types.d.ts.map +1 -1
  121. package/dest/utils.d.ts +16 -3
  122. package/dest/utils.d.ts.map +1 -1
  123. package/dest/utils.js +64 -0
  124. package/package.json +33 -14
  125. package/src/client.ts +2 -2
  126. package/src/config.ts +62 -457
  127. package/src/contracts/README.md +157 -0
  128. package/src/contracts/empire_base.ts +1 -1
  129. package/src/contracts/empire_slashing_proposer.ts +22 -28
  130. package/src/contracts/fee_asset_handler.ts +10 -7
  131. package/src/contracts/governance.ts +10 -1
  132. package/src/contracts/governance_proposer.ts +10 -2
  133. package/src/contracts/inbox.ts +55 -3
  134. package/src/contracts/index.ts +2 -0
  135. package/src/contracts/log.ts +13 -0
  136. package/src/contracts/multicall.ts +5 -2
  137. package/src/contracts/outbox.ts +98 -0
  138. package/src/contracts/rollup.ts +379 -111
  139. package/src/contracts/tally_slashing_proposer.ts +7 -1
  140. package/src/deploy_aztec_l1_contracts.ts +619 -0
  141. package/src/deploy_l1_contract.ts +362 -0
  142. package/src/forwarder_proxy.ts +108 -0
  143. package/src/generated/l1-contracts-defaults.ts +32 -0
  144. package/src/l1_contract_addresses.ts +22 -20
  145. package/src/l1_reader.ts +8 -0
  146. package/src/l1_tx_utils/config.ts +24 -6
  147. package/src/l1_tx_utils/constants.ts +13 -2
  148. package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
  149. package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +163 -0
  150. package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +245 -0
  151. package/src/l1_tx_utils/fee-strategies/types.ts +56 -0
  152. package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +119 -0
  153. package/src/l1_tx_utils/index-blobs.ts +2 -0
  154. package/src/l1_tx_utils/index.ts +2 -0
  155. package/src/l1_tx_utils/interfaces.ts +1 -1
  156. package/src/l1_tx_utils/l1_fee_analyzer.ts +803 -0
  157. package/src/l1_tx_utils/l1_tx_utils.ts +30 -10
  158. package/src/l1_tx_utils/readonly_l1_tx_utils.ts +67 -206
  159. package/src/publisher_manager.ts +4 -2
  160. package/src/queries.ts +11 -3
  161. package/src/test/chain_monitor.ts +18 -16
  162. package/src/test/eth_cheat_codes.ts +2 -2
  163. package/src/test/rollup_cheat_codes.ts +32 -9
  164. package/src/test/start_anvil.ts +3 -1
  165. package/src/test/tx_delayer.ts +5 -3
  166. package/src/types.ts +62 -0
  167. package/src/utils.ts +83 -1
  168. package/dest/deploy_l1_contracts.d.ts +0 -673
  169. package/dest/deploy_l1_contracts.d.ts.map +0 -1
  170. package/dest/deploy_l1_contracts.js +0 -1491
  171. package/dest/index.d.ts +0 -18
  172. package/dest/index.d.ts.map +0 -1
  173. package/dest/index.js +0 -17
  174. package/src/deploy_l1_contracts.ts +0 -1869
  175. package/src/index.ts +0 -17
@@ -1,12 +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
+ };
6
369
  }
7
- import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
370
+ function _apply_decs_2203_r(targetClass, memberDecs, classDecs, parentClass) {
371
+ return (_apply_decs_2203_r = applyDecs2203RFactory())(targetClass, memberDecs, classDecs, parentClass);
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';
8
377
  import { memoize } from '@aztec/foundation/decorators';
9
378
  import { EthAddress } from '@aztec/foundation/eth-address';
379
+ import { makeBackoff, retry } from '@aztec/foundation/retry';
380
+ import { EscapeHatchAbi } from '@aztec/l1-artifacts/EscapeHatchAbi';
10
381
  import { RollupAbi } from '@aztec/l1-artifacts/RollupAbi';
11
382
  import { RollupStorage } from '@aztec/l1-artifacts/RollupStorage';
12
383
  import chunk from 'lodash.chunk';
@@ -24,10 +395,120 @@ export var SlashingProposerType = /*#__PURE__*/ function(SlashingProposerType) {
24
395
  SlashingProposerType[SlashingProposerType["Empire"] = 2] = "Empire";
25
396
  return SlashingProposerType;
26
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
+ }({});
27
408
  export class RollupContract {
28
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
+ }
29
509
  rollup;
30
510
  static cachedStfStorageSlot;
511
+ cachedEscapeHatch;
31
512
  static get checkBlobStorageSlot() {
32
513
  const asString = RollupStorage.find((storage)=>storage.label === 'checkBlob')?.slot;
33
514
  if (asString === undefined) {
@@ -49,6 +530,7 @@ export class RollupContract {
49
530
  }
50
531
  constructor(client, address){
51
532
  this.client = client;
533
+ _initProto(this);
52
534
  if (address instanceof EthAddress) {
53
535
  address = address.toString();
54
536
  }
@@ -58,8 +540,8 @@ export class RollupContract {
58
540
  client
59
541
  });
60
542
  }
61
- getGSE() {
62
- return this.rollup.read.getGSE();
543
+ async getGSE() {
544
+ return EthAddress.fromString(await this.rollup.read.getGSE());
63
545
  }
64
546
  get address() {
65
547
  return this.rollup.address;
@@ -108,17 +590,17 @@ export class RollupContract {
108
590
  getL1GenesisTime() {
109
591
  return this.rollup.read.getGenesisTime();
110
592
  }
111
- getProofSubmissionEpochs() {
112
- return this.rollup.read.getProofSubmissionEpochs();
593
+ async getProofSubmissionEpochs() {
594
+ return Number(await this.rollup.read.getProofSubmissionEpochs());
113
595
  }
114
- getEpochDuration() {
115
- return this.rollup.read.getEpochDuration();
596
+ async getEpochDuration() {
597
+ return Number(await this.rollup.read.getEpochDuration());
116
598
  }
117
599
  async getSlotDuration() {
118
600
  return Number(await this.rollup.read.getSlotDuration());
119
601
  }
120
- getTargetCommitteeSize() {
121
- return this.rollup.read.getTargetCommitteeSize();
602
+ async getTargetCommitteeSize() {
603
+ return Number(await this.rollup.read.getTargetCommitteeSize());
122
604
  }
123
605
  getEjectionThreshold() {
124
606
  return this.rollup.read.getEjectionThreshold();
@@ -126,17 +608,17 @@ export class RollupContract {
126
608
  getLocalEjectionThreshold() {
127
609
  return this.rollup.read.getLocalEjectionThreshold();
128
610
  }
129
- getLagInEpochsForValidatorSet() {
130
- return this.rollup.read.getLagInEpochsForValidatorSet();
611
+ async getLagInEpochsForValidatorSet() {
612
+ return Number(await this.rollup.read.getLagInEpochsForValidatorSet());
131
613
  }
132
- getLagInEpochsForRandao() {
133
- return this.rollup.read.getLagInEpochsForRandao();
614
+ async getLagInEpochsForRandao() {
615
+ return Number(await this.rollup.read.getLagInEpochsForRandao());
134
616
  }
135
617
  getActivationThreshold() {
136
618
  return this.rollup.read.getActivationThreshold();
137
619
  }
138
- getExitDelay() {
139
- return this.rollup.read.getExitDelay();
620
+ async getExitDelay() {
621
+ return Number(await this.rollup.read.getExitDelay());
140
622
  }
141
623
  getManaTarget() {
142
624
  return this.rollup.read.getManaTarget();
@@ -154,9 +636,9 @@ export class RollupContract {
154
636
  return this.rollup.read.getVersion();
155
637
  }
156
638
  async getGenesisArchiveTreeRoot() {
157
- return await this.rollup.read.archiveAt([
639
+ return Fr.fromString(await this.rollup.read.archiveAt([
158
640
  0n
159
- ]);
641
+ ]));
160
642
  }
161
643
  /**
162
644
  * Returns rollup constants used for epoch queries.
@@ -178,23 +660,67 @@ export class RollupContract {
178
660
  proofSubmissionEpochs: Number(proofSubmissionEpochs)
179
661
  };
180
662
  }
181
- getSlasherAddress() {
182
- 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
+ }
183
709
  }
184
710
  /**
185
711
  * Returns a SlasherContract instance for interacting with the slasher contract.
186
712
  */ async getSlasherContract() {
187
- const slasherAddress = EthAddress.fromString(await this.getSlasherAddress());
713
+ const slasherAddress = await this.getSlasherAddress();
188
714
  if (slasherAddress.isZero()) {
189
715
  return undefined;
190
716
  }
191
717
  return new SlasherContract(this.client, slasherAddress);
192
718
  }
193
- getOwner() {
194
- return this.rollup.read.owner();
719
+ async getOwner() {
720
+ return EthAddress.fromString(await this.rollup.read.owner());
195
721
  }
196
- getActiveAttesterCount() {
197
- return this.rollup.read.getActiveAttesterCount();
722
+ async getActiveAttesterCount() {
723
+ return Number(await this.rollup.read.getActiveAttesterCount());
198
724
  }
199
725
  async getSlashingProposerAddress() {
200
726
  const slasher = await this.getSlasherContract();
@@ -206,22 +732,26 @@ export class RollupContract {
206
732
  getCheckpointReward() {
207
733
  return this.rollup.read.getCheckpointReward();
208
734
  }
209
- getCheckpointNumber() {
210
- return this.rollup.read.getPendingCheckpointNumber();
735
+ async getCheckpointNumber() {
736
+ return CheckpointNumber.fromBigInt(await this.rollup.read.getPendingCheckpointNumber());
211
737
  }
212
- getProvenCheckpointNumber() {
213
- return this.rollup.read.getProvenCheckpointNumber();
738
+ async getProvenCheckpointNumber() {
739
+ return CheckpointNumber.fromBigInt(await this.rollup.read.getProvenCheckpointNumber());
214
740
  }
215
741
  async getSlotNumber() {
216
742
  return SlotNumber.fromBigInt(await this.rollup.read.getCurrentSlot());
217
743
  }
218
- getL1FeesAt(timestamp) {
219
- return this.rollup.read.getL1FeesAt([
744
+ async getL1FeesAt(timestamp) {
745
+ const result = await this.rollup.read.getL1FeesAt([
220
746
  timestamp
221
747
  ]);
748
+ return {
749
+ baseFee: result.baseFee,
750
+ blobFee: result.blobFee
751
+ };
222
752
  }
223
- getFeeAssetPerEth() {
224
- return this.rollup.read.getFeeAssetPerEth();
753
+ getEthPerFeeAsset() {
754
+ return this.rollup.read.getEthPerFeeAsset();
225
755
  }
226
756
  async getCommitteeAt(timestamp) {
227
757
  const { result } = await this.client.simulateContract({
@@ -239,15 +769,15 @@ export class RollupContract {
239
769
  }
240
770
  throw e;
241
771
  });
242
- return result;
772
+ return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
243
773
  }
244
- getSampleSeedAt(timestamp) {
245
- return this.rollup.read.getSampleSeedAt([
774
+ async getSampleSeedAt(timestamp) {
775
+ return Buffer32.fromBigInt(await this.rollup.read.getSampleSeedAt([
246
776
  timestamp
247
- ]);
777
+ ]));
248
778
  }
249
- getCurrentSampleSeed() {
250
- return this.rollup.read.getCurrentSampleSeed();
779
+ async getCurrentSampleSeed() {
780
+ return Buffer32.fromBigInt(await this.rollup.read.getCurrentSampleSeed());
251
781
  }
252
782
  async getCurrentEpoch() {
253
783
  return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
@@ -266,7 +796,7 @@ export class RollupContract {
266
796
  }
267
797
  throw e;
268
798
  });
269
- return result;
799
+ return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
270
800
  }
271
801
  async getCurrentProposer() {
272
802
  const { result } = await this.client.simulateContract({
@@ -275,7 +805,7 @@ export class RollupContract {
275
805
  functionName: 'getCurrentProposer',
276
806
  args: []
277
807
  });
278
- return result;
808
+ return EthAddress.fromString(result);
279
809
  }
280
810
  async getProposerAt(timestamp) {
281
811
  const { result } = await this.client.simulateContract({
@@ -286,26 +816,58 @@ export class RollupContract {
286
816
  timestamp
287
817
  ]
288
818
  });
289
- return result;
819
+ return EthAddress.fromString(result);
290
820
  }
291
- getCheckpoint(checkpointNumber) {
292
- return this.rollup.read.getCheckpoint([
821
+ async getCheckpoint(checkpointNumber) {
822
+ const result = await this.rollup.read.getCheckpoint([
293
823
  BigInt(checkpointNumber)
294
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
+ };
295
840
  }
296
- getTips() {
297
- 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
+ };
298
860
  }
299
861
  getTimestampForSlot(slot) {
300
862
  return this.rollup.read.getTimestampForSlot([
301
863
  BigInt(slot)
302
864
  ]);
303
865
  }
304
- getEntryQueueLength() {
305
- return this.rollup.read.getEntryQueueLength();
866
+ async getEntryQueueLength() {
867
+ return Number(await this.rollup.read.getEntryQueueLength());
306
868
  }
307
- getAvailableValidatorFlushes() {
308
- return this.rollup.read.getAvailableValidatorFlushes();
869
+ async getAvailableValidatorFlushes() {
870
+ return Number(await this.rollup.read.getAvailableValidatorFlushes());
309
871
  }
310
872
  async getNextFlushableEpoch() {
311
873
  return EpochNumber.fromBigInt(await this.rollup.read.getNextFlushableEpoch());
@@ -347,8 +909,9 @@ export class RollupContract {
347
909
  BigInt(slotNumber)
348
910
  ]));
349
911
  }
350
- getEpochProofPublicInputs(args) {
351
- 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);
352
915
  }
353
916
  async validateHeader(args, account) {
354
917
  try {
@@ -391,7 +954,7 @@ export class RollupContract {
391
954
  });
392
955
  return {
393
956
  slot: SlotNumber.fromBigInt(slot),
394
- checkpointNumber,
957
+ checkpointNumber: CheckpointNumber.fromBigInt(checkpointNumber),
395
958
  timeOfNextL1Slot
396
959
  };
397
960
  } catch (err) {
@@ -428,6 +991,7 @@ export class RollupContract {
428
991
  /** Creates a request to Rollup#invalidateBadAttestation to be simulated or sent */ buildInvalidateBadAttestationRequest(checkpointNumber, attestationsAndSigners, committee, invalidIndex) {
429
992
  return {
430
993
  to: this.address,
994
+ abi: RollupAbi,
431
995
  data: encodeFunctionData({
432
996
  abi: RollupAbi,
433
997
  functionName: 'invalidateBadAttestation',
@@ -443,6 +1007,7 @@ export class RollupContract {
443
1007
  /** Creates a request to Rollup#invalidateInsufficientAttestations to be simulated or sent */ buildInvalidateInsufficientAttestationsRequest(checkpointNumber, attestationsAndSigners, committee) {
444
1008
  return {
445
1009
  to: this.address,
1010
+ abi: RollupAbi,
446
1011
  data: encodeFunctionData({
447
1012
  abi: RollupAbi,
448
1013
  functionName: 'invalidateInsufficientAttestations',
@@ -464,8 +1029,8 @@ export class RollupContract {
464
1029
  prover
465
1030
  ]);
466
1031
  }
467
- getManaBaseFeeAt(timestamp, inFeeAsset) {
468
- return this.rollup.read.getManaBaseFeeAt([
1032
+ getManaMinFeeAt(timestamp, inFeeAsset) {
1033
+ return this.rollup.read.getManaMinFeeAt([
469
1034
  timestamp,
470
1035
  inFeeAsset
471
1036
  ]);
@@ -477,9 +1042,16 @@ export class RollupContract {
477
1042
  }
478
1043
  async status(checkpointNumber, options) {
479
1044
  await checkBlockTag(options?.blockNumber, this.client);
480
- return this.rollup.read.status([
481
- checkpointNumber
1045
+ const result = await this.rollup.read.status([
1046
+ BigInt(checkpointNumber)
482
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
+ };
483
1055
  }
484
1056
  async canPruneAtTime(timestamp, options) {
485
1057
  await checkBlockTag(options?.blockNumber, this.client);
@@ -487,13 +1059,13 @@ export class RollupContract {
487
1059
  timestamp
488
1060
  ], options);
489
1061
  }
490
- archive() {
491
- return this.rollup.read.archive();
1062
+ async archive() {
1063
+ return Fr.fromString(await this.rollup.read.archive());
492
1064
  }
493
- archiveAt(checkpointNumber) {
494
- return this.rollup.read.archiveAt([
495
- checkpointNumber
496
- ]);
1065
+ async archiveAt(checkpointNumber) {
1066
+ return Fr.fromString(await this.rollup.read.archiveAt([
1067
+ BigInt(checkpointNumber)
1068
+ ]));
497
1069
  }
498
1070
  getSequencerRewards(address) {
499
1071
  if (address instanceof EthAddress) {
@@ -517,44 +1089,71 @@ export class RollupContract {
517
1089
  const gse = new GSEContract(this.client, await this.getGSE());
518
1090
  const ts = (await this.client.getBlock()).timestamp;
519
1091
  const indices = Array.from({
520
- length: Number(attesterSize)
1092
+ length: attesterSize
521
1093
  }, (_, i)=>BigInt(i));
522
1094
  const chunks = chunk(indices, 1000);
523
- return (await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)))).flat();
1095
+ const results = await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)));
1096
+ return results.flat().map((addr)=>EthAddress.fromString(addr));
524
1097
  }
525
- getAttesterView(address) {
1098
+ async getAttesterView(address) {
526
1099
  if (address instanceof EthAddress) {
527
1100
  address = address.toString();
528
1101
  }
529
- return this.rollup.read.getAttesterView([
1102
+ const result = await this.rollup.read.getAttesterView([
530
1103
  address
531
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
+ };
532
1124
  }
533
- getStatus(address) {
1125
+ async getStatus(address) {
534
1126
  if (address instanceof EthAddress) {
535
1127
  address = address.toString();
536
1128
  }
537
- return this.rollup.read.getStatus([
1129
+ return await this.rollup.read.getStatus([
538
1130
  address
539
1131
  ]);
540
1132
  }
541
- getBlobCommitmentsHash(checkpointNumber) {
542
- return this.rollup.read.getBlobCommitmentsHash([
543
- checkpointNumber
544
- ]);
1133
+ async getBlobCommitmentsHash(checkpointNumber) {
1134
+ return Buffer32.fromString(await this.rollup.read.getBlobCommitmentsHash([
1135
+ BigInt(checkpointNumber)
1136
+ ]));
545
1137
  }
546
- getCurrentBlobCommitmentsHash() {
547
- return this.rollup.read.getCurrentBlobCommitmentsHash();
1138
+ async getCurrentBlobCommitmentsHash() {
1139
+ return Buffer32.fromString(await this.rollup.read.getCurrentBlobCommitmentsHash());
548
1140
  }
549
- getStakingAsset() {
550
- return this.rollup.read.getStakingAsset();
1141
+ async getStakingAsset() {
1142
+ return EthAddress.fromString(await this.rollup.read.getStakingAsset());
551
1143
  }
552
- getRewardConfig() {
553
- return this.rollup.read.getRewardConfig();
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
+ };
554
1152
  }
555
1153
  setupEpoch(l1TxUtils) {
556
1154
  return l1TxUtils.sendAndMonitorTransaction({
557
1155
  to: this.address,
1156
+ abi: RollupAbi,
558
1157
  data: encodeFunctionData({
559
1158
  abi: RollupAbi,
560
1159
  functionName: 'setupEpoch',
@@ -565,6 +1164,7 @@ export class RollupContract {
565
1164
  vote(l1TxUtils, proposalId) {
566
1165
  return l1TxUtils.sendAndMonitorTransaction({
567
1166
  to: this.address,
1167
+ abi: RollupAbi,
568
1168
  data: encodeFunctionData({
569
1169
  abi: RollupAbi,
570
1170
  functionName: 'vote',
@@ -593,7 +1193,7 @@ export class RollupContract {
593
1193
  const args = log.args;
594
1194
  if (args.checkpointNumber !== undefined) {
595
1195
  callback({
596
- checkpointNumber: args.checkpointNumber
1196
+ checkpointNumber: CheckpointNumber.fromBigInt(args.checkpointNumber)
597
1197
  });
598
1198
  }
599
1199
  }
@@ -624,61 +1224,22 @@ export class RollupContract {
624
1224
  }
625
1225
  });
626
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
+ }
627
1245
  }
628
- _ts_decorate([
629
- memoize
630
- ], RollupContract.prototype, "getL1StartBlock", null);
631
- _ts_decorate([
632
- memoize
633
- ], RollupContract.prototype, "getL1GenesisTime", null);
634
- _ts_decorate([
635
- memoize
636
- ], RollupContract.prototype, "getProofSubmissionEpochs", null);
637
- _ts_decorate([
638
- memoize
639
- ], RollupContract.prototype, "getEpochDuration", null);
640
- _ts_decorate([
641
- memoize
642
- ], RollupContract.prototype, "getSlotDuration", null);
643
- _ts_decorate([
644
- memoize
645
- ], RollupContract.prototype, "getTargetCommitteeSize", null);
646
- _ts_decorate([
647
- memoize
648
- ], RollupContract.prototype, "getEjectionThreshold", null);
649
- _ts_decorate([
650
- memoize
651
- ], RollupContract.prototype, "getLocalEjectionThreshold", null);
652
- _ts_decorate([
653
- memoize
654
- ], RollupContract.prototype, "getLagInEpochsForValidatorSet", null);
655
- _ts_decorate([
656
- memoize
657
- ], RollupContract.prototype, "getLagInEpochsForRandao", null);
658
- _ts_decorate([
659
- memoize
660
- ], RollupContract.prototype, "getActivationThreshold", null);
661
- _ts_decorate([
662
- memoize
663
- ], RollupContract.prototype, "getExitDelay", null);
664
- _ts_decorate([
665
- memoize
666
- ], RollupContract.prototype, "getManaTarget", null);
667
- _ts_decorate([
668
- memoize
669
- ], RollupContract.prototype, "getProvingCostPerMana", null);
670
- _ts_decorate([
671
- memoize
672
- ], RollupContract.prototype, "getProvingCostPerManaInFeeAsset", null);
673
- _ts_decorate([
674
- memoize
675
- ], RollupContract.prototype, "getManaLimit", null);
676
- _ts_decorate([
677
- memoize
678
- ], RollupContract.prototype, "getVersion", null);
679
- _ts_decorate([
680
- memoize
681
- ], RollupContract.prototype, "getGenesisArchiveTreeRoot", null);
682
- _ts_decorate([
683
- memoize
684
- ], RollupContract.prototype, "getRollupConstants", null);