-
Notifications
You must be signed in to change notification settings - Fork 92
/
Copy pathethereum.star
88 lines (82 loc) · 5.88 KB
/
ethereum.star
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
ethereum_package = import_module(
"github.com/ethpandaops/ethereum-package/main.star@4.4.0"
)
GETH_IMAGE = "ethereum/client-go:v1.14.12"
LIGHTHOUSE_IMAGE = "sigp/lighthouse:v6.0.0"
def run(plan, args):
port_publisher = generate_port_publisher_config(args)
ethereum_package.run(
plan,
{
"participants": [
{
"el_type": "geth",
"el_image": GETH_IMAGE,
"cl_type": "lighthouse",
"cl_image": LIGHTHOUSE_IMAGE,
"el_extra_params": ["--gcmode archive"],
"cl_extra_params": [
# Disable optimistic finalized sync. This will force Lighthouse to
# verify every execution block hash with the execution client during
# finalized sync. By default block hashes will be checked in Lighthouse
# and only passed to the EL if initial verification fails.
"--disable-optimistic-finalized-sync",
# Disable the backfill sync rate-limiting. This allow users to just sync
# the entire chain as fast as possible, however it can result in
# resource contention which degrades staking performance. Stakers should
# generally choose to avoid this flag since backfill sync is not
# required for staking.
"--disable-backfill-rate-limiting",
],
"vc_type": "lighthouse",
"vc_image": LIGHTHOUSE_IMAGE,
"count": args["l1_participants_count"],
}
],
"network_params": {
"network_id": str(args["l1_chain_id"]),
"preregistered_validator_keys_mnemonic": args[
"l1_preallocated_mnemonic"
],
"preset": args["l1_preset"],
"seconds_per_slot": args["l1_seconds_per_slot"],
# ETH1_FOLLOW_DISTANCE, Default: 2048
# This is used to calculate the minimum depth of block on the Ethereum 1 chain that can be considered by the Eth2 chain: it applies to the Genesis process and the processing of deposits by validators. The Eth1 chain depth is estimated by multiplying this value by the target average Eth1 block time, SECONDS_PER_ETH1_BLOCK.
# The value of ETH1_FOLLOW_DISTANCE is not based on the expected depth of any reorgs of the Eth1 chain, which are rarely if ever more than 2-3 blocks deep. It is about providing time to respond to an incident on the Eth1 chain such as a consensus failure between clients.
# This parameter was increased from 1024 to 2048 blocks for the beacon chain mainnet, to allow devs more time to respond if there were any trouble on the Eth1 chain.
# The whole follow distance concept has been made redundant by the Merge and may be removed in a future upgrade, so that validators can make deposits and become active more-or-less instantly.
"eth1_follow_distance": 2048,
# MIN_VALIDATOR_WITHDRAWABILITY_DELAY, Default: 256
# A validator can stop participating once it has made it through the exit queue. However, its stake remains locked for the duration of MIN_VALIDATOR_WITHDRAWABILITY_DELAY. This is to allow some time for any slashable behaviour to be detected and reported so that the validator can still be penalised (in which case the validator's withdrawable time is pushed EPOCHS_PER_SLASHINGS_VECTOR into the future).
# Once the MIN_VALIDATOR_WITHDRAWABILITY_DELAY period has passed, the validator becomes eligible for a full withdrawal of its stake and rewards on the next withdrawals sweep, as long as it has ETH1_ADDRESS_WITHDRAWAL_PREFIX (0x01) withdrawal credentials set. In any case, being in a "withdrawable" state means that a validator has now fully exited from the protocol.
"min_validator_withdrawability_delay": 256,
# SHARD_COMMITTEE_PERIOD, Default: 256
# This really anticipates the implementation of data shards, which is no longer planned, at least in its originally envisaged form. The idea is that it's bad for the stability of longer-lived committees if validators can appear and disappear very rapidly.
# Therefore, a validator cannot initiate a voluntary exit until SHARD_COMMITTEE_PERIOD epochs after it has been activated. However, it could still be ejected by slashing before this time.
"shard_committee_period": 256,
# GENESIS_DELAY, Default: 12
# This is a grace period to allow nodes and node operators time to prepare for the genesis event. The genesis event cannot occur before MIN_GENESIS_TIME. If MIN_GENESIS_ACTIVE_VALIDATOR_COUNT validators are not registered sufficiently in advance of MIN_GENESIS_TIME, then Genesis will occur GENESIS_DELAY seconds after enough validators have been registered.
"genesis_delay": 12,
},
"additional_services": args["l1_additional_services"],
"port_publisher": port_publisher,
},
)
# Generate ethereum package public ports configuration.
def generate_port_publisher_config(args):
port_mappings = {
"el": "l1_el_start_port",
"cl": "l1_cl_start_port",
"vc": "l1_vc_start_port",
"additional_services": "l1_additional_services_start_port",
}
port_publisher_config = {}
public_port_config = args.get("static_ports", {})
for key, value in port_mappings.items():
public_port_start = public_port_config.get(value, None)
if public_port_start:
port_publisher_config[key] = {
"enabled": True,
"public_port_start": public_port_start,
}
return port_publisher_config