@aztec/ethereum 0.0.1-commit.b655e406 → 0.0.1-commit.b6e433891

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.
Files changed (229) hide show
  1. package/dest/account.d.ts +1 -1
  2. package/dest/chain.d.ts +1 -1
  3. package/dest/client.d.ts +10 -2
  4. package/dest/client.d.ts.map +1 -1
  5. package/dest/client.js +13 -3
  6. package/dest/config.d.ts +24 -68
  7. package/dest/config.d.ts.map +1 -1
  8. package/dest/config.js +67 -380
  9. package/dest/constants.d.ts +1 -1
  10. package/dest/contracts/empire_base.d.ts +9 -5
  11. package/dest/contracts/empire_base.d.ts.map +1 -1
  12. package/dest/contracts/empire_base.js +1 -1
  13. package/dest/contracts/empire_slashing_proposer.d.ts +8 -4
  14. package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -1
  15. package/dest/contracts/empire_slashing_proposer.js +39 -17
  16. package/dest/contracts/errors.d.ts +1 -1
  17. package/dest/contracts/errors.d.ts.map +1 -1
  18. package/dest/contracts/fee_asset_handler.d.ts +6 -5
  19. package/dest/contracts/fee_asset_handler.d.ts.map +1 -1
  20. package/dest/contracts/fee_asset_handler.js +11 -9
  21. package/dest/contracts/fee_asset_price_oracle.d.ts +101 -0
  22. package/dest/contracts/fee_asset_price_oracle.d.ts.map +1 -0
  23. package/dest/contracts/fee_asset_price_oracle.js +651 -0
  24. package/dest/contracts/fee_juice.d.ts +1 -1
  25. package/dest/contracts/fee_juice.d.ts.map +1 -1
  26. package/dest/contracts/governance.d.ts +18 -16
  27. package/dest/contracts/governance.d.ts.map +1 -1
  28. package/dest/contracts/governance.js +14 -4
  29. package/dest/contracts/governance_proposer.d.ts +8 -4
  30. package/dest/contracts/governance_proposer.d.ts.map +1 -1
  31. package/dest/contracts/governance_proposer.js +412 -11
  32. package/dest/contracts/gse.d.ts +1 -1
  33. package/dest/contracts/gse.d.ts.map +1 -1
  34. package/dest/contracts/inbox.d.ts +24 -3
  35. package/dest/contracts/inbox.d.ts.map +1 -1
  36. package/dest/contracts/inbox.js +36 -1
  37. package/dest/contracts/index.d.ts +4 -1
  38. package/dest/contracts/index.d.ts.map +1 -1
  39. package/dest/contracts/index.js +3 -0
  40. package/dest/contracts/log.d.ts +13 -0
  41. package/dest/contracts/log.d.ts.map +1 -0
  42. package/dest/contracts/log.js +1 -0
  43. package/dest/contracts/multicall.d.ts +2 -2
  44. package/dest/contracts/multicall.d.ts.map +1 -1
  45. package/dest/contracts/multicall.js +2 -1
  46. package/dest/contracts/outbox.d.ts +41 -0
  47. package/dest/contracts/outbox.d.ts.map +1 -0
  48. package/dest/contracts/outbox.js +86 -0
  49. package/dest/contracts/registry.d.ts +3 -1
  50. package/dest/contracts/registry.d.ts.map +1 -1
  51. package/dest/contracts/registry.js +30 -1
  52. package/dest/contracts/rollup.d.ts +208 -123
  53. package/dest/contracts/rollup.d.ts.map +1 -1
  54. package/dest/contracts/rollup.js +807 -188
  55. package/dest/contracts/slasher_contract.d.ts +1 -1
  56. package/dest/contracts/slasher_contract.d.ts.map +1 -1
  57. package/dest/contracts/tally_slashing_proposer.d.ts +9 -7
  58. package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -1
  59. package/dest/contracts/tally_slashing_proposer.js +11 -4
  60. package/dest/contracts/utils.d.ts +1 -1
  61. package/dest/deploy_aztec_l1_contracts.d.ts +259 -0
  62. package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
  63. package/dest/deploy_aztec_l1_contracts.js +413 -0
  64. package/dest/deploy_l1_contract.d.ts +68 -0
  65. package/dest/deploy_l1_contract.d.ts.map +1 -0
  66. package/dest/deploy_l1_contract.js +312 -0
  67. package/dest/eth-signer/eth-signer.d.ts +1 -1
  68. package/dest/eth-signer/index.d.ts +1 -1
  69. package/dest/forwarder_proxy.d.ts +32 -0
  70. package/dest/forwarder_proxy.d.ts.map +1 -0
  71. package/dest/forwarder_proxy.js +93 -0
  72. package/dest/generated/l1-contracts-defaults.d.ts +30 -0
  73. package/dest/generated/l1-contracts-defaults.d.ts.map +1 -0
  74. package/dest/generated/l1-contracts-defaults.js +30 -0
  75. package/dest/l1_artifacts.d.ts +7608 -2048
  76. package/dest/l1_artifacts.d.ts.map +1 -1
  77. package/dest/l1_contract_addresses.d.ts +3 -3
  78. package/dest/l1_contract_addresses.d.ts.map +1 -1
  79. package/dest/l1_contract_addresses.js +3 -3
  80. package/dest/l1_reader.d.ts +5 -1
  81. package/dest/l1_reader.d.ts.map +1 -1
  82. package/dest/l1_reader.js +12 -1
  83. package/dest/l1_tx_utils/config.d.ts +11 -5
  84. package/dest/l1_tx_utils/config.d.ts.map +1 -1
  85. package/dest/l1_tx_utils/config.js +43 -7
  86. package/dest/l1_tx_utils/constants.d.ts +8 -2
  87. package/dest/l1_tx_utils/constants.d.ts.map +1 -1
  88. package/dest/l1_tx_utils/constants.js +27 -2
  89. package/dest/l1_tx_utils/factory.d.ts +18 -10
  90. package/dest/l1_tx_utils/factory.d.ts.map +1 -1
  91. package/dest/l1_tx_utils/factory.js +17 -7
  92. package/dest/l1_tx_utils/fee-strategies/index.d.ts +10 -0
  93. package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
  94. package/dest/l1_tx_utils/fee-strategies/index.js +12 -0
  95. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +8 -0
  96. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
  97. package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +129 -0
  98. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +23 -0
  99. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
  100. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +191 -0
  101. package/dest/l1_tx_utils/fee-strategies/types.d.ts +51 -0
  102. package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
  103. package/dest/l1_tx_utils/fee-strategies/types.js +3 -0
  104. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
  105. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
  106. package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +42 -0
  107. package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
  108. package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
  109. package/dest/l1_tx_utils/index-blobs.js +2 -0
  110. package/dest/l1_tx_utils/index.d.ts +4 -1
  111. package/dest/l1_tx_utils/index.d.ts.map +1 -1
  112. package/dest/l1_tx_utils/index.js +3 -0
  113. package/dest/l1_tx_utils/interfaces.d.ts +2 -2
  114. package/dest/l1_tx_utils/interfaces.d.ts.map +1 -1
  115. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
  116. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
  117. package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
  118. package/dest/l1_tx_utils/l1_tx_utils.d.ts +18 -8
  119. package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -1
  120. package/dest/l1_tx_utils/l1_tx_utils.js +75 -46
  121. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +19 -30
  122. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -1
  123. package/dest/l1_tx_utils/readonly_l1_tx_utils.js +63 -167
  124. package/dest/l1_tx_utils/signer.d.ts +1 -1
  125. package/dest/l1_tx_utils/tx_delayer.d.ts +56 -0
  126. package/dest/l1_tx_utils/tx_delayer.d.ts.map +1 -0
  127. package/dest/{test → l1_tx_utils}/tx_delayer.js +65 -36
  128. package/dest/l1_tx_utils/types.d.ts +1 -1
  129. package/dest/l1_tx_utils/types.d.ts.map +1 -1
  130. package/dest/l1_tx_utils/utils.d.ts +1 -1
  131. package/dest/l1_types.d.ts +1 -1
  132. package/dest/publisher_manager.d.ts +3 -2
  133. package/dest/publisher_manager.d.ts.map +1 -1
  134. package/dest/publisher_manager.js +2 -2
  135. package/dest/queries.d.ts +2 -2
  136. package/dest/queries.d.ts.map +1 -1
  137. package/dest/queries.js +16 -6
  138. package/dest/test/chain_monitor.d.ts +47 -25
  139. package/dest/test/chain_monitor.d.ts.map +1 -1
  140. package/dest/test/chain_monitor.js +66 -38
  141. package/dest/test/eth_cheat_codes.d.ts +11 -3
  142. package/dest/test/eth_cheat_codes.d.ts.map +1 -1
  143. package/dest/test/eth_cheat_codes.js +11 -3
  144. package/dest/test/eth_cheat_codes_with_state.d.ts +1 -1
  145. package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
  146. package/dest/test/index.d.ts +1 -3
  147. package/dest/test/index.d.ts.map +1 -1
  148. package/dest/test/index.js +0 -2
  149. package/dest/test/rollup_cheat_codes.d.ts +17 -13
  150. package/dest/test/rollup_cheat_codes.d.ts.map +1 -1
  151. package/dest/test/rollup_cheat_codes.js +62 -38
  152. package/dest/test/start_anvil.d.ts +18 -2
  153. package/dest/test/start_anvil.d.ts.map +1 -1
  154. package/dest/test/start_anvil.js +129 -28
  155. package/dest/test/upgrade_utils.d.ts +1 -1
  156. package/dest/test/upgrade_utils.js +2 -2
  157. package/dest/types.d.ts +57 -2
  158. package/dest/types.d.ts.map +1 -1
  159. package/dest/utils.d.ts +16 -3
  160. package/dest/utils.d.ts.map +1 -1
  161. package/dest/utils.js +80 -12
  162. package/dest/zkPassportVerifierAddress.d.ts +1 -1
  163. package/package.json +34 -16
  164. package/src/client.ts +10 -2
  165. package/src/config.ts +86 -460
  166. package/src/contracts/README.md +157 -0
  167. package/src/contracts/empire_base.ts +8 -5
  168. package/src/contracts/empire_slashing_proposer.ts +38 -32
  169. package/src/contracts/fee_asset_handler.ts +10 -7
  170. package/src/contracts/fee_asset_price_oracle.ts +280 -0
  171. package/src/contracts/governance.ts +13 -4
  172. package/src/contracts/governance_proposer.ts +26 -6
  173. package/src/contracts/inbox.ts +55 -3
  174. package/src/contracts/index.ts +3 -0
  175. package/src/contracts/log.ts +13 -0
  176. package/src/contracts/multicall.ts +5 -2
  177. package/src/contracts/outbox.ts +98 -0
  178. package/src/contracts/registry.ts +31 -1
  179. package/src/contracts/rollup.ts +485 -162
  180. package/src/contracts/tally_slashing_proposer.ts +15 -8
  181. package/src/deploy_aztec_l1_contracts.ts +650 -0
  182. package/src/deploy_l1_contract.ts +362 -0
  183. package/src/forwarder_proxy.ts +108 -0
  184. package/src/generated/l1-contracts-defaults.ts +32 -0
  185. package/src/l1_contract_addresses.ts +22 -20
  186. package/src/l1_reader.ts +21 -1
  187. package/src/l1_tx_utils/config.ts +52 -11
  188. package/src/l1_tx_utils/constants.ts +13 -2
  189. package/src/l1_tx_utils/factory.ts +31 -31
  190. package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
  191. package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +163 -0
  192. package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +245 -0
  193. package/src/l1_tx_utils/fee-strategies/types.ts +56 -0
  194. package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +108 -0
  195. package/src/l1_tx_utils/index-blobs.ts +2 -0
  196. package/src/l1_tx_utils/index.ts +3 -0
  197. package/src/l1_tx_utils/interfaces.ts +1 -1
  198. package/src/l1_tx_utils/l1_fee_analyzer.ts +803 -0
  199. package/src/l1_tx_utils/l1_tx_utils.ts +84 -36
  200. package/src/l1_tx_utils/readonly_l1_tx_utils.ts +77 -213
  201. package/src/{test → l1_tx_utils}/tx_delayer.ts +82 -52
  202. package/src/publisher_manager.ts +4 -2
  203. package/src/queries.ts +17 -6
  204. package/src/test/chain_monitor.ts +110 -51
  205. package/src/test/eth_cheat_codes.ts +9 -3
  206. package/src/test/index.ts +0 -2
  207. package/src/test/rollup_cheat_codes.ts +63 -43
  208. package/src/test/start_anvil.ts +156 -27
  209. package/src/test/upgrade_utils.ts +2 -2
  210. package/src/types.ts +62 -0
  211. package/src/utils.ts +100 -15
  212. package/dest/deploy_l1_contracts.d.ts +0 -226
  213. package/dest/deploy_l1_contracts.d.ts.map +0 -1
  214. package/dest/deploy_l1_contracts.js +0 -1473
  215. package/dest/index.d.ts +0 -18
  216. package/dest/index.d.ts.map +0 -1
  217. package/dest/index.js +0 -17
  218. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +0 -26
  219. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +0 -1
  220. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.js +0 -26
  221. package/dest/test/delayed_tx_utils.d.ts +0 -13
  222. package/dest/test/delayed_tx_utils.d.ts.map +0 -1
  223. package/dest/test/delayed_tx_utils.js +0 -28
  224. package/dest/test/tx_delayer.d.ts +0 -36
  225. package/dest/test/tx_delayer.d.ts.map +0 -1
  226. package/src/deploy_l1_contracts.ts +0 -1849
  227. package/src/index.ts +0 -17
  228. package/src/l1_tx_utils/l1_tx_utils_with_blobs.ts +0 -77
  229. package/src/test/delayed_tx_utils.ts +0 -52
package/src/config.ts CHANGED
@@ -1,22 +1,26 @@
1
1
  import {
2
2
  type ConfigMappingsType,
3
- type NetworkNames,
4
3
  bigintConfigHelper,
5
4
  booleanConfigHelper,
6
5
  enumConfigHelper,
7
6
  getConfigFromMappings,
7
+ getDefaultConfig,
8
8
  numberConfigHelper,
9
+ omitConfigMappings,
9
10
  optionalNumberConfigHelper,
10
11
  } from '@aztec/foundation/config';
11
12
  import { EthAddress } from '@aztec/foundation/eth-address';
12
13
 
13
- import { type L1TxUtilsConfig, l1TxUtilsConfigMappings } from './l1_tx_utils/index.js';
14
+ import { l1ContractsDefaultEnv } from './generated/l1-contracts-defaults.js';
15
+ import { type L1TxUtilsConfig, l1TxUtilsConfigMappings } from './l1_tx_utils/config.js';
14
16
 
15
17
  export type GenesisStateConfig = {
16
18
  /** Whether to populate the genesis state with initial fee juice for the test accounts */
17
19
  testAccounts: boolean;
18
20
  /** Whether to populate the genesis state with initial fee juice for the sponsored FPC */
19
21
  sponsoredFPC: boolean;
22
+ /** Additional addresses to prefund with fee juice at genesis */
23
+ prefundAddresses: string[];
20
24
  };
21
25
 
22
26
  export type L1ContractsConfig = {
@@ -29,7 +33,11 @@ export type L1ContractsConfig = {
29
33
  /** The target validator committee size. */
30
34
  aztecTargetCommitteeSize: number;
31
35
  /** The number of epochs to lag behind the current epoch for validator selection. */
32
- lagInEpochs: number;
36
+ lagInEpochsForValidatorSet: number;
37
+ /** The number of epochs to lag behind the current epoch for randao selection. */
38
+ lagInEpochsForRandao: number;
39
+ /** The number of checkpoints to lag in the inbox (prevents sequencer DOS attacks). */
40
+ inboxLag: number;
33
41
  /** The number of epochs after an epoch ends that proofs are still accepted. */
34
42
  aztecProofSubmissionEpochs: number;
35
43
  /** The deposit amount for a validator */
@@ -64,314 +72,108 @@ export type L1ContractsConfig = {
64
72
  governanceProposerQuorum?: number;
65
73
  /** Governance proposing round size */
66
74
  governanceProposerRoundSize: number;
75
+ /** Governance voting duration in seconds (only for local/devnet/next-net, default 3600) */
76
+ governanceVotingDuration?: number;
67
77
  /** The mana target for the rollup */
68
78
  manaTarget: bigint;
69
79
  /** The proving cost per mana */
70
80
  provingCostPerMana: bigint;
81
+ /** The initial ETH per fee asset price (with 1e12 precision) */
82
+ initialEthPerFeeAsset: bigint;
71
83
  /** The number of seconds to wait for an exit */
72
84
  exitDelaySeconds: number;
73
85
  } & L1TxUtilsConfig;
74
86
 
75
- export const DefaultL1ContractsConfig = {
76
- ethereumSlotDuration: 12,
77
- aztecSlotDuration: 36,
78
- aztecEpochDuration: 32,
79
- aztecTargetCommitteeSize: 48,
80
- lagInEpochs: 2,
81
- aztecProofSubmissionEpochs: 1, // you have a full epoch to submit a proof after the epoch to prove ends
82
- activationThreshold: 100n * 10n ** 18n,
83
- ejectionThreshold: 50n * 10n ** 18n,
84
- localEjectionThreshold: 98n * 10n ** 18n,
85
- slashAmountSmall: 10n * 10n ** 18n,
86
- slashAmountMedium: 20n * 10n ** 18n,
87
- slashAmountLarge: 50n * 10n ** 18n,
88
- slashingRoundSizeInEpochs: 4,
89
- slashingLifetimeInRounds: 5,
90
- slashingExecutionDelayInRounds: 0, // round N may be submitted in round N + 1
91
- slashingVetoer: EthAddress.ZERO,
92
- governanceProposerRoundSize: 300,
93
- manaTarget: BigInt(1e10),
94
- provingCostPerMana: BigInt(100),
95
- exitDelaySeconds: 2 * 24 * 60 * 60,
96
- slasherFlavor: 'tally' as const,
97
- slashingOffsetInRounds: 2,
98
- slashingDisableDuration: 5 * 24 * 60 * 60, // 5 days in seconds
99
- } satisfies L1ContractsConfig;
100
-
101
- const LocalGovernanceConfiguration = {
102
- proposeConfig: {
103
- lockDelay: 60n * 60n * 24n * 30n,
104
- lockAmount: 1n * 10n ** 24n,
105
- },
106
- votingDelay: 60n,
107
- votingDuration: 60n * 60n,
108
- executionDelay: 60n,
109
- gracePeriod: 60n * 60n * 24n * 7n,
110
- quorum: 1n * 10n ** 17n, // 10%
111
- requiredYeaMargin: 4n * 10n ** 16n, // 4%
112
- minimumVotes: 400n * 10n ** 18n,
113
- };
114
-
115
- const StagingPublicGovernanceConfiguration = {
116
- proposeConfig: {
117
- lockDelay: 60n * 60n * 24n * 30n,
118
- lockAmount: DefaultL1ContractsConfig.activationThreshold * 100n,
119
- },
120
- votingDelay: 60n,
121
- votingDuration: 60n * 60n,
122
- executionDelay: 60n,
123
- gracePeriod: 60n * 60n * 24n * 7n,
124
- quorum: 3n * 10n ** 17n, // 30%
125
- requiredYeaMargin: 4n * 10n ** 16n, // 4%
126
- minimumVotes: DefaultL1ContractsConfig.ejectionThreshold * 200n, // >= 200 validators must vote
127
- };
128
-
129
- const TestnetGovernanceConfiguration = {
130
- proposeConfig: {
131
- lockDelay: 10n * 365n * 24n * 60n * 60n,
132
- lockAmount: 1250n * 200_000n * 10n ** 18n,
133
- },
134
-
135
- votingDelay: 12n * 60n * 60n, // 12 hours
136
- votingDuration: 1n * 24n * 60n * 60n, // 1 day
137
- executionDelay: 12n * 60n * 60n, // 12 hours
138
- gracePeriod: 1n * 24n * 60n * 60n, // 1 day
139
- quorum: 2n * 10n ** 17n, // 20%
140
- requiredYeaMargin: 1n * 10n ** 17n, // 10%
141
- minimumVotes: 100n * 200_000n * 10n ** 18n,
142
- };
143
-
144
- const StagingIgnitionGovernanceConfiguration = {
145
- proposeConfig: {
146
- lockDelay: 10n * 365n * 24n * 60n * 60n,
147
- lockAmount: 1250n * 200_000n * 10n ** 18n,
148
- },
149
-
150
- votingDelay: 7n * 24n * 60n * 60n,
151
- votingDuration: 7n * 24n * 60n * 60n,
152
- executionDelay: 30n * 24n * 60n * 60n,
153
- gracePeriod: 7n * 24n * 60n * 60n,
154
- quorum: 2n * 10n ** 17n, // 20%
155
- requiredYeaMargin: 1n * 10n ** 17n, // 10%
156
- minimumVotes: 1250n * 200_000n * 10n ** 18n,
157
- };
158
-
159
- const MainnetGovernanceConfiguration = {
160
- proposeConfig: {
161
- lockDelay: 90n * 24n * 60n * 60n,
162
- lockAmount: 258_750_000n * 10n ** 18n,
163
- },
164
-
165
- votingDelay: 3n * 24n * 60n * 60n,
166
- votingDuration: 7n * 24n * 60n * 60n,
167
- executionDelay: 7n * 24n * 60n * 60n,
168
- gracePeriod: 7n * 24n * 60n * 60n,
169
- quorum: 2n * 10n ** 17n, // 20%
170
- requiredYeaMargin: 33n * 10n ** 16n, // 33%
171
- minimumVotes: 1000n * 200_000n * 10n ** 18n,
172
- };
173
-
174
- export const getGovernanceConfiguration = (networkName: NetworkNames) => {
175
- switch (networkName) {
176
- case 'local':
177
- return LocalGovernanceConfiguration;
178
- case 'next-net':
179
- return LocalGovernanceConfiguration;
180
- case 'devnet':
181
- return LocalGovernanceConfiguration;
182
- case 'staging-public':
183
- return StagingPublicGovernanceConfiguration;
184
- case 'testnet':
185
- return TestnetGovernanceConfiguration;
186
- case 'staging-ignition':
187
- return StagingIgnitionGovernanceConfiguration;
188
- case 'mainnet':
189
- return MainnetGovernanceConfiguration;
190
- default:
191
- throw new Error(`Unrecognized network name: ${networkName}`);
192
- }
193
- };
194
-
195
- // Making a default config here as we are only using it thought the deployment
196
- // and do not expect to be using different setups, so having environment variables
197
- // for it seems overkill
198
-
199
- const DefaultRewardConfig = {
200
- sequencerBps: 8000,
201
- rewardDistributor: EthAddress.ZERO.toString(),
202
- booster: EthAddress.ZERO.toString(),
203
- blockReward: 500n * 10n ** 18n,
204
- };
205
-
206
- const MainnetRewardConfig = {
207
- sequencerBps: 7_000,
208
- rewardDistributor: EthAddress.ZERO.toString(),
209
- booster: EthAddress.ZERO.toString(),
210
- blockReward: 400n * 10n ** 18n,
211
- };
212
-
213
- export const getRewardConfig = (networkName: NetworkNames) => {
214
- switch (networkName) {
215
- case 'local':
216
- case 'devnet':
217
- case 'next-net':
218
- case 'staging-public':
219
- case 'testnet':
220
- case 'staging-ignition':
221
- return DefaultRewardConfig;
222
- case 'mainnet':
223
- return MainnetRewardConfig;
224
- default:
225
- throw new Error(`Unrecognized network name: ${networkName}`);
226
- }
227
- };
228
-
229
- export const getRewardBoostConfig = () => {
230
- // The reward configuration is specified with a precision of 1e5, and we use the same across
231
- // all networks.
232
- return {
233
- increment: 125_000, // 1.25
234
- maxScore: 15_000_000, // 150
235
- a: 1_000, // 0.01
236
- k: 1_000_000, // 10
237
- minimum: 100_000, // 1
238
- };
239
- };
240
-
241
- // Similar to the above, no need for environment variables for this.
242
- const LocalEntryQueueConfig = {
243
- bootstrapValidatorSetSize: 0n,
244
- bootstrapFlushSize: 0n,
245
- normalFlushSizeMin: 48n,
246
- normalFlushSizeQuotient: 2n,
247
- maxQueueFlushSize: 48n,
248
- };
249
-
250
- const StagingPublicEntryQueueConfig = {
251
- bootstrapValidatorSetSize: 48n,
252
- bootstrapFlushSize: 48n,
253
- normalFlushSizeMin: 1n,
254
- normalFlushSizeQuotient: 2475n,
255
- maxQueueFlushSize: 32n, // Limited to 32 so flush cost are kept below 15M gas.
256
- };
257
-
258
- const TestnetEntryQueueConfig = {
259
- bootstrapValidatorSetSize: 256n,
260
- bootstrapFlushSize: 256n,
261
- normalFlushSizeMin: 4n,
262
- normalFlushSizeQuotient: 2048n,
263
- maxQueueFlushSize: 8n,
264
- };
265
-
266
- const StagingIgnitionEntryQueueConfig = {
267
- bootstrapValidatorSetSize: 48n,
268
- bootstrapFlushSize: 48n,
269
- normalFlushSizeMin: 1n,
270
- normalFlushSizeQuotient: 2048n,
271
- maxQueueFlushSize: 24n,
272
- };
273
-
274
- const MainnetEntryQueueConfig = {
275
- bootstrapValidatorSetSize: 1_000n,
276
- bootstrapFlushSize: 1_000n,
277
- normalFlushSizeMin: 1n,
278
- normalFlushSizeQuotient: 2_048n,
279
- maxQueueFlushSize: 8n,
280
- };
281
-
282
- export const getEntryQueueConfig = (networkName: NetworkNames) => {
283
- switch (networkName) {
284
- case 'local':
285
- return LocalEntryQueueConfig;
286
- case 'next-net':
287
- return LocalEntryQueueConfig;
288
- case 'devnet':
289
- return LocalEntryQueueConfig;
290
- case 'staging-public':
291
- return StagingPublicEntryQueueConfig;
292
- case 'testnet':
293
- return TestnetEntryQueueConfig;
294
- case 'staging-ignition':
295
- return StagingIgnitionEntryQueueConfig;
296
- case 'mainnet':
297
- return MainnetEntryQueueConfig;
298
- default:
299
- throw new Error(`Unrecognized network name: ${networkName}`);
300
- }
301
- };
302
-
87
+ /**
88
+ * Config mappings for L1ContractsConfig.
89
+ * Default values come from generated l1-contracts-defaults.json (source: defaults.yml).
90
+ * Real deployments use forge scripts which require explicit env vars (vm.envUint).
91
+ */
303
92
  export const l1ContractsConfigMappings: ConfigMappingsType<L1ContractsConfig> = {
304
93
  ethereumSlotDuration: {
305
94
  env: 'ETHEREUM_SLOT_DURATION',
306
95
  description: 'How many seconds an L1 slot lasts.',
307
- ...numberConfigHelper(DefaultL1ContractsConfig.ethereumSlotDuration),
96
+ ...numberConfigHelper(l1ContractsDefaultEnv.ETHEREUM_SLOT_DURATION),
308
97
  },
309
98
  aztecSlotDuration: {
310
99
  env: 'AZTEC_SLOT_DURATION',
311
100
  description: 'How many seconds an L2 slots lasts (must be multiple of ethereum slot duration).',
312
- ...numberConfigHelper(DefaultL1ContractsConfig.aztecSlotDuration),
101
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLOT_DURATION),
313
102
  },
314
103
  aztecEpochDuration: {
315
104
  env: 'AZTEC_EPOCH_DURATION',
316
- description: `How many L2 slots an epoch lasts (maximum AZTEC_MAX_EPOCH_DURATION).`,
317
- ...numberConfigHelper(DefaultL1ContractsConfig.aztecEpochDuration),
105
+ description: `How many L2 slots an epoch lasts (maximum MAX_CHECKPOINTS_PER_EPOCH).`,
106
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_EPOCH_DURATION),
318
107
  },
319
108
  aztecTargetCommitteeSize: {
320
109
  env: 'AZTEC_TARGET_COMMITTEE_SIZE',
321
110
  description: 'The target validator committee size.',
322
- ...numberConfigHelper(DefaultL1ContractsConfig.aztecTargetCommitteeSize),
111
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_TARGET_COMMITTEE_SIZE),
323
112
  },
324
- lagInEpochs: {
325
- env: 'AZTEC_LAG_IN_EPOCHS',
113
+ lagInEpochsForValidatorSet: {
114
+ env: 'AZTEC_LAG_IN_EPOCHS_FOR_VALIDATOR_SET',
326
115
  description: 'The number of epochs to lag behind the current epoch for validator selection.',
327
- ...numberConfigHelper(DefaultL1ContractsConfig.lagInEpochs),
116
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_LAG_IN_EPOCHS_FOR_VALIDATOR_SET),
117
+ },
118
+ lagInEpochsForRandao: {
119
+ env: 'AZTEC_LAG_IN_EPOCHS_FOR_RANDAO',
120
+ description: 'The number of epochs to lag behind the current epoch for randao selection.',
121
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_LAG_IN_EPOCHS_FOR_RANDAO),
122
+ },
123
+ inboxLag: {
124
+ env: 'AZTEC_INBOX_LAG',
125
+ description: 'The number of checkpoints to lag in the inbox (prevents sequencer DOS attacks).',
126
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_INBOX_LAG),
328
127
  },
329
128
  aztecProofSubmissionEpochs: {
330
129
  env: 'AZTEC_PROOF_SUBMISSION_EPOCHS',
331
130
  description: 'The number of epochs after an epoch ends that proofs are still accepted.',
332
- ...numberConfigHelper(DefaultL1ContractsConfig.aztecProofSubmissionEpochs),
131
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_PROOF_SUBMISSION_EPOCHS),
333
132
  },
334
133
  activationThreshold: {
335
134
  env: 'AZTEC_ACTIVATION_THRESHOLD',
336
135
  description: 'The deposit amount for a validator',
337
- ...bigintConfigHelper(DefaultL1ContractsConfig.activationThreshold),
136
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_ACTIVATION_THRESHOLD)),
338
137
  },
339
138
  ejectionThreshold: {
340
139
  env: 'AZTEC_EJECTION_THRESHOLD',
341
140
  description: 'The minimum stake for a validator.',
342
- ...bigintConfigHelper(DefaultL1ContractsConfig.ejectionThreshold),
141
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_EJECTION_THRESHOLD)),
343
142
  },
344
143
  localEjectionThreshold: {
345
144
  env: 'AZTEC_LOCAL_EJECTION_THRESHOLD',
346
145
  description:
347
146
  'The local ejection threshold for a validator. Stricter than ejectionThreshold but local to a specific rollup',
348
- ...bigintConfigHelper(DefaultL1ContractsConfig.localEjectionThreshold),
147
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_LOCAL_EJECTION_THRESHOLD)),
349
148
  },
350
149
  slashingOffsetInRounds: {
351
150
  env: 'AZTEC_SLASHING_OFFSET_IN_ROUNDS',
352
151
  description:
353
152
  'How many slashing rounds back we slash (ie when slashing in round N, we slash for offenses committed during epochs of round N-offset)',
354
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingOffsetInRounds),
153
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_OFFSET_IN_ROUNDS),
355
154
  },
356
155
  slasherFlavor: {
357
156
  env: 'AZTEC_SLASHER_FLAVOR',
358
157
  description: 'Type of slasher proposer (empire, tally, or none)',
359
- ...enumConfigHelper(['empire', 'tally', 'none'] as const, DefaultL1ContractsConfig.slasherFlavor),
158
+ ...enumConfigHelper(
159
+ ['empire', 'tally', 'none'] as const,
160
+ l1ContractsDefaultEnv.AZTEC_SLASHER_FLAVOR as 'empire' | 'tally' | 'none',
161
+ ),
360
162
  },
361
163
  slashAmountSmall: {
362
164
  env: 'AZTEC_SLASH_AMOUNT_SMALL',
363
165
  description: 'Small slashing amount for light offenses',
364
- ...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountSmall),
166
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_SLASH_AMOUNT_SMALL)),
365
167
  },
366
168
  slashAmountMedium: {
367
169
  env: 'AZTEC_SLASH_AMOUNT_MEDIUM',
368
170
  description: 'Medium slashing amount for moderate offenses',
369
- ...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountMedium),
171
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_SLASH_AMOUNT_MEDIUM)),
370
172
  },
371
173
  slashAmountLarge: {
372
174
  env: 'AZTEC_SLASH_AMOUNT_LARGE',
373
175
  description: 'Large slashing amount for severe offenses',
374
- ...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountLarge),
176
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_SLASH_AMOUNT_LARGE)),
375
177
  },
376
178
  slashingQuorum: {
377
179
  env: 'AZTEC_SLASHING_QUORUM',
@@ -381,28 +183,28 @@ export const l1ContractsConfigMappings: ConfigMappingsType<L1ContractsConfig> =
381
183
  slashingRoundSizeInEpochs: {
382
184
  env: 'AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS',
383
185
  description: 'The slashing round size',
384
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingRoundSizeInEpochs),
186
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS),
385
187
  },
386
188
  slashingLifetimeInRounds: {
387
189
  env: 'AZTEC_SLASHING_LIFETIME_IN_ROUNDS',
388
190
  description: 'The slashing lifetime in rounds',
389
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingLifetimeInRounds),
191
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_LIFETIME_IN_ROUNDS),
390
192
  },
391
193
  slashingExecutionDelayInRounds: {
392
194
  env: 'AZTEC_SLASHING_EXECUTION_DELAY_IN_ROUNDS',
393
195
  description: 'The slashing execution delay in rounds',
394
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingExecutionDelayInRounds),
196
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_EXECUTION_DELAY_IN_ROUNDS),
395
197
  },
396
198
  slashingVetoer: {
397
199
  env: 'AZTEC_SLASHING_VETOER',
398
200
  description: 'The slashing vetoer',
399
201
  parseEnv: (val: string) => EthAddress.fromString(val),
400
- defaultValue: DefaultL1ContractsConfig.slashingVetoer,
202
+ defaultValue: EthAddress.fromString(l1ContractsDefaultEnv.AZTEC_SLASHING_VETOER),
401
203
  },
402
204
  slashingDisableDuration: {
403
205
  env: 'AZTEC_SLASHING_DISABLE_DURATION',
404
206
  description: 'How long slashing can be disabled for in seconds when vetoer disables it',
405
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingDisableDuration),
207
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_DISABLE_DURATION),
406
208
  },
407
209
  governanceProposerQuorum: {
408
210
  env: 'AZTEC_GOVERNANCE_PROPOSER_QUORUM',
@@ -412,26 +214,42 @@ export const l1ContractsConfigMappings: ConfigMappingsType<L1ContractsConfig> =
412
214
  governanceProposerRoundSize: {
413
215
  env: 'AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE',
414
216
  description: 'The governance proposing round size',
415
- ...numberConfigHelper(DefaultL1ContractsConfig.governanceProposerRoundSize),
217
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE),
218
+ },
219
+ governanceVotingDuration: {
220
+ env: 'AZTEC_GOVERNANCE_VOTING_DURATION',
221
+ description: 'Governance voting duration in seconds (only for local/devnet/next-net)',
222
+ ...numberConfigHelper(3600), // 1 hour default, not in generated defaults as it's deployment-time only
416
223
  },
417
224
  manaTarget: {
418
225
  env: 'AZTEC_MANA_TARGET',
419
226
  description: 'The mana target for the rollup',
420
- ...bigintConfigHelper(DefaultL1ContractsConfig.manaTarget),
227
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_MANA_TARGET)),
421
228
  },
422
229
  provingCostPerMana: {
423
230
  env: 'AZTEC_PROVING_COST_PER_MANA',
424
231
  description: 'The proving cost per mana',
425
- ...bigintConfigHelper(DefaultL1ContractsConfig.provingCostPerMana),
232
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_PROVING_COST_PER_MANA)),
233
+ },
234
+ initialEthPerFeeAsset: {
235
+ env: 'AZTEC_INITIAL_ETH_PER_FEE_ASSET',
236
+ description: 'The initial ETH per fee asset price (with 1e12 precision)',
237
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_INITIAL_ETH_PER_FEE_ASSET)),
426
238
  },
427
239
  exitDelaySeconds: {
428
240
  env: 'AZTEC_EXIT_DELAY_SECONDS',
429
241
  description: 'The delay before a validator can exit the set',
430
- ...numberConfigHelper(DefaultL1ContractsConfig.exitDelaySeconds),
242
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_EXIT_DELAY_SECONDS),
431
243
  },
432
- ...l1TxUtilsConfigMappings,
244
+ ...omitConfigMappings(l1TxUtilsConfigMappings, ['ethereumSlotDuration']),
433
245
  };
434
246
 
247
+ /**
248
+ * Default L1 contracts configuration derived from l1ContractsConfigMappings.
249
+ * Source of truth: spartan/environments/defaults.yml -> defaults.l1-contracts
250
+ */
251
+ export const DefaultL1ContractsConfig = getDefaultConfig(l1ContractsConfigMappings);
252
+
435
253
  export const genesisStateConfigMappings: ConfigMappingsType<GenesisStateConfig> = {
436
254
  testAccounts: {
437
255
  env: 'TEST_ACCOUNTS',
@@ -443,6 +261,16 @@ export const genesisStateConfigMappings: ConfigMappingsType<GenesisStateConfig>
443
261
  description: 'Whether to populate the genesis state with initial fee juice for the sponsored FPC.',
444
262
  ...booleanConfigHelper(false),
445
263
  },
264
+ prefundAddresses: {
265
+ env: 'PREFUND_ADDRESSES',
266
+ description: 'Comma-separated list of Aztec addresses to prefund with fee juice at genesis (local network only).',
267
+ parseEnv: (val: string) =>
268
+ val
269
+ .split(',')
270
+ .map(a => a.trim())
271
+ .filter(a => a.length > 0),
272
+ defaultValue: [],
273
+ },
446
274
  };
447
275
 
448
276
  export function getL1ContractsConfigEnvVars(): L1ContractsConfig {
@@ -452,205 +280,3 @@ export function getL1ContractsConfigEnvVars(): L1ContractsConfig {
452
280
  export function getGenesisStateConfigEnvVars(): GenesisStateConfig {
453
281
  return getConfigFromMappings(genesisStateConfigMappings);
454
282
  }
455
-
456
- /**
457
- * Validates the L1 contracts configuration to ensure all requirements enforced by L1 contracts
458
- * during construction are satisfied before deployment.
459
- * Accumulates all validation errors and throws an exception listing them all if any are found.
460
- */
461
- export function validateConfig(config: Omit<L1ContractsConfig, keyof L1TxUtilsConfig>): void {
462
- const errors: string[] = [];
463
-
464
- // RollupCore constructor validation: normalFlushSizeMin > 0
465
- // From: require(_config.stakingQueueConfig.normalFlushSizeMin > 0, Errors.Staking__InvalidStakingQueueConfig());
466
- const entryQueueConfig = getEntryQueueConfig('testnet'); // Get config to check normalFlushSizeMin
467
- if (entryQueueConfig.normalFlushSizeMin <= 0n) {
468
- errors.push('normalFlushSizeMin must be greater than 0');
469
- }
470
-
471
- // TimeLib initialization validation: aztecSlotDuration should be a multiple of ethereumSlotDuration
472
- // While not explicitly required in constructor, this is a common validation for time-based systems
473
- if (config.aztecSlotDuration % config.ethereumSlotDuration !== 0) {
474
- errors.push(
475
- `aztecSlotDuration (${config.aztecSlotDuration}) must be a multiple of ethereumSlotDuration (${config.ethereumSlotDuration})`,
476
- );
477
- }
478
-
479
- // EmpireBase constructor validations for governance/slashing proposers
480
- // From: require(QUORUM_SIZE > ROUND_SIZE / 2, Errors.EmpireBase__InvalidQuorumAndRoundSize(QUORUM_SIZE, ROUND_SIZE));
481
- const { governanceProposerQuorum, governanceProposerRoundSize } = config;
482
- if (
483
- governanceProposerQuorum !== undefined &&
484
- governanceProposerQuorum <= Math.floor(governanceProposerRoundSize / 2)
485
- ) {
486
- errors.push(
487
- `governanceProposerQuorum (${governanceProposerQuorum}) must be greater than half of governanceProposerRoundSize (${Math.floor(governanceProposerRoundSize / 2)})`,
488
- );
489
- }
490
-
491
- // From: require(QUORUM_SIZE <= ROUND_SIZE, Errors.EmpireBase__QuorumCannotBeLargerThanRoundSize(QUORUM_SIZE, ROUND_SIZE));
492
- if (governanceProposerQuorum !== undefined && governanceProposerQuorum > governanceProposerRoundSize) {
493
- errors.push(
494
- `governanceProposerQuorum (${governanceProposerQuorum}) cannot be larger than governanceProposerRoundSize (${governanceProposerRoundSize})`,
495
- );
496
- }
497
-
498
- // Slashing quorum validations (similar to governance quorum)
499
- const slashingRoundSize = config.slashingRoundSizeInEpochs * config.aztecEpochDuration;
500
- const { slashingQuorum } = config;
501
- if (slashingQuorum !== undefined && slashingQuorum <= Math.floor(slashingRoundSize / 2)) {
502
- errors.push(
503
- `slashingQuorum (${slashingQuorum}) must be greater than half of slashingRoundSizeInEpochs (${Math.floor(slashingRoundSize / 2)})`,
504
- );
505
- }
506
-
507
- if (slashingQuorum !== undefined && slashingQuorum > slashingRoundSize) {
508
- errors.push(
509
- `slashingQuorum (${slashingQuorum}) cannot be larger than slashingRoundSizeInEpochs (${slashingRoundSize})`,
510
- );
511
- }
512
-
513
- // EmpireBase and TallySlashingProposer lifetime and execution delay validation
514
- // From: require(LIFETIME_IN_ROUNDS > EXECUTION_DELAY_IN_ROUNDS);
515
- if (config.slashingLifetimeInRounds <= config.slashingExecutionDelayInRounds) {
516
- errors.push(
517
- `slashingLifetimeInRounds (${config.slashingLifetimeInRounds}) must be greater than slashingExecutionDelayInRounds (${config.slashingExecutionDelayInRounds})`,
518
- );
519
- }
520
-
521
- // Staking asset validation: activationThreshold > ejectionThreshold
522
- if (config.activationThreshold < config.ejectionThreshold) {
523
- errors.push(
524
- `activationThreshold (${config.activationThreshold}) must be greater than ejectionThreshold (${config.ejectionThreshold})`,
525
- );
526
- }
527
-
528
- // TallySlashingProposer constructor validations
529
- if (config.slasherFlavor === 'tally') {
530
- validateTallySlasherConfig(config, errors);
531
- }
532
-
533
- // Epoch and slot duration validations
534
- if (config.aztecSlotDuration <= 0) {
535
- errors.push('aztecSlotDuration must be greater than 0');
536
- }
537
-
538
- if (config.ethereumSlotDuration <= 0) {
539
- errors.push('ethereumSlotDuration must be greater than 0');
540
- }
541
-
542
- if (config.aztecEpochDuration <= 0) {
543
- errors.push('aztecEpochDuration must be greater than 0');
544
- }
545
-
546
- // Committee size validation
547
- if (config.aztecTargetCommitteeSize < 0) {
548
- errors.push('aztecTargetCommitteeSize cannot be negative');
549
- }
550
-
551
- // Proof submission epochs validation
552
- if (config.aztecProofSubmissionEpochs < 0) {
553
- errors.push('aztecProofSubmissionEpochs cannot be negative');
554
- }
555
-
556
- // Exit delay validation
557
- if (config.exitDelaySeconds < 0) {
558
- errors.push('exitDelaySeconds cannot be negative');
559
- }
560
-
561
- // Mana validation
562
- if (config.manaTarget < 0n) {
563
- errors.push('manaTarget cannot be negative');
564
- }
565
-
566
- if (config.provingCostPerMana < 0n) {
567
- errors.push('provingCostPerMana cannot be negative');
568
- }
569
-
570
- // If any errors were found, throw an exception with all of them
571
- if (errors.length > 0) {
572
- throw new Error(
573
- `L1 contracts configuration validation failed with ${errors.length} error(s):\n${errors.map((error, index) => `${index + 1}. ${error}`).join('\n')}`,
574
- );
575
- }
576
- }
577
-
578
- function validateTallySlasherConfig(config: L1ContractsConfig, errors: string[]) {
579
- if (config.slasherFlavor !== 'tally') {
580
- return;
581
- }
582
-
583
- // From: require(SLASH_OFFSET_IN_ROUNDS > 0, Errors.TallySlashingProposer__SlashOffsetMustBeGreaterThanZero(...));
584
- if (config.slashingOffsetInRounds <= 0) {
585
- errors.push(`slashingOffsetInRounds (${config.slashingOffsetInRounds}) must be greater than 0`);
586
- }
587
-
588
- // From: require(ROUND_SIZE_IN_EPOCHS * _epochDuration == ROUND_SIZE, Errors.TallySlashingProposer__RoundSizeMustBeMultipleOfEpochDuration(...));
589
- const roundSizeInSlots = config.slashingRoundSizeInEpochs * config.aztecEpochDuration;
590
-
591
- // From: require(QUORUM > 0, Errors.TallySlashingProposer__QuorumMustBeGreaterThanZero());
592
- const { slashingQuorum } = config;
593
- if (slashingQuorum !== undefined && slashingQuorum <= 0) {
594
- errors.push(`slashingQuorum (${slashingQuorum}) must be greater than 0`);
595
- }
596
-
597
- // From: require(ROUND_SIZE > 1, Errors.TallySlashingProposer__InvalidQuorumAndRoundSize(QUORUM, ROUND_SIZE));
598
- if (roundSizeInSlots <= 1) {
599
- errors.push(`slashing round size in slots (${roundSizeInSlots}) must be greater than 1`);
600
- }
601
-
602
- // From: require(_slashAmounts[0] <= _slashAmounts[1], Errors.TallySlashingProposer__InvalidSlashAmounts(_slashAmounts));
603
- if (config.slashAmountSmall > config.slashAmountMedium) {
604
- errors.push(
605
- `slashAmountSmall (${config.slashAmountSmall}) must be less than or equal to slashAmountMedium (${config.slashAmountMedium})`,
606
- );
607
- }
608
-
609
- // From: require(_slashAmounts[1] <= _slashAmounts[2], Errors.TallySlashingProposer__InvalidSlashAmounts(_slashAmounts));
610
- if (config.slashAmountMedium > config.slashAmountLarge) {
611
- errors.push(
612
- `slashAmountMedium (${config.slashAmountMedium}) must be less than or equal to slashAmountLarge (${config.slashAmountLarge})`,
613
- );
614
- }
615
-
616
- // From: require(LIFETIME_IN_ROUNDS < ROUNDABOUT_SIZE, Errors.TallySlashingProposer__LifetimeMustBeLessThanRoundabout(...));
617
- const ROUNDABOUT_SIZE = 128; // Constant from TallySlashingProposer
618
- if (config.slashingLifetimeInRounds >= ROUNDABOUT_SIZE) {
619
- errors.push(`slashingLifetimeInRounds (${config.slashingLifetimeInRounds}) must be less than ${ROUNDABOUT_SIZE}`);
620
- }
621
-
622
- // From: require(ROUND_SIZE_IN_EPOCHS > 0, Errors.TallySlashingProposer__RoundSizeInEpochsMustBeGreaterThanZero(...));
623
- if (config.slashingRoundSizeInEpochs <= 0) {
624
- errors.push(`slashingRoundSizeInEpochs (${config.slashingRoundSizeInEpochs}) must be greater than 0`);
625
- }
626
-
627
- // From: require(ROUND_SIZE < MAX_ROUND_SIZE, Errors.TallySlashingProposer__RoundSizeTooLarge(ROUND_SIZE, MAX_ROUND_SIZE));
628
- const MAX_ROUND_SIZE = 1024; // Constant from TallySlashingProposer
629
- if (roundSizeInSlots >= MAX_ROUND_SIZE) {
630
- errors.push(`slashing round size in slots (${roundSizeInSlots}) must be less than ${MAX_ROUND_SIZE}`);
631
- }
632
-
633
- // From: require(COMMITTEE_SIZE > 0, Errors.TallySlashingProposer__CommitteeSizeMustBeGreaterThanZero(COMMITTEE_SIZE));
634
- if (config.aztecTargetCommitteeSize <= 0) {
635
- errors.push(`aztecTargetCommitteeSize (${config.aztecTargetCommitteeSize}) must be greater than 0`);
636
- }
637
-
638
- // From: require(voteSize <= 128, Errors.TallySlashingProposer__VoteSizeTooBig(voteSize, 128));
639
- // voteSize = COMMITTEE_SIZE * ROUND_SIZE_IN_EPOCHS / 4
640
- const voteSize = (config.aztecTargetCommitteeSize * config.slashingRoundSizeInEpochs) / 4;
641
- if (voteSize > 128) {
642
- errors.push(`vote size (${voteSize}) must be <= 128 (committee size * round size in epochs / 4)`);
643
- }
644
-
645
- // From: require(COMMITTEE_SIZE * ROUND_SIZE_IN_EPOCHS % 4 == 0, Errors.TallySlashingProposer__InvalidCommitteeAndRoundSize(...));
646
- if ((config.aztecTargetCommitteeSize * config.slashingRoundSizeInEpochs) % 4 !== 0) {
647
- errors.push(
648
- `aztecTargetCommitteeSize * slashingRoundSizeInEpochs (${config.aztecTargetCommitteeSize * config.slashingRoundSizeInEpochs}) must be divisible by 4`,
649
- );
650
- }
651
-
652
- // Slashing offset validation: should be positive to allow proper slashing timing
653
- if (config.slashingOffsetInRounds < 0) {
654
- errors.push('slashingOffsetInRounds cannot be negative');
655
- }
656
- }