Electra -- Networking¶
Table of contents¶
- Introduction
- Modifications in Electra
- Configuration
- The gossip domain: gossipsub
- The Req/Resp domain
Introduction¶
This document contains the consensus-layer networking specification for Electra.
The specification of these changes continues in the same format as the network specifications of previous upgrades, and assumes them as pre-requisite.
Modifications in Electra¶
Configuration¶
[New in Electra:EIP7691]
Name | Value | Description |
---|---|---|
MAX_REQUEST_BLOB_SIDECARS_ELECTRA |
MAX_REQUEST_BLOCKS_DENEB * MAX_BLOBS_PER_BLOCK_ELECTRA |
Maximum number of blob sidecars in a single request |
BLOB_SIDECAR_SUBNET_COUNT_ELECTRA |
9 |
The number of blob sidecar subnets used in the gossipsub protocol |
The gossip domain: gossipsub¶
Some gossip meshes are upgraded in the fork of Electra to support upgraded types.
Topics and messages¶
Topics follow the same specification as in prior upgrades.
The beacon_block
topic is modified to also support Electra blocks.
The beacon_aggregate_and_proof
and beacon_attestation_{subnet_id}
topics are modified to support the gossip of the new attestation type.
The attester_slashing
topic is modified to support the gossip of the new AttesterSlashing
type.
The specification around the creation, validation, and dissemination of messages has not changed from the Capella document unless explicitly noted here.
The derivation of the message-id
remains stable.
Global topics¶
beacon_block
¶
Updated validation
- [REJECT] The length of KZG commitments is less than or equal to the limitation defined in Consensus Layer --
i.e. validate that
len(body.signed_beacon_block.message.blob_kzg_commitments) <= MAX_BLOBS_PER_BLOCK_ELECTRA
beacon_aggregate_and_proof
¶
The following convenience variables are re-defined
- index = get_committee_indices(aggregate.committee_bits)[0]
The following validations are added:
* [REJECT] len(committee_indices) == 1
, where committee_indices = get_committee_indices(aggregate)
.
* [REJECT] aggregate.data.index == 0
Attestation subnets¶
beacon_attestation_{subnet_id}
¶
The topic is updated to propagate SingleAttestation
objects.
The following convenience variables are re-defined:
- index = attestation.committee_index
The following validations are added:
- [REJECT] attestation.data.index == 0
- [REJECT] The attester is a member of the committee -- i.e.
attestation.attester_index in get_beacon_committee(state, attestation.data.slot, index)
.
The following validations are removed:
- [REJECT] The attestation is unaggregated --
that is, it has exactly one participating validator (len([bit for bit in aggregation_bits if bit]) == 1
, i.e. exactly 1 bit is set).
- [REJECT] The number of aggregation bits matches the committee size -- i.e.
len(aggregation_bits) == len(get_beacon_committee(state, attestation.data.slot, index))
.
The Req/Resp domain¶
Messages¶
BlobSidecarsByRoot v2¶
Protocol ID: /eth2/beacon_chain/req/blob_sidecars_by_root/2/
[Modified in Electra:EIP7691]
The <context-bytes>
field is calculated as context = compute_fork_digest(fork_version, genesis_validators_root)
:
fork_version |
Chunk SSZ type |
---|---|
DENEB_FORK_VERSION |
deneb.BlobSidecar |
ELECTRA_FORK_VERSION |
electra.BlobSidecar |
Request Content:
Response Content:
Updated validation
No more than MAX_REQUEST_BLOB_SIDECARS_ELECTRA
may be requested at a time.
BlobSidecarsByRange v2¶
Protocol ID: /eth2/beacon_chain/req/blob_sidecars_by_range/2/
[Modified in Electra:EIP7691]
The <context-bytes>
field is calculated as context = compute_fork_digest(fork_version, genesis_validators_root)
:
fork_version |
Chunk SSZ type |
---|---|
DENEB_FORK_VERSION |
deneb.BlobSidecar |
ELECTRA_FORK_VERSION |
electra.BlobSidecar |
Request Content:
Response Content:
Updated validation
Clients MUST respond with at least the blob sidecars of the first blob-carrying block that exists in the range, if they have it, and no more than MAX_REQUEST_BLOB_SIDECARS_ELECTRA
sidecars.