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