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

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 (206) hide show
  1. package/dest/account.d.ts +1 -1
  2. package/dest/chain.d.ts +1 -1
  3. package/dest/client.d.ts +1 -1
  4. package/dest/client.js +6 -2
  5. package/dest/config.d.ts +22 -68
  6. package/dest/config.d.ts.map +1 -1
  7. package/dest/config.js +57 -378
  8. package/dest/constants.d.ts +1 -1
  9. package/dest/contracts/empire_base.d.ts +7 -5
  10. package/dest/contracts/empire_base.d.ts.map +1 -1
  11. package/dest/contracts/empire_base.js +1 -1
  12. package/dest/contracts/empire_slashing_proposer.d.ts +6 -4
  13. package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -1
  14. package/dest/contracts/empire_slashing_proposer.js +17 -2
  15. package/dest/contracts/errors.d.ts +1 -1
  16. package/dest/contracts/errors.d.ts.map +1 -1
  17. package/dest/contracts/fee_asset_handler.d.ts +6 -5
  18. package/dest/contracts/fee_asset_handler.d.ts.map +1 -1
  19. package/dest/contracts/fee_asset_handler.js +9 -9
  20. package/dest/contracts/fee_juice.d.ts +1 -1
  21. package/dest/contracts/fee_juice.d.ts.map +1 -1
  22. package/dest/contracts/governance.d.ts +18 -16
  23. package/dest/contracts/governance.d.ts.map +1 -1
  24. package/dest/contracts/governance.js +9 -1
  25. package/dest/contracts/governance_proposer.d.ts +6 -4
  26. package/dest/contracts/governance_proposer.d.ts.map +1 -1
  27. package/dest/contracts/governance_proposer.js +399 -10
  28. package/dest/contracts/gse.d.ts +1 -1
  29. package/dest/contracts/gse.d.ts.map +1 -1
  30. package/dest/contracts/inbox.d.ts +24 -3
  31. package/dest/contracts/inbox.d.ts.map +1 -1
  32. package/dest/contracts/inbox.js +36 -1
  33. package/dest/contracts/index.d.ts +3 -1
  34. package/dest/contracts/index.d.ts.map +1 -1
  35. package/dest/contracts/index.js +2 -0
  36. package/dest/contracts/log.d.ts +13 -0
  37. package/dest/contracts/log.d.ts.map +1 -0
  38. package/dest/contracts/log.js +1 -0
  39. package/dest/contracts/multicall.d.ts +2 -2
  40. package/dest/contracts/multicall.d.ts.map +1 -1
  41. package/dest/contracts/outbox.d.ts +41 -0
  42. package/dest/contracts/outbox.d.ts.map +1 -0
  43. package/dest/contracts/outbox.js +86 -0
  44. package/dest/contracts/registry.d.ts +1 -1
  45. package/dest/contracts/registry.d.ts.map +1 -1
  46. package/dest/contracts/rollup.d.ts +194 -123
  47. package/dest/contracts/rollup.d.ts.map +1 -1
  48. package/dest/contracts/rollup.js +746 -184
  49. package/dest/contracts/slasher_contract.d.ts +1 -1
  50. package/dest/contracts/slasher_contract.d.ts.map +1 -1
  51. package/dest/contracts/tally_slashing_proposer.d.ts +9 -7
  52. package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -1
  53. package/dest/contracts/tally_slashing_proposer.js +4 -4
  54. package/dest/contracts/utils.d.ts +1 -1
  55. package/dest/deploy_aztec_l1_contracts.d.ts +260 -0
  56. package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
  57. package/dest/deploy_aztec_l1_contracts.js +398 -0
  58. package/dest/deploy_l1_contract.d.ts +68 -0
  59. package/dest/deploy_l1_contract.d.ts.map +1 -0
  60. package/dest/deploy_l1_contract.js +312 -0
  61. package/dest/eth-signer/eth-signer.d.ts +1 -1
  62. package/dest/eth-signer/index.d.ts +1 -1
  63. package/dest/forwarder_proxy.d.ts +32 -0
  64. package/dest/forwarder_proxy.d.ts.map +1 -0
  65. package/dest/forwarder_proxy.js +93 -0
  66. package/dest/generated/l1-contracts-defaults.d.ts +30 -0
  67. package/dest/generated/l1-contracts-defaults.d.ts.map +1 -0
  68. package/dest/generated/l1-contracts-defaults.js +30 -0
  69. package/dest/l1_artifacts.d.ts +6597 -2046
  70. package/dest/l1_artifacts.d.ts.map +1 -1
  71. package/dest/l1_contract_addresses.d.ts +3 -3
  72. package/dest/l1_contract_addresses.d.ts.map +1 -1
  73. package/dest/l1_contract_addresses.js +3 -3
  74. package/dest/l1_reader.d.ts +3 -1
  75. package/dest/l1_reader.d.ts.map +1 -1
  76. package/dest/l1_reader.js +6 -0
  77. package/dest/l1_tx_utils/config.d.ts +5 -5
  78. package/dest/l1_tx_utils/config.d.ts.map +1 -1
  79. package/dest/l1_tx_utils/config.js +30 -7
  80. package/dest/l1_tx_utils/constants.d.ts +7 -1
  81. package/dest/l1_tx_utils/constants.d.ts.map +1 -1
  82. package/dest/l1_tx_utils/constants.js +25 -0
  83. package/dest/l1_tx_utils/factory.d.ts +1 -1
  84. package/dest/l1_tx_utils/fee-strategies/index.d.ts +10 -0
  85. package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
  86. package/dest/l1_tx_utils/fee-strategies/index.js +12 -0
  87. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +8 -0
  88. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
  89. package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +129 -0
  90. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +23 -0
  91. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
  92. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +191 -0
  93. package/dest/l1_tx_utils/fee-strategies/types.d.ts +51 -0
  94. package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
  95. package/dest/l1_tx_utils/fee-strategies/types.js +3 -0
  96. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
  97. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
  98. package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +48 -0
  99. package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
  100. package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
  101. package/dest/l1_tx_utils/index-blobs.js +2 -0
  102. package/dest/l1_tx_utils/index.d.ts +3 -1
  103. package/dest/l1_tx_utils/index.d.ts.map +1 -1
  104. package/dest/l1_tx_utils/index.js +2 -0
  105. package/dest/l1_tx_utils/interfaces.d.ts +2 -2
  106. package/dest/l1_tx_utils/interfaces.d.ts.map +1 -1
  107. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
  108. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
  109. package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
  110. package/dest/l1_tx_utils/l1_tx_utils.d.ts +1 -2
  111. package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -1
  112. package/dest/l1_tx_utils/l1_tx_utils.js +17 -4
  113. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +1 -1
  114. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +1 -1
  115. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +19 -30
  116. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -1
  117. package/dest/l1_tx_utils/readonly_l1_tx_utils.js +54 -162
  118. package/dest/l1_tx_utils/signer.d.ts +1 -1
  119. package/dest/l1_tx_utils/types.d.ts +1 -1
  120. package/dest/l1_tx_utils/types.d.ts.map +1 -1
  121. package/dest/l1_tx_utils/utils.d.ts +1 -1
  122. package/dest/l1_types.d.ts +1 -1
  123. package/dest/publisher_manager.d.ts +3 -2
  124. package/dest/publisher_manager.d.ts.map +1 -1
  125. package/dest/publisher_manager.js +2 -2
  126. package/dest/queries.d.ts +2 -2
  127. package/dest/queries.d.ts.map +1 -1
  128. package/dest/queries.js +16 -6
  129. package/dest/test/chain_monitor.d.ts +27 -24
  130. package/dest/test/chain_monitor.d.ts.map +1 -1
  131. package/dest/test/chain_monitor.js +33 -36
  132. package/dest/test/delayed_tx_utils.d.ts +1 -1
  133. package/dest/test/delayed_tx_utils.d.ts.map +1 -1
  134. package/dest/test/eth_cheat_codes.d.ts +11 -3
  135. package/dest/test/eth_cheat_codes.d.ts.map +1 -1
  136. package/dest/test/eth_cheat_codes.js +11 -3
  137. package/dest/test/eth_cheat_codes_with_state.d.ts +1 -1
  138. package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
  139. package/dest/test/index.d.ts +1 -1
  140. package/dest/test/rollup_cheat_codes.d.ts +17 -13
  141. package/dest/test/rollup_cheat_codes.d.ts.map +1 -1
  142. package/dest/test/rollup_cheat_codes.js +62 -38
  143. package/dest/test/start_anvil.d.ts +4 -1
  144. package/dest/test/start_anvil.d.ts.map +1 -1
  145. package/dest/test/start_anvil.js +3 -2
  146. package/dest/test/tx_delayer.d.ts +1 -1
  147. package/dest/test/tx_delayer.d.ts.map +1 -1
  148. package/dest/test/tx_delayer.js +4 -3
  149. package/dest/test/upgrade_utils.d.ts +1 -1
  150. package/dest/types.d.ts +57 -2
  151. package/dest/types.d.ts.map +1 -1
  152. package/dest/utils.d.ts +15 -3
  153. package/dest/utils.d.ts.map +1 -1
  154. package/dest/utils.js +18 -0
  155. package/dest/zkPassportVerifierAddress.d.ts +1 -1
  156. package/package.json +34 -14
  157. package/src/client.ts +2 -2
  158. package/src/config.ts +71 -458
  159. package/src/contracts/README.md +157 -0
  160. package/src/contracts/empire_base.ts +6 -5
  161. package/src/contracts/empire_slashing_proposer.ts +16 -5
  162. package/src/contracts/fee_asset_handler.ts +8 -7
  163. package/src/contracts/governance.ts +8 -1
  164. package/src/contracts/governance_proposer.ts +16 -5
  165. package/src/contracts/inbox.ts +55 -3
  166. package/src/contracts/index.ts +2 -0
  167. package/src/contracts/log.ts +13 -0
  168. package/src/contracts/outbox.ts +98 -0
  169. package/src/contracts/rollup.ts +417 -160
  170. package/src/contracts/tally_slashing_proposer.ts +11 -8
  171. package/src/deploy_aztec_l1_contracts.ts +619 -0
  172. package/src/deploy_l1_contract.ts +362 -0
  173. package/src/forwarder_proxy.ts +108 -0
  174. package/src/generated/l1-contracts-defaults.ts +32 -0
  175. package/src/l1_contract_addresses.ts +22 -20
  176. package/src/l1_reader.ts +8 -0
  177. package/src/l1_tx_utils/config.ts +32 -11
  178. package/src/l1_tx_utils/constants.ts +11 -0
  179. package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
  180. package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +163 -0
  181. package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +245 -0
  182. package/src/l1_tx_utils/fee-strategies/types.ts +56 -0
  183. package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +119 -0
  184. package/src/l1_tx_utils/index-blobs.ts +2 -0
  185. package/src/l1_tx_utils/index.ts +2 -0
  186. package/src/l1_tx_utils/interfaces.ts +1 -1
  187. package/src/l1_tx_utils/l1_fee_analyzer.ts +803 -0
  188. package/src/l1_tx_utils/l1_tx_utils.ts +24 -4
  189. package/src/l1_tx_utils/readonly_l1_tx_utils.ts +67 -207
  190. package/src/publisher_manager.ts +4 -2
  191. package/src/queries.ts +17 -6
  192. package/src/test/chain_monitor.ts +51 -49
  193. package/src/test/eth_cheat_codes.ts +9 -3
  194. package/src/test/rollup_cheat_codes.ts +63 -43
  195. package/src/test/start_anvil.ts +5 -1
  196. package/src/test/tx_delayer.ts +5 -3
  197. package/src/types.ts +62 -0
  198. package/src/utils.ts +30 -1
  199. package/dest/deploy_l1_contracts.d.ts +0 -226
  200. package/dest/deploy_l1_contracts.d.ts.map +0 -1
  201. package/dest/deploy_l1_contracts.js +0 -1473
  202. package/dest/index.d.ts +0 -18
  203. package/dest/index.d.ts.map +0 -1
  204. package/dest/index.js +0 -17
  205. package/src/deploy_l1_contracts.ts +0 -1849
  206. package/src/index.ts +0 -17
package/dest/config.js CHANGED
@@ -1,263 +1,71 @@
1
- import { bigintConfigHelper, booleanConfigHelper, enumConfigHelper, getConfigFromMappings, numberConfigHelper, optionalNumberConfigHelper } from '@aztec/foundation/config';
1
+ import { bigintConfigHelper, booleanConfigHelper, enumConfigHelper, getConfigFromMappings, getDefaultConfig, numberConfigHelper, optionalNumberConfigHelper } from '@aztec/foundation/config';
2
2
  import { EthAddress } from '@aztec/foundation/eth-address';
3
- import { l1TxUtilsConfigMappings } from './l1_tx_utils/index.js';
4
- export const DefaultL1ContractsConfig = {
5
- ethereumSlotDuration: 12,
6
- aztecSlotDuration: 36,
7
- aztecEpochDuration: 32,
8
- aztecTargetCommitteeSize: 48,
9
- lagInEpochs: 2,
10
- aztecProofSubmissionEpochs: 1,
11
- activationThreshold: 100n * 10n ** 18n,
12
- ejectionThreshold: 50n * 10n ** 18n,
13
- localEjectionThreshold: 98n * 10n ** 18n,
14
- slashAmountSmall: 10n * 10n ** 18n,
15
- slashAmountMedium: 20n * 10n ** 18n,
16
- slashAmountLarge: 50n * 10n ** 18n,
17
- slashingRoundSizeInEpochs: 4,
18
- slashingLifetimeInRounds: 5,
19
- slashingExecutionDelayInRounds: 0,
20
- slashingVetoer: EthAddress.ZERO,
21
- governanceProposerRoundSize: 300,
22
- manaTarget: BigInt(1e10),
23
- provingCostPerMana: BigInt(100),
24
- exitDelaySeconds: 2 * 24 * 60 * 60,
25
- slasherFlavor: 'tally',
26
- slashingOffsetInRounds: 2,
27
- slashingDisableDuration: 5 * 24 * 60 * 60
28
- };
29
- const LocalGovernanceConfiguration = {
30
- proposeConfig: {
31
- lockDelay: 60n * 60n * 24n * 30n,
32
- lockAmount: 1n * 10n ** 24n
33
- },
34
- votingDelay: 60n,
35
- votingDuration: 60n * 60n,
36
- executionDelay: 60n,
37
- gracePeriod: 60n * 60n * 24n * 7n,
38
- quorum: 1n * 10n ** 17n,
39
- requiredYeaMargin: 4n * 10n ** 16n,
40
- minimumVotes: 400n * 10n ** 18n
41
- };
42
- const StagingPublicGovernanceConfiguration = {
43
- proposeConfig: {
44
- lockDelay: 60n * 60n * 24n * 30n,
45
- lockAmount: DefaultL1ContractsConfig.activationThreshold * 100n
46
- },
47
- votingDelay: 60n,
48
- votingDuration: 60n * 60n,
49
- executionDelay: 60n,
50
- gracePeriod: 60n * 60n * 24n * 7n,
51
- quorum: 3n * 10n ** 17n,
52
- requiredYeaMargin: 4n * 10n ** 16n,
53
- minimumVotes: DefaultL1ContractsConfig.ejectionThreshold * 200n
54
- };
55
- const TestnetGovernanceConfiguration = {
56
- proposeConfig: {
57
- lockDelay: 10n * 365n * 24n * 60n * 60n,
58
- lockAmount: 1250n * 200_000n * 10n ** 18n
59
- },
60
- votingDelay: 12n * 60n * 60n,
61
- votingDuration: 1n * 24n * 60n * 60n,
62
- executionDelay: 12n * 60n * 60n,
63
- gracePeriod: 1n * 24n * 60n * 60n,
64
- quorum: 2n * 10n ** 17n,
65
- requiredYeaMargin: 1n * 10n ** 17n,
66
- minimumVotes: 100n * 200_000n * 10n ** 18n
67
- };
68
- const StagingIgnitionGovernanceConfiguration = {
69
- proposeConfig: {
70
- lockDelay: 10n * 365n * 24n * 60n * 60n,
71
- lockAmount: 1250n * 200_000n * 10n ** 18n
72
- },
73
- votingDelay: 7n * 24n * 60n * 60n,
74
- votingDuration: 7n * 24n * 60n * 60n,
75
- executionDelay: 30n * 24n * 60n * 60n,
76
- gracePeriod: 7n * 24n * 60n * 60n,
77
- quorum: 2n * 10n ** 17n,
78
- requiredYeaMargin: 1n * 10n ** 17n,
79
- minimumVotes: 1250n * 200_000n * 10n ** 18n
80
- };
81
- const MainnetGovernanceConfiguration = {
82
- proposeConfig: {
83
- lockDelay: 90n * 24n * 60n * 60n,
84
- lockAmount: 258_750_000n * 10n ** 18n
85
- },
86
- votingDelay: 3n * 24n * 60n * 60n,
87
- votingDuration: 7n * 24n * 60n * 60n,
88
- executionDelay: 7n * 24n * 60n * 60n,
89
- gracePeriod: 7n * 24n * 60n * 60n,
90
- quorum: 2n * 10n ** 17n,
91
- requiredYeaMargin: 33n * 10n ** 16n,
92
- minimumVotes: 1000n * 200_000n * 10n ** 18n
93
- };
94
- export const getGovernanceConfiguration = (networkName)=>{
95
- switch(networkName){
96
- case 'local':
97
- return LocalGovernanceConfiguration;
98
- case 'next-net':
99
- return LocalGovernanceConfiguration;
100
- case 'devnet':
101
- return LocalGovernanceConfiguration;
102
- case 'staging-public':
103
- return StagingPublicGovernanceConfiguration;
104
- case 'testnet':
105
- return TestnetGovernanceConfiguration;
106
- case 'staging-ignition':
107
- return StagingIgnitionGovernanceConfiguration;
108
- case 'mainnet':
109
- return MainnetGovernanceConfiguration;
110
- default:
111
- throw new Error(`Unrecognized network name: ${networkName}`);
112
- }
113
- };
114
- // Making a default config here as we are only using it thought the deployment
115
- // and do not expect to be using different setups, so having environment variables
116
- // for it seems overkill
117
- const DefaultRewardConfig = {
118
- sequencerBps: 8000,
119
- rewardDistributor: EthAddress.ZERO.toString(),
120
- booster: EthAddress.ZERO.toString(),
121
- blockReward: 500n * 10n ** 18n
122
- };
123
- const MainnetRewardConfig = {
124
- sequencerBps: 7_000,
125
- rewardDistributor: EthAddress.ZERO.toString(),
126
- booster: EthAddress.ZERO.toString(),
127
- blockReward: 400n * 10n ** 18n
128
- };
129
- export const getRewardConfig = (networkName)=>{
130
- switch(networkName){
131
- case 'local':
132
- case 'devnet':
133
- case 'next-net':
134
- case 'staging-public':
135
- case 'testnet':
136
- case 'staging-ignition':
137
- return DefaultRewardConfig;
138
- case 'mainnet':
139
- return MainnetRewardConfig;
140
- default:
141
- throw new Error(`Unrecognized network name: ${networkName}`);
142
- }
143
- };
144
- export const getRewardBoostConfig = ()=>{
145
- // The reward configuration is specified with a precision of 1e5, and we use the same across
146
- // all networks.
147
- return {
148
- increment: 125_000,
149
- maxScore: 15_000_000,
150
- a: 1_000,
151
- k: 1_000_000,
152
- minimum: 100_000
153
- };
154
- };
155
- // Similar to the above, no need for environment variables for this.
156
- const LocalEntryQueueConfig = {
157
- bootstrapValidatorSetSize: 0n,
158
- bootstrapFlushSize: 0n,
159
- normalFlushSizeMin: 48n,
160
- normalFlushSizeQuotient: 2n,
161
- maxQueueFlushSize: 48n
162
- };
163
- const StagingPublicEntryQueueConfig = {
164
- bootstrapValidatorSetSize: 48n,
165
- bootstrapFlushSize: 48n,
166
- normalFlushSizeMin: 1n,
167
- normalFlushSizeQuotient: 2475n,
168
- maxQueueFlushSize: 32n
169
- };
170
- const TestnetEntryQueueConfig = {
171
- bootstrapValidatorSetSize: 256n,
172
- bootstrapFlushSize: 256n,
173
- normalFlushSizeMin: 4n,
174
- normalFlushSizeQuotient: 2048n,
175
- maxQueueFlushSize: 8n
176
- };
177
- const StagingIgnitionEntryQueueConfig = {
178
- bootstrapValidatorSetSize: 48n,
179
- bootstrapFlushSize: 48n,
180
- normalFlushSizeMin: 1n,
181
- normalFlushSizeQuotient: 2048n,
182
- maxQueueFlushSize: 24n
183
- };
184
- const MainnetEntryQueueConfig = {
185
- bootstrapValidatorSetSize: 1_000n,
186
- bootstrapFlushSize: 1_000n,
187
- normalFlushSizeMin: 1n,
188
- normalFlushSizeQuotient: 2_048n,
189
- maxQueueFlushSize: 8n
190
- };
191
- export const getEntryQueueConfig = (networkName)=>{
192
- switch(networkName){
193
- case 'local':
194
- return LocalEntryQueueConfig;
195
- case 'next-net':
196
- return LocalEntryQueueConfig;
197
- case 'devnet':
198
- return LocalEntryQueueConfig;
199
- case 'staging-public':
200
- return StagingPublicEntryQueueConfig;
201
- case 'testnet':
202
- return TestnetEntryQueueConfig;
203
- case 'staging-ignition':
204
- return StagingIgnitionEntryQueueConfig;
205
- case 'mainnet':
206
- return MainnetEntryQueueConfig;
207
- default:
208
- throw new Error(`Unrecognized network name: ${networkName}`);
209
- }
210
- };
211
- export const l1ContractsConfigMappings = {
3
+ import { l1ContractsDefaultEnv } from './generated/l1-contracts-defaults.js';
4
+ import { l1TxUtilsConfigMappings } from './l1_tx_utils/config.js';
5
+ /**
6
+ * Config mappings for L1ContractsConfig.
7
+ * Default values come from generated l1-contracts-defaults.json (source: defaults.yml).
8
+ * Real deployments use forge scripts which require explicit env vars (vm.envUint).
9
+ */ export const l1ContractsConfigMappings = {
212
10
  ethereumSlotDuration: {
213
11
  env: 'ETHEREUM_SLOT_DURATION',
214
12
  description: 'How many seconds an L1 slot lasts.',
215
- ...numberConfigHelper(DefaultL1ContractsConfig.ethereumSlotDuration)
13
+ ...numberConfigHelper(l1ContractsDefaultEnv.ETHEREUM_SLOT_DURATION)
216
14
  },
217
15
  aztecSlotDuration: {
218
16
  env: 'AZTEC_SLOT_DURATION',
219
17
  description: 'How many seconds an L2 slots lasts (must be multiple of ethereum slot duration).',
220
- ...numberConfigHelper(DefaultL1ContractsConfig.aztecSlotDuration)
18
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLOT_DURATION)
221
19
  },
222
20
  aztecEpochDuration: {
223
21
  env: 'AZTEC_EPOCH_DURATION',
224
22
  description: `How many L2 slots an epoch lasts (maximum AZTEC_MAX_EPOCH_DURATION).`,
225
- ...numberConfigHelper(DefaultL1ContractsConfig.aztecEpochDuration)
23
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_EPOCH_DURATION)
226
24
  },
227
25
  aztecTargetCommitteeSize: {
228
26
  env: 'AZTEC_TARGET_COMMITTEE_SIZE',
229
27
  description: 'The target validator committee size.',
230
- ...numberConfigHelper(DefaultL1ContractsConfig.aztecTargetCommitteeSize)
28
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_TARGET_COMMITTEE_SIZE)
231
29
  },
232
- lagInEpochs: {
233
- env: 'AZTEC_LAG_IN_EPOCHS',
30
+ lagInEpochsForValidatorSet: {
31
+ env: 'AZTEC_LAG_IN_EPOCHS_FOR_VALIDATOR_SET',
234
32
  description: 'The number of epochs to lag behind the current epoch for validator selection.',
235
- ...numberConfigHelper(DefaultL1ContractsConfig.lagInEpochs)
33
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_LAG_IN_EPOCHS_FOR_VALIDATOR_SET)
34
+ },
35
+ lagInEpochsForRandao: {
36
+ env: 'AZTEC_LAG_IN_EPOCHS_FOR_RANDAO',
37
+ description: 'The number of epochs to lag behind the current epoch for randao selection.',
38
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_LAG_IN_EPOCHS_FOR_RANDAO)
39
+ },
40
+ inboxLag: {
41
+ env: 'AZTEC_INBOX_LAG',
42
+ description: 'The number of checkpoints to lag in the inbox (prevents sequencer DOS attacks).',
43
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_INBOX_LAG)
236
44
  },
237
45
  aztecProofSubmissionEpochs: {
238
46
  env: 'AZTEC_PROOF_SUBMISSION_EPOCHS',
239
47
  description: 'The number of epochs after an epoch ends that proofs are still accepted.',
240
- ...numberConfigHelper(DefaultL1ContractsConfig.aztecProofSubmissionEpochs)
48
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_PROOF_SUBMISSION_EPOCHS)
241
49
  },
242
50
  activationThreshold: {
243
51
  env: 'AZTEC_ACTIVATION_THRESHOLD',
244
52
  description: 'The deposit amount for a validator',
245
- ...bigintConfigHelper(DefaultL1ContractsConfig.activationThreshold)
53
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_ACTIVATION_THRESHOLD))
246
54
  },
247
55
  ejectionThreshold: {
248
56
  env: 'AZTEC_EJECTION_THRESHOLD',
249
57
  description: 'The minimum stake for a validator.',
250
- ...bigintConfigHelper(DefaultL1ContractsConfig.ejectionThreshold)
58
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_EJECTION_THRESHOLD))
251
59
  },
252
60
  localEjectionThreshold: {
253
61
  env: 'AZTEC_LOCAL_EJECTION_THRESHOLD',
254
62
  description: 'The local ejection threshold for a validator. Stricter than ejectionThreshold but local to a specific rollup',
255
- ...bigintConfigHelper(DefaultL1ContractsConfig.localEjectionThreshold)
63
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_LOCAL_EJECTION_THRESHOLD))
256
64
  },
257
65
  slashingOffsetInRounds: {
258
66
  env: 'AZTEC_SLASHING_OFFSET_IN_ROUNDS',
259
67
  description: 'How many slashing rounds back we slash (ie when slashing in round N, we slash for offenses committed during epochs of round N-offset)',
260
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingOffsetInRounds)
68
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_OFFSET_IN_ROUNDS)
261
69
  },
262
70
  slasherFlavor: {
263
71
  env: 'AZTEC_SLASHER_FLAVOR',
@@ -266,22 +74,22 @@ export const l1ContractsConfigMappings = {
266
74
  'empire',
267
75
  'tally',
268
76
  'none'
269
- ], DefaultL1ContractsConfig.slasherFlavor)
77
+ ], l1ContractsDefaultEnv.AZTEC_SLASHER_FLAVOR)
270
78
  },
271
79
  slashAmountSmall: {
272
80
  env: 'AZTEC_SLASH_AMOUNT_SMALL',
273
81
  description: 'Small slashing amount for light offenses',
274
- ...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountSmall)
82
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_SLASH_AMOUNT_SMALL))
275
83
  },
276
84
  slashAmountMedium: {
277
85
  env: 'AZTEC_SLASH_AMOUNT_MEDIUM',
278
86
  description: 'Medium slashing amount for moderate offenses',
279
- ...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountMedium)
87
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_SLASH_AMOUNT_MEDIUM))
280
88
  },
281
89
  slashAmountLarge: {
282
90
  env: 'AZTEC_SLASH_AMOUNT_LARGE',
283
91
  description: 'Large slashing amount for severe offenses',
284
- ...bigintConfigHelper(DefaultL1ContractsConfig.slashAmountLarge)
92
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_SLASH_AMOUNT_LARGE))
285
93
  },
286
94
  slashingQuorum: {
287
95
  env: 'AZTEC_SLASHING_QUORUM',
@@ -291,28 +99,28 @@ export const l1ContractsConfigMappings = {
291
99
  slashingRoundSizeInEpochs: {
292
100
  env: 'AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS',
293
101
  description: 'The slashing round size',
294
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingRoundSizeInEpochs)
102
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS)
295
103
  },
296
104
  slashingLifetimeInRounds: {
297
105
  env: 'AZTEC_SLASHING_LIFETIME_IN_ROUNDS',
298
106
  description: 'The slashing lifetime in rounds',
299
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingLifetimeInRounds)
107
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_LIFETIME_IN_ROUNDS)
300
108
  },
301
109
  slashingExecutionDelayInRounds: {
302
110
  env: 'AZTEC_SLASHING_EXECUTION_DELAY_IN_ROUNDS',
303
111
  description: 'The slashing execution delay in rounds',
304
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingExecutionDelayInRounds)
112
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_EXECUTION_DELAY_IN_ROUNDS)
305
113
  },
306
114
  slashingVetoer: {
307
115
  env: 'AZTEC_SLASHING_VETOER',
308
116
  description: 'The slashing vetoer',
309
117
  parseEnv: (val)=>EthAddress.fromString(val),
310
- defaultValue: DefaultL1ContractsConfig.slashingVetoer
118
+ defaultValue: EthAddress.fromString(l1ContractsDefaultEnv.AZTEC_SLASHING_VETOER)
311
119
  },
312
120
  slashingDisableDuration: {
313
121
  env: 'AZTEC_SLASHING_DISABLE_DURATION',
314
122
  description: 'How long slashing can be disabled for in seconds when vetoer disables it',
315
- ...numberConfigHelper(DefaultL1ContractsConfig.slashingDisableDuration)
123
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_SLASHING_DISABLE_DURATION)
316
124
  },
317
125
  governanceProposerQuorum: {
318
126
  env: 'AZTEC_GOVERNANCE_PROPOSER_QUORUM',
@@ -322,25 +130,39 @@ export const l1ContractsConfigMappings = {
322
130
  governanceProposerRoundSize: {
323
131
  env: 'AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE',
324
132
  description: 'The governance proposing round size',
325
- ...numberConfigHelper(DefaultL1ContractsConfig.governanceProposerRoundSize)
133
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE)
134
+ },
135
+ governanceVotingDuration: {
136
+ env: 'AZTEC_GOVERNANCE_VOTING_DURATION',
137
+ description: 'Governance voting duration in seconds (only for local/devnet/next-net)',
138
+ ...numberConfigHelper(3600)
326
139
  },
327
140
  manaTarget: {
328
141
  env: 'AZTEC_MANA_TARGET',
329
142
  description: 'The mana target for the rollup',
330
- ...bigintConfigHelper(DefaultL1ContractsConfig.manaTarget)
143
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_MANA_TARGET))
331
144
  },
332
145
  provingCostPerMana: {
333
146
  env: 'AZTEC_PROVING_COST_PER_MANA',
334
147
  description: 'The proving cost per mana',
335
- ...bigintConfigHelper(DefaultL1ContractsConfig.provingCostPerMana)
148
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_PROVING_COST_PER_MANA))
149
+ },
150
+ initialEthPerFeeAsset: {
151
+ env: 'AZTEC_INITIAL_ETH_PER_FEE_ASSET',
152
+ description: 'The initial ETH per fee asset price (with 1e12 precision)',
153
+ ...bigintConfigHelper(BigInt(l1ContractsDefaultEnv.AZTEC_INITIAL_ETH_PER_FEE_ASSET))
336
154
  },
337
155
  exitDelaySeconds: {
338
156
  env: 'AZTEC_EXIT_DELAY_SECONDS',
339
157
  description: 'The delay before a validator can exit the set',
340
- ...numberConfigHelper(DefaultL1ContractsConfig.exitDelaySeconds)
158
+ ...numberConfigHelper(l1ContractsDefaultEnv.AZTEC_EXIT_DELAY_SECONDS)
341
159
  },
342
160
  ...l1TxUtilsConfigMappings
343
161
  };
162
+ /**
163
+ * Default L1 contracts configuration derived from l1ContractsConfigMappings.
164
+ * Source of truth: spartan/environments/defaults.yml -> defaults.l1-contracts
165
+ */ export const DefaultL1ContractsConfig = getDefaultConfig(l1ContractsConfigMappings);
344
166
  export const genesisStateConfigMappings = {
345
167
  testAccounts: {
346
168
  env: 'TEST_ACCOUNTS',
@@ -359,146 +181,3 @@ export function getL1ContractsConfigEnvVars() {
359
181
  export function getGenesisStateConfigEnvVars() {
360
182
  return getConfigFromMappings(genesisStateConfigMappings);
361
183
  }
362
- /**
363
- * Validates the L1 contracts configuration to ensure all requirements enforced by L1 contracts
364
- * during construction are satisfied before deployment.
365
- * Accumulates all validation errors and throws an exception listing them all if any are found.
366
- */ export function validateConfig(config) {
367
- const errors = [];
368
- // RollupCore constructor validation: normalFlushSizeMin > 0
369
- // From: require(_config.stakingQueueConfig.normalFlushSizeMin > 0, Errors.Staking__InvalidStakingQueueConfig());
370
- const entryQueueConfig = getEntryQueueConfig('testnet'); // Get config to check normalFlushSizeMin
371
- if (entryQueueConfig.normalFlushSizeMin <= 0n) {
372
- errors.push('normalFlushSizeMin must be greater than 0');
373
- }
374
- // TimeLib initialization validation: aztecSlotDuration should be a multiple of ethereumSlotDuration
375
- // While not explicitly required in constructor, this is a common validation for time-based systems
376
- if (config.aztecSlotDuration % config.ethereumSlotDuration !== 0) {
377
- errors.push(`aztecSlotDuration (${config.aztecSlotDuration}) must be a multiple of ethereumSlotDuration (${config.ethereumSlotDuration})`);
378
- }
379
- // EmpireBase constructor validations for governance/slashing proposers
380
- // From: require(QUORUM_SIZE > ROUND_SIZE / 2, Errors.EmpireBase__InvalidQuorumAndRoundSize(QUORUM_SIZE, ROUND_SIZE));
381
- const { governanceProposerQuorum, governanceProposerRoundSize } = config;
382
- if (governanceProposerQuorum !== undefined && governanceProposerQuorum <= Math.floor(governanceProposerRoundSize / 2)) {
383
- errors.push(`governanceProposerQuorum (${governanceProposerQuorum}) must be greater than half of governanceProposerRoundSize (${Math.floor(governanceProposerRoundSize / 2)})`);
384
- }
385
- // From: require(QUORUM_SIZE <= ROUND_SIZE, Errors.EmpireBase__QuorumCannotBeLargerThanRoundSize(QUORUM_SIZE, ROUND_SIZE));
386
- if (governanceProposerQuorum !== undefined && governanceProposerQuorum > governanceProposerRoundSize) {
387
- errors.push(`governanceProposerQuorum (${governanceProposerQuorum}) cannot be larger than governanceProposerRoundSize (${governanceProposerRoundSize})`);
388
- }
389
- // Slashing quorum validations (similar to governance quorum)
390
- const slashingRoundSize = config.slashingRoundSizeInEpochs * config.aztecEpochDuration;
391
- const { slashingQuorum } = config;
392
- if (slashingQuorum !== undefined && slashingQuorum <= Math.floor(slashingRoundSize / 2)) {
393
- errors.push(`slashingQuorum (${slashingQuorum}) must be greater than half of slashingRoundSizeInEpochs (${Math.floor(slashingRoundSize / 2)})`);
394
- }
395
- if (slashingQuorum !== undefined && slashingQuorum > slashingRoundSize) {
396
- errors.push(`slashingQuorum (${slashingQuorum}) cannot be larger than slashingRoundSizeInEpochs (${slashingRoundSize})`);
397
- }
398
- // EmpireBase and TallySlashingProposer lifetime and execution delay validation
399
- // From: require(LIFETIME_IN_ROUNDS > EXECUTION_DELAY_IN_ROUNDS);
400
- if (config.slashingLifetimeInRounds <= config.slashingExecutionDelayInRounds) {
401
- errors.push(`slashingLifetimeInRounds (${config.slashingLifetimeInRounds}) must be greater than slashingExecutionDelayInRounds (${config.slashingExecutionDelayInRounds})`);
402
- }
403
- // Staking asset validation: activationThreshold > ejectionThreshold
404
- if (config.activationThreshold < config.ejectionThreshold) {
405
- errors.push(`activationThreshold (${config.activationThreshold}) must be greater than ejectionThreshold (${config.ejectionThreshold})`);
406
- }
407
- // TallySlashingProposer constructor validations
408
- if (config.slasherFlavor === 'tally') {
409
- validateTallySlasherConfig(config, errors);
410
- }
411
- // Epoch and slot duration validations
412
- if (config.aztecSlotDuration <= 0) {
413
- errors.push('aztecSlotDuration must be greater than 0');
414
- }
415
- if (config.ethereumSlotDuration <= 0) {
416
- errors.push('ethereumSlotDuration must be greater than 0');
417
- }
418
- if (config.aztecEpochDuration <= 0) {
419
- errors.push('aztecEpochDuration must be greater than 0');
420
- }
421
- // Committee size validation
422
- if (config.aztecTargetCommitteeSize < 0) {
423
- errors.push('aztecTargetCommitteeSize cannot be negative');
424
- }
425
- // Proof submission epochs validation
426
- if (config.aztecProofSubmissionEpochs < 0) {
427
- errors.push('aztecProofSubmissionEpochs cannot be negative');
428
- }
429
- // Exit delay validation
430
- if (config.exitDelaySeconds < 0) {
431
- errors.push('exitDelaySeconds cannot be negative');
432
- }
433
- // Mana validation
434
- if (config.manaTarget < 0n) {
435
- errors.push('manaTarget cannot be negative');
436
- }
437
- if (config.provingCostPerMana < 0n) {
438
- errors.push('provingCostPerMana cannot be negative');
439
- }
440
- // If any errors were found, throw an exception with all of them
441
- if (errors.length > 0) {
442
- throw new Error(`L1 contracts configuration validation failed with ${errors.length} error(s):\n${errors.map((error, index)=>`${index + 1}. ${error}`).join('\n')}`);
443
- }
444
- }
445
- function validateTallySlasherConfig(config, errors) {
446
- if (config.slasherFlavor !== 'tally') {
447
- return;
448
- }
449
- // From: require(SLASH_OFFSET_IN_ROUNDS > 0, Errors.TallySlashingProposer__SlashOffsetMustBeGreaterThanZero(...));
450
- if (config.slashingOffsetInRounds <= 0) {
451
- errors.push(`slashingOffsetInRounds (${config.slashingOffsetInRounds}) must be greater than 0`);
452
- }
453
- // From: require(ROUND_SIZE_IN_EPOCHS * _epochDuration == ROUND_SIZE, Errors.TallySlashingProposer__RoundSizeMustBeMultipleOfEpochDuration(...));
454
- const roundSizeInSlots = config.slashingRoundSizeInEpochs * config.aztecEpochDuration;
455
- // From: require(QUORUM > 0, Errors.TallySlashingProposer__QuorumMustBeGreaterThanZero());
456
- const { slashingQuorum } = config;
457
- if (slashingQuorum !== undefined && slashingQuorum <= 0) {
458
- errors.push(`slashingQuorum (${slashingQuorum}) must be greater than 0`);
459
- }
460
- // From: require(ROUND_SIZE > 1, Errors.TallySlashingProposer__InvalidQuorumAndRoundSize(QUORUM, ROUND_SIZE));
461
- if (roundSizeInSlots <= 1) {
462
- errors.push(`slashing round size in slots (${roundSizeInSlots}) must be greater than 1`);
463
- }
464
- // From: require(_slashAmounts[0] <= _slashAmounts[1], Errors.TallySlashingProposer__InvalidSlashAmounts(_slashAmounts));
465
- if (config.slashAmountSmall > config.slashAmountMedium) {
466
- errors.push(`slashAmountSmall (${config.slashAmountSmall}) must be less than or equal to slashAmountMedium (${config.slashAmountMedium})`);
467
- }
468
- // From: require(_slashAmounts[1] <= _slashAmounts[2], Errors.TallySlashingProposer__InvalidSlashAmounts(_slashAmounts));
469
- if (config.slashAmountMedium > config.slashAmountLarge) {
470
- errors.push(`slashAmountMedium (${config.slashAmountMedium}) must be less than or equal to slashAmountLarge (${config.slashAmountLarge})`);
471
- }
472
- // From: require(LIFETIME_IN_ROUNDS < ROUNDABOUT_SIZE, Errors.TallySlashingProposer__LifetimeMustBeLessThanRoundabout(...));
473
- const ROUNDABOUT_SIZE = 128; // Constant from TallySlashingProposer
474
- if (config.slashingLifetimeInRounds >= ROUNDABOUT_SIZE) {
475
- errors.push(`slashingLifetimeInRounds (${config.slashingLifetimeInRounds}) must be less than ${ROUNDABOUT_SIZE}`);
476
- }
477
- // From: require(ROUND_SIZE_IN_EPOCHS > 0, Errors.TallySlashingProposer__RoundSizeInEpochsMustBeGreaterThanZero(...));
478
- if (config.slashingRoundSizeInEpochs <= 0) {
479
- errors.push(`slashingRoundSizeInEpochs (${config.slashingRoundSizeInEpochs}) must be greater than 0`);
480
- }
481
- // From: require(ROUND_SIZE < MAX_ROUND_SIZE, Errors.TallySlashingProposer__RoundSizeTooLarge(ROUND_SIZE, MAX_ROUND_SIZE));
482
- const MAX_ROUND_SIZE = 1024; // Constant from TallySlashingProposer
483
- if (roundSizeInSlots >= MAX_ROUND_SIZE) {
484
- errors.push(`slashing round size in slots (${roundSizeInSlots}) must be less than ${MAX_ROUND_SIZE}`);
485
- }
486
- // From: require(COMMITTEE_SIZE > 0, Errors.TallySlashingProposer__CommitteeSizeMustBeGreaterThanZero(COMMITTEE_SIZE));
487
- if (config.aztecTargetCommitteeSize <= 0) {
488
- errors.push(`aztecTargetCommitteeSize (${config.aztecTargetCommitteeSize}) must be greater than 0`);
489
- }
490
- // From: require(voteSize <= 128, Errors.TallySlashingProposer__VoteSizeTooBig(voteSize, 128));
491
- // voteSize = COMMITTEE_SIZE * ROUND_SIZE_IN_EPOCHS / 4
492
- const voteSize = config.aztecTargetCommitteeSize * config.slashingRoundSizeInEpochs / 4;
493
- if (voteSize > 128) {
494
- errors.push(`vote size (${voteSize}) must be <= 128 (committee size * round size in epochs / 4)`);
495
- }
496
- // From: require(COMMITTEE_SIZE * ROUND_SIZE_IN_EPOCHS % 4 == 0, Errors.TallySlashingProposer__InvalidCommitteeAndRoundSize(...));
497
- if (config.aztecTargetCommitteeSize * config.slashingRoundSizeInEpochs % 4 !== 0) {
498
- errors.push(`aztecTargetCommitteeSize * slashingRoundSizeInEpochs (${config.aztecTargetCommitteeSize * config.slashingRoundSizeInEpochs}) must be divisible by 4`);
499
- }
500
- // Slashing offset validation: should be positive to allow proper slashing timing
501
- if (config.slashingOffsetInRounds < 0) {
502
- errors.push('slashingOffsetInRounds cannot be negative');
503
- }
504
- }
@@ -1,4 +1,4 @@
1
1
  import type { Hex } from 'viem';
2
2
  export declare const NULL_KEY: Hex;
3
3
  export declare const AZTEC_TEST_CHAIN_ID = 677692;
4
- //# sourceMappingURL=constants.d.ts.map
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVoQyxlQUFPLE1BQU0sUUFBUSxFQUFFLEdBQStFLENBQUM7QUFDdkcsZUFBTyxNQUFNLG1CQUFtQixTQUFTLENBQUMifQ==
@@ -1,3 +1,4 @@
1
+ import type { SlotNumber } from '@aztec/foundation/branded-types';
1
2
  import type { EthAddress } from '@aztec/foundation/eth-address';
2
3
  import { Signature } from '@aztec/foundation/eth-signature';
3
4
  import { type Hex, type TypedDataDefinition } from 'viem';
@@ -5,13 +6,14 @@ import type { L1TxRequest } from '../l1_tx_utils/index.js';
5
6
  export interface IEmpireBase {
6
7
  get address(): EthAddress;
7
8
  getRoundInfo(rollupAddress: Hex, round: bigint): Promise<{
8
- lastSignalSlot: bigint;
9
+ lastSignalSlot: SlotNumber;
9
10
  payloadWithMostSignals: Hex;
11
+ quorumReached: boolean;
10
12
  executed: boolean;
11
13
  }>;
12
- computeRound(slot: bigint): Promise<bigint>;
14
+ computeRound(slot: SlotNumber): Promise<bigint>;
13
15
  createSignalRequest(payload: Hex): L1TxRequest;
14
- createSignalRequestWithSignature(payload: Hex, round: bigint, chainId: number, signerAddress: Hex, signer: (msg: TypedDataDefinition) => Promise<Hex>): Promise<L1TxRequest>;
16
+ createSignalRequestWithSignature(payload: Hex, slot: SlotNumber, chainId: number, signerAddress: Hex, signer: (msg: TypedDataDefinition) => Promise<Hex>): Promise<L1TxRequest>;
15
17
  }
16
18
  export declare function encodeSignal(payload: Hex): Hex;
17
19
  export declare function encodeSignalWithSignature(payload: Hex, signature: Signature): `0x${string}`;
@@ -24,5 +26,5 @@ export declare function encodeSignalWithSignature(payload: Hex, signature: Signa
24
26
  * @param account - The account to sign with (optional if hoisted on wallet client)
25
27
  * @returns The EIP-712 signature
26
28
  */
27
- export declare function signSignalWithSig(signer: (msg: TypedDataDefinition) => Promise<Hex>, payload: Hex, slot: bigint, instance: Hex, verifyingContract: Hex, chainId: number): Promise<Signature>;
28
- //# sourceMappingURL=empire_base.d.ts.map
29
+ export declare function signSignalWithSig(signer: (msg: TypedDataDefinition) => Promise<Hex>, payload: Hex, slot: SlotNumber, instance: Hex, verifyingContract: Hex, chainId: number): Promise<Signature>;
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1waXJlX2Jhc2UuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cmFjdHMvZW1waXJlX2Jhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDaEUsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBRzVELE9BQU8sRUFBRSxLQUFLLEdBQUcsRUFBRSxLQUFLLG1CQUFtQixFQUFzQixNQUFNLE1BQU0sQ0FBQztBQUU5RSxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUUzRCxNQUFNLFdBQVcsV0FBVztJQUMxQixJQUFJLE9BQU8sSUFBSSxVQUFVLENBQUM7SUFDMUIsWUFBWSxDQUNWLGFBQWEsRUFBRSxHQUFHLEVBQ2xCLEtBQUssRUFBRSxNQUFNLEdBQ1osT0FBTyxDQUFDO1FBQUUsY0FBYyxFQUFFLFVBQVUsQ0FBQztRQUFDLHNCQUFzQixFQUFFLEdBQUcsQ0FBQztRQUFDLGFBQWEsRUFBRSxPQUFPLENBQUM7UUFBQyxRQUFRLEVBQUUsT0FBTyxDQUFBO0tBQUUsQ0FBQyxDQUFDO0lBQ25ILFlBQVksQ0FBQyxJQUFJLEVBQUUsVUFBVSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNoRCxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsR0FBRyxHQUFHLFdBQVcsQ0FBQztJQUMvQyxnQ0FBZ0MsQ0FDOUIsT0FBTyxFQUFFLEdBQUcsRUFDWixJQUFJLEVBQUUsVUFBVSxFQUNoQixPQUFPLEVBQUUsTUFBTSxFQUNmLGFBQWEsRUFBRSxHQUFHLEVBQ2xCLE1BQU0sRUFBRSxDQUFDLEdBQUcsRUFBRSxtQkFBbUIsS0FBSyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQ2pELE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztDQUN6QjtBQUVELHdCQUFnQixZQUFZLENBQUMsT0FBTyxFQUFFLEdBQUcsR0FBRyxHQUFHLENBTTlDO0FBRUQsd0JBQWdCLHlCQUF5QixDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLFNBQVMsaUJBTTNFO0FBRUQ7Ozs7Ozs7O0dBUUc7QUFDSCx3QkFBc0IsaUJBQWlCLENBQ3JDLE1BQU0sRUFBRSxDQUFDLEdBQUcsRUFBRSxtQkFBbUIsS0FBSyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQ2xELE9BQU8sRUFBRSxHQUFHLEVBQ1osSUFBSSxFQUFFLFVBQVUsRUFDaEIsUUFBUSxFQUFFLEdBQUcsRUFDYixpQkFBaUIsRUFBRSxHQUFHLEVBQ3RCLE9BQU8sRUFBRSxNQUFNLEdBQ2QsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQThCcEIifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"empire_base.d.ts","sourceRoot":"","sources":["../../src/contracts/empire_base.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAG5D,OAAO,EAAE,KAAK,GAAG,EAAE,KAAK,mBAAmB,EAAsB,MAAM,MAAM,CAAC;AAE9E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,WAAW,WAAW;IAC1B,IAAI,OAAO,IAAI,UAAU,CAAC;IAC1B,YAAY,CACV,aAAa,EAAE,GAAG,EAClB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC;QAAE,cAAc,EAAE,MAAM,CAAC;QAAC,sBAAsB,EAAE,GAAG,CAAC;QAAC,QAAQ,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;IACvF,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC5C,mBAAmB,CAAC,OAAO,EAAE,GAAG,GAAG,WAAW,CAAC;IAC/C,gCAAgC,CAC9B,OAAO,EAAE,GAAG,EACZ,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,GAAG,EAClB,MAAM,EAAE,CAAC,GAAG,EAAE,mBAAmB,KAAK,OAAO,CAAC,GAAG,CAAC,GACjD,OAAO,CAAC,WAAW,CAAC,CAAC;CACzB;AAED,wBAAgB,YAAY,CAAC,OAAO,EAAE,GAAG,GAAG,GAAG,CAM9C;AAED,wBAAgB,yBAAyB,CAAC,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,iBAM3E;AAED;;;;;;;;GAQG;AACH,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,CAAC,GAAG,EAAE,mBAAmB,KAAK,OAAO,CAAC,GAAG,CAAC,EAClD,OAAO,EAAE,GAAG,EACZ,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,GAAG,EACb,iBAAiB,EAAE,GAAG,EACtB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,SAAS,CAAC,CA8BpB"}
1
+ {"version":3,"file":"empire_base.d.ts","sourceRoot":"","sources":["../../src/contracts/empire_base.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAG5D,OAAO,EAAE,KAAK,GAAG,EAAE,KAAK,mBAAmB,EAAsB,MAAM,MAAM,CAAC;AAE9E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,WAAW,WAAW;IAC1B,IAAI,OAAO,IAAI,UAAU,CAAC;IAC1B,YAAY,CACV,aAAa,EAAE,GAAG,EAClB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC;QAAE,cAAc,EAAE,UAAU,CAAC;QAAC,sBAAsB,EAAE,GAAG,CAAC;QAAC,aAAa,EAAE,OAAO,CAAC;QAAC,QAAQ,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;IACnH,YAAY,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAChD,mBAAmB,CAAC,OAAO,EAAE,GAAG,GAAG,WAAW,CAAC;IAC/C,gCAAgC,CAC9B,OAAO,EAAE,GAAG,EACZ,IAAI,EAAE,UAAU,EAChB,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,GAAG,EAClB,MAAM,EAAE,CAAC,GAAG,EAAE,mBAAmB,KAAK,OAAO,CAAC,GAAG,CAAC,GACjD,OAAO,CAAC,WAAW,CAAC,CAAC;CACzB;AAED,wBAAgB,YAAY,CAAC,OAAO,EAAE,GAAG,GAAG,GAAG,CAM9C;AAED,wBAAgB,yBAAyB,CAAC,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,iBAM3E;AAED;;;;;;;;GAQG;AACH,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,CAAC,GAAG,EAAE,mBAAmB,KAAK,OAAO,CAAC,GAAG,CAAC,EAClD,OAAO,EAAE,GAAG,EACZ,IAAI,EAAE,UAAU,EAChB,QAAQ,EAAE,GAAG,EACb,iBAAiB,EAAE,GAAG,EACtB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,SAAS,CAAC,CA8BpB"}
@@ -71,7 +71,7 @@ export function encodeSignalWithSignature(payload, signature) {
71
71
  };
72
72
  const message = {
73
73
  payload,
74
- slot,
74
+ slot: BigInt(slot),
75
75
  instance
76
76
  };
77
77
  const typedData = {
@@ -1,3 +1,4 @@
1
+ import { SlotNumber } from '@aztec/foundation/branded-types';
1
2
  import { EthAddress } from '@aztec/foundation/eth-address';
2
3
  import EventEmitter from 'events';
3
4
  import { type Hex, type Log, type TypedDataDefinition } from 'viem';
@@ -19,16 +20,17 @@ export declare class EmpireSlashingProposerContract extends EventEmitter impleme
19
20
  getLifetimeInRounds(): Promise<bigint>;
20
21
  getExecutionDelayInRounds(): Promise<bigint>;
21
22
  getCurrentRound(): Promise<bigint>;
22
- computeRound(slot: bigint): Promise<bigint>;
23
+ computeRound(slot: SlotNumber): Promise<bigint>;
23
24
  getInstance(): Promise<`0x${string}`>;
24
25
  getRoundInfo(rollupAddress: Hex, round: bigint): Promise<{
25
- lastSignalSlot: bigint;
26
+ lastSignalSlot: SlotNumber;
26
27
  payloadWithMostSignals: Hex;
28
+ quorumReached: boolean;
27
29
  executed: boolean;
28
30
  }>;
29
31
  getPayloadSignals(rollupAddress: Hex, round: bigint, payload: Hex): Promise<bigint>;
30
32
  createSignalRequest(payload: Hex): L1TxRequest;
31
- createSignalRequestWithSignature(payload: Hex, slot: bigint, chainId: number, signerAddress: Hex, signer: (msg: TypedDataDefinition) => Promise<Hex>): Promise<L1TxRequest>;
33
+ createSignalRequestWithSignature(payload: Hex, slot: SlotNumber, chainId: number, signerAddress: Hex, signer: (msg: TypedDataDefinition) => Promise<Hex>): Promise<L1TxRequest>;
32
34
  listenToSubmittablePayloads(callback: (args: {
33
35
  payload: `0x${string}`;
34
36
  round: bigint;
@@ -62,4 +64,4 @@ export declare class EmpireSlashingProposerContract extends EventEmitter impleme
62
64
  waitForRound(round: bigint, pollingIntervalSeconds?: number): Promise<boolean>;
63
65
  executeRound(txUtils: L1TxUtils, round: bigint | number): ReturnType<typeof txUtils.sendAndMonitorTransaction>;
64
66
  }
65
- //# sourceMappingURL=empire_slashing_proposer.d.ts.map
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1waXJlX3NsYXNoaW5nX3Byb3Bvc2VyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udHJhY3RzL2VtcGlyZV9zbGFzaGluZ19wcm9wb3Nlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDN0QsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBSzNELE9BQU8sWUFBWSxNQUFNLFFBQVEsQ0FBQztBQUNsQyxPQUFPLEVBR0wsS0FBSyxHQUFHLEVBQ1IsS0FBSyxHQUFHLEVBQ1IsS0FBSyxtQkFBbUIsRUFHekIsTUFBTSxNQUFNLENBQUM7QUFFZCxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDdEUsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRTlDLE9BQU8sRUFBRSxLQUFLLFdBQVcsRUFBOEQsTUFBTSxrQkFBa0IsQ0FBQztBQUVoSCxxQkFBYSw0QkFBNkIsU0FBUSxLQUFLO0lBQ3JELFlBQVksS0FBSyxFQUFFLE1BQU0sRUFFeEI7Q0FDRjtBQUVELHFCQUFhLDhCQUErQixTQUFRLFlBQWEsWUFBVyxXQUFXO2FBT25FLE1BQU0sRUFBRSxVQUFVO0lBTnBDLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUErRDtJQUN0RixPQUFPLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBc0U7SUFFL0YsU0FBZ0IsSUFBSSxXQUFxQjtJQUV6QyxZQUNrQixNQUFNLEVBQUUsVUFBVSxFQUNsQyxPQUFPLEVBQUUsR0FBRyxHQUFHLFVBQVUsRUFRMUI7SUFFRCxJQUFXLE9BQU8sZUFFakI7SUFFTSxhQUFhLG9CQUVuQjtJQUVNLFlBQVksb0JBRWxCO0lBRU0sbUJBQW1CLG9CQUV6QjtJQUVNLHlCQUF5QixvQkFFL0I7SUFFTSxlQUFlLG9CQUVyQjtJQUVNLFlBQVksQ0FBQyxJQUFJLEVBQUUsVUFBVSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FFckQ7SUFFTSxXQUFXLDJCQUVqQjtJQUVZLFlBQVksQ0FDdkIsYUFBYSxFQUFFLEdBQUcsRUFDbEIsS0FBSyxFQUFFLE1BQU0sR0FDWixPQUFPLENBQUM7UUFBRSxjQUFjLEVBQUUsVUFBVSxDQUFDO1FBQUMsc0JBQXNCLEVBQUUsR0FBRyxDQUFDO1FBQUMsYUFBYSxFQUFFLE9BQU8sQ0FBQztRQUFDLFFBQVEsRUFBRSxPQUFPLENBQUE7S0FBRSxDQUFDLENBWWpIO0lBRU0saUJBQWlCLENBQUMsYUFBYSxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUV6RjtJQUVNLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxHQUFHLEdBQUcsV0FBVyxDQUtwRDtJQUVZLGdDQUFnQyxDQUMzQyxPQUFPLEVBQUUsR0FBRyxFQUNaLElBQUksRUFBRSxVQUFVLEVBQ2hCLE9BQU8sRUFBRSxNQUFNLEVBQ2YsYUFBYSxFQUFFLEdBQUcsRUFDbEIsTUFBTSxFQUFFLENBQUMsR0FBRyxFQUFFLG1CQUFtQixLQUFLLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FDakQsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQWF0QjtJQUVNLDJCQUEyQixDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksRUFBRTtRQUFFLE9BQU8sRUFBRSxLQUFLLE1BQU0sRUFBRSxDQUFDO1FBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQTtLQUFFLEtBQUssT0FBTywrQ0FleEc7SUFFTSx3QkFBd0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxJQUFJLEVBQUU7UUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDO1FBQUMsT0FBTyxFQUFFLEtBQUssTUFBTSxFQUFFLENBQUE7S0FBRSxLQUFLLE9BQU8sK0NBY3JHO0lBRU0sb0JBQW9CLENBQ3pCLFFBQVEsRUFBRSxDQUFDLElBQUksRUFBRTtRQUFFLEtBQUssRUFBRSxNQUFNLENBQUM7UUFBQyxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQUUsQ0FBQztRQUFDLFFBQVEsRUFBRSxLQUFLLE1BQU0sRUFBRSxDQUFBO0tBQUUsS0FBSyxPQUFPLCtDQWVoRztJQUVELDZFQUE2RTtJQUN0RSx3QkFBd0IsQ0FBQyxLQUFLLEVBQUUsTUFBTSxHQUFHLFdBQVcsQ0FTMUQ7SUFFRCxxRUFBcUU7SUFDOUQsK0JBQStCLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRTs7Ozs7O2tCQUVqRDtJQUVEOzs7Ozs7T0FNRztJQUNJLFlBQVksQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLHNCQUFzQixHQUFFLE1BQVUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBYXZGO0lBRVksWUFBWSxDQUN2QixPQUFPLEVBQUUsU0FBUyxFQUNsQixLQUFLLEVBQUUsTUFBTSxHQUFHLE1BQU0sR0FDckIsVUFBVSxDQUFDLE9BQU8sT0FBTyxDQUFDLHlCQUF5QixDQUFDLENBZ0R0RDtDQUNGIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"empire_slashing_proposer.d.ts","sourceRoot":"","sources":["../../src/contracts/empire_slashing_proposer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAK3D,OAAO,YAAY,MAAM,QAAQ,CAAC;AAClC,OAAO,EAGL,KAAK,GAAG,EACR,KAAK,GAAG,EACR,KAAK,mBAAmB,EAGzB,MAAM,MAAM,CAAC;AAEd,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACtE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAE9C,OAAO,EAAE,KAAK,WAAW,EAA8D,MAAM,kBAAkB,CAAC;AAEhH,qBAAa,4BAA6B,SAAQ,KAAK;gBACzC,KAAK,EAAE,MAAM;CAG1B;AAED,qBAAa,8BAA+B,SAAQ,YAAa,YAAW,WAAW;aAOnE,MAAM,EAAE,UAAU;IANpC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA+D;IACtF,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAsE;IAE/F,SAAgB,IAAI,EAAG,QAAQ,CAAU;gBAGvB,MAAM,EAAE,UAAU,EAClC,OAAO,EAAE,GAAG,GAAG,UAAU;IAU3B,IAAW,OAAO,eAEjB;IAEM,aAAa;IAIb,YAAY;IAIZ,mBAAmB;IAInB,yBAAyB;IAIzB,eAAe;IAIf,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAI3C,WAAW;IAIL,YAAY,CACvB,aAAa,EAAE,GAAG,EAClB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC;QAAE,cAAc,EAAE,MAAM,CAAC;QAAC,sBAAsB,EAAE,GAAG,CAAC;QAAC,QAAQ,EAAE,OAAO,CAAA;KAAE,CAAC;IAI/E,iBAAiB,CAAC,aAAa,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC;IAInF,mBAAmB,CAAC,OAAO,EAAE,GAAG,GAAG,WAAW;IAOxC,gCAAgC,CAC3C,OAAO,EAAE,GAAG,EACZ,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,GAAG,EAClB,MAAM,EAAE,CAAC,GAAG,EAAE,mBAAmB,KAAK,OAAO,CAAC,GAAG,CAAC,GACjD,OAAO,CAAC,WAAW,CAAC;IAehB,2BAA2B,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE;QAAE,OAAO,EAAE,KAAK,MAAM,EAAE,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,OAAO;IAiBlG,wBAAwB,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,KAAK,MAAM,EAAE,CAAA;KAAE,KAAK,OAAO;IAgB/F,oBAAoB,CACzB,QAAQ,EAAE,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,KAAK,MAAM,EAAE,CAAC;QAAC,QAAQ,EAAE,KAAK,MAAM,EAAE,CAAA;KAAE,KAAK,OAAO;IAiBjG,6EAA6E;IACtE,wBAAwB,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW;IAW3D,qEAAqE;IAC9D,+BAA+B,CAAC,IAAI,EAAE,GAAG,EAAE;;;;;;;IAIlD;;;;;;OAMG;IACI,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,sBAAsB,GAAE,MAAU,GAAG,OAAO,CAAC,OAAO,CAAC;IAe3E,YAAY,CACvB,OAAO,EAAE,SAAS,EAClB,KAAK,EAAE,MAAM,GAAG,MAAM,GACrB,UAAU,CAAC,OAAO,OAAO,CAAC,yBAAyB,CAAC;CAiDxD"}
1
+ {"version":3,"file":"empire_slashing_proposer.d.ts","sourceRoot":"","sources":["../../src/contracts/empire_slashing_proposer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAK3D,OAAO,YAAY,MAAM,QAAQ,CAAC;AAClC,OAAO,EAGL,KAAK,GAAG,EACR,KAAK,GAAG,EACR,KAAK,mBAAmB,EAGzB,MAAM,MAAM,CAAC;AAEd,OAAO,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACtE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAE9C,OAAO,EAAE,KAAK,WAAW,EAA8D,MAAM,kBAAkB,CAAC;AAEhH,qBAAa,4BAA6B,SAAQ,KAAK;IACrD,YAAY,KAAK,EAAE,MAAM,EAExB;CACF;AAED,qBAAa,8BAA+B,SAAQ,YAAa,YAAW,WAAW;aAOnE,MAAM,EAAE,UAAU;IANpC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA+D;IACtF,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAsE;IAE/F,SAAgB,IAAI,WAAqB;IAEzC,YACkB,MAAM,EAAE,UAAU,EAClC,OAAO,EAAE,GAAG,GAAG,UAAU,EAQ1B;IAED,IAAW,OAAO,eAEjB;IAEM,aAAa,oBAEnB;IAEM,YAAY,oBAElB;IAEM,mBAAmB,oBAEzB;IAEM,yBAAyB,oBAE/B;IAEM,eAAe,oBAErB;IAEM,YAAY,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,CAErD;IAEM,WAAW,2BAEjB;IAEY,YAAY,CACvB,aAAa,EAAE,GAAG,EAClB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC;QAAE,cAAc,EAAE,UAAU,CAAC;QAAC,sBAAsB,EAAE,GAAG,CAAC;QAAC,aAAa,EAAE,OAAO,CAAC;QAAC,QAAQ,EAAE,OAAO,CAAA;KAAE,CAAC,CAYjH;IAEM,iBAAiB,CAAC,aAAa,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,CAEzF;IAEM,mBAAmB,CAAC,OAAO,EAAE,GAAG,GAAG,WAAW,CAKpD;IAEY,gCAAgC,CAC3C,OAAO,EAAE,GAAG,EACZ,IAAI,EAAE,UAAU,EAChB,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,GAAG,EAClB,MAAM,EAAE,CAAC,GAAG,EAAE,mBAAmB,KAAK,OAAO,CAAC,GAAG,CAAC,GACjD,OAAO,CAAC,WAAW,CAAC,CAatB;IAEM,2BAA2B,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE;QAAE,OAAO,EAAE,KAAK,MAAM,EAAE,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,OAAO,+CAexG;IAEM,wBAAwB,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,KAAK,MAAM,EAAE,CAAA;KAAE,KAAK,OAAO,+CAcrG;IAEM,oBAAoB,CACzB,QAAQ,EAAE,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,KAAK,MAAM,EAAE,CAAC;QAAC,QAAQ,EAAE,KAAK,MAAM,EAAE,CAAA;KAAE,KAAK,OAAO,+CAehG;IAED,6EAA6E;IACtE,wBAAwB,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,CAS1D;IAED,qEAAqE;IAC9D,+BAA+B,CAAC,IAAI,EAAE,GAAG,EAAE;;;;;;kBAEjD;IAED;;;;;;OAMG;IACI,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,sBAAsB,GAAE,MAAU,GAAG,OAAO,CAAC,OAAO,CAAC,CAavF;IAEY,YAAY,CACvB,OAAO,EAAE,SAAS,EAClB,KAAK,EAAE,MAAM,GAAG,MAAM,GACrB,UAAU,CAAC,OAAO,OAAO,CAAC,yBAAyB,CAAC,CAgDtD;CACF"}