Skip to content

Electra -- Networking

Table of contents

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:

1
2
3
(
  List[BlobIdentifier, MAX_REQUEST_BLOB_SIDECARS_ELECTRA]
)

Response Content:

1
2
3
(
  List[BlobSidecar, MAX_REQUEST_BLOB_SIDECARS_ELECTRA]
)

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:

1
2
3
4
(
  start_slot: Slot
  count: uint64
)

Response Content:

1
2
3
(
  List[BlobSidecar, MAX_REQUEST_BLOB_SIDECARS_ELECTRA]
)

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.