@aztec/ethereum 0.0.1-commit.5daedc8 → 0.0.1-commit.5de5ca79e

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 (205) hide show
  1. package/dest/client.d.ts +10 -2
  2. package/dest/client.d.ts.map +1 -1
  3. package/dest/client.js +13 -3
  4. package/dest/config.d.ts +21 -68
  5. package/dest/config.d.ts.map +1 -1
  6. package/dest/config.js +61 -380
  7. package/dest/contracts/empire_base.d.ts +4 -1
  8. package/dest/contracts/empire_base.d.ts.map +1 -1
  9. package/dest/contracts/empire_slashing_proposer.d.ts +4 -1
  10. package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -1
  11. package/dest/contracts/empire_slashing_proposer.js +31 -15
  12. package/dest/contracts/fee_asset_handler.d.ts +6 -5
  13. package/dest/contracts/fee_asset_handler.d.ts.map +1 -1
  14. package/dest/contracts/fee_asset_handler.js +11 -9
  15. package/dest/contracts/fee_asset_price_oracle.d.ts +101 -0
  16. package/dest/contracts/fee_asset_price_oracle.d.ts.map +1 -0
  17. package/dest/contracts/fee_asset_price_oracle.js +651 -0
  18. package/dest/contracts/governance.d.ts +3 -1
  19. package/dest/contracts/governance.d.ts.map +1 -1
  20. package/dest/contracts/governance.js +14 -4
  21. package/dest/contracts/governance_proposer.d.ts +4 -1
  22. package/dest/contracts/governance_proposer.d.ts.map +1 -1
  23. package/dest/contracts/governance_proposer.js +404 -9
  24. package/dest/contracts/inbox.d.ts +24 -3
  25. package/dest/contracts/inbox.d.ts.map +1 -1
  26. package/dest/contracts/inbox.js +36 -1
  27. package/dest/contracts/index.d.ts +4 -1
  28. package/dest/contracts/index.d.ts.map +1 -1
  29. package/dest/contracts/index.js +3 -0
  30. package/dest/contracts/log.d.ts +13 -0
  31. package/dest/contracts/log.d.ts.map +1 -0
  32. package/dest/contracts/log.js +1 -0
  33. package/dest/contracts/multicall.d.ts +1 -1
  34. package/dest/contracts/multicall.d.ts.map +1 -1
  35. package/dest/contracts/multicall.js +2 -1
  36. package/dest/contracts/outbox.d.ts +41 -0
  37. package/dest/contracts/outbox.d.ts.map +1 -0
  38. package/dest/contracts/outbox.js +86 -0
  39. package/dest/contracts/registry.d.ts +3 -1
  40. package/dest/contracts/registry.d.ts.map +1 -1
  41. package/dest/contracts/registry.js +30 -1
  42. package/dest/contracts/rollup.d.ts +191 -97
  43. package/dest/contracts/rollup.d.ts.map +1 -1
  44. package/dest/contracts/rollup.js +760 -146
  45. package/dest/contracts/tally_slashing_proposer.d.ts +3 -2
  46. package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -1
  47. package/dest/contracts/tally_slashing_proposer.js +8 -1
  48. package/dest/deploy_aztec_l1_contracts.d.ts +259 -0
  49. package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
  50. package/dest/deploy_aztec_l1_contracts.js +413 -0
  51. package/dest/deploy_l1_contract.d.ts +68 -0
  52. package/dest/deploy_l1_contract.d.ts.map +1 -0
  53. package/dest/deploy_l1_contract.js +312 -0
  54. package/dest/forwarder_proxy.d.ts +32 -0
  55. package/dest/forwarder_proxy.d.ts.map +1 -0
  56. package/dest/forwarder_proxy.js +93 -0
  57. package/dest/generated/l1-contracts-defaults.d.ts +30 -0
  58. package/dest/generated/l1-contracts-defaults.d.ts.map +1 -0
  59. package/dest/generated/l1-contracts-defaults.js +30 -0
  60. package/dest/l1_artifacts.d.ts +5975 -1575
  61. package/dest/l1_artifacts.d.ts.map +1 -1
  62. package/dest/l1_contract_addresses.d.ts +1 -1
  63. package/dest/l1_contract_addresses.d.ts.map +1 -1
  64. package/dest/l1_contract_addresses.js +3 -3
  65. package/dest/l1_reader.d.ts +5 -1
  66. package/dest/l1_reader.d.ts.map +1 -1
  67. package/dest/l1_reader.js +12 -1
  68. package/dest/l1_tx_utils/config.d.ts +9 -3
  69. package/dest/l1_tx_utils/config.d.ts.map +1 -1
  70. package/dest/l1_tx_utils/config.js +31 -4
  71. package/dest/l1_tx_utils/constants.d.ts +8 -2
  72. package/dest/l1_tx_utils/constants.d.ts.map +1 -1
  73. package/dest/l1_tx_utils/constants.js +27 -2
  74. package/dest/l1_tx_utils/factory.d.ts +18 -10
  75. package/dest/l1_tx_utils/factory.d.ts.map +1 -1
  76. package/dest/l1_tx_utils/factory.js +17 -7
  77. package/dest/l1_tx_utils/fee-strategies/index.d.ts +10 -0
  78. package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
  79. package/dest/l1_tx_utils/fee-strategies/index.js +12 -0
  80. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +8 -0
  81. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
  82. package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +129 -0
  83. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +23 -0
  84. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
  85. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +191 -0
  86. package/dest/l1_tx_utils/fee-strategies/types.d.ts +51 -0
  87. package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
  88. package/dest/l1_tx_utils/fee-strategies/types.js +3 -0
  89. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
  90. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
  91. package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +42 -0
  92. package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
  93. package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
  94. package/dest/l1_tx_utils/index-blobs.js +2 -0
  95. package/dest/l1_tx_utils/index.d.ts +4 -1
  96. package/dest/l1_tx_utils/index.d.ts.map +1 -1
  97. package/dest/l1_tx_utils/index.js +3 -0
  98. package/dest/l1_tx_utils/interfaces.d.ts +2 -2
  99. package/dest/l1_tx_utils/interfaces.d.ts.map +1 -1
  100. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
  101. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
  102. package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
  103. package/dest/l1_tx_utils/l1_tx_utils.d.ts +18 -7
  104. package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -1
  105. package/dest/l1_tx_utils/l1_tx_utils.js +75 -46
  106. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +4 -15
  107. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -1
  108. package/dest/l1_tx_utils/readonly_l1_tx_utils.js +61 -164
  109. package/dest/l1_tx_utils/tx_delayer.d.ts +56 -0
  110. package/dest/l1_tx_utils/tx_delayer.d.ts.map +1 -0
  111. package/dest/{test → l1_tx_utils}/tx_delayer.js +65 -36
  112. package/dest/publisher_manager.d.ts +3 -2
  113. package/dest/publisher_manager.d.ts.map +1 -1
  114. package/dest/publisher_manager.js +2 -2
  115. package/dest/queries.d.ts +2 -2
  116. package/dest/queries.d.ts.map +1 -1
  117. package/dest/queries.js +12 -4
  118. package/dest/test/chain_monitor.d.ts +35 -14
  119. package/dest/test/chain_monitor.d.ts.map +1 -1
  120. package/dest/test/chain_monitor.js +40 -11
  121. package/dest/test/eth_cheat_codes.d.ts +13 -1
  122. package/dest/test/eth_cheat_codes.d.ts.map +1 -1
  123. package/dest/test/eth_cheat_codes.js +4 -2
  124. package/dest/test/index.d.ts +1 -3
  125. package/dest/test/index.d.ts.map +1 -1
  126. package/dest/test/index.js +0 -2
  127. package/dest/test/rollup_cheat_codes.d.ts +9 -6
  128. package/dest/test/rollup_cheat_codes.d.ts.map +1 -1
  129. package/dest/test/rollup_cheat_codes.js +32 -6
  130. package/dest/test/start_anvil.d.ts +17 -2
  131. package/dest/test/start_anvil.d.ts.map +1 -1
  132. package/dest/test/start_anvil.js +129 -29
  133. package/dest/test/upgrade_utils.js +2 -2
  134. package/dest/types.d.ts +57 -2
  135. package/dest/types.d.ts.map +1 -1
  136. package/dest/utils.d.ts +16 -3
  137. package/dest/utils.d.ts.map +1 -1
  138. package/dest/utils.js +80 -12
  139. package/package.json +33 -16
  140. package/src/client.ts +10 -2
  141. package/src/config.ts +77 -459
  142. package/src/contracts/README.md +157 -0
  143. package/src/contracts/empire_base.ts +3 -1
  144. package/src/contracts/empire_slashing_proposer.ts +28 -28
  145. package/src/contracts/fee_asset_handler.ts +10 -7
  146. package/src/contracts/fee_asset_price_oracle.ts +280 -0
  147. package/src/contracts/governance.ts +13 -4
  148. package/src/contracts/governance_proposer.ts +16 -2
  149. package/src/contracts/inbox.ts +55 -3
  150. package/src/contracts/index.ts +3 -0
  151. package/src/contracts/log.ts +13 -0
  152. package/src/contracts/multicall.ts +5 -2
  153. package/src/contracts/outbox.ts +98 -0
  154. package/src/contracts/registry.ts +31 -1
  155. package/src/contracts/rollup.ts +445 -115
  156. package/src/contracts/tally_slashing_proposer.ts +7 -1
  157. package/src/deploy_aztec_l1_contracts.ts +650 -0
  158. package/src/deploy_l1_contract.ts +362 -0
  159. package/src/forwarder_proxy.ts +108 -0
  160. package/src/generated/l1-contracts-defaults.ts +32 -0
  161. package/src/l1_contract_addresses.ts +22 -20
  162. package/src/l1_reader.ts +21 -1
  163. package/src/l1_tx_utils/config.ts +44 -6
  164. package/src/l1_tx_utils/constants.ts +13 -2
  165. package/src/l1_tx_utils/factory.ts +31 -31
  166. package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
  167. package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +163 -0
  168. package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +245 -0
  169. package/src/l1_tx_utils/fee-strategies/types.ts +56 -0
  170. package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +108 -0
  171. package/src/l1_tx_utils/index-blobs.ts +2 -0
  172. package/src/l1_tx_utils/index.ts +3 -0
  173. package/src/l1_tx_utils/interfaces.ts +1 -1
  174. package/src/l1_tx_utils/l1_fee_analyzer.ts +803 -0
  175. package/src/l1_tx_utils/l1_tx_utils.ts +84 -36
  176. package/src/l1_tx_utils/readonly_l1_tx_utils.ts +75 -210
  177. package/src/{test → l1_tx_utils}/tx_delayer.ts +82 -52
  178. package/src/publisher_manager.ts +4 -2
  179. package/src/queries.ts +11 -3
  180. package/src/test/chain_monitor.ts +77 -18
  181. package/src/test/eth_cheat_codes.ts +2 -2
  182. package/src/test/index.ts +0 -2
  183. package/src/test/rollup_cheat_codes.ts +32 -9
  184. package/src/test/start_anvil.ts +155 -28
  185. package/src/test/upgrade_utils.ts +2 -2
  186. package/src/types.ts +62 -0
  187. package/src/utils.ts +100 -15
  188. package/dest/deploy_l1_contracts.d.ts +0 -673
  189. package/dest/deploy_l1_contracts.d.ts.map +0 -1
  190. package/dest/deploy_l1_contracts.js +0 -1491
  191. package/dest/index.d.ts +0 -18
  192. package/dest/index.d.ts.map +0 -1
  193. package/dest/index.js +0 -17
  194. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +0 -26
  195. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +0 -1
  196. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.js +0 -26
  197. package/dest/test/delayed_tx_utils.d.ts +0 -13
  198. package/dest/test/delayed_tx_utils.d.ts.map +0 -1
  199. package/dest/test/delayed_tx_utils.js +0 -28
  200. package/dest/test/tx_delayer.d.ts +0 -36
  201. package/dest/test/tx_delayer.d.ts.map +0 -1
  202. package/src/deploy_l1_contracts.ts +0 -1869
  203. package/src/index.ts +0 -17
  204. package/src/l1_tx_utils/l1_tx_utils_with_blobs.ts +0 -77
  205. package/src/test/delayed_tx_utils.ts +0 -52
@@ -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
+ };
369
+ }
370
+ function _apply_decs_2203_r(targetClass, memberDecs, classDecs, parentClass) {
371
+ return (_apply_decs_2203_r = applyDecs2203RFactory())(targetClass, memberDecs, classDecs, parentClass);
6
372
  }
7
- import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
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,130 @@ 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
+ "getVkTreeRoot"
506
+ ],
507
+ [
508
+ memoize,
509
+ 2,
510
+ "getProtocolContractsHash"
511
+ ],
512
+ [
513
+ memoize,
514
+ 2,
515
+ "getRollupConstants"
516
+ ]
517
+ ], []));
518
+ }
29
519
  rollup;
30
520
  static cachedStfStorageSlot;
521
+ cachedEscapeHatch;
31
522
  static get checkBlobStorageSlot() {
32
523
  const asString = RollupStorage.find((storage)=>storage.label === 'checkBlob')?.slot;
33
524
  if (asString === undefined) {
@@ -49,6 +540,7 @@ export class RollupContract {
49
540
  }
50
541
  constructor(client, address){
51
542
  this.client = client;
543
+ _initProto(this);
52
544
  if (address instanceof EthAddress) {
53
545
  address = address.toString();
54
546
  }
@@ -58,8 +550,8 @@ export class RollupContract {
58
550
  client
59
551
  });
60
552
  }
61
- getGSE() {
62
- return this.rollup.read.getGSE();
553
+ async getGSE() {
554
+ return EthAddress.fromString(await this.rollup.read.getGSE());
63
555
  }
64
556
  get address() {
65
557
  return this.rollup.address;
@@ -108,17 +600,17 @@ export class RollupContract {
108
600
  getL1GenesisTime() {
109
601
  return this.rollup.read.getGenesisTime();
110
602
  }
111
- getProofSubmissionEpochs() {
112
- return this.rollup.read.getProofSubmissionEpochs();
603
+ async getProofSubmissionEpochs() {
604
+ return Number(await this.rollup.read.getProofSubmissionEpochs());
113
605
  }
114
- getEpochDuration() {
115
- return this.rollup.read.getEpochDuration();
606
+ async getEpochDuration() {
607
+ return Number(await this.rollup.read.getEpochDuration());
116
608
  }
117
609
  async getSlotDuration() {
118
610
  return Number(await this.rollup.read.getSlotDuration());
119
611
  }
120
- getTargetCommitteeSize() {
121
- return this.rollup.read.getTargetCommitteeSize();
612
+ async getTargetCommitteeSize() {
613
+ return Number(await this.rollup.read.getTargetCommitteeSize());
122
614
  }
123
615
  getEjectionThreshold() {
124
616
  return this.rollup.read.getEjectionThreshold();
@@ -126,17 +618,17 @@ export class RollupContract {
126
618
  getLocalEjectionThreshold() {
127
619
  return this.rollup.read.getLocalEjectionThreshold();
128
620
  }
129
- getLagInEpochsForValidatorSet() {
130
- return this.rollup.read.getLagInEpochsForValidatorSet();
621
+ async getLagInEpochsForValidatorSet() {
622
+ return Number(await this.rollup.read.getLagInEpochsForValidatorSet());
131
623
  }
132
- getLagInEpochsForRandao() {
133
- return this.rollup.read.getLagInEpochsForRandao();
624
+ async getLagInEpochsForRandao() {
625
+ return Number(await this.rollup.read.getLagInEpochsForRandao());
134
626
  }
135
627
  getActivationThreshold() {
136
628
  return this.rollup.read.getActivationThreshold();
137
629
  }
138
- getExitDelay() {
139
- return this.rollup.read.getExitDelay();
630
+ async getExitDelay() {
631
+ return Number(await this.rollup.read.getExitDelay());
140
632
  }
141
633
  getManaTarget() {
142
634
  return this.rollup.read.getManaTarget();
@@ -154,47 +646,111 @@ export class RollupContract {
154
646
  return this.rollup.read.getVersion();
155
647
  }
156
648
  async getGenesisArchiveTreeRoot() {
157
- return await this.rollup.read.archiveAt([
649
+ return Fr.fromString(await this.rollup.read.archiveAt([
158
650
  0n
159
- ]);
651
+ ]));
652
+ }
653
+ async getVkTreeRoot() {
654
+ const slot = BigInt(RollupContract.stfStorageSlot) + 3n;
655
+ const value = await this.client.getStorageAt({
656
+ address: this.address,
657
+ slot: `0x${slot.toString(16)}`
658
+ });
659
+ return Fr.fromString(value ?? '0x0');
660
+ }
661
+ async getProtocolContractsHash() {
662
+ const slot = BigInt(RollupContract.stfStorageSlot) + 4n;
663
+ const value = await this.client.getStorageAt({
664
+ address: this.address,
665
+ slot: `0x${slot.toString(16)}`
666
+ });
667
+ return Fr.fromString(value ?? '0x0');
160
668
  }
161
669
  /**
162
670
  * Returns rollup constants used for epoch queries.
163
671
  * Return type is `L1RollupConstants` which is defined in stdlib,
164
672
  * so we cant reference it until we move this contract to that package.
165
673
  */ async getRollupConstants() {
166
- const [l1StartBlock, l1GenesisTime, slotDuration, epochDuration, proofSubmissionEpochs] = await Promise.all([
674
+ const [l1StartBlock, l1GenesisTime, slotDuration, epochDuration, proofSubmissionEpochs, targetCommitteeSize, rollupManaLimit] = await Promise.all([
167
675
  this.getL1StartBlock(),
168
676
  this.getL1GenesisTime(),
169
677
  this.getSlotDuration(),
170
678
  this.getEpochDuration(),
171
- this.getProofSubmissionEpochs()
679
+ this.getProofSubmissionEpochs(),
680
+ this.getTargetCommitteeSize(),
681
+ this.getManaLimit()
172
682
  ]);
173
683
  return {
174
684
  l1StartBlock,
175
685
  l1GenesisTime,
176
686
  slotDuration,
177
687
  epochDuration: Number(epochDuration),
178
- proofSubmissionEpochs: Number(proofSubmissionEpochs)
688
+ proofSubmissionEpochs: Number(proofSubmissionEpochs),
689
+ targetCommitteeSize,
690
+ rollupManaLimit: Number(rollupManaLimit)
179
691
  };
180
692
  }
181
- getSlasherAddress() {
182
- return this.rollup.read.getSlasher();
693
+ async getSlasherAddress() {
694
+ return EthAddress.fromString(await this.rollup.read.getSlasher());
695
+ }
696
+ /**
697
+ * Returns the configured escape hatch contract address, or zero if disabled.
698
+ */ async getEscapeHatchAddress() {
699
+ return EthAddress.fromString(await this.rollup.read.getEscapeHatch());
700
+ }
701
+ async getEscapeHatchContract() {
702
+ const escapeHatchAddress = await this.getEscapeHatchAddress();
703
+ if (escapeHatchAddress.isZero()) {
704
+ return undefined;
705
+ }
706
+ // Cache the viem contract wrapper since it will be used frequently.
707
+ if (!this.cachedEscapeHatch || !this.cachedEscapeHatch.address.equals(escapeHatchAddress)) {
708
+ this.cachedEscapeHatch = {
709
+ address: escapeHatchAddress,
710
+ contract: getContract({
711
+ address: escapeHatchAddress.toString(),
712
+ abi: EscapeHatchAbi,
713
+ client: this.client
714
+ })
715
+ };
716
+ }
717
+ return this.cachedEscapeHatch.contract;
718
+ }
719
+ /**
720
+ * Returns whether the escape hatch is open for the given epoch.
721
+ * If escape hatch is not configured, returns false.
722
+ *
723
+ * This function is intentionally defensive: any failure to query the escape hatch
724
+ * (RPC issues, transient errors, etc.) is treated as "closed" to avoid callers
725
+ * needing to sprinkle try/catch everywhere.
726
+ */ async isEscapeHatchOpen(epoch) {
727
+ try {
728
+ const escapeHatch = await this.getEscapeHatchContract();
729
+ if (!escapeHatch) {
730
+ return false;
731
+ }
732
+ const [isOpen] = await escapeHatch.read.isHatchOpen([
733
+ BigInt(epoch)
734
+ ]);
735
+ return isOpen;
736
+ } catch {
737
+ return false;
738
+ }
183
739
  }
184
740
  /**
185
741
  * Returns a SlasherContract instance for interacting with the slasher contract.
186
742
  */ async getSlasherContract() {
187
- const slasherAddress = EthAddress.fromString(await this.getSlasherAddress());
743
+ const slasherAddress = await this.getSlasherAddress();
188
744
  if (slasherAddress.isZero()) {
189
745
  return undefined;
190
746
  }
191
747
  return new SlasherContract(this.client, slasherAddress);
192
748
  }
193
- getOwner() {
194
- return this.rollup.read.owner();
749
+ async getOwner() {
750
+ return EthAddress.fromString(await this.rollup.read.owner());
195
751
  }
196
- getActiveAttesterCount() {
197
- return this.rollup.read.getActiveAttesterCount();
752
+ async getActiveAttesterCount() {
753
+ return Number(await this.rollup.read.getActiveAttesterCount());
198
754
  }
199
755
  async getSlashingProposerAddress() {
200
756
  const slasher = await this.getSlasherContract();
@@ -206,22 +762,27 @@ export class RollupContract {
206
762
  getCheckpointReward() {
207
763
  return this.rollup.read.getCheckpointReward();
208
764
  }
209
- getCheckpointNumber() {
210
- return this.rollup.read.getPendingCheckpointNumber();
765
+ async getCheckpointNumber() {
766
+ return CheckpointNumber.fromBigInt(await this.rollup.read.getPendingCheckpointNumber());
211
767
  }
212
- getProvenCheckpointNumber() {
213
- return this.rollup.read.getProvenCheckpointNumber();
768
+ async getProvenCheckpointNumber(options) {
769
+ await checkBlockTag(options?.blockNumber, this.client);
770
+ return CheckpointNumber.fromBigInt(await this.rollup.read.getProvenCheckpointNumber(options));
214
771
  }
215
772
  async getSlotNumber() {
216
773
  return SlotNumber.fromBigInt(await this.rollup.read.getCurrentSlot());
217
774
  }
218
- getL1FeesAt(timestamp) {
219
- return this.rollup.read.getL1FeesAt([
775
+ async getL1FeesAt(timestamp) {
776
+ const result = await this.rollup.read.getL1FeesAt([
220
777
  timestamp
221
778
  ]);
779
+ return {
780
+ baseFee: result.baseFee,
781
+ blobFee: result.blobFee
782
+ };
222
783
  }
223
- getFeeAssetPerEth() {
224
- return this.rollup.read.getFeeAssetPerEth();
784
+ getEthPerFeeAsset() {
785
+ return this.rollup.read.getEthPerFeeAsset();
225
786
  }
226
787
  async getCommitteeAt(timestamp) {
227
788
  const { result } = await this.client.simulateContract({
@@ -239,15 +800,15 @@ export class RollupContract {
239
800
  }
240
801
  throw e;
241
802
  });
242
- return result;
803
+ return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
243
804
  }
244
- getSampleSeedAt(timestamp) {
245
- return this.rollup.read.getSampleSeedAt([
805
+ async getSampleSeedAt(timestamp) {
806
+ return Buffer32.fromBigInt(await this.rollup.read.getSampleSeedAt([
246
807
  timestamp
247
- ]);
808
+ ]));
248
809
  }
249
- getCurrentSampleSeed() {
250
- return this.rollup.read.getCurrentSampleSeed();
810
+ async getCurrentSampleSeed() {
811
+ return Buffer32.fromBigInt(await this.rollup.read.getCurrentSampleSeed());
251
812
  }
252
813
  async getCurrentEpoch() {
253
814
  return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
@@ -266,7 +827,7 @@ export class RollupContract {
266
827
  }
267
828
  throw e;
268
829
  });
269
- return result;
830
+ return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
270
831
  }
271
832
  async getCurrentProposer() {
272
833
  const { result } = await this.client.simulateContract({
@@ -275,7 +836,7 @@ export class RollupContract {
275
836
  functionName: 'getCurrentProposer',
276
837
  args: []
277
838
  });
278
- return result;
839
+ return EthAddress.fromString(result);
279
840
  }
280
841
  async getProposerAt(timestamp) {
281
842
  const { result } = await this.client.simulateContract({
@@ -286,26 +847,58 @@ export class RollupContract {
286
847
  timestamp
287
848
  ]
288
849
  });
289
- return result;
850
+ return EthAddress.fromString(result);
290
851
  }
291
- getCheckpoint(checkpointNumber) {
292
- return this.rollup.read.getCheckpoint([
852
+ async getCheckpoint(checkpointNumber) {
853
+ const result = await this.rollup.read.getCheckpoint([
293
854
  BigInt(checkpointNumber)
294
855
  ]);
856
+ return {
857
+ archive: Fr.fromString(result.archive),
858
+ headerHash: Buffer32.fromString(result.headerHash),
859
+ blobCommitmentsHash: Buffer32.fromString(result.blobCommitmentsHash),
860
+ attestationsHash: Buffer32.fromString(result.attestationsHash),
861
+ payloadDigest: Buffer32.fromString(result.payloadDigest),
862
+ slotNumber: SlotNumber.fromBigInt(result.slotNumber),
863
+ feeHeader: {
864
+ excessMana: result.feeHeader.excessMana,
865
+ manaUsed: result.feeHeader.manaUsed,
866
+ ethPerFeeAsset: result.feeHeader.ethPerFeeAsset,
867
+ congestionCost: result.feeHeader.congestionCost,
868
+ proverCost: result.feeHeader.proverCost
869
+ }
870
+ };
295
871
  }
296
- getTips() {
297
- return this.rollup.read.getTips();
872
+ /** Returns the pending checkpoint from the rollup contract */ getPendingCheckpoint() {
873
+ // We retry because of race conditions during prunes: we may get a pending checkpoint number which is immediately
874
+ // reorged out due to a prune happening, causing the subsequent getCheckpoint call to fail. So we try again in that case.
875
+ return retry(async ()=>{
876
+ const pendingCheckpointNumber = await this.getCheckpointNumber();
877
+ const pendingCheckpoint = await this.getCheckpoint(pendingCheckpointNumber);
878
+ return pendingCheckpoint;
879
+ }, 'getting pending checkpoint', makeBackoff([
880
+ 0.5,
881
+ 0.5,
882
+ 0.5
883
+ ]));
884
+ }
885
+ async getTips() {
886
+ const { pending, proven } = await this.rollup.read.getTips();
887
+ return {
888
+ pending: CheckpointNumber.fromBigInt(pending),
889
+ proven: CheckpointNumber.fromBigInt(proven)
890
+ };
298
891
  }
299
892
  getTimestampForSlot(slot) {
300
893
  return this.rollup.read.getTimestampForSlot([
301
894
  BigInt(slot)
302
895
  ]);
303
896
  }
304
- getEntryQueueLength() {
305
- return this.rollup.read.getEntryQueueLength();
897
+ async getEntryQueueLength() {
898
+ return Number(await this.rollup.read.getEntryQueueLength());
306
899
  }
307
- getAvailableValidatorFlushes() {
308
- return this.rollup.read.getAvailableValidatorFlushes();
900
+ async getAvailableValidatorFlushes() {
901
+ return Number(await this.rollup.read.getAvailableValidatorFlushes());
309
902
  }
310
903
  async getNextFlushableEpoch() {
311
904
  return EpochNumber.fromBigInt(await this.rollup.read.getNextFlushableEpoch());
@@ -347,8 +940,9 @@ export class RollupContract {
347
940
  BigInt(slotNumber)
348
941
  ]));
349
942
  }
350
- getEpochProofPublicInputs(args) {
351
- return this.rollup.read.getEpochProofPublicInputs(args);
943
+ async getEpochProofPublicInputs(args) {
944
+ const result = await this.rollup.read.getEpochProofPublicInputs(args);
945
+ return result.map(Fr.fromString);
352
946
  }
353
947
  async validateHeader(args, account) {
354
948
  try {
@@ -372,9 +966,9 @@ export class RollupContract {
372
966
  * @return [slot, checkpointNumber, timeOfNextL1Slot] - If you can propose, the L2 slot number, checkpoint number and
373
967
  * timestamp of the next L1 block
374
968
  * @throws otherwise
375
- */ async canProposeAtNextEthBlock(archive, account, slotDuration, opts = {}) {
969
+ */ async canProposeAt(archive, account, slotDuration, slotOffset, opts = {}) {
376
970
  const latestBlock = await this.client.getBlock();
377
- const timeOfNextL1Slot = latestBlock.timestamp + BigInt(slotDuration);
971
+ const timeOfNextL1Slot = latestBlock.timestamp + slotDuration + slotOffset;
378
972
  const who = typeof account === 'string' ? account : account.address;
379
973
  try {
380
974
  const { result: [slot, checkpointNumber] } = await this.client.simulateContract({
@@ -391,7 +985,7 @@ export class RollupContract {
391
985
  });
392
986
  return {
393
987
  slot: SlotNumber.fromBigInt(slot),
394
- checkpointNumber,
988
+ checkpointNumber: CheckpointNumber.fromBigInt(checkpointNumber),
395
989
  timeOfNextL1Slot
396
990
  };
397
991
  } catch (err) {
@@ -428,6 +1022,7 @@ export class RollupContract {
428
1022
  /** Creates a request to Rollup#invalidateBadAttestation to be simulated or sent */ buildInvalidateBadAttestationRequest(checkpointNumber, attestationsAndSigners, committee, invalidIndex) {
429
1023
  return {
430
1024
  to: this.address,
1025
+ abi: RollupAbi,
431
1026
  data: encodeFunctionData({
432
1027
  abi: RollupAbi,
433
1028
  functionName: 'invalidateBadAttestation',
@@ -443,6 +1038,7 @@ export class RollupContract {
443
1038
  /** Creates a request to Rollup#invalidateInsufficientAttestations to be simulated or sent */ buildInvalidateInsufficientAttestationsRequest(checkpointNumber, attestationsAndSigners, committee) {
444
1039
  return {
445
1040
  to: this.address,
1041
+ abi: RollupAbi,
446
1042
  data: encodeFunctionData({
447
1043
  abi: RollupAbi,
448
1044
  functionName: 'invalidateInsufficientAttestations',
@@ -464,12 +1060,24 @@ export class RollupContract {
464
1060
  prover
465
1061
  ]);
466
1062
  }
467
- getManaBaseFeeAt(timestamp, inFeeAsset) {
468
- return this.rollup.read.getManaBaseFeeAt([
1063
+ getManaMinFeeAt(timestamp, inFeeAsset) {
1064
+ return this.rollup.read.getManaMinFeeAt([
469
1065
  timestamp,
470
1066
  inFeeAsset
471
1067
  ]);
472
1068
  }
1069
+ async getManaMinFeeComponentsAt(timestamp, inFeeAsset) {
1070
+ const result = await this.rollup.read.getManaMinFeeComponentsAt([
1071
+ timestamp,
1072
+ inFeeAsset
1073
+ ]);
1074
+ return {
1075
+ sequencerCost: result.sequencerCost,
1076
+ proverCost: result.proverCost,
1077
+ congestionCost: result.congestionCost,
1078
+ congestionMultiplier: result.congestionMultiplier
1079
+ };
1080
+ }
473
1081
  async getSlotAt(timestamp) {
474
1082
  return SlotNumber.fromBigInt(await this.rollup.read.getSlotAt([
475
1083
  timestamp
@@ -477,9 +1085,16 @@ export class RollupContract {
477
1085
  }
478
1086
  async status(checkpointNumber, options) {
479
1087
  await checkBlockTag(options?.blockNumber, this.client);
480
- return this.rollup.read.status([
481
- checkpointNumber
1088
+ const result = await this.rollup.read.status([
1089
+ BigInt(checkpointNumber)
482
1090
  ], options);
1091
+ return {
1092
+ provenCheckpointNumber: CheckpointNumber.fromBigInt(result[0]),
1093
+ provenArchive: Fr.fromString(result[1]),
1094
+ pendingCheckpointNumber: CheckpointNumber.fromBigInt(result[2]),
1095
+ pendingArchive: Fr.fromString(result[3]),
1096
+ archiveOfMyCheckpoint: Fr.fromString(result[4])
1097
+ };
483
1098
  }
484
1099
  async canPruneAtTime(timestamp, options) {
485
1100
  await checkBlockTag(options?.blockNumber, this.client);
@@ -487,13 +1102,13 @@ export class RollupContract {
487
1102
  timestamp
488
1103
  ], options);
489
1104
  }
490
- archive() {
491
- return this.rollup.read.archive();
1105
+ async archive() {
1106
+ return Fr.fromString(await this.rollup.read.archive());
492
1107
  }
493
- archiveAt(checkpointNumber) {
494
- return this.rollup.read.archiveAt([
495
- checkpointNumber
496
- ]);
1108
+ async archiveAt(checkpointNumber) {
1109
+ return Fr.fromString(await this.rollup.read.archiveAt([
1110
+ BigInt(checkpointNumber)
1111
+ ]));
497
1112
  }
498
1113
  getSequencerRewards(address) {
499
1114
  if (address instanceof EthAddress) {
@@ -517,44 +1132,71 @@ export class RollupContract {
517
1132
  const gse = new GSEContract(this.client, await this.getGSE());
518
1133
  const ts = (await this.client.getBlock()).timestamp;
519
1134
  const indices = Array.from({
520
- length: Number(attesterSize)
1135
+ length: attesterSize
521
1136
  }, (_, i)=>BigInt(i));
522
1137
  const chunks = chunk(indices, 1000);
523
- return (await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)))).flat();
1138
+ const results = await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)));
1139
+ return results.flat().map((addr)=>EthAddress.fromString(addr));
524
1140
  }
525
- getAttesterView(address) {
1141
+ async getAttesterView(address) {
526
1142
  if (address instanceof EthAddress) {
527
1143
  address = address.toString();
528
1144
  }
529
- return this.rollup.read.getAttesterView([
1145
+ const result = await this.rollup.read.getAttesterView([
530
1146
  address
531
1147
  ]);
1148
+ return {
1149
+ status: result.status,
1150
+ effectiveBalance: result.effectiveBalance,
1151
+ exit: {
1152
+ withdrawalId: result.exit.withdrawalId,
1153
+ amount: result.exit.amount,
1154
+ exitableAt: result.exit.exitableAt,
1155
+ recipientOrWithdrawer: EthAddress.fromString(result.exit.recipientOrWithdrawer),
1156
+ isRecipient: result.exit.isRecipient,
1157
+ exists: result.exit.exists
1158
+ },
1159
+ config: {
1160
+ publicKey: {
1161
+ x: result.config.publicKey.x,
1162
+ y: result.config.publicKey.y
1163
+ },
1164
+ withdrawer: EthAddress.fromString(result.config.withdrawer)
1165
+ }
1166
+ };
532
1167
  }
533
- getStatus(address) {
1168
+ async getStatus(address) {
534
1169
  if (address instanceof EthAddress) {
535
1170
  address = address.toString();
536
1171
  }
537
- return this.rollup.read.getStatus([
1172
+ return await this.rollup.read.getStatus([
538
1173
  address
539
1174
  ]);
540
1175
  }
541
- getBlobCommitmentsHash(checkpointNumber) {
542
- return this.rollup.read.getBlobCommitmentsHash([
543
- checkpointNumber
544
- ]);
1176
+ async getBlobCommitmentsHash(checkpointNumber) {
1177
+ return Buffer32.fromString(await this.rollup.read.getBlobCommitmentsHash([
1178
+ BigInt(checkpointNumber)
1179
+ ]));
545
1180
  }
546
- getCurrentBlobCommitmentsHash() {
547
- return this.rollup.read.getCurrentBlobCommitmentsHash();
1181
+ async getCurrentBlobCommitmentsHash() {
1182
+ return Buffer32.fromString(await this.rollup.read.getCurrentBlobCommitmentsHash());
548
1183
  }
549
- getStakingAsset() {
550
- return this.rollup.read.getStakingAsset();
1184
+ async getStakingAsset() {
1185
+ return EthAddress.fromString(await this.rollup.read.getStakingAsset());
551
1186
  }
552
- getRewardConfig() {
553
- return this.rollup.read.getRewardConfig();
1187
+ async getRewardConfig() {
1188
+ const result = await this.rollup.read.getRewardConfig();
1189
+ return {
1190
+ rewardDistributor: EthAddress.fromString(result.rewardDistributor),
1191
+ sequencerBps: BigInt(result.sequencerBps),
1192
+ booster: EthAddress.fromString(result.booster),
1193
+ checkpointReward: result.checkpointReward
1194
+ };
554
1195
  }
555
1196
  setupEpoch(l1TxUtils) {
556
1197
  return l1TxUtils.sendAndMonitorTransaction({
557
1198
  to: this.address,
1199
+ abi: RollupAbi,
558
1200
  data: encodeFunctionData({
559
1201
  abi: RollupAbi,
560
1202
  functionName: 'setupEpoch',
@@ -565,6 +1207,7 @@ export class RollupContract {
565
1207
  vote(l1TxUtils, proposalId) {
566
1208
  return l1TxUtils.sendAndMonitorTransaction({
567
1209
  to: this.address,
1210
+ abi: RollupAbi,
568
1211
  data: encodeFunctionData({
569
1212
  abi: RollupAbi,
570
1213
  functionName: 'vote',
@@ -593,7 +1236,7 @@ export class RollupContract {
593
1236
  const args = log.args;
594
1237
  if (args.checkpointNumber !== undefined) {
595
1238
  callback({
596
- checkpointNumber: args.checkpointNumber
1239
+ checkpointNumber: CheckpointNumber.fromBigInt(args.checkpointNumber)
597
1240
  });
598
1241
  }
599
1242
  }
@@ -624,61 +1267,32 @@ export class RollupContract {
624
1267
  }
625
1268
  });
626
1269
  }
1270
+ /** Fetches CheckpointProposed events within the given block range. */ async getCheckpointProposedEvents(fromBlock, toBlock) {
1271
+ const logs = await this.rollup.getEvents.CheckpointProposed({}, {
1272
+ fromBlock,
1273
+ toBlock
1274
+ });
1275
+ return logs.filter((log)=>log.blockNumber >= fromBlock && log.blockNumber <= toBlock).map((log)=>({
1276
+ l1BlockNumber: log.blockNumber,
1277
+ l1BlockHash: Buffer32.fromString(log.blockHash),
1278
+ l1TransactionHash: log.transactionHash,
1279
+ args: {
1280
+ checkpointNumber: CheckpointNumber.fromBigInt(log.args.checkpointNumber),
1281
+ archive: Fr.fromString(log.args.archive),
1282
+ versionedBlobHashes: log.args.versionedBlobHashes.map((h)=>Buffer.from(h.slice(2), 'hex')),
1283
+ attestationsHash: (()=>{
1284
+ if (!log.args.attestationsHash) {
1285
+ throw new Error(`CheckpointProposed event missing attestationsHash for checkpoint ${log.args.checkpointNumber}`);
1286
+ }
1287
+ return Buffer32.fromString(log.args.attestationsHash);
1288
+ })(),
1289
+ payloadDigest: (()=>{
1290
+ if (!log.args.payloadDigest) {
1291
+ throw new Error(`CheckpointProposed event missing payloadDigest for checkpoint ${log.args.checkpointNumber}`);
1292
+ }
1293
+ return Buffer32.fromString(log.args.payloadDigest);
1294
+ })()
1295
+ }
1296
+ }));
1297
+ }
627
1298
  }
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);