@aztec/ethereum 0.0.1-commit.24de95ac → 0.0.1-commit.2e2504e2
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/account.d.ts +1 -1
- package/dest/chain.d.ts +1 -1
- package/dest/client.d.ts +1 -1
- package/dest/client.js +6 -2
- package/dest/config.d.ts +22 -68
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +57 -378
- package/dest/constants.d.ts +1 -1
- package/dest/contracts/empire_base.d.ts +7 -5
- package/dest/contracts/empire_base.d.ts.map +1 -1
- package/dest/contracts/empire_base.js +1 -1
- package/dest/contracts/empire_slashing_proposer.d.ts +6 -4
- package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -1
- package/dest/contracts/empire_slashing_proposer.js +30 -17
- package/dest/contracts/errors.d.ts +1 -1
- package/dest/contracts/errors.d.ts.map +1 -1
- 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 +11 -9
- package/dest/contracts/fee_juice.d.ts +1 -1
- package/dest/contracts/fee_juice.d.ts.map +1 -1
- package/dest/contracts/governance.d.ts +18 -16
- package/dest/contracts/governance.d.ts.map +1 -1
- package/dest/contracts/governance.js +11 -1
- package/dest/contracts/governance_proposer.d.ts +6 -4
- package/dest/contracts/governance_proposer.d.ts.map +1 -1
- package/dest/contracts/governance_proposer.js +403 -11
- package/dest/contracts/gse.d.ts +1 -1
- package/dest/contracts/gse.d.ts.map +1 -1
- 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/multicall.d.ts +2 -2
- package/dest/contracts/multicall.d.ts.map +1 -1
- package/dest/contracts/multicall.js +2 -1
- 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/registry.d.ts +1 -1
- package/dest/contracts/registry.d.ts.map +1 -1
- package/dest/contracts/rollup.d.ts +194 -123
- package/dest/contracts/rollup.d.ts.map +1 -1
- package/dest/contracts/rollup.js +750 -184
- package/dest/contracts/slasher_contract.d.ts +1 -1
- package/dest/contracts/slasher_contract.d.ts.map +1 -1
- package/dest/contracts/tally_slashing_proposer.d.ts +9 -7
- package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -1
- package/dest/contracts/tally_slashing_proposer.js +11 -4
- package/dest/contracts/utils.d.ts +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 +399 -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/eth-signer/eth-signer.d.ts +1 -1
- package/dest/eth-signer/index.d.ts +1 -1
- 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 +6597 -2046
- package/dest/l1_artifacts.d.ts.map +1 -1
- package/dest/l1_contract_addresses.d.ts +3 -3
- 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 +5 -5
- package/dest/l1_tx_utils/config.d.ts.map +1 -1
- package/dest/l1_tx_utils/config.js +30 -7
- package/dest/l1_tx_utils/constants.d.ts +8 -2
- package/dest/l1_tx_utils/constants.d.ts.map +1 -1
- package/dest/l1_tx_utils/constants.js +27 -2
- package/dest/l1_tx_utils/factory.d.ts +1 -1
- 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 -2
- package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -1
- package/dest/l1_tx_utils/l1_tx_utils.js +23 -10
- package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +1 -1
- package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +1 -1
- package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +19 -30
- package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -1
- package/dest/l1_tx_utils/readonly_l1_tx_utils.js +55 -163
- package/dest/l1_tx_utils/signer.d.ts +1 -1
- package/dest/l1_tx_utils/types.d.ts +1 -1
- package/dest/l1_tx_utils/types.d.ts.map +1 -1
- package/dest/l1_tx_utils/utils.d.ts +1 -1
- package/dest/l1_types.d.ts +1 -1
- package/dest/publisher_manager.d.ts +3 -2
- package/dest/publisher_manager.d.ts.map +1 -1
- package/dest/publisher_manager.js +2 -2
- package/dest/queries.d.ts +2 -2
- package/dest/queries.d.ts.map +1 -1
- package/dest/queries.js +16 -6
- package/dest/test/chain_monitor.d.ts +27 -24
- package/dest/test/chain_monitor.d.ts.map +1 -1
- package/dest/test/chain_monitor.js +33 -36
- package/dest/test/delayed_tx_utils.d.ts +1 -1
- package/dest/test/delayed_tx_utils.d.ts.map +1 -1
- package/dest/test/eth_cheat_codes.d.ts +11 -3
- package/dest/test/eth_cheat_codes.d.ts.map +1 -1
- package/dest/test/eth_cheat_codes.js +11 -3
- package/dest/test/eth_cheat_codes_with_state.d.ts +1 -1
- package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
- package/dest/test/index.d.ts +1 -1
- package/dest/test/rollup_cheat_codes.d.ts +17 -13
- package/dest/test/rollup_cheat_codes.d.ts.map +1 -1
- package/dest/test/rollup_cheat_codes.js +62 -38
- package/dest/test/start_anvil.d.ts +4 -1
- package/dest/test/start_anvil.d.ts.map +1 -1
- package/dest/test/start_anvil.js +3 -2
- 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/test/upgrade_utils.d.ts +1 -1
- package/dest/types.d.ts +57 -2
- package/dest/types.d.ts.map +1 -1
- package/dest/utils.d.ts +16 -3
- package/dest/utils.d.ts.map +1 -1
- package/dest/utils.js +64 -0
- package/dest/zkPassportVerifierAddress.d.ts +1 -1
- package/package.json +34 -14
- package/src/client.ts +2 -2
- package/src/config.ts +71 -458
- package/src/contracts/README.md +157 -0
- package/src/contracts/empire_base.ts +6 -5
- package/src/contracts/empire_slashing_proposer.ts +32 -32
- package/src/contracts/fee_asset_handler.ts +10 -7
- package/src/contracts/governance.ts +10 -1
- package/src/contracts/governance_proposer.ts +20 -6
- package/src/contracts/inbox.ts +55 -3
- package/src/contracts/index.ts +2 -0
- package/src/contracts/log.ts +13 -0
- package/src/contracts/multicall.ts +5 -2
- package/src/contracts/outbox.ts +98 -0
- package/src/contracts/rollup.ts +421 -160
- package/src/contracts/tally_slashing_proposer.ts +15 -8
- package/src/deploy_aztec_l1_contracts.ts +623 -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 +32 -11
- package/src/l1_tx_utils/constants.ts +13 -2
- 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 +30 -10
- package/src/l1_tx_utils/readonly_l1_tx_utils.ts +69 -209
- package/src/publisher_manager.ts +4 -2
- package/src/queries.ts +17 -6
- package/src/test/chain_monitor.ts +51 -49
- package/src/test/eth_cheat_codes.ts +9 -3
- package/src/test/rollup_cheat_codes.ts +63 -43
- package/src/test/start_anvil.ts +5 -1
- package/src/test/tx_delayer.ts +5 -3
- package/src/types.ts +62 -0
- package/src/utils.ts +83 -1
- package/dest/deploy_l1_contracts.d.ts +0 -226
- package/dest/deploy_l1_contracts.d.ts.map +0 -1
- package/dest/deploy_l1_contracts.js +0 -1473
- 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 -1849
- package/src/index.ts +0 -17
package/dest/contracts/rollup.js
CHANGED
|
@@ -1,11 +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;
|
|
374
|
+
import { CheckpointNumber, EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
375
|
+
import { Buffer32 } from '@aztec/foundation/buffer';
|
|
376
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
7
377
|
import { memoize } from '@aztec/foundation/decorators';
|
|
8
378
|
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
379
|
+
import { makeBackoff, retry } from '@aztec/foundation/retry';
|
|
380
|
+
import { EscapeHatchAbi } from '@aztec/l1-artifacts/EscapeHatchAbi';
|
|
9
381
|
import { RollupAbi } from '@aztec/l1-artifacts/RollupAbi';
|
|
10
382
|
import { RollupStorage } from '@aztec/l1-artifacts/RollupStorage';
|
|
11
383
|
import chunk from 'lodash.chunk';
|
|
@@ -23,10 +395,120 @@ export var SlashingProposerType = /*#__PURE__*/ function(SlashingProposerType) {
|
|
|
23
395
|
SlashingProposerType[SlashingProposerType["Empire"] = 2] = "Empire";
|
|
24
396
|
return SlashingProposerType;
|
|
25
397
|
}({});
|
|
398
|
+
/**
|
|
399
|
+
* Status of a validator/attester in the staking system.
|
|
400
|
+
* Matches the Status enum in StakingLib.sol
|
|
401
|
+
*/ export var AttesterStatus = /*#__PURE__*/ function(AttesterStatus) {
|
|
402
|
+
AttesterStatus[AttesterStatus["NONE"] = 0] = "NONE";
|
|
403
|
+
AttesterStatus[AttesterStatus["VALIDATING"] = 1] = "VALIDATING";
|
|
404
|
+
AttesterStatus[AttesterStatus["ZOMBIE"] = 2] = "ZOMBIE";
|
|
405
|
+
AttesterStatus[AttesterStatus["EXITING"] = 3] = "EXITING";
|
|
406
|
+
return AttesterStatus;
|
|
407
|
+
}({});
|
|
26
408
|
export class RollupContract {
|
|
27
409
|
client;
|
|
410
|
+
static{
|
|
411
|
+
({ e: [_initProto] } = _apply_decs_2203_r(this, [
|
|
412
|
+
[
|
|
413
|
+
memoize,
|
|
414
|
+
2,
|
|
415
|
+
"getL1StartBlock"
|
|
416
|
+
],
|
|
417
|
+
[
|
|
418
|
+
memoize,
|
|
419
|
+
2,
|
|
420
|
+
"getL1GenesisTime"
|
|
421
|
+
],
|
|
422
|
+
[
|
|
423
|
+
memoize,
|
|
424
|
+
2,
|
|
425
|
+
"getProofSubmissionEpochs"
|
|
426
|
+
],
|
|
427
|
+
[
|
|
428
|
+
memoize,
|
|
429
|
+
2,
|
|
430
|
+
"getEpochDuration"
|
|
431
|
+
],
|
|
432
|
+
[
|
|
433
|
+
memoize,
|
|
434
|
+
2,
|
|
435
|
+
"getSlotDuration"
|
|
436
|
+
],
|
|
437
|
+
[
|
|
438
|
+
memoize,
|
|
439
|
+
2,
|
|
440
|
+
"getTargetCommitteeSize"
|
|
441
|
+
],
|
|
442
|
+
[
|
|
443
|
+
memoize,
|
|
444
|
+
2,
|
|
445
|
+
"getEjectionThreshold"
|
|
446
|
+
],
|
|
447
|
+
[
|
|
448
|
+
memoize,
|
|
449
|
+
2,
|
|
450
|
+
"getLocalEjectionThreshold"
|
|
451
|
+
],
|
|
452
|
+
[
|
|
453
|
+
memoize,
|
|
454
|
+
2,
|
|
455
|
+
"getLagInEpochsForValidatorSet"
|
|
456
|
+
],
|
|
457
|
+
[
|
|
458
|
+
memoize,
|
|
459
|
+
2,
|
|
460
|
+
"getLagInEpochsForRandao"
|
|
461
|
+
],
|
|
462
|
+
[
|
|
463
|
+
memoize,
|
|
464
|
+
2,
|
|
465
|
+
"getActivationThreshold"
|
|
466
|
+
],
|
|
467
|
+
[
|
|
468
|
+
memoize,
|
|
469
|
+
2,
|
|
470
|
+
"getExitDelay"
|
|
471
|
+
],
|
|
472
|
+
[
|
|
473
|
+
memoize,
|
|
474
|
+
2,
|
|
475
|
+
"getManaTarget"
|
|
476
|
+
],
|
|
477
|
+
[
|
|
478
|
+
memoize,
|
|
479
|
+
2,
|
|
480
|
+
"getProvingCostPerMana"
|
|
481
|
+
],
|
|
482
|
+
[
|
|
483
|
+
memoize,
|
|
484
|
+
2,
|
|
485
|
+
"getProvingCostPerManaInFeeAsset"
|
|
486
|
+
],
|
|
487
|
+
[
|
|
488
|
+
memoize,
|
|
489
|
+
2,
|
|
490
|
+
"getManaLimit"
|
|
491
|
+
],
|
|
492
|
+
[
|
|
493
|
+
memoize,
|
|
494
|
+
2,
|
|
495
|
+
"getVersion"
|
|
496
|
+
],
|
|
497
|
+
[
|
|
498
|
+
memoize,
|
|
499
|
+
2,
|
|
500
|
+
"getGenesisArchiveTreeRoot"
|
|
501
|
+
],
|
|
502
|
+
[
|
|
503
|
+
memoize,
|
|
504
|
+
2,
|
|
505
|
+
"getRollupConstants"
|
|
506
|
+
]
|
|
507
|
+
], []));
|
|
508
|
+
}
|
|
28
509
|
rollup;
|
|
29
510
|
static cachedStfStorageSlot;
|
|
511
|
+
cachedEscapeHatch;
|
|
30
512
|
static get checkBlobStorageSlot() {
|
|
31
513
|
const asString = RollupStorage.find((storage)=>storage.label === 'checkBlob')?.slot;
|
|
32
514
|
if (asString === undefined) {
|
|
@@ -48,6 +530,7 @@ export class RollupContract {
|
|
|
48
530
|
}
|
|
49
531
|
constructor(client, address){
|
|
50
532
|
this.client = client;
|
|
533
|
+
_initProto(this);
|
|
51
534
|
if (address instanceof EthAddress) {
|
|
52
535
|
address = address.toString();
|
|
53
536
|
}
|
|
@@ -57,8 +540,8 @@ export class RollupContract {
|
|
|
57
540
|
client
|
|
58
541
|
});
|
|
59
542
|
}
|
|
60
|
-
getGSE() {
|
|
61
|
-
return this.rollup.read.getGSE();
|
|
543
|
+
async getGSE() {
|
|
544
|
+
return EthAddress.fromString(await this.rollup.read.getGSE());
|
|
62
545
|
}
|
|
63
546
|
get address() {
|
|
64
547
|
return this.rollup.address;
|
|
@@ -107,17 +590,17 @@ export class RollupContract {
|
|
|
107
590
|
getL1GenesisTime() {
|
|
108
591
|
return this.rollup.read.getGenesisTime();
|
|
109
592
|
}
|
|
110
|
-
getProofSubmissionEpochs() {
|
|
111
|
-
return this.rollup.read.getProofSubmissionEpochs();
|
|
593
|
+
async getProofSubmissionEpochs() {
|
|
594
|
+
return Number(await this.rollup.read.getProofSubmissionEpochs());
|
|
112
595
|
}
|
|
113
|
-
getEpochDuration() {
|
|
114
|
-
return this.rollup.read.getEpochDuration();
|
|
596
|
+
async getEpochDuration() {
|
|
597
|
+
return Number(await this.rollup.read.getEpochDuration());
|
|
115
598
|
}
|
|
116
|
-
getSlotDuration() {
|
|
117
|
-
return this.rollup.read.getSlotDuration();
|
|
599
|
+
async getSlotDuration() {
|
|
600
|
+
return Number(await this.rollup.read.getSlotDuration());
|
|
118
601
|
}
|
|
119
|
-
getTargetCommitteeSize() {
|
|
120
|
-
return this.rollup.read.getTargetCommitteeSize();
|
|
602
|
+
async getTargetCommitteeSize() {
|
|
603
|
+
return Number(await this.rollup.read.getTargetCommitteeSize());
|
|
121
604
|
}
|
|
122
605
|
getEjectionThreshold() {
|
|
123
606
|
return this.rollup.read.getEjectionThreshold();
|
|
@@ -125,14 +608,17 @@ export class RollupContract {
|
|
|
125
608
|
getLocalEjectionThreshold() {
|
|
126
609
|
return this.rollup.read.getLocalEjectionThreshold();
|
|
127
610
|
}
|
|
128
|
-
|
|
129
|
-
return this.rollup.read.
|
|
611
|
+
async getLagInEpochsForValidatorSet() {
|
|
612
|
+
return Number(await this.rollup.read.getLagInEpochsForValidatorSet());
|
|
613
|
+
}
|
|
614
|
+
async getLagInEpochsForRandao() {
|
|
615
|
+
return Number(await this.rollup.read.getLagInEpochsForRandao());
|
|
130
616
|
}
|
|
131
617
|
getActivationThreshold() {
|
|
132
618
|
return this.rollup.read.getActivationThreshold();
|
|
133
619
|
}
|
|
134
|
-
getExitDelay() {
|
|
135
|
-
return this.rollup.read.getExitDelay();
|
|
620
|
+
async getExitDelay() {
|
|
621
|
+
return Number(await this.rollup.read.getExitDelay());
|
|
136
622
|
}
|
|
137
623
|
getManaTarget() {
|
|
138
624
|
return this.rollup.read.getManaTarget();
|
|
@@ -150,9 +636,9 @@ export class RollupContract {
|
|
|
150
636
|
return this.rollup.read.getVersion();
|
|
151
637
|
}
|
|
152
638
|
async getGenesisArchiveTreeRoot() {
|
|
153
|
-
return await this.rollup.read.archiveAt([
|
|
639
|
+
return Fr.fromString(await this.rollup.read.archiveAt([
|
|
154
640
|
0n
|
|
155
|
-
]);
|
|
641
|
+
]));
|
|
156
642
|
}
|
|
157
643
|
/**
|
|
158
644
|
* Returns rollup constants used for epoch queries.
|
|
@@ -169,28 +655,72 @@ export class RollupContract {
|
|
|
169
655
|
return {
|
|
170
656
|
l1StartBlock,
|
|
171
657
|
l1GenesisTime,
|
|
172
|
-
slotDuration
|
|
658
|
+
slotDuration,
|
|
173
659
|
epochDuration: Number(epochDuration),
|
|
174
660
|
proofSubmissionEpochs: Number(proofSubmissionEpochs)
|
|
175
661
|
};
|
|
176
662
|
}
|
|
177
|
-
getSlasherAddress() {
|
|
178
|
-
return this.rollup.read.getSlasher();
|
|
663
|
+
async getSlasherAddress() {
|
|
664
|
+
return EthAddress.fromString(await this.rollup.read.getSlasher());
|
|
665
|
+
}
|
|
666
|
+
/**
|
|
667
|
+
* Returns the configured escape hatch contract address, or zero if disabled.
|
|
668
|
+
*/ async getEscapeHatchAddress() {
|
|
669
|
+
return EthAddress.fromString(await this.rollup.read.getEscapeHatch());
|
|
670
|
+
}
|
|
671
|
+
async getEscapeHatchContract() {
|
|
672
|
+
const escapeHatchAddress = await this.getEscapeHatchAddress();
|
|
673
|
+
if (escapeHatchAddress.isZero()) {
|
|
674
|
+
return undefined;
|
|
675
|
+
}
|
|
676
|
+
// Cache the viem contract wrapper since it will be used frequently.
|
|
677
|
+
if (!this.cachedEscapeHatch || !this.cachedEscapeHatch.address.equals(escapeHatchAddress)) {
|
|
678
|
+
this.cachedEscapeHatch = {
|
|
679
|
+
address: escapeHatchAddress,
|
|
680
|
+
contract: getContract({
|
|
681
|
+
address: escapeHatchAddress.toString(),
|
|
682
|
+
abi: EscapeHatchAbi,
|
|
683
|
+
client: this.client
|
|
684
|
+
})
|
|
685
|
+
};
|
|
686
|
+
}
|
|
687
|
+
return this.cachedEscapeHatch.contract;
|
|
688
|
+
}
|
|
689
|
+
/**
|
|
690
|
+
* Returns whether the escape hatch is open for the given epoch.
|
|
691
|
+
* If escape hatch is not configured, returns false.
|
|
692
|
+
*
|
|
693
|
+
* This function is intentionally defensive: any failure to query the escape hatch
|
|
694
|
+
* (RPC issues, transient errors, etc.) is treated as "closed" to avoid callers
|
|
695
|
+
* needing to sprinkle try/catch everywhere.
|
|
696
|
+
*/ async isEscapeHatchOpen(epoch) {
|
|
697
|
+
try {
|
|
698
|
+
const escapeHatch = await this.getEscapeHatchContract();
|
|
699
|
+
if (!escapeHatch) {
|
|
700
|
+
return false;
|
|
701
|
+
}
|
|
702
|
+
const [isOpen] = await escapeHatch.read.isHatchOpen([
|
|
703
|
+
BigInt(epoch)
|
|
704
|
+
]);
|
|
705
|
+
return isOpen;
|
|
706
|
+
} catch {
|
|
707
|
+
return false;
|
|
708
|
+
}
|
|
179
709
|
}
|
|
180
710
|
/**
|
|
181
711
|
* Returns a SlasherContract instance for interacting with the slasher contract.
|
|
182
712
|
*/ async getSlasherContract() {
|
|
183
|
-
const slasherAddress =
|
|
713
|
+
const slasherAddress = await this.getSlasherAddress();
|
|
184
714
|
if (slasherAddress.isZero()) {
|
|
185
715
|
return undefined;
|
|
186
716
|
}
|
|
187
717
|
return new SlasherContract(this.client, slasherAddress);
|
|
188
718
|
}
|
|
189
|
-
getOwner() {
|
|
190
|
-
return this.rollup.read.owner();
|
|
719
|
+
async getOwner() {
|
|
720
|
+
return EthAddress.fromString(await this.rollup.read.owner());
|
|
191
721
|
}
|
|
192
|
-
getActiveAttesterCount() {
|
|
193
|
-
return this.rollup.read.getActiveAttesterCount();
|
|
722
|
+
async getActiveAttesterCount() {
|
|
723
|
+
return Number(await this.rollup.read.getActiveAttesterCount());
|
|
194
724
|
}
|
|
195
725
|
async getSlashingProposerAddress() {
|
|
196
726
|
const slasher = await this.getSlasherContract();
|
|
@@ -199,25 +729,29 @@ export class RollupContract {
|
|
|
199
729
|
}
|
|
200
730
|
return await slasher.getProposer();
|
|
201
731
|
}
|
|
202
|
-
|
|
203
|
-
return this.rollup.read.
|
|
732
|
+
getCheckpointReward() {
|
|
733
|
+
return this.rollup.read.getCheckpointReward();
|
|
204
734
|
}
|
|
205
|
-
|
|
206
|
-
return this.rollup.read.
|
|
735
|
+
async getCheckpointNumber() {
|
|
736
|
+
return CheckpointNumber.fromBigInt(await this.rollup.read.getPendingCheckpointNumber());
|
|
207
737
|
}
|
|
208
|
-
|
|
209
|
-
return this.rollup.read.
|
|
738
|
+
async getProvenCheckpointNumber() {
|
|
739
|
+
return CheckpointNumber.fromBigInt(await this.rollup.read.getProvenCheckpointNumber());
|
|
210
740
|
}
|
|
211
|
-
getSlotNumber() {
|
|
212
|
-
return this.rollup.read.getCurrentSlot();
|
|
741
|
+
async getSlotNumber() {
|
|
742
|
+
return SlotNumber.fromBigInt(await this.rollup.read.getCurrentSlot());
|
|
213
743
|
}
|
|
214
|
-
getL1FeesAt(timestamp) {
|
|
215
|
-
|
|
744
|
+
async getL1FeesAt(timestamp) {
|
|
745
|
+
const result = await this.rollup.read.getL1FeesAt([
|
|
216
746
|
timestamp
|
|
217
747
|
]);
|
|
748
|
+
return {
|
|
749
|
+
baseFee: result.baseFee,
|
|
750
|
+
blobFee: result.blobFee
|
|
751
|
+
};
|
|
218
752
|
}
|
|
219
|
-
|
|
220
|
-
return this.rollup.read.
|
|
753
|
+
getEthPerFeeAsset() {
|
|
754
|
+
return this.rollup.read.getEthPerFeeAsset();
|
|
221
755
|
}
|
|
222
756
|
async getCommitteeAt(timestamp) {
|
|
223
757
|
const { result } = await this.client.simulateContract({
|
|
@@ -235,18 +769,18 @@ export class RollupContract {
|
|
|
235
769
|
}
|
|
236
770
|
throw e;
|
|
237
771
|
});
|
|
238
|
-
return result;
|
|
772
|
+
return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
|
|
239
773
|
}
|
|
240
|
-
getSampleSeedAt(timestamp) {
|
|
241
|
-
return this.rollup.read.getSampleSeedAt([
|
|
774
|
+
async getSampleSeedAt(timestamp) {
|
|
775
|
+
return Buffer32.fromBigInt(await this.rollup.read.getSampleSeedAt([
|
|
242
776
|
timestamp
|
|
243
|
-
]);
|
|
777
|
+
]));
|
|
244
778
|
}
|
|
245
|
-
getCurrentSampleSeed() {
|
|
246
|
-
return this.rollup.read.getCurrentSampleSeed();
|
|
779
|
+
async getCurrentSampleSeed() {
|
|
780
|
+
return Buffer32.fromBigInt(await this.rollup.read.getCurrentSampleSeed());
|
|
247
781
|
}
|
|
248
|
-
getCurrentEpoch() {
|
|
249
|
-
return this.rollup.read.getCurrentEpoch();
|
|
782
|
+
async getCurrentEpoch() {
|
|
783
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
|
|
250
784
|
}
|
|
251
785
|
async getCurrentEpochCommittee() {
|
|
252
786
|
const { result } = await this.client.simulateContract({
|
|
@@ -262,7 +796,7 @@ export class RollupContract {
|
|
|
262
796
|
}
|
|
263
797
|
throw e;
|
|
264
798
|
});
|
|
265
|
-
return result;
|
|
799
|
+
return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
|
|
266
800
|
}
|
|
267
801
|
async getCurrentProposer() {
|
|
268
802
|
const { result } = await this.client.simulateContract({
|
|
@@ -271,7 +805,7 @@ export class RollupContract {
|
|
|
271
805
|
functionName: 'getCurrentProposer',
|
|
272
806
|
args: []
|
|
273
807
|
});
|
|
274
|
-
return result;
|
|
808
|
+
return EthAddress.fromString(result);
|
|
275
809
|
}
|
|
276
810
|
async getProposerAt(timestamp) {
|
|
277
811
|
const { result } = await this.client.simulateContract({
|
|
@@ -282,37 +816,69 @@ export class RollupContract {
|
|
|
282
816
|
timestamp
|
|
283
817
|
]
|
|
284
818
|
});
|
|
285
|
-
return result;
|
|
819
|
+
return EthAddress.fromString(result);
|
|
286
820
|
}
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
BigInt(
|
|
821
|
+
async getCheckpoint(checkpointNumber) {
|
|
822
|
+
const result = await this.rollup.read.getCheckpoint([
|
|
823
|
+
BigInt(checkpointNumber)
|
|
290
824
|
]);
|
|
825
|
+
return {
|
|
826
|
+
archive: Fr.fromString(result.archive),
|
|
827
|
+
headerHash: Buffer32.fromString(result.headerHash),
|
|
828
|
+
blobCommitmentsHash: Buffer32.fromString(result.blobCommitmentsHash),
|
|
829
|
+
attestationsHash: Buffer32.fromString(result.attestationsHash),
|
|
830
|
+
payloadDigest: Buffer32.fromString(result.payloadDigest),
|
|
831
|
+
slotNumber: SlotNumber.fromBigInt(result.slotNumber),
|
|
832
|
+
feeHeader: {
|
|
833
|
+
excessMana: result.feeHeader.excessMana,
|
|
834
|
+
manaUsed: result.feeHeader.manaUsed,
|
|
835
|
+
ethPerFeeAsset: result.feeHeader.ethPerFeeAsset,
|
|
836
|
+
congestionCost: result.feeHeader.congestionCost,
|
|
837
|
+
proverCost: result.feeHeader.proverCost
|
|
838
|
+
}
|
|
839
|
+
};
|
|
291
840
|
}
|
|
292
|
-
|
|
293
|
-
|
|
841
|
+
/** Returns the pending checkpoint from the rollup contract */ getPendingCheckpoint() {
|
|
842
|
+
// We retry because of race conditions during prunes: we may get a pending checkpoint number which is immediately
|
|
843
|
+
// reorged out due to a prune happening, causing the subsequent getCheckpoint call to fail. So we try again in that case.
|
|
844
|
+
return retry(async ()=>{
|
|
845
|
+
const pendingCheckpointNumber = await this.getCheckpointNumber();
|
|
846
|
+
const pendingCheckpoint = await this.getCheckpoint(pendingCheckpointNumber);
|
|
847
|
+
return pendingCheckpoint;
|
|
848
|
+
}, 'getting pending checkpoint', makeBackoff([
|
|
849
|
+
0.5,
|
|
850
|
+
0.5,
|
|
851
|
+
0.5
|
|
852
|
+
]));
|
|
853
|
+
}
|
|
854
|
+
async getTips() {
|
|
855
|
+
const { pending, proven } = await this.rollup.read.getTips();
|
|
856
|
+
return {
|
|
857
|
+
pending: CheckpointNumber.fromBigInt(pending),
|
|
858
|
+
proven: CheckpointNumber.fromBigInt(proven)
|
|
859
|
+
};
|
|
294
860
|
}
|
|
295
861
|
getTimestampForSlot(slot) {
|
|
296
862
|
return this.rollup.read.getTimestampForSlot([
|
|
297
|
-
slot
|
|
863
|
+
BigInt(slot)
|
|
298
864
|
]);
|
|
299
865
|
}
|
|
300
|
-
getEntryQueueLength() {
|
|
301
|
-
return this.rollup.read.getEntryQueueLength();
|
|
866
|
+
async getEntryQueueLength() {
|
|
867
|
+
return Number(await this.rollup.read.getEntryQueueLength());
|
|
302
868
|
}
|
|
303
|
-
getAvailableValidatorFlushes() {
|
|
304
|
-
return this.rollup.read.getAvailableValidatorFlushes();
|
|
869
|
+
async getAvailableValidatorFlushes() {
|
|
870
|
+
return Number(await this.rollup.read.getAvailableValidatorFlushes());
|
|
305
871
|
}
|
|
306
|
-
getNextFlushableEpoch() {
|
|
307
|
-
return this.rollup.read.getNextFlushableEpoch();
|
|
872
|
+
async getNextFlushableEpoch() {
|
|
873
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getNextFlushableEpoch());
|
|
308
874
|
}
|
|
309
|
-
getCurrentEpochNumber() {
|
|
310
|
-
return this.rollup.read.getCurrentEpoch();
|
|
875
|
+
async getCurrentEpochNumber() {
|
|
876
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
|
|
311
877
|
}
|
|
312
|
-
|
|
313
|
-
return this.rollup.read.
|
|
314
|
-
BigInt(
|
|
315
|
-
]);
|
|
878
|
+
async getEpochNumberForCheckpoint(checkpointNumber) {
|
|
879
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getEpochForCheckpoint([
|
|
880
|
+
BigInt(checkpointNumber)
|
|
881
|
+
]));
|
|
316
882
|
}
|
|
317
883
|
async getRollupAddresses() {
|
|
318
884
|
const [inboxAddress, outboxAddress, feeJuicePortalAddress, rewardDistributorAddress, feeJuiceAddress, stakingAssetAddress, gseAddress] = (await Promise.all([
|
|
@@ -339,12 +905,13 @@ export class RollupContract {
|
|
|
339
905
|
return EthAddress.fromString(await this.rollup.read.getFeeAssetPortal());
|
|
340
906
|
}
|
|
341
907
|
async getEpochNumberForSlotNumber(slotNumber) {
|
|
342
|
-
return await this.rollup.read.getEpochAtSlot([
|
|
343
|
-
slotNumber
|
|
344
|
-
]);
|
|
908
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getEpochAtSlot([
|
|
909
|
+
BigInt(slotNumber)
|
|
910
|
+
]));
|
|
345
911
|
}
|
|
346
|
-
getEpochProofPublicInputs(args) {
|
|
347
|
-
|
|
912
|
+
async getEpochProofPublicInputs(args) {
|
|
913
|
+
const result = await this.rollup.read.getEpochProofPublicInputs(args);
|
|
914
|
+
return result.map(Fr.fromString);
|
|
348
915
|
}
|
|
349
916
|
async validateHeader(args, account) {
|
|
350
917
|
try {
|
|
@@ -365,17 +932,15 @@ export class RollupContract {
|
|
|
365
932
|
* @dev Throws if unable to propose
|
|
366
933
|
*
|
|
367
934
|
* @param archive - The archive that we expect to be current state
|
|
368
|
-
* @return [slot,
|
|
935
|
+
* @return [slot, checkpointNumber, timeOfNextL1Slot] - If you can propose, the L2 slot number, checkpoint number and
|
|
936
|
+
* timestamp of the next L1 block
|
|
369
937
|
* @throws otherwise
|
|
370
938
|
*/ async canProposeAtNextEthBlock(archive, account, slotDuration, opts = {}) {
|
|
371
|
-
if (typeof slotDuration === 'number') {
|
|
372
|
-
slotDuration = BigInt(slotDuration);
|
|
373
|
-
}
|
|
374
939
|
const latestBlock = await this.client.getBlock();
|
|
375
|
-
const timeOfNextL1Slot = latestBlock.timestamp + slotDuration;
|
|
940
|
+
const timeOfNextL1Slot = latestBlock.timestamp + BigInt(slotDuration);
|
|
376
941
|
const who = typeof account === 'string' ? account : account.address;
|
|
377
942
|
try {
|
|
378
|
-
const { result: [slot,
|
|
943
|
+
const { result: [slot, checkpointNumber] } = await this.client.simulateContract({
|
|
379
944
|
address: this.address,
|
|
380
945
|
abi: RollupAbi,
|
|
381
946
|
functionName: 'canProposeAtTime',
|
|
@@ -385,11 +950,11 @@ export class RollupContract {
|
|
|
385
950
|
who
|
|
386
951
|
],
|
|
387
952
|
account,
|
|
388
|
-
stateOverride: await this.
|
|
953
|
+
stateOverride: await this.makePendingCheckpointNumberOverride(opts.forcePendingCheckpointNumber)
|
|
389
954
|
});
|
|
390
955
|
return {
|
|
391
|
-
slot,
|
|
392
|
-
|
|
956
|
+
slot: SlotNumber.fromBigInt(slot),
|
|
957
|
+
checkpointNumber: CheckpointNumber.fromBigInt(checkpointNumber),
|
|
393
958
|
timeOfNextL1Slot
|
|
394
959
|
};
|
|
395
960
|
} catch (err) {
|
|
@@ -397,11 +962,11 @@ export class RollupContract {
|
|
|
397
962
|
}
|
|
398
963
|
}
|
|
399
964
|
/**
|
|
400
|
-
* Returns a state override that sets the pending
|
|
401
|
-
* Requires querying the current state of the contract to get the current proven
|
|
965
|
+
* Returns a state override that sets the pending checkpoint number to the specified value. Useful for simulations.
|
|
966
|
+
* Requires querying the current state of the contract to get the current proven checkpoint number, as they are both
|
|
402
967
|
* stored in the same slot. If the argument is undefined, it returns an empty override.
|
|
403
|
-
*/ async
|
|
404
|
-
if (
|
|
968
|
+
*/ async makePendingCheckpointNumberOverride(forcePendingCheckpointNumber) {
|
|
969
|
+
if (forcePendingCheckpointNumber === undefined) {
|
|
405
970
|
return [];
|
|
406
971
|
}
|
|
407
972
|
const slot = RollupContract.stfStorageSlot;
|
|
@@ -409,8 +974,8 @@ export class RollupContract {
|
|
|
409
974
|
address: this.address,
|
|
410
975
|
slot
|
|
411
976
|
});
|
|
412
|
-
const
|
|
413
|
-
const newValue = BigInt(
|
|
977
|
+
const currentProvenCheckpointNumber = currentValue ? hexToBigInt(currentValue) & (1n << 128n) - 1n : 0n;
|
|
978
|
+
const newValue = BigInt(forcePendingCheckpointNumber) << 128n | currentProvenCheckpointNumber;
|
|
414
979
|
return [
|
|
415
980
|
{
|
|
416
981
|
address: this.address,
|
|
@@ -423,14 +988,15 @@ export class RollupContract {
|
|
|
423
988
|
}
|
|
424
989
|
];
|
|
425
990
|
}
|
|
426
|
-
/** Creates a request to Rollup#invalidateBadAttestation to be simulated or sent */ buildInvalidateBadAttestationRequest(
|
|
991
|
+
/** Creates a request to Rollup#invalidateBadAttestation to be simulated or sent */ buildInvalidateBadAttestationRequest(checkpointNumber, attestationsAndSigners, committee, invalidIndex) {
|
|
427
992
|
return {
|
|
428
993
|
to: this.address,
|
|
994
|
+
abi: RollupAbi,
|
|
429
995
|
data: encodeFunctionData({
|
|
430
996
|
abi: RollupAbi,
|
|
431
997
|
functionName: 'invalidateBadAttestation',
|
|
432
998
|
args: [
|
|
433
|
-
BigInt(
|
|
999
|
+
BigInt(checkpointNumber),
|
|
434
1000
|
attestationsAndSigners,
|
|
435
1001
|
committee.map((addr)=>addr.toString()),
|
|
436
1002
|
BigInt(invalidIndex)
|
|
@@ -438,46 +1004,54 @@ export class RollupContract {
|
|
|
438
1004
|
})
|
|
439
1005
|
};
|
|
440
1006
|
}
|
|
441
|
-
/** Creates a request to Rollup#invalidateInsufficientAttestations to be simulated or sent */ buildInvalidateInsufficientAttestationsRequest(
|
|
1007
|
+
/** Creates a request to Rollup#invalidateInsufficientAttestations to be simulated or sent */ buildInvalidateInsufficientAttestationsRequest(checkpointNumber, attestationsAndSigners, committee) {
|
|
442
1008
|
return {
|
|
443
1009
|
to: this.address,
|
|
1010
|
+
abi: RollupAbi,
|
|
444
1011
|
data: encodeFunctionData({
|
|
445
1012
|
abi: RollupAbi,
|
|
446
1013
|
functionName: 'invalidateInsufficientAttestations',
|
|
447
1014
|
args: [
|
|
448
|
-
BigInt(
|
|
1015
|
+
BigInt(checkpointNumber),
|
|
449
1016
|
attestationsAndSigners,
|
|
450
1017
|
committee.map((addr)=>addr.toString())
|
|
451
1018
|
]
|
|
452
1019
|
})
|
|
453
1020
|
};
|
|
454
1021
|
}
|
|
455
|
-
/** Calls getHasSubmitted directly. Returns whether the given prover has submitted a proof with the given length for the given epoch. */ getHasSubmittedProof(epochNumber,
|
|
1022
|
+
/** Calls getHasSubmitted directly. Returns whether the given prover has submitted a proof with the given length for the given epoch. */ getHasSubmittedProof(epochNumber, numberOfCheckpointsInEpoch, prover) {
|
|
456
1023
|
if (prover instanceof EthAddress) {
|
|
457
1024
|
prover = prover.toString();
|
|
458
1025
|
}
|
|
459
1026
|
return this.rollup.read.getHasSubmitted([
|
|
460
1027
|
BigInt(epochNumber),
|
|
461
|
-
BigInt(
|
|
1028
|
+
BigInt(numberOfCheckpointsInEpoch),
|
|
462
1029
|
prover
|
|
463
1030
|
]);
|
|
464
1031
|
}
|
|
465
|
-
|
|
466
|
-
return this.rollup.read.
|
|
1032
|
+
getManaMinFeeAt(timestamp, inFeeAsset) {
|
|
1033
|
+
return this.rollup.read.getManaMinFeeAt([
|
|
467
1034
|
timestamp,
|
|
468
1035
|
inFeeAsset
|
|
469
1036
|
]);
|
|
470
1037
|
}
|
|
471
|
-
getSlotAt(timestamp) {
|
|
472
|
-
return this.rollup.read.getSlotAt([
|
|
1038
|
+
async getSlotAt(timestamp) {
|
|
1039
|
+
return SlotNumber.fromBigInt(await this.rollup.read.getSlotAt([
|
|
473
1040
|
timestamp
|
|
474
|
-
]);
|
|
1041
|
+
]));
|
|
475
1042
|
}
|
|
476
|
-
async status(
|
|
1043
|
+
async status(checkpointNumber, options) {
|
|
477
1044
|
await checkBlockTag(options?.blockNumber, this.client);
|
|
478
|
-
|
|
479
|
-
|
|
1045
|
+
const result = await this.rollup.read.status([
|
|
1046
|
+
BigInt(checkpointNumber)
|
|
480
1047
|
], options);
|
|
1048
|
+
return {
|
|
1049
|
+
provenCheckpointNumber: CheckpointNumber.fromBigInt(result[0]),
|
|
1050
|
+
provenArchive: Fr.fromString(result[1]),
|
|
1051
|
+
pendingCheckpointNumber: CheckpointNumber.fromBigInt(result[2]),
|
|
1052
|
+
pendingArchive: Fr.fromString(result[3]),
|
|
1053
|
+
archiveOfMyCheckpoint: Fr.fromString(result[4])
|
|
1054
|
+
};
|
|
481
1055
|
}
|
|
482
1056
|
async canPruneAtTime(timestamp, options) {
|
|
483
1057
|
await checkBlockTag(options?.blockNumber, this.client);
|
|
@@ -485,13 +1059,13 @@ export class RollupContract {
|
|
|
485
1059
|
timestamp
|
|
486
1060
|
], options);
|
|
487
1061
|
}
|
|
488
|
-
archive() {
|
|
489
|
-
return this.rollup.read.archive();
|
|
1062
|
+
async archive() {
|
|
1063
|
+
return Fr.fromString(await this.rollup.read.archive());
|
|
490
1064
|
}
|
|
491
|
-
archiveAt(
|
|
492
|
-
return this.rollup.read.archiveAt([
|
|
493
|
-
|
|
494
|
-
]);
|
|
1065
|
+
async archiveAt(checkpointNumber) {
|
|
1066
|
+
return Fr.fromString(await this.rollup.read.archiveAt([
|
|
1067
|
+
BigInt(checkpointNumber)
|
|
1068
|
+
]));
|
|
495
1069
|
}
|
|
496
1070
|
getSequencerRewards(address) {
|
|
497
1071
|
if (address instanceof EthAddress) {
|
|
@@ -515,44 +1089,71 @@ export class RollupContract {
|
|
|
515
1089
|
const gse = new GSEContract(this.client, await this.getGSE());
|
|
516
1090
|
const ts = (await this.client.getBlock()).timestamp;
|
|
517
1091
|
const indices = Array.from({
|
|
518
|
-
length:
|
|
1092
|
+
length: attesterSize
|
|
519
1093
|
}, (_, i)=>BigInt(i));
|
|
520
1094
|
const chunks = chunk(indices, 1000);
|
|
521
|
-
|
|
1095
|
+
const results = await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)));
|
|
1096
|
+
return results.flat().map((addr)=>EthAddress.fromString(addr));
|
|
522
1097
|
}
|
|
523
|
-
getAttesterView(address) {
|
|
1098
|
+
async getAttesterView(address) {
|
|
524
1099
|
if (address instanceof EthAddress) {
|
|
525
1100
|
address = address.toString();
|
|
526
1101
|
}
|
|
527
|
-
|
|
1102
|
+
const result = await this.rollup.read.getAttesterView([
|
|
528
1103
|
address
|
|
529
1104
|
]);
|
|
1105
|
+
return {
|
|
1106
|
+
status: result.status,
|
|
1107
|
+
effectiveBalance: result.effectiveBalance,
|
|
1108
|
+
exit: {
|
|
1109
|
+
withdrawalId: result.exit.withdrawalId,
|
|
1110
|
+
amount: result.exit.amount,
|
|
1111
|
+
exitableAt: result.exit.exitableAt,
|
|
1112
|
+
recipientOrWithdrawer: EthAddress.fromString(result.exit.recipientOrWithdrawer),
|
|
1113
|
+
isRecipient: result.exit.isRecipient,
|
|
1114
|
+
exists: result.exit.exists
|
|
1115
|
+
},
|
|
1116
|
+
config: {
|
|
1117
|
+
publicKey: {
|
|
1118
|
+
x: result.config.publicKey.x,
|
|
1119
|
+
y: result.config.publicKey.y
|
|
1120
|
+
},
|
|
1121
|
+
withdrawer: EthAddress.fromString(result.config.withdrawer)
|
|
1122
|
+
}
|
|
1123
|
+
};
|
|
530
1124
|
}
|
|
531
|
-
getStatus(address) {
|
|
1125
|
+
async getStatus(address) {
|
|
532
1126
|
if (address instanceof EthAddress) {
|
|
533
1127
|
address = address.toString();
|
|
534
1128
|
}
|
|
535
|
-
return this.rollup.read.getStatus([
|
|
1129
|
+
return await this.rollup.read.getStatus([
|
|
536
1130
|
address
|
|
537
1131
|
]);
|
|
538
1132
|
}
|
|
539
|
-
getBlobCommitmentsHash(
|
|
540
|
-
return this.rollup.read.getBlobCommitmentsHash([
|
|
541
|
-
|
|
542
|
-
]);
|
|
1133
|
+
async getBlobCommitmentsHash(checkpointNumber) {
|
|
1134
|
+
return Buffer32.fromString(await this.rollup.read.getBlobCommitmentsHash([
|
|
1135
|
+
BigInt(checkpointNumber)
|
|
1136
|
+
]));
|
|
543
1137
|
}
|
|
544
|
-
getCurrentBlobCommitmentsHash() {
|
|
545
|
-
return this.rollup.read.getCurrentBlobCommitmentsHash();
|
|
1138
|
+
async getCurrentBlobCommitmentsHash() {
|
|
1139
|
+
return Buffer32.fromString(await this.rollup.read.getCurrentBlobCommitmentsHash());
|
|
546
1140
|
}
|
|
547
|
-
getStakingAsset() {
|
|
548
|
-
return this.rollup.read.getStakingAsset();
|
|
1141
|
+
async getStakingAsset() {
|
|
1142
|
+
return EthAddress.fromString(await this.rollup.read.getStakingAsset());
|
|
549
1143
|
}
|
|
550
|
-
getRewardConfig() {
|
|
551
|
-
|
|
1144
|
+
async getRewardConfig() {
|
|
1145
|
+
const result = await this.rollup.read.getRewardConfig();
|
|
1146
|
+
return {
|
|
1147
|
+
rewardDistributor: EthAddress.fromString(result.rewardDistributor),
|
|
1148
|
+
sequencerBps: BigInt(result.sequencerBps),
|
|
1149
|
+
booster: EthAddress.fromString(result.booster),
|
|
1150
|
+
checkpointReward: result.checkpointReward
|
|
1151
|
+
};
|
|
552
1152
|
}
|
|
553
1153
|
setupEpoch(l1TxUtils) {
|
|
554
1154
|
return l1TxUtils.sendAndMonitorTransaction({
|
|
555
1155
|
to: this.address,
|
|
1156
|
+
abi: RollupAbi,
|
|
556
1157
|
data: encodeFunctionData({
|
|
557
1158
|
abi: RollupAbi,
|
|
558
1159
|
functionName: 'setupEpoch',
|
|
@@ -563,6 +1164,7 @@ export class RollupContract {
|
|
|
563
1164
|
vote(l1TxUtils, proposalId) {
|
|
564
1165
|
return l1TxUtils.sendAndMonitorTransaction({
|
|
565
1166
|
to: this.address,
|
|
1167
|
+
abi: RollupAbi,
|
|
566
1168
|
data: encodeFunctionData({
|
|
567
1169
|
abi: RollupAbi,
|
|
568
1170
|
functionName: 'vote',
|
|
@@ -584,14 +1186,14 @@ export class RollupContract {
|
|
|
584
1186
|
}
|
|
585
1187
|
});
|
|
586
1188
|
}
|
|
587
|
-
|
|
588
|
-
return this.rollup.watchEvent.
|
|
1189
|
+
listenToCheckpointInvalidated(callback) {
|
|
1190
|
+
return this.rollup.watchEvent.CheckpointInvalidated({}, {
|
|
589
1191
|
onLogs: (logs)=>{
|
|
590
1192
|
for (const log of logs){
|
|
591
1193
|
const args = log.args;
|
|
592
|
-
if (args.
|
|
1194
|
+
if (args.checkpointNumber !== undefined) {
|
|
593
1195
|
callback({
|
|
594
|
-
|
|
1196
|
+
checkpointNumber: CheckpointNumber.fromBigInt(args.checkpointNumber)
|
|
595
1197
|
});
|
|
596
1198
|
}
|
|
597
1199
|
}
|
|
@@ -622,58 +1224,22 @@ export class RollupContract {
|
|
|
622
1224
|
}
|
|
623
1225
|
});
|
|
624
1226
|
}
|
|
1227
|
+
/** Fetches CheckpointProposed events within the given block range. */ async getCheckpointProposedEvents(fromBlock, toBlock) {
|
|
1228
|
+
const logs = await this.rollup.getEvents.CheckpointProposed({}, {
|
|
1229
|
+
fromBlock,
|
|
1230
|
+
toBlock
|
|
1231
|
+
});
|
|
1232
|
+
return logs.filter((log)=>log.blockNumber >= fromBlock && log.blockNumber <= toBlock).map((log)=>({
|
|
1233
|
+
l1BlockNumber: log.blockNumber,
|
|
1234
|
+
l1BlockHash: Buffer32.fromString(log.blockHash),
|
|
1235
|
+
l1TransactionHash: log.transactionHash,
|
|
1236
|
+
args: {
|
|
1237
|
+
checkpointNumber: CheckpointNumber.fromBigInt(log.args.checkpointNumber),
|
|
1238
|
+
archive: Fr.fromString(log.args.archive),
|
|
1239
|
+
versionedBlobHashes: log.args.versionedBlobHashes.map((h)=>Buffer.from(h.slice(2), 'hex')),
|
|
1240
|
+
attestationsHash: log.args.attestationsHash ? Buffer32.fromString(log.args.attestationsHash) : undefined,
|
|
1241
|
+
payloadDigest: log.args.payloadDigest ? Buffer32.fromString(log.args.payloadDigest) : undefined
|
|
1242
|
+
}
|
|
1243
|
+
}));
|
|
1244
|
+
}
|
|
625
1245
|
}
|
|
626
|
-
_ts_decorate([
|
|
627
|
-
memoize
|
|
628
|
-
], RollupContract.prototype, "getL1StartBlock", null);
|
|
629
|
-
_ts_decorate([
|
|
630
|
-
memoize
|
|
631
|
-
], RollupContract.prototype, "getL1GenesisTime", null);
|
|
632
|
-
_ts_decorate([
|
|
633
|
-
memoize
|
|
634
|
-
], RollupContract.prototype, "getProofSubmissionEpochs", null);
|
|
635
|
-
_ts_decorate([
|
|
636
|
-
memoize
|
|
637
|
-
], RollupContract.prototype, "getEpochDuration", null);
|
|
638
|
-
_ts_decorate([
|
|
639
|
-
memoize
|
|
640
|
-
], RollupContract.prototype, "getSlotDuration", null);
|
|
641
|
-
_ts_decorate([
|
|
642
|
-
memoize
|
|
643
|
-
], RollupContract.prototype, "getTargetCommitteeSize", null);
|
|
644
|
-
_ts_decorate([
|
|
645
|
-
memoize
|
|
646
|
-
], RollupContract.prototype, "getEjectionThreshold", null);
|
|
647
|
-
_ts_decorate([
|
|
648
|
-
memoize
|
|
649
|
-
], RollupContract.prototype, "getLocalEjectionThreshold", null);
|
|
650
|
-
_ts_decorate([
|
|
651
|
-
memoize
|
|
652
|
-
], RollupContract.prototype, "getLagInEpochs", null);
|
|
653
|
-
_ts_decorate([
|
|
654
|
-
memoize
|
|
655
|
-
], RollupContract.prototype, "getActivationThreshold", null);
|
|
656
|
-
_ts_decorate([
|
|
657
|
-
memoize
|
|
658
|
-
], RollupContract.prototype, "getExitDelay", null);
|
|
659
|
-
_ts_decorate([
|
|
660
|
-
memoize
|
|
661
|
-
], RollupContract.prototype, "getManaTarget", null);
|
|
662
|
-
_ts_decorate([
|
|
663
|
-
memoize
|
|
664
|
-
], RollupContract.prototype, "getProvingCostPerMana", null);
|
|
665
|
-
_ts_decorate([
|
|
666
|
-
memoize
|
|
667
|
-
], RollupContract.prototype, "getProvingCostPerManaInFeeAsset", null);
|
|
668
|
-
_ts_decorate([
|
|
669
|
-
memoize
|
|
670
|
-
], RollupContract.prototype, "getManaLimit", null);
|
|
671
|
-
_ts_decorate([
|
|
672
|
-
memoize
|
|
673
|
-
], RollupContract.prototype, "getVersion", null);
|
|
674
|
-
_ts_decorate([
|
|
675
|
-
memoize
|
|
676
|
-
], RollupContract.prototype, "getGenesisArchiveTreeRoot", null);
|
|
677
|
-
_ts_decorate([
|
|
678
|
-
memoize
|
|
679
|
-
], RollupContract.prototype, "getRollupConstants", null);
|