@aztec/ethereum 0.0.0-test.1 → 0.0.1-commit.0208eb9
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 +2 -0
- package/dest/account.d.ts.map +1 -0
- package/dest/account.js +4 -0
- package/dest/chain.d.ts +1 -1
- package/dest/client.d.ts +6 -4
- package/dest/client.d.ts.map +1 -1
- package/dest/client.js +21 -3
- package/dest/config.d.ts +68 -23
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +145 -32
- package/dest/constants.d.ts +1 -1
- package/dest/contracts/empire_base.d.ts +25 -8
- package/dest/contracts/empire_base.d.ts.map +1 -1
- package/dest/contracts/empire_base.js +75 -2
- package/dest/contracts/empire_slashing_proposer.d.ts +67 -0
- package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -0
- package/dest/contracts/empire_slashing_proposer.js +207 -0
- package/dest/contracts/errors.d.ts +7 -0
- package/dest/contracts/errors.d.ts.map +1 -0
- package/dest/contracts/errors.js +12 -0
- package/dest/contracts/fee_asset_handler.d.ts +20 -0
- package/dest/contracts/fee_asset_handler.d.ts.map +1 -0
- package/dest/contracts/fee_asset_handler.js +59 -0
- package/dest/contracts/fee_juice.d.ts +6 -7
- package/dest/contracts/fee_juice.d.ts.map +1 -1
- package/dest/contracts/fee_juice.js +27 -20
- package/dest/contracts/governance.d.ts +45 -32
- package/dest/contracts/governance.d.ts.map +1 -1
- package/dest/contracts/governance.js +98 -85
- package/dest/contracts/governance_proposer.d.ts +17 -13
- package/dest/contracts/governance_proposer.d.ts.map +1 -1
- package/dest/contracts/governance_proposer.js +432 -26
- package/dest/contracts/gse.d.ts +32 -0
- package/dest/contracts/gse.d.ts.map +1 -0
- package/dest/contracts/gse.js +72 -0
- package/dest/contracts/inbox.d.ts +47 -0
- package/dest/contracts/inbox.d.ts.map +1 -0
- package/dest/contracts/inbox.js +80 -0
- package/dest/contracts/index.d.ts +11 -3
- package/dest/contracts/index.d.ts.map +1 -1
- package/dest/contracts/index.js +10 -2
- 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 +21 -0
- package/dest/contracts/multicall.d.ts.map +1 -0
- package/dest/contracts/multicall.js +157 -0
- package/dest/contracts/outbox.d.ts +41 -0
- package/dest/contracts/outbox.d.ts.map +1 -0
- package/dest/contracts/outbox.js +86 -0
- package/dest/contracts/registry.d.ts +10 -5
- package/dest/contracts/registry.d.ts.map +1 -1
- package/dest/contracts/registry.js +44 -16
- package/dest/contracts/rollup.d.ts +297 -53
- package/dest/contracts/rollup.d.ts.map +1 -1
- package/dest/contracts/rollup.js +1127 -116
- package/dest/contracts/slasher_contract.d.ts +44 -0
- package/dest/contracts/slasher_contract.d.ts.map +1 -0
- package/dest/contracts/slasher_contract.js +75 -0
- package/dest/contracts/tally_slashing_proposer.d.ts +140 -0
- package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -0
- package/dest/contracts/tally_slashing_proposer.js +320 -0
- package/dest/contracts/utils.d.ts +3 -0
- package/dest/contracts/utils.d.ts.map +1 -0
- package/dest/contracts/utils.js +11 -0
- 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 +21 -0
- package/dest/eth-signer/eth-signer.d.ts.map +1 -0
- package/dest/eth-signer/eth-signer.js +5 -0
- package/dest/eth-signer/index.d.ts +2 -0
- package/dest/eth-signer/index.d.ts.map +1 -0
- package/dest/eth-signer/index.js +1 -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 +80735 -0
- package/dest/l1_artifacts.d.ts.map +1 -0
- package/dest/l1_artifacts.js +166 -0
- package/dest/l1_contract_addresses.d.ts +24 -4
- package/dest/l1_contract_addresses.d.ts.map +1 -1
- package/dest/l1_contract_addresses.js +25 -21
- package/dest/l1_reader.d.ts +4 -2
- package/dest/l1_reader.d.ts.map +1 -1
- package/dest/l1_reader.js +14 -8
- package/dest/l1_tx_utils/config.d.ts +59 -0
- package/dest/l1_tx_utils/config.d.ts.map +1 -0
- package/dest/l1_tx_utils/config.js +96 -0
- package/dest/l1_tx_utils/constants.d.ts +12 -0
- package/dest/l1_tx_utils/constants.d.ts.map +1 -0
- package/dest/l1_tx_utils/constants.js +39 -0
- package/dest/l1_tx_utils/factory.d.ts +24 -0
- package/dest/l1_tx_utils/factory.d.ts.map +1 -0
- package/dest/l1_tx_utils/factory.js +12 -0
- package/dest/l1_tx_utils/fee-strategies/index.d.ts +10 -0
- package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/index.js +12 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +8 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +129 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +23 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +191 -0
- package/dest/l1_tx_utils/fee-strategies/types.d.ts +51 -0
- package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/types.js +3 -0
- package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
- package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
- package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +48 -0
- package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
- package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
- package/dest/l1_tx_utils/index-blobs.js +2 -0
- package/dest/l1_tx_utils/index.d.ts +12 -0
- package/dest/l1_tx_utils/index.d.ts.map +1 -0
- package/dest/l1_tx_utils/index.js +12 -0
- package/dest/l1_tx_utils/interfaces.d.ts +76 -0
- package/dest/l1_tx_utils/interfaces.d.ts.map +1 -0
- package/dest/l1_tx_utils/interfaces.js +4 -0
- 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 +94 -0
- package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -0
- package/dest/l1_tx_utils/l1_tx_utils.js +623 -0
- package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +26 -0
- package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +1 -0
- package/dest/l1_tx_utils/l1_tx_utils_with_blobs.js +26 -0
- package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +83 -0
- package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -0
- package/dest/l1_tx_utils/readonly_l1_tx_utils.js +323 -0
- package/dest/l1_tx_utils/signer.d.ts +4 -0
- package/dest/l1_tx_utils/signer.d.ts.map +1 -0
- package/dest/l1_tx_utils/signer.js +16 -0
- package/dest/l1_tx_utils/types.d.ts +67 -0
- package/dest/l1_tx_utils/types.d.ts.map +1 -0
- package/dest/l1_tx_utils/types.js +26 -0
- package/dest/l1_tx_utils/utils.d.ts +4 -0
- package/dest/l1_tx_utils/utils.d.ts.map +1 -0
- package/dest/l1_tx_utils/utils.js +14 -0
- package/dest/l1_types.d.ts +6 -0
- package/dest/l1_types.d.ts.map +1 -0
- package/dest/l1_types.js +1 -0
- package/dest/publisher_manager.d.ts +16 -0
- package/dest/publisher_manager.d.ts.map +1 -0
- package/dest/publisher_manager.js +88 -0
- package/dest/queries.d.ts +5 -3
- package/dest/queries.d.ts.map +1 -1
- package/dest/queries.js +61 -12
- package/dest/test/chain_monitor.d.ts +75 -0
- package/dest/test/chain_monitor.d.ts.map +1 -0
- package/dest/test/chain_monitor.js +213 -0
- package/dest/test/delayed_tx_utils.d.ts +8 -3
- package/dest/test/delayed_tx_utils.d.ts.map +1 -1
- package/dest/test/delayed_tx_utils.js +13 -6
- package/dest/test/eth_cheat_codes.d.ts +229 -0
- package/dest/test/eth_cheat_codes.d.ts.map +1 -0
- package/dest/test/eth_cheat_codes.js +560 -0
- package/dest/test/eth_cheat_codes_with_state.d.ts +2 -2
- package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
- package/dest/test/eth_cheat_codes_with_state.js +1 -1
- package/dest/test/index.d.ts +4 -1
- package/dest/test/index.d.ts.map +1 -1
- package/dest/test/index.js +3 -0
- package/dest/test/rollup_cheat_codes.d.ts +90 -0
- package/dest/test/rollup_cheat_codes.d.ts.map +1 -0
- package/dest/test/rollup_cheat_codes.js +292 -0
- package/dest/test/start_anvil.d.ts +9 -1
- package/dest/test/start_anvil.d.ts.map +1 -1
- package/dest/test/start_anvil.js +16 -7
- package/dest/test/tx_delayer.d.ts +18 -7
- package/dest/test/tx_delayer.d.ts.map +1 -1
- package/dest/test/tx_delayer.js +97 -20
- package/dest/test/upgrade_utils.d.ts +6 -5
- package/dest/test/upgrade_utils.d.ts.map +1 -1
- package/dest/test/upgrade_utils.js +23 -16
- package/dest/types.d.ts +62 -8
- package/dest/types.d.ts.map +1 -1
- package/dest/types.js +3 -1
- package/dest/utils.d.ts +17 -3
- package/dest/utils.d.ts.map +1 -1
- package/dest/utils.js +107 -88
- package/dest/zkPassportVerifierAddress.d.ts +15 -0
- package/dest/zkPassportVerifierAddress.d.ts.map +1 -0
- package/dest/zkPassportVerifierAddress.js +11 -0
- package/package.json +51 -23
- package/src/account.ts +5 -0
- package/src/client.ts +43 -5
- package/src/config.ts +207 -41
- package/src/contracts/README.md +157 -0
- package/src/contracts/empire_base.ts +77 -7
- package/src/contracts/empire_slashing_proposer.ts +259 -0
- package/src/contracts/errors.ts +13 -0
- package/src/contracts/fee_asset_handler.ts +66 -0
- package/src/contracts/fee_juice.ts +29 -15
- package/src/contracts/governance.ts +90 -78
- package/src/contracts/governance_proposer.ts +75 -25
- package/src/contracts/gse.ts +88 -0
- package/src/contracts/inbox.ts +115 -0
- package/src/contracts/index.ts +10 -2
- package/src/contracts/log.ts +13 -0
- package/src/contracts/multicall.ts +158 -0
- package/src/contracts/outbox.ts +98 -0
- package/src/contracts/registry.ts +51 -26
- package/src/contracts/rollup.ts +879 -89
- package/src/contracts/slasher_contract.ts +89 -0
- package/src/contracts/tally_slashing_proposer.ts +322 -0
- package/src/contracts/utils.ts +14 -0
- package/src/deploy_aztec_l1_contracts.ts +623 -0
- package/src/deploy_l1_contract.ts +362 -0
- package/src/eth-signer/eth-signer.ts +25 -0
- package/src/eth-signer/index.ts +1 -0
- package/src/forwarder_proxy.ts +108 -0
- package/src/generated/l1-contracts-defaults.ts +32 -0
- package/src/l1_artifacts.ts +254 -0
- package/src/l1_contract_addresses.ts +49 -34
- package/src/l1_reader.ts +17 -9
- package/src/l1_tx_utils/README.md +177 -0
- package/src/l1_tx_utils/config.ts +161 -0
- package/src/l1_tx_utils/constants.ts +29 -0
- package/src/l1_tx_utils/factory.ts +64 -0
- package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
- package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +163 -0
- package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +245 -0
- package/src/l1_tx_utils/fee-strategies/types.ts +56 -0
- package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +119 -0
- package/src/l1_tx_utils/index-blobs.ts +2 -0
- package/src/l1_tx_utils/index.ts +14 -0
- package/src/l1_tx_utils/interfaces.ts +86 -0
- package/src/l1_tx_utils/l1_fee_analyzer.ts +803 -0
- package/src/l1_tx_utils/l1_tx_utils.ts +738 -0
- package/src/l1_tx_utils/l1_tx_utils_with_blobs.ts +77 -0
- package/src/l1_tx_utils/readonly_l1_tx_utils.ts +419 -0
- package/src/l1_tx_utils/signer.ts +28 -0
- package/src/l1_tx_utils/types.ts +85 -0
- package/src/l1_tx_utils/utils.ts +16 -0
- package/src/l1_types.ts +6 -0
- package/src/publisher_manager.ts +108 -0
- package/src/queries.ts +82 -16
- package/src/test/chain_monitor.ts +245 -0
- package/src/test/delayed_tx_utils.ts +34 -6
- package/src/test/eth_cheat_codes.ts +588 -0
- package/src/test/eth_cheat_codes_with_state.ts +1 -1
- package/src/test/index.ts +3 -0
- package/src/test/rollup_cheat_codes.ts +330 -0
- package/src/test/start_anvil.ts +24 -5
- package/src/test/tx_delayer.ts +130 -27
- package/src/test/upgrade_utils.ts +30 -21
- package/src/types.ts +71 -7
- package/src/utils.ts +133 -92
- package/src/zkPassportVerifierAddress.ts +15 -0
- package/dest/contracts/forwarder.d.ts +0 -24
- package/dest/contracts/forwarder.d.ts.map +0 -1
- package/dest/contracts/forwarder.js +0 -101
- package/dest/contracts/slashing_proposer.d.ts +0 -21
- package/dest/contracts/slashing_proposer.d.ts.map +0 -1
- package/dest/contracts/slashing_proposer.js +0 -47
- package/dest/deploy_l1_contracts.d.ts +0 -21210
- package/dest/deploy_l1_contracts.d.ts.map +0 -1
- package/dest/deploy_l1_contracts.js +0 -687
- package/dest/eth_cheat_codes.d.ts +0 -147
- package/dest/eth_cheat_codes.d.ts.map +0 -1
- package/dest/eth_cheat_codes.js +0 -303
- package/dest/index.d.ts +0 -14
- package/dest/index.d.ts.map +0 -1
- package/dest/index.js +0 -13
- package/dest/l1_tx_utils.d.ts +0 -192
- package/dest/l1_tx_utils.d.ts.map +0 -1
- package/dest/l1_tx_utils.js +0 -641
- package/dest/l1_tx_utils_with_blobs.d.ts +0 -12
- package/dest/l1_tx_utils_with_blobs.d.ts.map +0 -1
- package/dest/l1_tx_utils_with_blobs.js +0 -64
- package/src/contracts/forwarder.ts +0 -132
- package/src/contracts/slashing_proposer.ts +0 -51
- package/src/deploy_l1_contracts.ts +0 -948
- package/src/eth_cheat_codes.ts +0 -314
- package/src/index.ts +0 -13
- package/src/l1_tx_utils.ts +0 -847
- package/src/l1_tx_utils_with_blobs.ts +0 -86
package/dest/contracts/rollup.js
CHANGED
|
@@ -1,19 +1,514 @@
|
|
|
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
|
}
|
|
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';
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
379
|
+
import { makeBackoff, retry } from '@aztec/foundation/retry';
|
|
380
|
+
import { EscapeHatchAbi } from '@aztec/l1-artifacts/EscapeHatchAbi';
|
|
381
|
+
import { RollupAbi } from '@aztec/l1-artifacts/RollupAbi';
|
|
382
|
+
import { RollupStorage } from '@aztec/l1-artifacts/RollupStorage';
|
|
383
|
+
import chunk from 'lodash.chunk';
|
|
384
|
+
import { encodeFunctionData, getContract, hexToBigInt, keccak256 } from 'viem';
|
|
11
385
|
import { getPublicClient } from '../client.js';
|
|
12
386
|
import { formatViemError } from '../utils.js';
|
|
13
|
-
import {
|
|
387
|
+
import { EmpireSlashingProposerContract } from './empire_slashing_proposer.js';
|
|
388
|
+
import { GSEContract } from './gse.js';
|
|
389
|
+
import { SlasherContract } from './slasher_contract.js';
|
|
390
|
+
import { TallySlashingProposerContract } from './tally_slashing_proposer.js';
|
|
391
|
+
import { checkBlockTag } from './utils.js';
|
|
392
|
+
export var SlashingProposerType = /*#__PURE__*/ function(SlashingProposerType) {
|
|
393
|
+
SlashingProposerType[SlashingProposerType["None"] = 0] = "None";
|
|
394
|
+
SlashingProposerType[SlashingProposerType["Tally"] = 1] = "Tally";
|
|
395
|
+
SlashingProposerType[SlashingProposerType["Empire"] = 2] = "Empire";
|
|
396
|
+
return SlashingProposerType;
|
|
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
|
+
}({});
|
|
14
408
|
export class RollupContract {
|
|
15
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
|
+
}
|
|
16
509
|
rollup;
|
|
510
|
+
static cachedStfStorageSlot;
|
|
511
|
+
cachedEscapeHatch;
|
|
17
512
|
static get checkBlobStorageSlot() {
|
|
18
513
|
const asString = RollupStorage.find((storage)=>storage.label === 'checkBlob')?.slot;
|
|
19
514
|
if (asString === undefined) {
|
|
@@ -21,9 +516,12 @@ export class RollupContract {
|
|
|
21
516
|
}
|
|
22
517
|
return BigInt(asString);
|
|
23
518
|
}
|
|
519
|
+
static get stfStorageSlot() {
|
|
520
|
+
return RollupContract.cachedStfStorageSlot ??= keccak256(Buffer.from('aztec.stf.storage', 'utf-8'));
|
|
521
|
+
}
|
|
24
522
|
static getFromL1ContractsValues(deployL1ContractsValues) {
|
|
25
|
-
const {
|
|
26
|
-
return new RollupContract(
|
|
523
|
+
const { l1Client, l1ContractAddresses: { rollupAddress } } = deployL1ContractsValues;
|
|
524
|
+
return new RollupContract(l1Client, rollupAddress.toString());
|
|
27
525
|
}
|
|
28
526
|
static getFromConfig(config) {
|
|
29
527
|
const client = getPublicClient(config);
|
|
@@ -32,6 +530,7 @@ export class RollupContract {
|
|
|
32
530
|
}
|
|
33
531
|
constructor(client, address){
|
|
34
532
|
this.client = client;
|
|
533
|
+
_initProto(this);
|
|
35
534
|
if (address instanceof EthAddress) {
|
|
36
535
|
address = address.toString();
|
|
37
536
|
}
|
|
@@ -41,18 +540,49 @@ export class RollupContract {
|
|
|
41
540
|
client
|
|
42
541
|
});
|
|
43
542
|
}
|
|
543
|
+
async getGSE() {
|
|
544
|
+
return EthAddress.fromString(await this.rollup.read.getGSE());
|
|
545
|
+
}
|
|
44
546
|
get address() {
|
|
45
547
|
return this.rollup.address;
|
|
46
548
|
}
|
|
549
|
+
getContract() {
|
|
550
|
+
return this.rollup;
|
|
551
|
+
}
|
|
47
552
|
async getSlashingProposer() {
|
|
48
|
-
const
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
553
|
+
const slasher = await this.getSlasherContract();
|
|
554
|
+
if (!slasher) {
|
|
555
|
+
return undefined;
|
|
556
|
+
}
|
|
557
|
+
const proposerAddress = await slasher.getProposer();
|
|
558
|
+
const proposerAbi = [
|
|
559
|
+
{
|
|
560
|
+
type: 'function',
|
|
561
|
+
name: 'SLASHING_PROPOSER_TYPE',
|
|
562
|
+
inputs: [],
|
|
563
|
+
outputs: [
|
|
564
|
+
{
|
|
565
|
+
name: '',
|
|
566
|
+
type: 'uint8',
|
|
567
|
+
internalType: 'enum SlasherFlavor'
|
|
568
|
+
}
|
|
569
|
+
],
|
|
570
|
+
stateMutability: 'view'
|
|
571
|
+
}
|
|
572
|
+
];
|
|
573
|
+
const proposer = getContract({
|
|
574
|
+
address: proposerAddress.toString(),
|
|
575
|
+
abi: proposerAbi,
|
|
52
576
|
client: this.client
|
|
53
577
|
});
|
|
54
|
-
const
|
|
55
|
-
|
|
578
|
+
const proposerType = await proposer.read.SLASHING_PROPOSER_TYPE();
|
|
579
|
+
if (proposerType === 1..valueOf()) {
|
|
580
|
+
return new TallySlashingProposerContract(this.client, proposerAddress);
|
|
581
|
+
} else if (proposerType === 2..valueOf()) {
|
|
582
|
+
return new EmpireSlashingProposerContract(this.client, proposerAddress);
|
|
583
|
+
} else {
|
|
584
|
+
throw new Error(`Unknown slashing proposer type: ${proposerType}`);
|
|
585
|
+
}
|
|
56
586
|
}
|
|
57
587
|
getL1StartBlock() {
|
|
58
588
|
return this.rollup.read.L1_BLOCK_AT_GENESIS();
|
|
@@ -60,90 +590,305 @@ export class RollupContract {
|
|
|
60
590
|
getL1GenesisTime() {
|
|
61
591
|
return this.rollup.read.getGenesisTime();
|
|
62
592
|
}
|
|
63
|
-
|
|
64
|
-
return this.rollup.read.
|
|
593
|
+
async getProofSubmissionEpochs() {
|
|
594
|
+
return Number(await this.rollup.read.getProofSubmissionEpochs());
|
|
595
|
+
}
|
|
596
|
+
async getEpochDuration() {
|
|
597
|
+
return Number(await this.rollup.read.getEpochDuration());
|
|
598
|
+
}
|
|
599
|
+
async getSlotDuration() {
|
|
600
|
+
return Number(await this.rollup.read.getSlotDuration());
|
|
65
601
|
}
|
|
66
|
-
|
|
67
|
-
return this.rollup.read.
|
|
602
|
+
async getTargetCommitteeSize() {
|
|
603
|
+
return Number(await this.rollup.read.getTargetCommitteeSize());
|
|
68
604
|
}
|
|
69
|
-
|
|
70
|
-
return this.rollup.read.
|
|
605
|
+
getEjectionThreshold() {
|
|
606
|
+
return this.rollup.read.getEjectionThreshold();
|
|
71
607
|
}
|
|
72
|
-
|
|
73
|
-
return this.rollup.read.
|
|
608
|
+
getLocalEjectionThreshold() {
|
|
609
|
+
return this.rollup.read.getLocalEjectionThreshold();
|
|
74
610
|
}
|
|
75
|
-
|
|
76
|
-
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());
|
|
616
|
+
}
|
|
617
|
+
getActivationThreshold() {
|
|
618
|
+
return this.rollup.read.getActivationThreshold();
|
|
619
|
+
}
|
|
620
|
+
async getExitDelay() {
|
|
621
|
+
return Number(await this.rollup.read.getExitDelay());
|
|
622
|
+
}
|
|
623
|
+
getManaTarget() {
|
|
624
|
+
return this.rollup.read.getManaTarget();
|
|
625
|
+
}
|
|
626
|
+
getProvingCostPerMana() {
|
|
627
|
+
return this.rollup.read.getProvingCostPerManaInEth();
|
|
628
|
+
}
|
|
629
|
+
getProvingCostPerManaInFeeAsset() {
|
|
630
|
+
return this.rollup.read.getProvingCostPerManaInFeeAsset();
|
|
631
|
+
}
|
|
632
|
+
getManaLimit() {
|
|
633
|
+
return this.rollup.read.getManaLimit();
|
|
634
|
+
}
|
|
635
|
+
getVersion() {
|
|
636
|
+
return this.rollup.read.getVersion();
|
|
637
|
+
}
|
|
638
|
+
async getGenesisArchiveTreeRoot() {
|
|
639
|
+
return Fr.fromString(await this.rollup.read.archiveAt([
|
|
640
|
+
0n
|
|
641
|
+
]));
|
|
642
|
+
}
|
|
643
|
+
/**
|
|
644
|
+
* Returns rollup constants used for epoch queries.
|
|
645
|
+
* Return type is `L1RollupConstants` which is defined in stdlib,
|
|
646
|
+
* so we cant reference it until we move this contract to that package.
|
|
647
|
+
*/ async getRollupConstants() {
|
|
648
|
+
const [l1StartBlock, l1GenesisTime, slotDuration, epochDuration, proofSubmissionEpochs] = await Promise.all([
|
|
649
|
+
this.getL1StartBlock(),
|
|
650
|
+
this.getL1GenesisTime(),
|
|
651
|
+
this.getSlotDuration(),
|
|
652
|
+
this.getEpochDuration(),
|
|
653
|
+
this.getProofSubmissionEpochs()
|
|
654
|
+
]);
|
|
655
|
+
return {
|
|
656
|
+
l1StartBlock,
|
|
657
|
+
l1GenesisTime,
|
|
658
|
+
slotDuration,
|
|
659
|
+
epochDuration: Number(epochDuration),
|
|
660
|
+
proofSubmissionEpochs: Number(proofSubmissionEpochs)
|
|
661
|
+
};
|
|
662
|
+
}
|
|
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
|
+
}
|
|
709
|
+
}
|
|
710
|
+
/**
|
|
711
|
+
* Returns a SlasherContract instance for interacting with the slasher contract.
|
|
712
|
+
*/ async getSlasherContract() {
|
|
713
|
+
const slasherAddress = await this.getSlasherAddress();
|
|
714
|
+
if (slasherAddress.isZero()) {
|
|
715
|
+
return undefined;
|
|
716
|
+
}
|
|
717
|
+
return new SlasherContract(this.client, slasherAddress);
|
|
718
|
+
}
|
|
719
|
+
async getOwner() {
|
|
720
|
+
return EthAddress.fromString(await this.rollup.read.owner());
|
|
721
|
+
}
|
|
722
|
+
async getActiveAttesterCount() {
|
|
723
|
+
return Number(await this.rollup.read.getActiveAttesterCount());
|
|
77
724
|
}
|
|
78
725
|
async getSlashingProposerAddress() {
|
|
79
|
-
const
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
726
|
+
const slasher = await this.getSlasherContract();
|
|
727
|
+
if (!slasher) {
|
|
728
|
+
return EthAddress.ZERO;
|
|
729
|
+
}
|
|
730
|
+
return await slasher.getProposer();
|
|
731
|
+
}
|
|
732
|
+
getCheckpointReward() {
|
|
733
|
+
return this.rollup.read.getCheckpointReward();
|
|
86
734
|
}
|
|
87
|
-
|
|
88
|
-
return this.rollup.read.
|
|
735
|
+
async getCheckpointNumber() {
|
|
736
|
+
return CheckpointNumber.fromBigInt(await this.rollup.read.getPendingCheckpointNumber());
|
|
89
737
|
}
|
|
90
|
-
|
|
91
|
-
return this.rollup.read.
|
|
738
|
+
async getProvenCheckpointNumber() {
|
|
739
|
+
return CheckpointNumber.fromBigInt(await this.rollup.read.getProvenCheckpointNumber());
|
|
92
740
|
}
|
|
93
|
-
getSlotNumber() {
|
|
94
|
-
return this.rollup.read.getCurrentSlot();
|
|
741
|
+
async getSlotNumber() {
|
|
742
|
+
return SlotNumber.fromBigInt(await this.rollup.read.getCurrentSlot());
|
|
95
743
|
}
|
|
96
|
-
|
|
97
|
-
|
|
744
|
+
async getL1FeesAt(timestamp) {
|
|
745
|
+
const result = await this.rollup.read.getL1FeesAt([
|
|
98
746
|
timestamp
|
|
99
747
|
]);
|
|
748
|
+
return {
|
|
749
|
+
baseFee: result.baseFee,
|
|
750
|
+
blobFee: result.blobFee
|
|
751
|
+
};
|
|
752
|
+
}
|
|
753
|
+
getEthPerFeeAsset() {
|
|
754
|
+
return this.rollup.read.getEthPerFeeAsset();
|
|
755
|
+
}
|
|
756
|
+
async getCommitteeAt(timestamp) {
|
|
757
|
+
const { result } = await this.client.simulateContract({
|
|
758
|
+
address: this.address,
|
|
759
|
+
abi: RollupAbi,
|
|
760
|
+
functionName: 'getCommitteeAt',
|
|
761
|
+
args: [
|
|
762
|
+
timestamp
|
|
763
|
+
]
|
|
764
|
+
}).catch((e)=>{
|
|
765
|
+
if (e instanceof Error && e.message.includes('ValidatorSelection__InsufficientValidatorSetSize')) {
|
|
766
|
+
return {
|
|
767
|
+
result: undefined
|
|
768
|
+
};
|
|
769
|
+
}
|
|
770
|
+
throw e;
|
|
771
|
+
});
|
|
772
|
+
return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
|
|
100
773
|
}
|
|
101
|
-
getSampleSeedAt(timestamp) {
|
|
102
|
-
return this.rollup.read.getSampleSeedAt([
|
|
774
|
+
async getSampleSeedAt(timestamp) {
|
|
775
|
+
return Buffer32.fromBigInt(await this.rollup.read.getSampleSeedAt([
|
|
103
776
|
timestamp
|
|
104
|
-
]);
|
|
777
|
+
]));
|
|
105
778
|
}
|
|
106
|
-
getCurrentSampleSeed() {
|
|
107
|
-
return this.rollup.read.getCurrentSampleSeed();
|
|
779
|
+
async getCurrentSampleSeed() {
|
|
780
|
+
return Buffer32.fromBigInt(await this.rollup.read.getCurrentSampleSeed());
|
|
108
781
|
}
|
|
109
|
-
|
|
110
|
-
return this.rollup.read.
|
|
782
|
+
async getCurrentEpoch() {
|
|
783
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
|
|
111
784
|
}
|
|
112
|
-
|
|
113
|
-
|
|
785
|
+
async getCurrentEpochCommittee() {
|
|
786
|
+
const { result } = await this.client.simulateContract({
|
|
787
|
+
address: this.address,
|
|
788
|
+
abi: RollupAbi,
|
|
789
|
+
functionName: 'getCurrentEpochCommittee',
|
|
790
|
+
args: []
|
|
791
|
+
}).catch((e)=>{
|
|
792
|
+
if (e instanceof Error && e.message.includes('ValidatorSelection__InsufficientValidatorSetSize')) {
|
|
793
|
+
return {
|
|
794
|
+
result: undefined
|
|
795
|
+
};
|
|
796
|
+
}
|
|
797
|
+
throw e;
|
|
798
|
+
});
|
|
799
|
+
return result ? result.map((addr)=>EthAddress.fromString(addr)) : undefined;
|
|
114
800
|
}
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
801
|
+
async getCurrentProposer() {
|
|
802
|
+
const { result } = await this.client.simulateContract({
|
|
803
|
+
address: this.address,
|
|
804
|
+
abi: RollupAbi,
|
|
805
|
+
functionName: 'getCurrentProposer',
|
|
806
|
+
args: []
|
|
807
|
+
});
|
|
808
|
+
return EthAddress.fromString(result);
|
|
809
|
+
}
|
|
810
|
+
async getProposerAt(timestamp) {
|
|
811
|
+
const { result } = await this.client.simulateContract({
|
|
812
|
+
address: this.address,
|
|
813
|
+
abi: RollupAbi,
|
|
814
|
+
functionName: 'getProposerAt',
|
|
815
|
+
args: [
|
|
816
|
+
timestamp
|
|
817
|
+
]
|
|
818
|
+
});
|
|
819
|
+
return EthAddress.fromString(result);
|
|
119
820
|
}
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
821
|
+
async getCheckpoint(checkpointNumber) {
|
|
822
|
+
const result = await this.rollup.read.getCheckpoint([
|
|
823
|
+
BigInt(checkpointNumber)
|
|
123
824
|
]);
|
|
825
|
+
return {
|
|
826
|
+
archive: Fr.fromString(result.archive),
|
|
827
|
+
headerHash: Buffer32.fromString(result.headerHash),
|
|
828
|
+
blobCommitmentsHash: Buffer32.fromString(result.blobCommitmentsHash),
|
|
829
|
+
attestationsHash: Buffer32.fromString(result.attestationsHash),
|
|
830
|
+
payloadDigest: Buffer32.fromString(result.payloadDigest),
|
|
831
|
+
slotNumber: SlotNumber.fromBigInt(result.slotNumber),
|
|
832
|
+
feeHeader: {
|
|
833
|
+
excessMana: result.feeHeader.excessMana,
|
|
834
|
+
manaUsed: result.feeHeader.manaUsed,
|
|
835
|
+
ethPerFeeAsset: result.feeHeader.ethPerFeeAsset,
|
|
836
|
+
congestionCost: result.feeHeader.congestionCost,
|
|
837
|
+
proverCost: result.feeHeader.proverCost
|
|
838
|
+
}
|
|
839
|
+
};
|
|
840
|
+
}
|
|
841
|
+
/** Returns the pending checkpoint from the rollup contract */ getPendingCheckpoint() {
|
|
842
|
+
// We retry because of race conditions during prunes: we may get a pending checkpoint number which is immediately
|
|
843
|
+
// reorged out due to a prune happening, causing the subsequent getCheckpoint call to fail. So we try again in that case.
|
|
844
|
+
return retry(async ()=>{
|
|
845
|
+
const pendingCheckpointNumber = await this.getCheckpointNumber();
|
|
846
|
+
const pendingCheckpoint = await this.getCheckpoint(pendingCheckpointNumber);
|
|
847
|
+
return pendingCheckpoint;
|
|
848
|
+
}, 'getting pending checkpoint', makeBackoff([
|
|
849
|
+
0.5,
|
|
850
|
+
0.5,
|
|
851
|
+
0.5
|
|
852
|
+
]));
|
|
124
853
|
}
|
|
125
|
-
getTips() {
|
|
126
|
-
|
|
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
|
+
};
|
|
127
860
|
}
|
|
128
861
|
getTimestampForSlot(slot) {
|
|
129
862
|
return this.rollup.read.getTimestampForSlot([
|
|
130
|
-
slot
|
|
863
|
+
BigInt(slot)
|
|
131
864
|
]);
|
|
132
865
|
}
|
|
133
|
-
async
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
866
|
+
async getEntryQueueLength() {
|
|
867
|
+
return Number(await this.rollup.read.getEntryQueueLength());
|
|
868
|
+
}
|
|
869
|
+
async getAvailableValidatorFlushes() {
|
|
870
|
+
return Number(await this.rollup.read.getAvailableValidatorFlushes());
|
|
871
|
+
}
|
|
872
|
+
async getNextFlushableEpoch() {
|
|
873
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getNextFlushableEpoch());
|
|
874
|
+
}
|
|
875
|
+
async getCurrentEpochNumber() {
|
|
876
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getCurrentEpoch());
|
|
877
|
+
}
|
|
878
|
+
async getEpochNumberForCheckpoint(checkpointNumber) {
|
|
879
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getEpochForCheckpoint([
|
|
880
|
+
BigInt(checkpointNumber)
|
|
881
|
+
]));
|
|
138
882
|
}
|
|
139
883
|
async getRollupAddresses() {
|
|
140
|
-
const [inboxAddress, outboxAddress, feeJuicePortalAddress, rewardDistributorAddress, feeJuiceAddress, stakingAssetAddress] = (await Promise.all([
|
|
884
|
+
const [inboxAddress, outboxAddress, feeJuicePortalAddress, rewardDistributorAddress, feeJuiceAddress, stakingAssetAddress, gseAddress] = (await Promise.all([
|
|
141
885
|
this.rollup.read.getInbox(),
|
|
142
886
|
this.rollup.read.getOutbox(),
|
|
143
887
|
this.rollup.read.getFeeAssetPortal(),
|
|
144
888
|
this.rollup.read.getRewardDistributor(),
|
|
145
889
|
this.rollup.read.getFeeAsset(),
|
|
146
|
-
this.rollup.read.getStakingAsset()
|
|
890
|
+
this.rollup.read.getStakingAsset(),
|
|
891
|
+
this.rollup.read.getGSE()
|
|
147
892
|
])).map(EthAddress.fromString);
|
|
148
893
|
return {
|
|
149
894
|
rollupAddress: EthAddress.fromString(this.address),
|
|
@@ -152,20 +897,29 @@ export class RollupContract {
|
|
|
152
897
|
feeJuicePortalAddress,
|
|
153
898
|
feeJuiceAddress,
|
|
154
899
|
stakingAssetAddress,
|
|
155
|
-
rewardDistributorAddress
|
|
900
|
+
rewardDistributorAddress,
|
|
901
|
+
gseAddress
|
|
156
902
|
};
|
|
157
903
|
}
|
|
904
|
+
async getFeeJuicePortal() {
|
|
905
|
+
return EthAddress.fromString(await this.rollup.read.getFeeAssetPortal());
|
|
906
|
+
}
|
|
158
907
|
async getEpochNumberForSlotNumber(slotNumber) {
|
|
159
|
-
return await this.rollup.read.getEpochAtSlot([
|
|
160
|
-
slotNumber
|
|
161
|
-
]);
|
|
908
|
+
return EpochNumber.fromBigInt(await this.rollup.read.getEpochAtSlot([
|
|
909
|
+
BigInt(slotNumber)
|
|
910
|
+
]));
|
|
162
911
|
}
|
|
163
|
-
getEpochProofPublicInputs(args) {
|
|
164
|
-
|
|
912
|
+
async getEpochProofPublicInputs(args) {
|
|
913
|
+
const result = await this.rollup.read.getEpochProofPublicInputs(args);
|
|
914
|
+
return result.map(Fr.fromString);
|
|
165
915
|
}
|
|
166
916
|
async validateHeader(args, account) {
|
|
167
917
|
try {
|
|
168
|
-
await this.
|
|
918
|
+
await this.client.simulateContract({
|
|
919
|
+
address: this.address,
|
|
920
|
+
abi: RollupAbi,
|
|
921
|
+
functionName: 'validateHeaderWithAttestations',
|
|
922
|
+
args,
|
|
169
923
|
account
|
|
170
924
|
});
|
|
171
925
|
} catch (error) {
|
|
@@ -178,57 +932,314 @@ export class RollupContract {
|
|
|
178
932
|
* @dev Throws if unable to propose
|
|
179
933
|
*
|
|
180
934
|
* @param archive - The archive that we expect to be current state
|
|
181
|
-
* @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
|
|
182
937
|
* @throws otherwise
|
|
183
|
-
*/ async canProposeAtNextEthBlock(archive, account, slotDuration) {
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
const timeOfNextL1Slot = (await this.client.getBlock()).timestamp + slotDuration;
|
|
938
|
+
*/ async canProposeAtNextEthBlock(archive, account, slotDuration, opts = {}) {
|
|
939
|
+
const latestBlock = await this.client.getBlock();
|
|
940
|
+
const timeOfNextL1Slot = latestBlock.timestamp + BigInt(slotDuration);
|
|
941
|
+
const who = typeof account === 'string' ? account : account.address;
|
|
188
942
|
try {
|
|
189
|
-
const [slot,
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
943
|
+
const { result: [slot, checkpointNumber] } = await this.client.simulateContract({
|
|
944
|
+
address: this.address,
|
|
945
|
+
abi: RollupAbi,
|
|
946
|
+
functionName: 'canProposeAtTime',
|
|
947
|
+
args: [
|
|
948
|
+
timeOfNextL1Slot,
|
|
949
|
+
`0x${archive.toString('hex')}`,
|
|
950
|
+
who
|
|
951
|
+
],
|
|
952
|
+
account,
|
|
953
|
+
stateOverride: await this.makePendingCheckpointNumberOverride(opts.forcePendingCheckpointNumber)
|
|
194
954
|
});
|
|
195
|
-
return
|
|
196
|
-
slot,
|
|
197
|
-
|
|
198
|
-
|
|
955
|
+
return {
|
|
956
|
+
slot: SlotNumber.fromBigInt(slot),
|
|
957
|
+
checkpointNumber: CheckpointNumber.fromBigInt(checkpointNumber),
|
|
958
|
+
timeOfNextL1Slot
|
|
959
|
+
};
|
|
199
960
|
} catch (err) {
|
|
200
961
|
throw formatViemError(err);
|
|
201
962
|
}
|
|
202
963
|
}
|
|
203
|
-
/**
|
|
964
|
+
/**
|
|
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
|
|
967
|
+
* stored in the same slot. If the argument is undefined, it returns an empty override.
|
|
968
|
+
*/ async makePendingCheckpointNumberOverride(forcePendingCheckpointNumber) {
|
|
969
|
+
if (forcePendingCheckpointNumber === undefined) {
|
|
970
|
+
return [];
|
|
971
|
+
}
|
|
972
|
+
const slot = RollupContract.stfStorageSlot;
|
|
973
|
+
const currentValue = await this.client.getStorageAt({
|
|
974
|
+
address: this.address,
|
|
975
|
+
slot
|
|
976
|
+
});
|
|
977
|
+
const currentProvenCheckpointNumber = currentValue ? hexToBigInt(currentValue) & (1n << 128n) - 1n : 0n;
|
|
978
|
+
const newValue = BigInt(forcePendingCheckpointNumber) << 128n | currentProvenCheckpointNumber;
|
|
979
|
+
return [
|
|
980
|
+
{
|
|
981
|
+
address: this.address,
|
|
982
|
+
stateDiff: [
|
|
983
|
+
{
|
|
984
|
+
slot,
|
|
985
|
+
value: `0x${newValue.toString(16).padStart(64, '0')}`
|
|
986
|
+
}
|
|
987
|
+
]
|
|
988
|
+
}
|
|
989
|
+
];
|
|
990
|
+
}
|
|
991
|
+
/** Creates a request to Rollup#invalidateBadAttestation to be simulated or sent */ buildInvalidateBadAttestationRequest(checkpointNumber, attestationsAndSigners, committee, invalidIndex) {
|
|
992
|
+
return {
|
|
993
|
+
to: this.address,
|
|
994
|
+
abi: RollupAbi,
|
|
995
|
+
data: encodeFunctionData({
|
|
996
|
+
abi: RollupAbi,
|
|
997
|
+
functionName: 'invalidateBadAttestation',
|
|
998
|
+
args: [
|
|
999
|
+
BigInt(checkpointNumber),
|
|
1000
|
+
attestationsAndSigners,
|
|
1001
|
+
committee.map((addr)=>addr.toString()),
|
|
1002
|
+
BigInt(invalidIndex)
|
|
1003
|
+
]
|
|
1004
|
+
})
|
|
1005
|
+
};
|
|
1006
|
+
}
|
|
1007
|
+
/** Creates a request to Rollup#invalidateInsufficientAttestations to be simulated or sent */ buildInvalidateInsufficientAttestationsRequest(checkpointNumber, attestationsAndSigners, committee) {
|
|
1008
|
+
return {
|
|
1009
|
+
to: this.address,
|
|
1010
|
+
abi: RollupAbi,
|
|
1011
|
+
data: encodeFunctionData({
|
|
1012
|
+
abi: RollupAbi,
|
|
1013
|
+
functionName: 'invalidateInsufficientAttestations',
|
|
1014
|
+
args: [
|
|
1015
|
+
BigInt(checkpointNumber),
|
|
1016
|
+
attestationsAndSigners,
|
|
1017
|
+
committee.map((addr)=>addr.toString())
|
|
1018
|
+
]
|
|
1019
|
+
})
|
|
1020
|
+
};
|
|
1021
|
+
}
|
|
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) {
|
|
1023
|
+
if (prover instanceof EthAddress) {
|
|
1024
|
+
prover = prover.toString();
|
|
1025
|
+
}
|
|
204
1026
|
return this.rollup.read.getHasSubmitted([
|
|
205
1027
|
BigInt(epochNumber),
|
|
206
|
-
BigInt(
|
|
207
|
-
prover
|
|
1028
|
+
BigInt(numberOfCheckpointsInEpoch),
|
|
1029
|
+
prover
|
|
1030
|
+
]);
|
|
1031
|
+
}
|
|
1032
|
+
getManaMinFeeAt(timestamp, inFeeAsset) {
|
|
1033
|
+
return this.rollup.read.getManaMinFeeAt([
|
|
1034
|
+
timestamp,
|
|
1035
|
+
inFeeAsset
|
|
1036
|
+
]);
|
|
1037
|
+
}
|
|
1038
|
+
async getSlotAt(timestamp) {
|
|
1039
|
+
return SlotNumber.fromBigInt(await this.rollup.read.getSlotAt([
|
|
1040
|
+
timestamp
|
|
1041
|
+
]));
|
|
1042
|
+
}
|
|
1043
|
+
async status(checkpointNumber, options) {
|
|
1044
|
+
await checkBlockTag(options?.blockNumber, this.client);
|
|
1045
|
+
const result = await this.rollup.read.status([
|
|
1046
|
+
BigInt(checkpointNumber)
|
|
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
|
+
};
|
|
1055
|
+
}
|
|
1056
|
+
async canPruneAtTime(timestamp, options) {
|
|
1057
|
+
await checkBlockTag(options?.blockNumber, this.client);
|
|
1058
|
+
return this.rollup.read.canPruneAtTime([
|
|
1059
|
+
timestamp
|
|
1060
|
+
], options);
|
|
1061
|
+
}
|
|
1062
|
+
async archive() {
|
|
1063
|
+
return Fr.fromString(await this.rollup.read.archive());
|
|
1064
|
+
}
|
|
1065
|
+
async archiveAt(checkpointNumber) {
|
|
1066
|
+
return Fr.fromString(await this.rollup.read.archiveAt([
|
|
1067
|
+
BigInt(checkpointNumber)
|
|
1068
|
+
]));
|
|
1069
|
+
}
|
|
1070
|
+
getSequencerRewards(address) {
|
|
1071
|
+
if (address instanceof EthAddress) {
|
|
1072
|
+
address = address.toString();
|
|
1073
|
+
}
|
|
1074
|
+
return this.rollup.read.getSequencerRewards([
|
|
1075
|
+
address
|
|
1076
|
+
]);
|
|
1077
|
+
}
|
|
1078
|
+
getSpecificProverRewardsForEpoch(epoch, prover) {
|
|
1079
|
+
if (prover instanceof EthAddress) {
|
|
1080
|
+
prover = prover.toString();
|
|
1081
|
+
}
|
|
1082
|
+
return this.rollup.read.getSpecificProverRewardsForEpoch([
|
|
1083
|
+
epoch,
|
|
1084
|
+
prover
|
|
1085
|
+
]);
|
|
1086
|
+
}
|
|
1087
|
+
async getAttesters() {
|
|
1088
|
+
const attesterSize = await this.getActiveAttesterCount();
|
|
1089
|
+
const gse = new GSEContract(this.client, await this.getGSE());
|
|
1090
|
+
const ts = (await this.client.getBlock()).timestamp;
|
|
1091
|
+
const indices = Array.from({
|
|
1092
|
+
length: attesterSize
|
|
1093
|
+
}, (_, i)=>BigInt(i));
|
|
1094
|
+
const chunks = chunk(indices, 1000);
|
|
1095
|
+
const results = await Promise.all(chunks.map((chunk)=>gse.getAttestersFromIndicesAtTime(this.address, ts, chunk)));
|
|
1096
|
+
return results.flat().map((addr)=>EthAddress.fromString(addr));
|
|
1097
|
+
}
|
|
1098
|
+
async getAttesterView(address) {
|
|
1099
|
+
if (address instanceof EthAddress) {
|
|
1100
|
+
address = address.toString();
|
|
1101
|
+
}
|
|
1102
|
+
const result = await this.rollup.read.getAttesterView([
|
|
1103
|
+
address
|
|
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
|
+
};
|
|
1124
|
+
}
|
|
1125
|
+
async getStatus(address) {
|
|
1126
|
+
if (address instanceof EthAddress) {
|
|
1127
|
+
address = address.toString();
|
|
1128
|
+
}
|
|
1129
|
+
return await this.rollup.read.getStatus([
|
|
1130
|
+
address
|
|
208
1131
|
]);
|
|
209
1132
|
}
|
|
1133
|
+
async getBlobCommitmentsHash(checkpointNumber) {
|
|
1134
|
+
return Buffer32.fromString(await this.rollup.read.getBlobCommitmentsHash([
|
|
1135
|
+
BigInt(checkpointNumber)
|
|
1136
|
+
]));
|
|
1137
|
+
}
|
|
1138
|
+
async getCurrentBlobCommitmentsHash() {
|
|
1139
|
+
return Buffer32.fromString(await this.rollup.read.getCurrentBlobCommitmentsHash());
|
|
1140
|
+
}
|
|
1141
|
+
async getStakingAsset() {
|
|
1142
|
+
return EthAddress.fromString(await this.rollup.read.getStakingAsset());
|
|
1143
|
+
}
|
|
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
|
+
};
|
|
1152
|
+
}
|
|
1153
|
+
setupEpoch(l1TxUtils) {
|
|
1154
|
+
return l1TxUtils.sendAndMonitorTransaction({
|
|
1155
|
+
to: this.address,
|
|
1156
|
+
abi: RollupAbi,
|
|
1157
|
+
data: encodeFunctionData({
|
|
1158
|
+
abi: RollupAbi,
|
|
1159
|
+
functionName: 'setupEpoch',
|
|
1160
|
+
args: []
|
|
1161
|
+
})
|
|
1162
|
+
});
|
|
1163
|
+
}
|
|
1164
|
+
vote(l1TxUtils, proposalId) {
|
|
1165
|
+
return l1TxUtils.sendAndMonitorTransaction({
|
|
1166
|
+
to: this.address,
|
|
1167
|
+
abi: RollupAbi,
|
|
1168
|
+
data: encodeFunctionData({
|
|
1169
|
+
abi: RollupAbi,
|
|
1170
|
+
functionName: 'vote',
|
|
1171
|
+
args: [
|
|
1172
|
+
proposalId
|
|
1173
|
+
]
|
|
1174
|
+
})
|
|
1175
|
+
});
|
|
1176
|
+
}
|
|
1177
|
+
listenToSlasherChanged(callback) {
|
|
1178
|
+
return this.rollup.watchEvent.SlasherUpdated({}, {
|
|
1179
|
+
onLogs: (logs)=>{
|
|
1180
|
+
for (const log of logs){
|
|
1181
|
+
const args = log.args;
|
|
1182
|
+
if (args.oldSlasher && args.newSlasher) {
|
|
1183
|
+
callback(args);
|
|
1184
|
+
}
|
|
1185
|
+
}
|
|
1186
|
+
}
|
|
1187
|
+
});
|
|
1188
|
+
}
|
|
1189
|
+
listenToCheckpointInvalidated(callback) {
|
|
1190
|
+
return this.rollup.watchEvent.CheckpointInvalidated({}, {
|
|
1191
|
+
onLogs: (logs)=>{
|
|
1192
|
+
for (const log of logs){
|
|
1193
|
+
const args = log.args;
|
|
1194
|
+
if (args.checkpointNumber !== undefined) {
|
|
1195
|
+
callback({
|
|
1196
|
+
checkpointNumber: CheckpointNumber.fromBigInt(args.checkpointNumber)
|
|
1197
|
+
});
|
|
1198
|
+
}
|
|
1199
|
+
}
|
|
1200
|
+
}
|
|
1201
|
+
});
|
|
1202
|
+
}
|
|
1203
|
+
async getSlashEvents(l1BlockHash) {
|
|
1204
|
+
const events = await this.rollup.getEvents.Slashed({}, {
|
|
1205
|
+
blockHash: l1BlockHash,
|
|
1206
|
+
strict: true
|
|
1207
|
+
});
|
|
1208
|
+
return events.map((event)=>({
|
|
1209
|
+
amount: event.args.amount,
|
|
1210
|
+
attester: EthAddress.fromString(event.args.attester)
|
|
1211
|
+
}));
|
|
1212
|
+
}
|
|
1213
|
+
listenToSlash(callback) {
|
|
1214
|
+
return this.rollup.watchEvent.Slashed({}, {
|
|
1215
|
+
strict: true,
|
|
1216
|
+
onLogs: (logs)=>{
|
|
1217
|
+
for (const log of logs){
|
|
1218
|
+
const args = log.args;
|
|
1219
|
+
callback({
|
|
1220
|
+
amount: args.amount,
|
|
1221
|
+
attester: EthAddress.fromString(args.attester)
|
|
1222
|
+
});
|
|
1223
|
+
}
|
|
1224
|
+
}
|
|
1225
|
+
});
|
|
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
|
+
}
|
|
210
1245
|
}
|
|
211
|
-
_ts_decorate([
|
|
212
|
-
memoize
|
|
213
|
-
], RollupContract.prototype, "getSlashingProposer", null);
|
|
214
|
-
_ts_decorate([
|
|
215
|
-
memoize
|
|
216
|
-
], RollupContract.prototype, "getL1StartBlock", null);
|
|
217
|
-
_ts_decorate([
|
|
218
|
-
memoize
|
|
219
|
-
], RollupContract.prototype, "getL1GenesisTime", null);
|
|
220
|
-
_ts_decorate([
|
|
221
|
-
memoize
|
|
222
|
-
], RollupContract.prototype, "getProofSubmissionWindow", null);
|
|
223
|
-
_ts_decorate([
|
|
224
|
-
memoize
|
|
225
|
-
], RollupContract.prototype, "getEpochDuration", null);
|
|
226
|
-
_ts_decorate([
|
|
227
|
-
memoize
|
|
228
|
-
], RollupContract.prototype, "getSlotDuration", null);
|
|
229
|
-
_ts_decorate([
|
|
230
|
-
memoize
|
|
231
|
-
], RollupContract.prototype, "getTargetCommitteeSize", null);
|
|
232
|
-
_ts_decorate([
|
|
233
|
-
memoize
|
|
234
|
-
], RollupContract.prototype, "getMinimumStake", null);
|