@aztec/ethereum 0.0.1-commit.d3ec352c → 0.0.1-commit.e6bd8901
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.
- package/dest/client.js +6 -2
- package/dest/config.d.ts +19 -68
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +51 -378
- package/dest/contracts/empire_base.d.ts +2 -1
- package/dest/contracts/empire_base.d.ts.map +1 -1
- package/dest/contracts/empire_slashing_proposer.d.ts +2 -1
- package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -1
- package/dest/contracts/empire_slashing_proposer.js +9 -0
- package/dest/contracts/fee_asset_handler.d.ts +6 -5
- package/dest/contracts/fee_asset_handler.d.ts.map +1 -1
- package/dest/contracts/fee_asset_handler.js +9 -9
- package/dest/contracts/governance.d.ts +3 -1
- package/dest/contracts/governance.d.ts.map +1 -1
- package/dest/contracts/governance.js +9 -1
- package/dest/contracts/governance_proposer.d.ts +2 -1
- package/dest/contracts/governance_proposer.d.ts.map +1 -1
- package/dest/contracts/governance_proposer.js +391 -8
- package/dest/contracts/inbox.d.ts +24 -3
- package/dest/contracts/inbox.d.ts.map +1 -1
- package/dest/contracts/inbox.js +36 -1
- package/dest/contracts/index.d.ts +3 -1
- package/dest/contracts/index.d.ts.map +1 -1
- package/dest/contracts/index.js +2 -0
- package/dest/contracts/log.d.ts +13 -0
- package/dest/contracts/log.d.ts.map +1 -0
- package/dest/contracts/log.js +1 -0
- package/dest/contracts/outbox.d.ts +41 -0
- package/dest/contracts/outbox.d.ts.map +1 -0
- package/dest/contracts/outbox.js +86 -0
- package/dest/contracts/rollup.d.ts +163 -83
- package/dest/contracts/rollup.d.ts.map +1 -1
- package/dest/contracts/rollup.js +682 -129
- package/dest/contracts/tally_slashing_proposer.d.ts +3 -2
- package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -1
- package/dest/contracts/tally_slashing_proposer.js +1 -1
- package/dest/deploy_aztec_l1_contracts.d.ts +260 -0
- package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
- package/dest/deploy_aztec_l1_contracts.js +398 -0
- package/dest/deploy_l1_contract.d.ts +68 -0
- package/dest/deploy_l1_contract.d.ts.map +1 -0
- package/dest/deploy_l1_contract.js +312 -0
- package/dest/forwarder_proxy.d.ts +32 -0
- package/dest/forwarder_proxy.d.ts.map +1 -0
- package/dest/forwarder_proxy.js +93 -0
- package/dest/generated/l1-contracts-defaults.d.ts +30 -0
- package/dest/generated/l1-contracts-defaults.d.ts.map +1 -0
- package/dest/generated/l1-contracts-defaults.js +30 -0
- package/dest/l1_artifacts.d.ts +4964 -1573
- package/dest/l1_artifacts.d.ts.map +1 -1
- package/dest/l1_contract_addresses.d.ts +1 -1
- package/dest/l1_contract_addresses.d.ts.map +1 -1
- package/dest/l1_contract_addresses.js +3 -3
- package/dest/l1_reader.d.ts +3 -1
- package/dest/l1_reader.d.ts.map +1 -1
- package/dest/l1_reader.js +6 -0
- package/dest/l1_tx_utils/config.d.ts +3 -3
- package/dest/l1_tx_utils/config.d.ts.map +1 -1
- package/dest/l1_tx_utils/config.js +17 -3
- package/dest/l1_tx_utils/constants.d.ts +7 -1
- package/dest/l1_tx_utils/constants.d.ts.map +1 -1
- package/dest/l1_tx_utils/constants.js +25 -0
- package/dest/l1_tx_utils/fee-strategies/index.d.ts +10 -0
- package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/index.js +12 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +8 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +129 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +23 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +191 -0
- package/dest/l1_tx_utils/fee-strategies/types.d.ts +51 -0
- package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/types.js +3 -0
- package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
- package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
- package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +48 -0
- package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
- package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
- package/dest/l1_tx_utils/index-blobs.js +2 -0
- package/dest/l1_tx_utils/index.d.ts +3 -1
- package/dest/l1_tx_utils/index.d.ts.map +1 -1
- package/dest/l1_tx_utils/index.js +2 -0
- package/dest/l1_tx_utils/interfaces.d.ts +2 -2
- package/dest/l1_tx_utils/interfaces.d.ts.map +1 -1
- package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
- package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
- package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
- package/dest/l1_tx_utils/l1_tx_utils.d.ts +1 -1
- package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -1
- package/dest/l1_tx_utils/l1_tx_utils.js +17 -4
- package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +4 -15
- package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -1
- package/dest/l1_tx_utils/readonly_l1_tx_utils.js +52 -159
- package/dest/queries.d.ts +2 -2
- package/dest/queries.d.ts.map +1 -1
- package/dest/queries.js +12 -4
- package/dest/test/chain_monitor.d.ts +2 -2
- package/dest/test/chain_monitor.d.ts.map +1 -1
- package/dest/test/chain_monitor.js +1 -2
- package/dest/test/eth_cheat_codes.d.ts +13 -1
- package/dest/test/eth_cheat_codes.d.ts.map +1 -1
- package/dest/test/eth_cheat_codes.js +4 -2
- package/dest/test/rollup_cheat_codes.d.ts +4 -3
- package/dest/test/rollup_cheat_codes.d.ts.map +1 -1
- package/dest/test/rollup_cheat_codes.js +17 -4
- package/dest/test/start_anvil.d.ts +3 -1
- package/dest/test/start_anvil.d.ts.map +1 -1
- package/dest/test/tx_delayer.d.ts +1 -1
- package/dest/test/tx_delayer.d.ts.map +1 -1
- package/dest/test/tx_delayer.js +4 -3
- package/dest/types.d.ts +57 -2
- package/dest/types.d.ts.map +1 -1
- package/dest/utils.d.ts +15 -3
- package/dest/utils.d.ts.map +1 -1
- package/dest/utils.js +18 -0
- package/package.json +31 -12
- package/src/client.ts +2 -2
- package/src/config.ts +62 -457
- package/src/contracts/README.md +157 -0
- package/src/contracts/empire_base.ts +1 -1
- package/src/contracts/empire_slashing_proposer.ts +6 -1
- package/src/contracts/fee_asset_handler.ts +8 -7
- package/src/contracts/governance.ts +8 -1
- package/src/contracts/governance_proposer.ts +6 -1
- package/src/contracts/inbox.ts +55 -3
- package/src/contracts/index.ts +2 -0
- package/src/contracts/log.ts +13 -0
- package/src/contracts/outbox.ts +98 -0
- package/src/contracts/rollup.ts +351 -95
- package/src/contracts/tally_slashing_proposer.ts +3 -1
- package/src/deploy_aztec_l1_contracts.ts +619 -0
- package/src/deploy_l1_contract.ts +362 -0
- package/src/forwarder_proxy.ts +108 -0
- package/src/generated/l1-contracts-defaults.ts +32 -0
- package/src/l1_contract_addresses.ts +22 -20
- package/src/l1_reader.ts +8 -0
- package/src/l1_tx_utils/config.ts +24 -6
- package/src/l1_tx_utils/constants.ts +11 -0
- package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
- package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +163 -0
- package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +245 -0
- package/src/l1_tx_utils/fee-strategies/types.ts +56 -0
- package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +119 -0
- package/src/l1_tx_utils/index-blobs.ts +2 -0
- package/src/l1_tx_utils/index.ts +2 -0
- package/src/l1_tx_utils/interfaces.ts +1 -1
- package/src/l1_tx_utils/l1_fee_analyzer.ts +803 -0
- package/src/l1_tx_utils/l1_tx_utils.ts +24 -4
- package/src/l1_tx_utils/readonly_l1_tx_utils.ts +65 -204
- package/src/queries.ts +11 -3
- package/src/test/chain_monitor.ts +3 -2
- package/src/test/eth_cheat_codes.ts +2 -2
- package/src/test/rollup_cheat_codes.ts +15 -5
- package/src/test/start_anvil.ts +2 -0
- package/src/test/tx_delayer.ts +5 -3
- package/src/types.ts +62 -0
- package/src/utils.ts +30 -1
- package/dest/deploy_l1_contracts.d.ts +0 -673
- package/dest/deploy_l1_contracts.d.ts.map +0 -1
- package/dest/deploy_l1_contracts.js +0 -1491
- package/dest/index.d.ts +0 -18
- package/dest/index.d.ts.map +0 -1
- package/dest/index.js +0 -17
- package/src/deploy_l1_contracts.ts +0 -1869
- package/src/index.ts +0 -17
package/dest/contracts/rollup.js
CHANGED
|
@@ -1,12 +1,383 @@
|
|
|
1
|
-
function
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
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
|
}
|
|
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;
|
|
7
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 =
|
|
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();
|
|
@@ -215,13 +741,17 @@ export class RollupContract {
|
|
|
215
741
|
async getSlotNumber() {
|
|
216
742
|
return SlotNumber.fromBigInt(await this.rollup.read.getCurrentSlot());
|
|
217
743
|
}
|
|
218
|
-
getL1FeesAt(timestamp) {
|
|
219
|
-
|
|
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
|
-
|
|
224
|
-
return this.rollup.read.
|
|
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,12 +816,40 @@ export class RollupContract {
|
|
|
286
816
|
timestamp
|
|
287
817
|
]
|
|
288
818
|
});
|
|
289
|
-
return result;
|
|
819
|
+
return EthAddress.fromString(result);
|
|
290
820
|
}
|
|
291
|
-
getCheckpoint(checkpointNumber) {
|
|
292
|
-
|
|
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
|
+
};
|
|
840
|
+
}
|
|
841
|
+
/** Returns the pending checkpoint from the rollup contract */ getPendingCheckpoint() {
|
|
842
|
+
// We retry because of race conditions during prunes: we may get a pending checkpoint number which is immediately
|
|
843
|
+
// reorged out due to a prune happening, causing the subsequent getCheckpoint call to fail. So we try again in that case.
|
|
844
|
+
return retry(async ()=>{
|
|
845
|
+
const pendingCheckpointNumber = await this.getCheckpointNumber();
|
|
846
|
+
const pendingCheckpoint = await this.getCheckpoint(pendingCheckpointNumber);
|
|
847
|
+
return pendingCheckpoint;
|
|
848
|
+
}, 'getting pending checkpoint', makeBackoff([
|
|
849
|
+
0.5,
|
|
850
|
+
0.5,
|
|
851
|
+
0.5
|
|
852
|
+
]));
|
|
295
853
|
}
|
|
296
854
|
async getTips() {
|
|
297
855
|
const { pending, proven } = await this.rollup.read.getTips();
|
|
@@ -305,11 +863,11 @@ export class RollupContract {
|
|
|
305
863
|
BigInt(slot)
|
|
306
864
|
]);
|
|
307
865
|
}
|
|
308
|
-
getEntryQueueLength() {
|
|
309
|
-
return this.rollup.read.getEntryQueueLength();
|
|
866
|
+
async getEntryQueueLength() {
|
|
867
|
+
return Number(await this.rollup.read.getEntryQueueLength());
|
|
310
868
|
}
|
|
311
|
-
getAvailableValidatorFlushes() {
|
|
312
|
-
return this.rollup.read.getAvailableValidatorFlushes();
|
|
869
|
+
async getAvailableValidatorFlushes() {
|
|
870
|
+
return Number(await this.rollup.read.getAvailableValidatorFlushes());
|
|
313
871
|
}
|
|
314
872
|
async getNextFlushableEpoch() {
|
|
315
873
|
return EpochNumber.fromBigInt(await this.rollup.read.getNextFlushableEpoch());
|
|
@@ -351,8 +909,9 @@ export class RollupContract {
|
|
|
351
909
|
BigInt(slotNumber)
|
|
352
910
|
]));
|
|
353
911
|
}
|
|
354
|
-
getEpochProofPublicInputs(args) {
|
|
355
|
-
|
|
912
|
+
async getEpochProofPublicInputs(args) {
|
|
913
|
+
const result = await this.rollup.read.getEpochProofPublicInputs(args);
|
|
914
|
+
return result.map(Fr.fromString);
|
|
356
915
|
}
|
|
357
916
|
async validateHeader(args, account) {
|
|
358
917
|
try {
|
|
@@ -468,8 +1027,8 @@ export class RollupContract {
|
|
|
468
1027
|
prover
|
|
469
1028
|
]);
|
|
470
1029
|
}
|
|
471
|
-
|
|
472
|
-
return this.rollup.read.
|
|
1030
|
+
getManaMinFeeAt(timestamp, inFeeAsset) {
|
|
1031
|
+
return this.rollup.read.getManaMinFeeAt([
|
|
473
1032
|
timestamp,
|
|
474
1033
|
inFeeAsset
|
|
475
1034
|
]);
|
|
@@ -481,9 +1040,16 @@ export class RollupContract {
|
|
|
481
1040
|
}
|
|
482
1041
|
async status(checkpointNumber, options) {
|
|
483
1042
|
await checkBlockTag(options?.blockNumber, this.client);
|
|
484
|
-
|
|
1043
|
+
const result = await this.rollup.read.status([
|
|
485
1044
|
BigInt(checkpointNumber)
|
|
486
1045
|
], options);
|
|
1046
|
+
return {
|
|
1047
|
+
provenCheckpointNumber: CheckpointNumber.fromBigInt(result[0]),
|
|
1048
|
+
provenArchive: Fr.fromString(result[1]),
|
|
1049
|
+
pendingCheckpointNumber: CheckpointNumber.fromBigInt(result[2]),
|
|
1050
|
+
pendingArchive: Fr.fromString(result[3]),
|
|
1051
|
+
archiveOfMyCheckpoint: Fr.fromString(result[4])
|
|
1052
|
+
};
|
|
487
1053
|
}
|
|
488
1054
|
async canPruneAtTime(timestamp, options) {
|
|
489
1055
|
await checkBlockTag(options?.blockNumber, this.client);
|
|
@@ -491,13 +1057,13 @@ export class RollupContract {
|
|
|
491
1057
|
timestamp
|
|
492
1058
|
], options);
|
|
493
1059
|
}
|
|
494
|
-
archive() {
|
|
495
|
-
return this.rollup.read.archive();
|
|
1060
|
+
async archive() {
|
|
1061
|
+
return Fr.fromString(await this.rollup.read.archive());
|
|
496
1062
|
}
|
|
497
|
-
archiveAt(checkpointNumber) {
|
|
498
|
-
return this.rollup.read.archiveAt([
|
|
1063
|
+
async archiveAt(checkpointNumber) {
|
|
1064
|
+
return Fr.fromString(await this.rollup.read.archiveAt([
|
|
499
1065
|
BigInt(checkpointNumber)
|
|
500
|
-
]);
|
|
1066
|
+
]));
|
|
501
1067
|
}
|
|
502
1068
|
getSequencerRewards(address) {
|
|
503
1069
|
if (address instanceof EthAddress) {
|
|
@@ -521,40 +1087,66 @@ export class RollupContract {
|
|
|
521
1087
|
const gse = new GSEContract(this.client, await this.getGSE());
|
|
522
1088
|
const ts = (await this.client.getBlock()).timestamp;
|
|
523
1089
|
const indices = Array.from({
|
|
524
|
-
length:
|
|
1090
|
+
length: attesterSize
|
|
525
1091
|
}, (_, i)=>BigInt(i));
|
|
526
1092
|
const chunks = chunk(indices, 1000);
|
|
527
|
-
|
|
1093
|
+
const results = await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)));
|
|
1094
|
+
return results.flat().map((addr)=>EthAddress.fromString(addr));
|
|
528
1095
|
}
|
|
529
|
-
getAttesterView(address) {
|
|
1096
|
+
async getAttesterView(address) {
|
|
530
1097
|
if (address instanceof EthAddress) {
|
|
531
1098
|
address = address.toString();
|
|
532
1099
|
}
|
|
533
|
-
|
|
1100
|
+
const result = await this.rollup.read.getAttesterView([
|
|
534
1101
|
address
|
|
535
1102
|
]);
|
|
1103
|
+
return {
|
|
1104
|
+
status: result.status,
|
|
1105
|
+
effectiveBalance: result.effectiveBalance,
|
|
1106
|
+
exit: {
|
|
1107
|
+
withdrawalId: result.exit.withdrawalId,
|
|
1108
|
+
amount: result.exit.amount,
|
|
1109
|
+
exitableAt: result.exit.exitableAt,
|
|
1110
|
+
recipientOrWithdrawer: EthAddress.fromString(result.exit.recipientOrWithdrawer),
|
|
1111
|
+
isRecipient: result.exit.isRecipient,
|
|
1112
|
+
exists: result.exit.exists
|
|
1113
|
+
},
|
|
1114
|
+
config: {
|
|
1115
|
+
publicKey: {
|
|
1116
|
+
x: result.config.publicKey.x,
|
|
1117
|
+
y: result.config.publicKey.y
|
|
1118
|
+
},
|
|
1119
|
+
withdrawer: EthAddress.fromString(result.config.withdrawer)
|
|
1120
|
+
}
|
|
1121
|
+
};
|
|
536
1122
|
}
|
|
537
|
-
getStatus(address) {
|
|
1123
|
+
async getStatus(address) {
|
|
538
1124
|
if (address instanceof EthAddress) {
|
|
539
1125
|
address = address.toString();
|
|
540
1126
|
}
|
|
541
|
-
return this.rollup.read.getStatus([
|
|
1127
|
+
return await this.rollup.read.getStatus([
|
|
542
1128
|
address
|
|
543
1129
|
]);
|
|
544
1130
|
}
|
|
545
|
-
getBlobCommitmentsHash(checkpointNumber) {
|
|
546
|
-
return this.rollup.read.getBlobCommitmentsHash([
|
|
1131
|
+
async getBlobCommitmentsHash(checkpointNumber) {
|
|
1132
|
+
return Buffer32.fromString(await this.rollup.read.getBlobCommitmentsHash([
|
|
547
1133
|
BigInt(checkpointNumber)
|
|
548
|
-
]);
|
|
1134
|
+
]));
|
|
549
1135
|
}
|
|
550
|
-
getCurrentBlobCommitmentsHash() {
|
|
551
|
-
return this.rollup.read.getCurrentBlobCommitmentsHash();
|
|
1136
|
+
async getCurrentBlobCommitmentsHash() {
|
|
1137
|
+
return Buffer32.fromString(await this.rollup.read.getCurrentBlobCommitmentsHash());
|
|
552
1138
|
}
|
|
553
|
-
getStakingAsset() {
|
|
554
|
-
return this.rollup.read.getStakingAsset();
|
|
1139
|
+
async getStakingAsset() {
|
|
1140
|
+
return EthAddress.fromString(await this.rollup.read.getStakingAsset());
|
|
555
1141
|
}
|
|
556
|
-
getRewardConfig() {
|
|
557
|
-
|
|
1142
|
+
async getRewardConfig() {
|
|
1143
|
+
const result = await this.rollup.read.getRewardConfig();
|
|
1144
|
+
return {
|
|
1145
|
+
rewardDistributor: EthAddress.fromString(result.rewardDistributor),
|
|
1146
|
+
sequencerBps: BigInt(result.sequencerBps),
|
|
1147
|
+
booster: EthAddress.fromString(result.booster),
|
|
1148
|
+
checkpointReward: result.checkpointReward
|
|
1149
|
+
};
|
|
558
1150
|
}
|
|
559
1151
|
setupEpoch(l1TxUtils) {
|
|
560
1152
|
return l1TxUtils.sendAndMonitorTransaction({
|
|
@@ -628,61 +1220,22 @@ export class RollupContract {
|
|
|
628
1220
|
}
|
|
629
1221
|
});
|
|
630
1222
|
}
|
|
1223
|
+
/** Fetches CheckpointProposed events within the given block range. */ async getCheckpointProposedEvents(fromBlock, toBlock) {
|
|
1224
|
+
const logs = await this.rollup.getEvents.CheckpointProposed({}, {
|
|
1225
|
+
fromBlock,
|
|
1226
|
+
toBlock
|
|
1227
|
+
});
|
|
1228
|
+
return logs.filter((log)=>log.blockNumber >= fromBlock && log.blockNumber <= toBlock).map((log)=>({
|
|
1229
|
+
l1BlockNumber: log.blockNumber,
|
|
1230
|
+
l1BlockHash: Buffer32.fromString(log.blockHash),
|
|
1231
|
+
l1TransactionHash: log.transactionHash,
|
|
1232
|
+
args: {
|
|
1233
|
+
checkpointNumber: CheckpointNumber.fromBigInt(log.args.checkpointNumber),
|
|
1234
|
+
archive: Fr.fromString(log.args.archive),
|
|
1235
|
+
versionedBlobHashes: log.args.versionedBlobHashes.map((h)=>Buffer.from(h.slice(2), 'hex')),
|
|
1236
|
+
attestationsHash: log.args.attestationsHash ? Buffer32.fromString(log.args.attestationsHash) : undefined,
|
|
1237
|
+
payloadDigest: log.args.payloadDigest ? Buffer32.fromString(log.args.payloadDigest) : undefined
|
|
1238
|
+
}
|
|
1239
|
+
}));
|
|
1240
|
+
}
|
|
631
1241
|
}
|
|
632
|
-
_ts_decorate([
|
|
633
|
-
memoize
|
|
634
|
-
], RollupContract.prototype, "getL1StartBlock", null);
|
|
635
|
-
_ts_decorate([
|
|
636
|
-
memoize
|
|
637
|
-
], RollupContract.prototype, "getL1GenesisTime", null);
|
|
638
|
-
_ts_decorate([
|
|
639
|
-
memoize
|
|
640
|
-
], RollupContract.prototype, "getProofSubmissionEpochs", null);
|
|
641
|
-
_ts_decorate([
|
|
642
|
-
memoize
|
|
643
|
-
], RollupContract.prototype, "getEpochDuration", null);
|
|
644
|
-
_ts_decorate([
|
|
645
|
-
memoize
|
|
646
|
-
], RollupContract.prototype, "getSlotDuration", null);
|
|
647
|
-
_ts_decorate([
|
|
648
|
-
memoize
|
|
649
|
-
], RollupContract.prototype, "getTargetCommitteeSize", null);
|
|
650
|
-
_ts_decorate([
|
|
651
|
-
memoize
|
|
652
|
-
], RollupContract.prototype, "getEjectionThreshold", null);
|
|
653
|
-
_ts_decorate([
|
|
654
|
-
memoize
|
|
655
|
-
], RollupContract.prototype, "getLocalEjectionThreshold", null);
|
|
656
|
-
_ts_decorate([
|
|
657
|
-
memoize
|
|
658
|
-
], RollupContract.prototype, "getLagInEpochsForValidatorSet", null);
|
|
659
|
-
_ts_decorate([
|
|
660
|
-
memoize
|
|
661
|
-
], RollupContract.prototype, "getLagInEpochsForRandao", null);
|
|
662
|
-
_ts_decorate([
|
|
663
|
-
memoize
|
|
664
|
-
], RollupContract.prototype, "getActivationThreshold", null);
|
|
665
|
-
_ts_decorate([
|
|
666
|
-
memoize
|
|
667
|
-
], RollupContract.prototype, "getExitDelay", null);
|
|
668
|
-
_ts_decorate([
|
|
669
|
-
memoize
|
|
670
|
-
], RollupContract.prototype, "getManaTarget", null);
|
|
671
|
-
_ts_decorate([
|
|
672
|
-
memoize
|
|
673
|
-
], RollupContract.prototype, "getProvingCostPerMana", null);
|
|
674
|
-
_ts_decorate([
|
|
675
|
-
memoize
|
|
676
|
-
], RollupContract.prototype, "getProvingCostPerManaInFeeAsset", null);
|
|
677
|
-
_ts_decorate([
|
|
678
|
-
memoize
|
|
679
|
-
], RollupContract.prototype, "getManaLimit", null);
|
|
680
|
-
_ts_decorate([
|
|
681
|
-
memoize
|
|
682
|
-
], RollupContract.prototype, "getVersion", null);
|
|
683
|
-
_ts_decorate([
|
|
684
|
-
memoize
|
|
685
|
-
], RollupContract.prototype, "getGenesisArchiveTreeRoot", null);
|
|
686
|
-
_ts_decorate([
|
|
687
|
-
memoize
|
|
688
|
-
], RollupContract.prototype, "getRollupConstants", null);
|