@aztec/ethereum 0.0.0-test.1 → 0.0.1-commit.03f7ef2
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 +71 -16
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +138 -22
- 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 +209 -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 +19 -0
- package/dest/contracts/fee_asset_handler.d.ts.map +1 -0
- package/dest/contracts/fee_asset_handler.js +57 -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 +43 -32
- package/dest/contracts/governance.d.ts.map +1 -1
- package/dest/contracts/governance.js +87 -84
- 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 +46 -17
- 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 +26 -0
- package/dest/contracts/inbox.d.ts.map +1 -0
- package/dest/contracts/inbox.js +45 -0
- package/dest/contracts/index.d.ts +9 -3
- package/dest/contracts/index.d.ts.map +1 -1
- package/dest/contracts/index.js +8 -2
- package/dest/contracts/multicall.d.ts +21 -0
- package/dest/contracts/multicall.d.ts.map +1 -0
- package/dest/contracts/multicall.js +156 -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 +221 -41
- package/dest/contracts/rollup.d.ts.map +1 -1
- package/dest/contracts/rollup.js +549 -81
- 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 +313 -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 +245 -0
- package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
- package/dest/deploy_aztec_l1_contracts.js +335 -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/l1_artifacts.d.ts +77364 -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 +9 -0
- package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/index.js +11 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +18 -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 +111 -0
- package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +32 -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 +173 -0
- package/dest/l1_tx_utils/fee-strategies/types.d.ts +64 -0
- package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
- package/dest/l1_tx_utils/fee-strategies/types.js +24 -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 +87 -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 +360 -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 +15 -0
- package/dest/publisher_manager.d.ts.map +1 -0
- package/dest/publisher_manager.js +88 -0
- package/dest/queries.d.ts +4 -2
- package/dest/queries.d.ts.map +1 -1
- package/dest/queries.js +53 -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 +214 -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 +217 -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 +87 -0
- package/dest/test/rollup_cheat_codes.d.ts.map +1 -0
- package/dest/test/rollup_cheat_codes.js +275 -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 +16 -3
- package/dest/utils.d.ts.map +1 -1
- package/dest/utils.js +61 -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 +50 -23
- package/src/account.ts +5 -0
- package/src/client.ts +43 -5
- package/src/config.ts +188 -31
- package/src/contracts/empire_base.ts +77 -7
- package/src/contracts/empire_slashing_proposer.ts +270 -0
- package/src/contracts/errors.ts +13 -0
- package/src/contracts/fee_asset_handler.ts +63 -0
- package/src/contracts/fee_juice.ts +29 -15
- package/src/contracts/governance.ts +80 -77
- package/src/contracts/governance_proposer.ts +71 -24
- package/src/contracts/gse.ts +88 -0
- package/src/contracts/inbox.ts +63 -0
- package/src/contracts/index.ts +8 -2
- package/src/contracts/multicall.ts +155 -0
- package/src/contracts/registry.ts +51 -26
- package/src/contracts/rollup.ts +624 -78
- package/src/contracts/slasher_contract.ts +89 -0
- package/src/contracts/tally_slashing_proposer.ts +318 -0
- package/src/contracts/utils.ts +14 -0
- package/src/deploy_aztec_l1_contracts.ts +556 -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/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 +159 -0
- package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +241 -0
- package/src/l1_tx_utils/fee-strategies/types.ts +88 -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 +804 -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 +458 -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 +106 -0
- package/src/queries.ts +73 -15
- 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 +312 -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 +79 -91
- 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
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"zkPassportVerifierAddress.d.ts","sourceRoot":"","sources":["../src/zkPassportVerifierAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAE3D;;;GAGG;AACH,eAAO,MAAM,4BAA4B,YAAsE,CAAC;AAChH;;GAEG;AACH,eAAO,MAAM,kBAAkB,0BAA0B,CAAC;AAC1D;;GAEG;AACH,eAAO,MAAM,iBAAiB,eAAe,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
2
|
+
/**
|
|
3
|
+
* The address of the zk passport verifier on sepolia
|
|
4
|
+
* get address from: ROOT/l1-contracts/lib/circuits/src/solidity/deployments/deployment-11155111.json
|
|
5
|
+
*/ export const ZK_PASSPORT_VERIFIER_ADDRESS = EthAddress.fromString('0x3101Bad9eA5fACadA5554844a1a88F7Fe48D4DE0');
|
|
6
|
+
/**
|
|
7
|
+
* The default domain of the zk passport site
|
|
8
|
+
*/ export const ZK_PASSPORT_DOMAIN = 'testnet.aztec.network';
|
|
9
|
+
/**
|
|
10
|
+
* The default scope of the zk passport proofs
|
|
11
|
+
*/ export const ZK_PASSPORT_SCOPE = 'personhood';
|
package/package.json
CHANGED
|
@@ -1,15 +1,32 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/ethereum",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.1-commit.03f7ef2",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": {
|
|
6
|
-
"
|
|
7
|
-
"./
|
|
8
|
-
"./
|
|
6
|
+
"./account": "./dest/account.js",
|
|
7
|
+
"./chain": "./dest/chain.js",
|
|
8
|
+
"./client": "./dest/client.js",
|
|
9
|
+
"./config": "./dest/config.js",
|
|
10
|
+
"./constants": "./dest/constants.js",
|
|
9
11
|
"./contracts": "./dest/contracts/index.js",
|
|
10
|
-
"./deploy-l1-contracts": "./dest/
|
|
12
|
+
"./deploy-aztec-l1-contracts": "./dest/deploy_aztec_l1_contracts.js",
|
|
13
|
+
"./deploy-l1-contract": "./dest/deploy_l1_contract.js",
|
|
14
|
+
"./contracts/registry": "./dest/contracts/registry.js",
|
|
15
|
+
"./contracts/rollup": "./dest/contracts/rollup.js",
|
|
16
|
+
"./eth-signer": "./dest/eth-signer/index.js",
|
|
17
|
+
"./forwarder-proxy": "./dest/forwarder_proxy.js",
|
|
18
|
+
"./l1-artifacts": "./dest/l1_artifacts.js",
|
|
11
19
|
"./l1-contract-addresses": "./dest/l1_contract_addresses.js",
|
|
12
|
-
"./l1-
|
|
20
|
+
"./l1-fee-analysis": "./dest/l1_tx_utils/l1_fee_analyzer.js",
|
|
21
|
+
"./l1-reader": "./dest/l1_reader.js",
|
|
22
|
+
"./l1-tx-utils": "./dest/l1_tx_utils/index.js",
|
|
23
|
+
"./l1-tx-utils-with-blobs": "./dest/l1_tx_utils/index-blobs.js",
|
|
24
|
+
"./l1-tx-utils/config": "./dest/l1_tx_utils/config.js",
|
|
25
|
+
"./l1-types": "./dest/l1_types.js",
|
|
26
|
+
"./publisher-manager": "./dest/publisher_manager.js",
|
|
27
|
+
"./queries": "./dest/queries.js",
|
|
28
|
+
"./test": "./dest/test/index.js",
|
|
29
|
+
"./types": "./dest/types.js",
|
|
13
30
|
"./utils": "./dest/utils.js"
|
|
14
31
|
},
|
|
15
32
|
"typedocOptions": {
|
|
@@ -20,45 +37,51 @@
|
|
|
20
37
|
"tsconfig": "./tsconfig.json"
|
|
21
38
|
},
|
|
22
39
|
"scripts": {
|
|
23
|
-
"build": "yarn clean && tsc
|
|
24
|
-
"build:dev": "tsc
|
|
40
|
+
"build": "yarn clean && ../scripts/tsc.sh",
|
|
41
|
+
"build:dev": "../scripts/tsc.sh --watch",
|
|
25
42
|
"clean": "rm -rf ./dest .tsbuildinfo",
|
|
26
|
-
"
|
|
27
|
-
"formatting:fix": "run -T eslint --fix ./src && run -T prettier -w ./src",
|
|
28
|
-
"start:dev": "tsc-watch -p tsconfig.json --onSuccess 'yarn start'",
|
|
43
|
+
"start:dev": "concurrently -k \"tsgo -b -w\" \"nodemon --watch dest --exec yarn start\"",
|
|
29
44
|
"start": "node ./dest/index.js",
|
|
30
|
-
"test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}"
|
|
45
|
+
"test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}",
|
|
46
|
+
"proposer-address": "node ./dest/cli/forwarder_address.js"
|
|
31
47
|
},
|
|
32
48
|
"inherits": [
|
|
33
49
|
"../package.common.json"
|
|
34
50
|
],
|
|
35
51
|
"dependencies": {
|
|
36
|
-
"@aztec/blob-lib": "0.0.
|
|
37
|
-
"@aztec/
|
|
38
|
-
"@aztec/
|
|
52
|
+
"@aztec/blob-lib": "0.0.1-commit.03f7ef2",
|
|
53
|
+
"@aztec/constants": "0.0.1-commit.03f7ef2",
|
|
54
|
+
"@aztec/foundation": "0.0.1-commit.03f7ef2",
|
|
55
|
+
"@aztec/l1-artifacts": "0.0.1-commit.03f7ef2",
|
|
39
56
|
"@viem/anvil": "^0.0.10",
|
|
40
57
|
"dotenv": "^16.0.3",
|
|
58
|
+
"lodash.chunk": "^4.2.0",
|
|
59
|
+
"lodash.pickby": "^4.5.0",
|
|
41
60
|
"tslib": "^2.4.0",
|
|
42
|
-
"viem": "2.
|
|
61
|
+
"viem": "npm:@aztec/viem@2.38.2",
|
|
43
62
|
"zod": "^3.23.8"
|
|
44
63
|
},
|
|
45
64
|
"devDependencies": {
|
|
46
|
-
"@jest/globals": "^
|
|
47
|
-
"@
|
|
48
|
-
"@types/
|
|
65
|
+
"@jest/globals": "^30.0.0",
|
|
66
|
+
"@noble/curves": "=1.7.0",
|
|
67
|
+
"@types/jest": "^30.0.0",
|
|
68
|
+
"@types/lodash.pickby": "^4",
|
|
69
|
+
"@types/node": "^22.15.17",
|
|
70
|
+
"@typescript/native-preview": "7.0.0-dev.20251126.1",
|
|
49
71
|
"@viem/anvil": "^0.0.10",
|
|
50
72
|
"get-port": "^7.1.0",
|
|
51
|
-
"jest": "^
|
|
73
|
+
"jest": "^30.0.0",
|
|
74
|
+
"jest-mock-extended": "^4.0.0",
|
|
52
75
|
"lodash.omit": "^4.5.0",
|
|
53
76
|
"ts-node": "^10.9.1",
|
|
54
|
-
"typescript": "^5.
|
|
77
|
+
"typescript": "^5.3.3"
|
|
55
78
|
},
|
|
56
79
|
"files": [
|
|
57
80
|
"dest",
|
|
58
81
|
"src",
|
|
59
82
|
"!*.test.*"
|
|
60
83
|
],
|
|
61
|
-
"types": "./dest/
|
|
84
|
+
"types": "./dest/types.d.ts",
|
|
62
85
|
"jest": {
|
|
63
86
|
"moduleNameMapper": {
|
|
64
87
|
"^(\\.{1,2}/.*)\\.[cm]?js$": "$1"
|
|
@@ -90,9 +113,13 @@
|
|
|
90
113
|
"testTimeout": 120000,
|
|
91
114
|
"setupFiles": [
|
|
92
115
|
"../../foundation/src/jest/setup.mjs"
|
|
116
|
+
],
|
|
117
|
+
"testEnvironment": "../../foundation/src/jest/env.mjs",
|
|
118
|
+
"setupFilesAfterEnv": [
|
|
119
|
+
"../../foundation/src/jest/setupAfterEnv.mjs"
|
|
93
120
|
]
|
|
94
121
|
},
|
|
95
122
|
"engines": {
|
|
96
|
-
"node": ">=
|
|
123
|
+
"node": ">=20.10"
|
|
97
124
|
}
|
|
98
125
|
}
|
package/src/account.ts
ADDED
package/src/client.ts
CHANGED
|
@@ -1,13 +1,25 @@
|
|
|
1
1
|
import type { Logger } from '@aztec/foundation/log';
|
|
2
2
|
import { retryUntil } from '@aztec/foundation/retry';
|
|
3
3
|
|
|
4
|
-
import {
|
|
4
|
+
import {
|
|
5
|
+
type Chain,
|
|
6
|
+
type HDAccount,
|
|
7
|
+
type LocalAccount,
|
|
8
|
+
type PrivateKeyAccount,
|
|
9
|
+
createPublicClient,
|
|
10
|
+
createWalletClient,
|
|
11
|
+
fallback,
|
|
12
|
+
http,
|
|
13
|
+
publicActions,
|
|
14
|
+
} from 'viem';
|
|
15
|
+
import { mnemonicToAccount, privateKeyToAccount } from 'viem/accounts';
|
|
16
|
+
import { foundry } from 'viem/chains';
|
|
5
17
|
|
|
6
18
|
import { createEthereumChain } from './chain.js';
|
|
7
|
-
import type { ViemPublicClient } from './types.js';
|
|
19
|
+
import type { ExtendedViemWalletClient, ViemPublicClient } from './types.js';
|
|
8
20
|
|
|
9
21
|
type Config = {
|
|
10
|
-
/**
|
|
22
|
+
/** List of URLs of Ethereum RPC nodes that services will connect to (comma separated). */
|
|
11
23
|
l1RpcUrls: string[];
|
|
12
24
|
/** The chain ID of the ethereum host. */
|
|
13
25
|
l1ChainId: number;
|
|
@@ -15,6 +27,8 @@ type Config = {
|
|
|
15
27
|
viemPollingIntervalMS?: number;
|
|
16
28
|
};
|
|
17
29
|
|
|
30
|
+
export type { Config as EthereumClientConfig };
|
|
31
|
+
|
|
18
32
|
// TODO: Use these methods to abstract the creation of viem clients.
|
|
19
33
|
|
|
20
34
|
/** Returns a viem public client given the L1 config. */
|
|
@@ -22,7 +36,7 @@ export function getPublicClient(config: Config): ViemPublicClient {
|
|
|
22
36
|
const chain = createEthereumChain(config.l1RpcUrls, config.l1ChainId);
|
|
23
37
|
return createPublicClient({
|
|
24
38
|
chain: chain.chainInfo,
|
|
25
|
-
transport: fallback(config.l1RpcUrls.map(url => http(url))),
|
|
39
|
+
transport: fallback(config.l1RpcUrls.map(url => http(url, { batch: false }))),
|
|
26
40
|
pollingInterval: config.viemPollingIntervalMS,
|
|
27
41
|
});
|
|
28
42
|
}
|
|
@@ -40,7 +54,7 @@ async function waitForRpc(client: ViemPublicClient, config: Config, logger?: Log
|
|
|
40
54
|
let chainId = 0;
|
|
41
55
|
try {
|
|
42
56
|
chainId = await client.getChainId();
|
|
43
|
-
} catch
|
|
57
|
+
} catch {
|
|
44
58
|
logger?.warn(`Failed to connect to Ethereum node at ${config.l1RpcUrls.join(', ')}. Retrying...`);
|
|
45
59
|
}
|
|
46
60
|
return chainId;
|
|
@@ -56,3 +70,27 @@ async function waitForRpc(client: ViemPublicClient, config: Config, logger?: Log
|
|
|
56
70
|
);
|
|
57
71
|
}
|
|
58
72
|
}
|
|
73
|
+
|
|
74
|
+
export function createExtendedL1Client(
|
|
75
|
+
rpcUrls: string[],
|
|
76
|
+
mnemonicOrPrivateKeyOrHdAccount: string | HDAccount | PrivateKeyAccount | LocalAccount,
|
|
77
|
+
chain: Chain = foundry,
|
|
78
|
+
pollingIntervalMS?: number,
|
|
79
|
+
addressIndex?: number,
|
|
80
|
+
): ExtendedViemWalletClient {
|
|
81
|
+
const hdAccount =
|
|
82
|
+
typeof mnemonicOrPrivateKeyOrHdAccount === 'string'
|
|
83
|
+
? mnemonicOrPrivateKeyOrHdAccount.startsWith('0x')
|
|
84
|
+
? privateKeyToAccount(mnemonicOrPrivateKeyOrHdAccount as `0x${string}`)
|
|
85
|
+
: mnemonicToAccount(mnemonicOrPrivateKeyOrHdAccount, { addressIndex })
|
|
86
|
+
: mnemonicOrPrivateKeyOrHdAccount;
|
|
87
|
+
|
|
88
|
+
const extendedClient = createWalletClient({
|
|
89
|
+
account: hdAccount,
|
|
90
|
+
chain,
|
|
91
|
+
transport: fallback(rpcUrls.map(url => http(url, { batch: false }))),
|
|
92
|
+
pollingInterval: pollingIntervalMS,
|
|
93
|
+
}).extend(publicActions);
|
|
94
|
+
|
|
95
|
+
return extendedClient;
|
|
96
|
+
}
|
package/src/config.ts
CHANGED
|
@@ -1,11 +1,23 @@
|
|
|
1
1
|
import {
|
|
2
2
|
type ConfigMappingsType,
|
|
3
|
+
// type NetworkNames,
|
|
3
4
|
bigintConfigHelper,
|
|
5
|
+
booleanConfigHelper,
|
|
6
|
+
enumConfigHelper,
|
|
4
7
|
getConfigFromMappings,
|
|
5
8
|
numberConfigHelper,
|
|
9
|
+
optionalNumberConfigHelper,
|
|
6
10
|
} from '@aztec/foundation/config';
|
|
11
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
7
12
|
|
|
8
|
-
import { type L1TxUtilsConfig, l1TxUtilsConfigMappings } from './l1_tx_utils.js';
|
|
13
|
+
import { type L1TxUtilsConfig, l1TxUtilsConfigMappings } from './l1_tx_utils/config.js';
|
|
14
|
+
|
|
15
|
+
export type GenesisStateConfig = {
|
|
16
|
+
/** Whether to populate the genesis state with initial fee juice for the test accounts */
|
|
17
|
+
testAccounts: boolean;
|
|
18
|
+
/** Whether to populate the genesis state with initial fee juice for the sponsored FPC */
|
|
19
|
+
sponsoredFPC: boolean;
|
|
20
|
+
};
|
|
9
21
|
|
|
10
22
|
export type L1ContractsConfig = {
|
|
11
23
|
/** How many seconds an L1 slot lasts. */
|
|
@@ -16,31 +28,77 @@ export type L1ContractsConfig = {
|
|
|
16
28
|
aztecEpochDuration: number;
|
|
17
29
|
/** The target validator committee size. */
|
|
18
30
|
aztecTargetCommitteeSize: number;
|
|
19
|
-
/** The number of
|
|
20
|
-
|
|
31
|
+
/** The number of epochs to lag behind the current epoch for validator selection. */
|
|
32
|
+
lagInEpochsForValidatorSet: number;
|
|
33
|
+
/** The number of epochs to lag behind the current epoch for randao selection. */
|
|
34
|
+
lagInEpochsForRandao: number;
|
|
35
|
+
/** The number of epochs after an epoch ends that proofs are still accepted. */
|
|
36
|
+
aztecProofSubmissionEpochs: number;
|
|
37
|
+
/** The deposit amount for a validator */
|
|
38
|
+
activationThreshold: bigint;
|
|
21
39
|
/** The minimum stake for a validator. */
|
|
22
|
-
|
|
23
|
-
/** The
|
|
24
|
-
|
|
25
|
-
/** The slashing round
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
|
|
40
|
+
ejectionThreshold: bigint;
|
|
41
|
+
/** The local ejection threshold for a validator. Stricter than ejectionThreshold but local to a specific rollup */
|
|
42
|
+
localEjectionThreshold: bigint;
|
|
43
|
+
/** The slashing quorum, i.e. how many slots must signal for the same payload in a round for it to be submittable to the Slasher (defaults to slashRoundSize / 2 + 1) */
|
|
44
|
+
slashingQuorum?: number;
|
|
45
|
+
/** The slashing round size, i.e. how many epochs are in a slashing round */
|
|
46
|
+
slashingRoundSizeInEpochs: number;
|
|
47
|
+
/** The slashing lifetime in rounds. I.e., if 1, round N must be submitted before round N + 2 */
|
|
48
|
+
slashingLifetimeInRounds: number;
|
|
49
|
+
/** The slashing execution delay in rounds. I.e., if 1, round N may not be submitted until round N + 2 */
|
|
50
|
+
slashingExecutionDelayInRounds: number;
|
|
51
|
+
/** The slashing vetoer. May blacklist a payload from being submitted. */
|
|
52
|
+
slashingVetoer: EthAddress;
|
|
53
|
+
/** How many slashing rounds back we slash (ie when slashing in round N, we slash for offenses committed during epochs of round N-offset) */
|
|
54
|
+
slashingOffsetInRounds: number;
|
|
55
|
+
/** How long slashing can be disabled for in seconds when vetoer disables it */
|
|
56
|
+
slashingDisableDuration: number;
|
|
57
|
+
/** Type of slasher proposer */
|
|
58
|
+
slasherFlavor: 'empire' | 'tally' | 'none';
|
|
59
|
+
/** Minimum amount that can be slashed in tally slashing */
|
|
60
|
+
slashAmountSmall: bigint;
|
|
61
|
+
/** Medium amount to slash in tally slashing */
|
|
62
|
+
slashAmountMedium: bigint;
|
|
63
|
+
/** Largest amount that can be slashed per round in tally slashing */
|
|
64
|
+
slashAmountLarge: bigint;
|
|
65
|
+
/** Governance proposing quorum (defaults to roundSize/2 + 1) */
|
|
66
|
+
governanceProposerQuorum?: number;
|
|
29
67
|
/** Governance proposing round size */
|
|
30
68
|
governanceProposerRoundSize: number;
|
|
69
|
+
/** The mana target for the rollup */
|
|
70
|
+
manaTarget: bigint;
|
|
71
|
+
/** The proving cost per mana */
|
|
72
|
+
provingCostPerMana: bigint;
|
|
73
|
+
/** The number of seconds to wait for an exit */
|
|
74
|
+
exitDelaySeconds: number;
|
|
31
75
|
} & L1TxUtilsConfig;
|
|
32
76
|
|
|
33
77
|
export const DefaultL1ContractsConfig = {
|
|
34
78
|
ethereumSlotDuration: 12,
|
|
35
|
-
aztecSlotDuration:
|
|
36
|
-
aztecEpochDuration:
|
|
79
|
+
aztecSlotDuration: 36,
|
|
80
|
+
aztecEpochDuration: 32,
|
|
37
81
|
aztecTargetCommitteeSize: 48,
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
82
|
+
lagInEpochsForValidatorSet: 2,
|
|
83
|
+
lagInEpochsForRandao: 2, // For PROD, this value should be > lagInEpochsForValidatorSet
|
|
84
|
+
aztecProofSubmissionEpochs: 1, // you have a full epoch to submit a proof after the epoch to prove ends
|
|
85
|
+
activationThreshold: 100n * 10n ** 18n,
|
|
86
|
+
ejectionThreshold: 50n * 10n ** 18n,
|
|
87
|
+
localEjectionThreshold: 98n * 10n ** 18n,
|
|
88
|
+
slashAmountSmall: 10n * 10n ** 18n,
|
|
89
|
+
slashAmountMedium: 20n * 10n ** 18n,
|
|
90
|
+
slashAmountLarge: 50n * 10n ** 18n,
|
|
91
|
+
slashingRoundSizeInEpochs: 4,
|
|
92
|
+
slashingLifetimeInRounds: 5,
|
|
93
|
+
slashingExecutionDelayInRounds: 0, // round N may be submitted in round N + 1
|
|
94
|
+
slashingVetoer: EthAddress.ZERO,
|
|
95
|
+
governanceProposerRoundSize: 300,
|
|
96
|
+
manaTarget: BigInt(100e6),
|
|
97
|
+
provingCostPerMana: BigInt(100),
|
|
98
|
+
exitDelaySeconds: 2 * 24 * 60 * 60,
|
|
99
|
+
slasherFlavor: 'tally' as const,
|
|
100
|
+
slashingOffsetInRounds: 2,
|
|
101
|
+
slashingDisableDuration: 5 * 24 * 60 * 60, // 5 days in seconds
|
|
44
102
|
} satisfies L1ContractsConfig;
|
|
45
103
|
|
|
46
104
|
export const l1ContractsConfigMappings: ConfigMappingsType<L1ContractsConfig> = {
|
|
@@ -64,40 +122,139 @@ export const l1ContractsConfigMappings: ConfigMappingsType<L1ContractsConfig> =
|
|
|
64
122
|
description: 'The target validator committee size.',
|
|
65
123
|
...numberConfigHelper(DefaultL1ContractsConfig.aztecTargetCommitteeSize),
|
|
66
124
|
},
|
|
67
|
-
|
|
68
|
-
env: '
|
|
69
|
-
description:
|
|
70
|
-
|
|
71
|
-
|
|
125
|
+
lagInEpochsForValidatorSet: {
|
|
126
|
+
env: 'AZTEC_LAG_IN_EPOCHS_FOR_VALIDATOR_SET',
|
|
127
|
+
description: 'The number of epochs to lag behind the current epoch for validator selection.',
|
|
128
|
+
...numberConfigHelper(DefaultL1ContractsConfig.lagInEpochsForValidatorSet),
|
|
129
|
+
},
|
|
130
|
+
lagInEpochsForRandao: {
|
|
131
|
+
env: 'AZTEC_LAG_IN_EPOCHS_FOR_RANDAO',
|
|
132
|
+
description: 'The number of epochs to lag behind the current epoch for randao selection.',
|
|
133
|
+
...numberConfigHelper(DefaultL1ContractsConfig.lagInEpochsForRandao),
|
|
72
134
|
},
|
|
73
|
-
|
|
74
|
-
env: '
|
|
135
|
+
aztecProofSubmissionEpochs: {
|
|
136
|
+
env: 'AZTEC_PROOF_SUBMISSION_EPOCHS',
|
|
137
|
+
description: 'The number of epochs after an epoch ends that proofs are still accepted.',
|
|
138
|
+
...numberConfigHelper(DefaultL1ContractsConfig.aztecProofSubmissionEpochs),
|
|
139
|
+
},
|
|
140
|
+
activationThreshold: {
|
|
141
|
+
env: 'AZTEC_ACTIVATION_THRESHOLD',
|
|
142
|
+
description: 'The deposit amount for a validator',
|
|
143
|
+
...bigintConfigHelper(DefaultL1ContractsConfig.activationThreshold),
|
|
144
|
+
},
|
|
145
|
+
ejectionThreshold: {
|
|
146
|
+
env: 'AZTEC_EJECTION_THRESHOLD',
|
|
75
147
|
description: 'The minimum stake for a validator.',
|
|
76
|
-
...bigintConfigHelper(DefaultL1ContractsConfig.
|
|
148
|
+
...bigintConfigHelper(DefaultL1ContractsConfig.ejectionThreshold),
|
|
149
|
+
},
|
|
150
|
+
localEjectionThreshold: {
|
|
151
|
+
env: 'AZTEC_LOCAL_EJECTION_THRESHOLD',
|
|
152
|
+
description:
|
|
153
|
+
'The local ejection threshold for a validator. Stricter than ejectionThreshold but local to a specific rollup',
|
|
154
|
+
...bigintConfigHelper(DefaultL1ContractsConfig.localEjectionThreshold),
|
|
155
|
+
},
|
|
156
|
+
slashingOffsetInRounds: {
|
|
157
|
+
env: 'AZTEC_SLASHING_OFFSET_IN_ROUNDS',
|
|
158
|
+
description:
|
|
159
|
+
'How many slashing rounds back we slash (ie when slashing in round N, we slash for offenses committed during epochs of round N-offset)',
|
|
160
|
+
...numberConfigHelper(DefaultL1ContractsConfig.slashingOffsetInRounds),
|
|
161
|
+
},
|
|
162
|
+
slasherFlavor: {
|
|
163
|
+
env: 'AZTEC_SLASHER_FLAVOR',
|
|
164
|
+
description: 'Type of slasher proposer (empire, tally, or none)',
|
|
165
|
+
...enumConfigHelper(['empire', 'tally', 'none'] as const, DefaultL1ContractsConfig.slasherFlavor),
|
|
166
|
+
},
|
|
167
|
+
slashAmountSmall: {
|
|
168
|
+
env: 'AZTEC_SLASH_AMOUNT_SMALL',
|
|
169
|
+
description: 'Small slashing amount for light offenses',
|
|
170
|
+
...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountSmall),
|
|
171
|
+
},
|
|
172
|
+
slashAmountMedium: {
|
|
173
|
+
env: 'AZTEC_SLASH_AMOUNT_MEDIUM',
|
|
174
|
+
description: 'Medium slashing amount for moderate offenses',
|
|
175
|
+
...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountMedium),
|
|
176
|
+
},
|
|
177
|
+
slashAmountLarge: {
|
|
178
|
+
env: 'AZTEC_SLASH_AMOUNT_LARGE',
|
|
179
|
+
description: 'Large slashing amount for severe offenses',
|
|
180
|
+
...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountLarge),
|
|
77
181
|
},
|
|
78
182
|
slashingQuorum: {
|
|
79
183
|
env: 'AZTEC_SLASHING_QUORUM',
|
|
80
184
|
description: 'The slashing quorum',
|
|
81
|
-
...
|
|
185
|
+
...optionalNumberConfigHelper(),
|
|
82
186
|
},
|
|
83
|
-
|
|
84
|
-
env: '
|
|
187
|
+
slashingRoundSizeInEpochs: {
|
|
188
|
+
env: 'AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS',
|
|
85
189
|
description: 'The slashing round size',
|
|
86
|
-
...numberConfigHelper(DefaultL1ContractsConfig.
|
|
190
|
+
...numberConfigHelper(DefaultL1ContractsConfig.slashingRoundSizeInEpochs),
|
|
191
|
+
},
|
|
192
|
+
slashingLifetimeInRounds: {
|
|
193
|
+
env: 'AZTEC_SLASHING_LIFETIME_IN_ROUNDS',
|
|
194
|
+
description: 'The slashing lifetime in rounds',
|
|
195
|
+
...numberConfigHelper(DefaultL1ContractsConfig.slashingLifetimeInRounds),
|
|
196
|
+
},
|
|
197
|
+
slashingExecutionDelayInRounds: {
|
|
198
|
+
env: 'AZTEC_SLASHING_EXECUTION_DELAY_IN_ROUNDS',
|
|
199
|
+
description: 'The slashing execution delay in rounds',
|
|
200
|
+
...numberConfigHelper(DefaultL1ContractsConfig.slashingExecutionDelayInRounds),
|
|
201
|
+
},
|
|
202
|
+
slashingVetoer: {
|
|
203
|
+
env: 'AZTEC_SLASHING_VETOER',
|
|
204
|
+
description: 'The slashing vetoer',
|
|
205
|
+
parseEnv: (val: string) => EthAddress.fromString(val),
|
|
206
|
+
defaultValue: DefaultL1ContractsConfig.slashingVetoer,
|
|
207
|
+
},
|
|
208
|
+
slashingDisableDuration: {
|
|
209
|
+
env: 'AZTEC_SLASHING_DISABLE_DURATION',
|
|
210
|
+
description: 'How long slashing can be disabled for in seconds when vetoer disables it',
|
|
211
|
+
...numberConfigHelper(DefaultL1ContractsConfig.slashingDisableDuration),
|
|
87
212
|
},
|
|
88
213
|
governanceProposerQuorum: {
|
|
89
214
|
env: 'AZTEC_GOVERNANCE_PROPOSER_QUORUM',
|
|
90
215
|
description: 'The governance proposing quorum',
|
|
91
|
-
...
|
|
216
|
+
...optionalNumberConfigHelper(),
|
|
92
217
|
},
|
|
93
218
|
governanceProposerRoundSize: {
|
|
94
219
|
env: 'AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE',
|
|
95
220
|
description: 'The governance proposing round size',
|
|
96
221
|
...numberConfigHelper(DefaultL1ContractsConfig.governanceProposerRoundSize),
|
|
97
222
|
},
|
|
223
|
+
manaTarget: {
|
|
224
|
+
env: 'AZTEC_MANA_TARGET',
|
|
225
|
+
description: 'The mana target for the rollup',
|
|
226
|
+
...bigintConfigHelper(DefaultL1ContractsConfig.manaTarget),
|
|
227
|
+
},
|
|
228
|
+
provingCostPerMana: {
|
|
229
|
+
env: 'AZTEC_PROVING_COST_PER_MANA',
|
|
230
|
+
description: 'The proving cost per mana',
|
|
231
|
+
...bigintConfigHelper(DefaultL1ContractsConfig.provingCostPerMana),
|
|
232
|
+
},
|
|
233
|
+
exitDelaySeconds: {
|
|
234
|
+
env: 'AZTEC_EXIT_DELAY_SECONDS',
|
|
235
|
+
description: 'The delay before a validator can exit the set',
|
|
236
|
+
...numberConfigHelper(DefaultL1ContractsConfig.exitDelaySeconds),
|
|
237
|
+
},
|
|
98
238
|
...l1TxUtilsConfigMappings,
|
|
99
239
|
};
|
|
100
240
|
|
|
241
|
+
export const genesisStateConfigMappings: ConfigMappingsType<GenesisStateConfig> = {
|
|
242
|
+
testAccounts: {
|
|
243
|
+
env: 'TEST_ACCOUNTS',
|
|
244
|
+
description: 'Whether to populate the genesis state with initial fee juice for the test accounts.',
|
|
245
|
+
...booleanConfigHelper(false),
|
|
246
|
+
},
|
|
247
|
+
sponsoredFPC: {
|
|
248
|
+
env: 'SPONSORED_FPC',
|
|
249
|
+
description: 'Whether to populate the genesis state with initial fee juice for the sponsored FPC.',
|
|
250
|
+
...booleanConfigHelper(false),
|
|
251
|
+
},
|
|
252
|
+
};
|
|
253
|
+
|
|
101
254
|
export function getL1ContractsConfigEnvVars(): L1ContractsConfig {
|
|
102
255
|
return getConfigFromMappings(l1ContractsConfigMappings);
|
|
103
256
|
}
|
|
257
|
+
|
|
258
|
+
export function getGenesisStateConfigEnvVars(): GenesisStateConfig {
|
|
259
|
+
return getConfigFromMappings(genesisStateConfigMappings);
|
|
260
|
+
}
|
|
@@ -1,19 +1,89 @@
|
|
|
1
|
+
import type { SlotNumber } from '@aztec/foundation/branded-types';
|
|
2
|
+
import type { EthAddress } from '@aztec/foundation/eth-address';
|
|
3
|
+
import { Signature } from '@aztec/foundation/eth-signature';
|
|
1
4
|
import { EmpireBaseAbi } from '@aztec/l1-artifacts/EmpireBaseAbi';
|
|
2
5
|
|
|
3
|
-
import { type Hex, encodeFunctionData } from 'viem';
|
|
6
|
+
import { type Hex, type TypedDataDefinition, encodeFunctionData } from 'viem';
|
|
4
7
|
|
|
5
|
-
import type { L1TxRequest } from '../l1_tx_utils.js';
|
|
8
|
+
import type { L1TxRequest } from '../l1_tx_utils/index.js';
|
|
6
9
|
|
|
7
10
|
export interface IEmpireBase {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
+
get address(): EthAddress;
|
|
12
|
+
getRoundInfo(
|
|
13
|
+
rollupAddress: Hex,
|
|
14
|
+
round: bigint,
|
|
15
|
+
): Promise<{ lastSignalSlot: SlotNumber; payloadWithMostSignals: Hex; quorumReached: boolean; executed: boolean }>;
|
|
16
|
+
computeRound(slot: SlotNumber): Promise<bigint>;
|
|
17
|
+
createSignalRequest(payload: Hex): L1TxRequest;
|
|
18
|
+
createSignalRequestWithSignature(
|
|
19
|
+
payload: Hex,
|
|
20
|
+
slot: SlotNumber,
|
|
21
|
+
chainId: number,
|
|
22
|
+
signerAddress: Hex,
|
|
23
|
+
signer: (msg: TypedDataDefinition) => Promise<Hex>,
|
|
24
|
+
): Promise<L1TxRequest>;
|
|
11
25
|
}
|
|
12
26
|
|
|
13
|
-
export function
|
|
27
|
+
export function encodeSignal(payload: Hex): Hex {
|
|
14
28
|
return encodeFunctionData({
|
|
15
29
|
abi: EmpireBaseAbi,
|
|
16
|
-
functionName: '
|
|
30
|
+
functionName: 'signal',
|
|
17
31
|
args: [payload],
|
|
18
32
|
});
|
|
19
33
|
}
|
|
34
|
+
|
|
35
|
+
export function encodeSignalWithSignature(payload: Hex, signature: Signature) {
|
|
36
|
+
return encodeFunctionData({
|
|
37
|
+
abi: EmpireBaseAbi,
|
|
38
|
+
functionName: 'signalWithSig',
|
|
39
|
+
args: [payload, signature.toViemSignature()],
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Signs a signal proposal using EIP-712 typed data for use with signalWithSig
|
|
45
|
+
* @param walletClient - The viem wallet client to sign with
|
|
46
|
+
* @param payload - The payload address to signal
|
|
47
|
+
* @param verifyingContract - The address of the EmpireBase contract
|
|
48
|
+
* @param chainId - The chain ID where the contract is deployed
|
|
49
|
+
* @param account - The account to sign with (optional if hoisted on wallet client)
|
|
50
|
+
* @returns The EIP-712 signature
|
|
51
|
+
*/
|
|
52
|
+
export async function signSignalWithSig(
|
|
53
|
+
signer: (msg: TypedDataDefinition) => Promise<Hex>,
|
|
54
|
+
payload: Hex,
|
|
55
|
+
slot: SlotNumber,
|
|
56
|
+
instance: Hex,
|
|
57
|
+
verifyingContract: Hex,
|
|
58
|
+
chainId: number,
|
|
59
|
+
): Promise<Signature> {
|
|
60
|
+
const domain = {
|
|
61
|
+
name: 'EmpireBase',
|
|
62
|
+
version: '1',
|
|
63
|
+
chainId,
|
|
64
|
+
verifyingContract,
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
const types = {
|
|
68
|
+
EIP712Domain: [
|
|
69
|
+
{ name: 'name', type: 'string' },
|
|
70
|
+
{ name: 'version', type: 'string' },
|
|
71
|
+
{ name: 'chainId', type: 'uint256' },
|
|
72
|
+
{ name: 'verifyingContract', type: 'address' },
|
|
73
|
+
],
|
|
74
|
+
Signal: [
|
|
75
|
+
{ name: 'payload', type: 'address' },
|
|
76
|
+
{ name: 'slot', type: 'uint256' },
|
|
77
|
+
{ name: 'instance', type: 'address' },
|
|
78
|
+
],
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
const message = {
|
|
82
|
+
payload,
|
|
83
|
+
slot: BigInt(slot),
|
|
84
|
+
instance,
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
const typedData = { domain, types, primaryType: 'Signal', message };
|
|
88
|
+
return Signature.fromString(await signer(typedData));
|
|
89
|
+
}
|