Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release v1.5.0-beta.0 #4078

Merged
merged 93 commits into from
Jan 10, 2025
Merged
Changes from 33 commits
Commits
Show all changes
93 commits
Select commit Hold shift + click to select a range
d82fa3d
Restrict best LC update collection to canonical blocks
etan-status Nov 21, 2023
940f45b
Merge branch 'dev' into lc-canonical
etan-status Feb 6, 2024
be29841
Add canonical data collection test infrastructure
etan-status Feb 6, 2024
2154298
Typo
etan-status Feb 6, 2024
248f32b
Lint
etan-status Feb 6, 2024
c0d037f
Fix missing `optimistc_update` in new tests
etan-status Feb 23, 2024
3f1a8fc
Merge branch 'dev' into lc-canonical
etan-status Feb 23, 2024
b8f0ddc
Add more tests for multi-period reorgs
etan-status Mar 3, 2024
337cd1e
ENR structure: Add `tcp6`, `quic6` and `udp6`.
nalepae Aug 8, 2024
bacba34
Merge branch 'dev' into lc-canonical
etan-status Sep 20, 2024
c9c21e9
Merge branch 'dev' into lc-canonical
etan-status Oct 9, 2024
9468496
Fix nits in data_collection format
jtraglia Nov 22, 2024
5639ca6
Rename two classes for consistency
jtraglia Nov 22, 2024
aff4e34
Move bellatrix/capella tests into respective dirs
jtraglia Nov 22, 2024
b6259a9
Revert "Move bellatrix/capella tests into respective dirs"
jtraglia Nov 22, 2024
e00e866
Synchronise capitalization change request across files
etan-status Nov 27, 2024
0e29f20
Merge branch 'dev' into lc-canonical
etan-status Nov 27, 2024
84bef3c
Split LC sync test into multiple files
etan-status Nov 27, 2024
75c65e6
Split LC data collection test into multiple files
etan-status Nov 27, 2024
24dffad
Link tests with generator
etan-status Nov 27, 2024
eaed600
Lint
etan-status Nov 27, 2024
531a0b0
Fix module list
etan-status Nov 27, 2024
12401a5
Move fork tests to origin rather than destination to fix issues
etan-status Nov 28, 2024
30bed61
Add missing mod
etan-status Nov 28, 2024
a52a82c
Extend decorator factory to support `other_phases`
etan-status Nov 28, 2024
09e8f01
Make `from` -> `to` bounds explicit
etan-status Nov 28, 2024
8ab7bc6
Address jxs comment.
nalepae Dec 12, 2024
85eff0c
Clarify gossip limits
arnetheduck Dec 12, 2024
9c4447b
Pepper in some lru_cache decorators
jtraglia Dec 13, 2024
a58b1f5
clarify gossip sources wording
rolfyone Dec 14, 2024
022bb22
Use single constant for gossip/req/resp, clarify encoded sizes
arnetheduck Dec 17, 2024
44ab11d
doctoc
arnetheduck Dec 17, 2024
6c581ca
Fix a few typos (#4055)
dapplion Dec 17, 2024
eff02a1
Merge branch 'dev' into max-gossip-limit
arnetheduck Dec 17, 2024
305f30e
Bump circleci's cached venv key
jtraglia Dec 17, 2024
702722f
Bump circleci's cached repo key
jtraglia Dec 17, 2024
b1205ef
Revert "Bump circleci's cached venv key"
jtraglia Dec 17, 2024
46f1dde
Revert "Bump circleci's cached repo key"
jtraglia Dec 17, 2024
cb4ed99
Fix linting errors for new functions
jtraglia Dec 17, 2024
2b710f3
clarify blob count validation on blob subnets
ralexstokes Dec 17, 2024
d41b7bd
Bump venv cache key again
jtraglia Dec 17, 2024
287c87f
Merge pull request #4056 from ralexstokes/electra/p2p-clarification-b…
jtraglia Dec 17, 2024
a32d0aa
Merge branch 'ethereum:dev' into speed-up-make-pyspec
jtraglia Dec 17, 2024
ea37fc5
Fix a few nits dealing with updated makefile
jtraglia Dec 17, 2024
0964db2
Fix custody `sampling_size` logic.
jimmygchen Dec 18, 2024
28cb6b4
Merge branch 'dev' into gossip-and-non-gossip-wording
rolfyone Dec 18, 2024
7be22ac
Remove non commit-pinned blob links
dapplion Dec 18, 2024
35603f5
Metadata: Replace `csc` by `cgc`.
nalepae Dec 18, 2024
9f2b1d7
Merge pull request #4049 from rolfyone/gossip-and-non-gossip-wording
jtraglia Dec 18, 2024
52360b9
Merge pull request #4061 from ethereum/dapplion-patch-2
jtraglia Dec 18, 2024
8d5c874
Merge pull request #4057 from jtraglia/speed-up-make-pyspec
jtraglia Dec 18, 2024
dde8119
EIP-7594: Fix custody group spec tests
ppopth Dec 18, 2024
6f9d029
Merge pull request #4063 from ppopth/fix-custody-group-spec-tests
jtraglia Dec 18, 2024
c33124e
Use integer division
jtraglia Dec 18, 2024
5567434
Merge pull request #4062 from nalepae/patch-2
jtraglia Dec 18, 2024
8e0d0d4
Simplify inline code
jimmygchen Dec 18, 2024
e6bddd9
Merge pull request #4060 from jimmygchen/fix-custody-sampling-size
jtraglia Dec 18, 2024
f17663f
Update blob sidecar subnet computation for EIP-7691
nflaig Dec 20, 2024
9e6d8a7
Fix garbled blob_kzg_commitments accesses
jtraglia Dec 23, 2024
6590cd0
Fix two minor typos
jtraglia Dec 23, 2024
92a2b20
In get_custody_groups, don't skip 0 value
jtraglia Dec 28, 2024
8696fbf
Merge pull request #4070 from jtraglia/allow-zero-id
jtraglia Dec 29, 2024
6ae48ce
Merge pull request #4069 from jtraglia/fix-garbled-fields
jtraglia Jan 2, 2025
6dd929f
Deneb: Add BeaconState
nalepae Jan 4, 2025
4f7fe82
Fulu: Remove V3 of blob sidecar by root/range RPC
nalepae Jan 6, 2025
7d511be
Emit correct block hash in random Electra tests
etan-status Jan 6, 2025
0c4c9e4
Merge pull request #4072 from etan-status/ef-reqhash
jtraglia Jan 6, 2025
777c023
Update unit test
jtraglia Jan 6, 2025
44731e8
Merge pull request #4071 from nalepae/patch-2
jtraglia Jan 6, 2025
cefc838
Merge pull request #4058 from jtraglia/fix-makefile-nits
jtraglia Jan 6, 2025
51ad00a
Merge branch 'dev' into lc-canonical
etan-status Jan 6, 2025
d1d50cc
Remove electra.BlobSidecar
ensi321 Jan 6, 2025
d85d36a
Merge pull request #4067 from nflaig/electra-compute-blob-subnet
jtraglia Jan 6, 2025
5565b2b
Merge branch 'dev' into lc-canonical
etan-status Jan 6, 2025
5b25758
Merge pull request #4073 from nalepae/patch-3
hwwhww Jan 7, 2025
44cecd2
fix bellatrix constant too
arnetheduck Jan 7, 2025
f6aef82
Merge branch 'max-gossip-limit' of github.com:status-im/eth2.0-specs …
arnetheduck Jan 7, 2025
3fced09
Add fork test with inactive, compounding validator with excess balance
jtraglia Jan 7, 2025
8e376dc
Use SubnetID for sync committee
ensi321 Jan 7, 2025
d8650a9
Merge pull request #4076 from ensi321/subnet-id
jtraglia Jan 8, 2025
742115a
Merge pull request #4074 from ensi321/electra-blobsidecar
jtraglia Jan 8, 2025
c086545
Merge pull request #3553 from etan-status/lc-canonical
jtraglia Jan 8, 2025
f02275e
Revert BlobSidecarsByRoot/Range version bump
jtraglia Jan 8, 2025
db52011
Bump version to 1.5.0-beta.0
jtraglia Jan 8, 2025
addbe71
Merge pull request #4079 from ethereum/bump-version-2
jtraglia Jan 8, 2025
454bd57
Update config files & fix some nits
jtraglia Jan 8, 2025
5127929
Try to polish new paragraphs a bit
jtraglia Jan 8, 2025
e8eb367
Fix two more small nits
jtraglia Jan 8, 2025
d867b84
Add back remark about compression bombs
jtraglia Jan 8, 2025
141ad47
Merge pull request #4077 from jtraglia/electra-bsbr-v1
ralexstokes Jan 9, 2025
4808c8d
Merge pull request #4075 from jtraglia/new-upgrade-to-electra-test
jtraglia Jan 9, 2025
d34f1c5
Merge pull request #3874 from nalepae/enr-ip6
jtraglia Jan 9, 2025
da17461
Merge pull request #4045 from status-im/max-gossip-limit
jtraglia Jan 9, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
23 changes: 13 additions & 10 deletions Makefile
Original file line number Diff line number Diff line change
@@ -16,7 +16,6 @@ ALL_EXECUTABLE_SPEC_NAMES = \

# A list of fake targets.
.PHONY: \
check_toc \
clean \
coverage \
detect_errors \
@@ -39,7 +38,6 @@ NORM = $(shell tput sgr0)

# Print target descriptions.
help:
@echo "make $(BOLD)check_toc$(NORM) -- check table of contents"
@echo "make $(BOLD)clean$(NORM) -- delete all untracked files"
@echo "make $(BOLD)coverage$(NORM) -- run pyspec tests with coverage"
@echo "make $(BOLD)detect_errors$(NORM) -- detect generator errors"
@@ -85,7 +83,7 @@ $(ETH2SPEC): setup.py | $(VENV)

# Force rebuild/install the eth2spec package.
eth2spec:
$(MAKE) --always-make $(ETH2SPEC)
@$(MAKE) --always-make $(ETH2SPEC)

# Create the pyspec for all phases.
pyspec: $(VENV) setup.py
@@ -99,6 +97,8 @@ pyspec: $(VENV) setup.py
TEST_REPORT_DIR = $(PYSPEC_DIR)/test-reports

# Run pyspec tests.
# Note: for debugging output to show, print to stderr.
#
# To run a specific test, append k=<test>, eg:
# make test k=test_verify_kzg_proof
# To run tests for a specific fork, append fork=<fork>, eg:
@@ -117,6 +117,7 @@ test: $(ETH2SPEC) pyspec
@mkdir -p $(TEST_REPORT_DIR)
@$(PYTHON_VENV) -m pytest \
-n auto \
--capture=no \
$(MAYBE_TEST) \
$(MAYBE_FORK) \
$(PRESET) \
@@ -193,10 +194,6 @@ MARKDOWN_FILES = $(wildcard $(SPEC_DIR)/*/*.md) \
$(wildcard $(SPEC_DIR)/_features/*/*/*.md) \
$(wildcard $(SSZ_DIR)/*.md)

# Check all files and error if any ToC were modified.
check_toc: $(MARKDOWN_FILES:=.toc)
@[ "$$(find . -name '*.md.tmp' -print -quit)" ] && exit 1 || exit 0

# Generate ToC sections & save copy of original if modified.
%.toc:
@cp $* $*.tmp; \
@@ -209,8 +206,12 @@ check_toc: $(MARKDOWN_FILES:=.toc)
echo "\033[1;34m See $*.tmp\033[0m"; \
fi

# Check all files and error if any ToC were modified.
_check_toc: $(MARKDOWN_FILES:=.toc)
@[ "$$(find . -name '*.md.tmp' -print -quit)" ] && exit 1 || exit 0

# Check for mistakes.
lint: $(ETH2SPEC) pyspec check_toc
lint: $(ETH2SPEC) pyspec _check_toc
@$(CODESPELL_VENV) . --skip "./.git,$(VENV),$(PYSPEC_DIR)/.mypy_cache" -I .codespell-whitelist
@$(PYTHON_VENV) -m flake8 --config $(FLAKE8_CONFIG) $(PYSPEC_DIR)/eth2spec
@$(PYTHON_VENV) -m flake8 --config $(FLAKE8_CONFIG) $(TEST_GENERATORS_DIR)
@@ -235,17 +236,19 @@ gen_list:
done

# Run one generator.
# This will forcibly rebuild eth2spec just in case.
# To check modules for a generator, append modcheck=true, eg:
# make gen_genesis modcheck=true
gen_%: MAYBE_MODCHECK := $(if $(filter true,$(modcheck)),--modcheck)
gen_%: $(ETH2SPEC) pyspec
gen_%: eth2spec
@mkdir -p $(TEST_VECTOR_DIR)
@$(PYTHON_VENV) $(GENERATOR_DIR)/$*/main.py \
--output $(TEST_VECTOR_DIR) \
$(MAYBE_MODCHECK)

# Run all generators then check for errors.
gen_all: $(GENERATOR_TARGETS) detect_errors
gen_all: $(GENERATOR_TARGETS)
@$(MAKE) detect_errors

# Detect errors in generators.
detect_errors: $(TEST_VECTOR_DIR)
2 changes: 1 addition & 1 deletion docker/README.md
Original file line number Diff line number Diff line change
@@ -10,7 +10,7 @@ Handy commands:

Ideally manual running of docker containers is for advanced users, we recommend the script based approach described below for most users.

The `scripts/build_run_docker_tests.sh` script will cover most usecases. The script allows the user to configure the fork(altair/bellatrix/capella..), `$IMAGE_NAME` (specifies the container to use), preset type (mainnet/minimal), and test all forks flags. Ideally, this is the main way that users interact with the spec tests instead of running it locally with varying versions of dependencies.
The `scripts/build_run_docker_tests.sh` script will cover most use cases. The script allows the user to configure the fork(altair/bellatrix/capella..), `$IMAGE_NAME` (specifies the container to use), preset type (mainnet/minimal), and test all forks flags. Ideally, this is the main way that users interact with the spec tests instead of running it locally with varying versions of dependencies.

E.g:
- `./build_run_docker_tests.sh --p mainnet` will run the mainnet preset tests
23 changes: 20 additions & 3 deletions setup.py
Original file line number Diff line number Diff line change
@@ -12,7 +12,7 @@
import copy
from collections import OrderedDict
import json
from functools import reduce
from functools import lru_cache

from pysetup.constants import (
# code names
@@ -70,22 +70,26 @@ def installPackage(package: str):
from marko.ext.gfm.elements import Table


@lru_cache(maxsize=None)
def _get_name_from_heading(heading: Heading) -> Optional[str]:
last_child = heading.children[-1]
if isinstance(last_child, CodeSpan):
return last_child.children
return None


@lru_cache(maxsize=None)
def _get_source_from_code_block(block: FencedCode) -> str:
return block.children[0].children.strip()


@lru_cache(maxsize=None)
def _get_function_name_from_source(source: str) -> str:
fn = ast.parse(source).body[0]
return fn.name


@lru_cache(maxsize=None)
def _get_self_type_from_source(source: str) -> Optional[str]:
fn = ast.parse(source).body[0]
args = fn.args.args
@@ -98,6 +102,7 @@ def _get_self_type_from_source(source: str) -> Optional[str]:
return args[0].annotation.id


@lru_cache(maxsize=None)
def _get_class_info_from_source(source: str) -> Tuple[str, Optional[str]]:
class_def = ast.parse(source).body[0]
base = class_def.bases[0]
@@ -113,12 +118,14 @@ def _get_class_info_from_source(source: str) -> Tuple[str, Optional[str]]:
return class_def.name, parent_class


@lru_cache(maxsize=None)
def _is_constant_id(name: str) -> bool:
if name[0] not in string.ascii_uppercase + '_':
return False
return all(map(lambda c: c in string.ascii_uppercase + '_' + string.digits, name[1:]))


@lru_cache(maxsize=None)
def _load_kzg_trusted_setups(preset_name):
trusted_setups_file_path = str(Path(__file__).parent) + '/presets/' + preset_name + '/trusted_setups/trusted_setup_4096.json'

@@ -130,6 +137,7 @@ def _load_kzg_trusted_setups(preset_name):

return trusted_setup_G1_monomial, trusted_setup_G1_lagrange, trusted_setup_G2_monomial

@lru_cache(maxsize=None)
def _load_curdleproofs_crs(preset_name):
"""
NOTE: File generated from https://github.com/asn-d6/curdleproofs/blob/8e8bf6d4191fb6a844002f75666fb7009716319b/tests/crs.rs#L53-L67
@@ -153,6 +161,7 @@ def _load_curdleproofs_crs(preset_name):
}


@lru_cache(maxsize=None)
def _get_eth2_spec_comment(child: LinkRefDef) -> Optional[str]:
_, _, title = child._parse_info
if not (title[0] == "(" and title[len(title)-1] == ")"):
@@ -163,6 +172,7 @@ def _get_eth2_spec_comment(child: LinkRefDef) -> Optional[str]:
return title[len(ETH2_SPEC_COMMENT_PREFIX):].strip()


@lru_cache(maxsize=None)
def _parse_value(name: str, typed_value: str, type_hint: Optional[str] = None) -> VariableDefinition:
comment = None
if name in ("ROOT_OF_UNITY_EXTENDED", "ROOTS_OF_UNITY_EXTENDED", "ROOTS_OF_UNITY_REDUCED"):
@@ -185,6 +195,11 @@ def _update_constant_vars_with_kzg_setups(constant_vars, preset_name):
constant_vars['KZG_SETUP_G2_MONOMIAL'] = VariableDefinition(constant_vars['KZG_SETUP_G2_MONOMIAL'].value, str(kzg_setups[2]), comment, None)


@lru_cache(maxsize=None)
def parse_markdown(content: str):
return gfm.parse(content)


def get_spec(file_name: Path, preset: Dict[str, str], config: Dict[str, str], preset_name=str) -> SpecObject:
functions: Dict[str, str] = {}
protocols: Dict[str, ProtocolDefinition] = {}
@@ -198,7 +213,7 @@ def get_spec(file_name: Path, preset: Dict[str, str], config: Dict[str, str], pr
custom_types: Dict[str, str] = {}

with open(file_name) as source_file:
document = gfm.parse(source_file.read())
document = parse_markdown(source_file.read())

current_name = None
should_skip = False
@@ -326,6 +341,7 @@ def get_spec(file_name: Path, preset: Dict[str, str], config: Dict[str, str], pr
)


@lru_cache(maxsize=None)
def load_preset(preset_files: Sequence[Path]) -> Dict[str, str]:
"""
Loads the a directory of preset files, merges the result into one preset.
@@ -344,6 +360,7 @@ def load_preset(preset_files: Sequence[Path]) -> Dict[str, str]:
return parse_config_vars(preset)


@lru_cache(maxsize=None)
def load_config(config_path: Path) -> Dict[str, str]:
"""
Loads the given configuration file.
@@ -358,7 +375,7 @@ def build_spec(fork: str,
source_files: Sequence[Path],
preset_files: Sequence[Path],
config_file: Path) -> str:
preset = load_preset(preset_files)
preset = load_preset(tuple(preset_files))
config = load_config(config_file)
all_specs = [get_spec(spec, preset, config, preset_name) for spec in source_files]

2 changes: 1 addition & 1 deletion specs/_features/custody_game/beacon-chain.md
Original file line number Diff line number Diff line change
@@ -619,7 +619,7 @@ def process_custody_slashing(state: BeaconState, signed_custody_slashing: Signed
for attester_index in attesters:
if attester_index != custody_slashing.malefactor_index:
increase_balance(state, attester_index, whistleblower_reward)
# No special whisteblower reward: it is expected to be an attester. Others are free to slash too however.
# No special whistleblower reward: it is expected to be an attester. Others are free to slash too however.
else:
# The claim was false, the custody bit was correct. Slash the whistleblower that induced this work.
slash_validator(state, custody_slashing.whistleblower_index)
6 changes: 3 additions & 3 deletions specs/_features/eip7732/p2p-interface.md
Original file line number Diff line number Diff line change
@@ -130,7 +130,7 @@ The *type* of the payload of this topic changes to the (modified) `SignedBeaconB

There are no new validations for this topic. However, all validations with regards to the `ExecutionPayload` are removed:

- _[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
- _[REJECT]_ The length of KZG commitments is less than or equal to the limitation defined in Consensus Layer -- i.e. validate that `len(signed_beacon_block.message.body.blob_kzg_commitments) <= MAX_BLOBS_PER_BLOCK`
- _[REJECT]_ The block's execution payload timestamp is correct with respect to the slot
-- i.e. `execution_payload.timestamp == compute_timestamp_at_slot(state, block.slot)`.
- If `execution_payload` verification of block's parent by an execution node is *not* complete:
@@ -151,7 +151,7 @@ This topic is used to propagate execution payload messages as `SignedExecutionPa

The following validations MUST pass before forwarding the `signed_execution_payload_envelope` on the network, assuming the alias `envelope = signed_execution_payload_envelope.message`, `payload = payload_envelope.payload`:

- _[IGNORE]_ The envelope's block root `envelope.block_root` has been seen (via both gossip and non-gossip sources) (a client MAY queue payload for processing once the block is retrieved).
- _[IGNORE]_ The envelope's block root `envelope.block_root` has been seen (via gossip or non-gossip sources) (a client MAY queue payload for processing once the block is retrieved).
- _[IGNORE]_ The node has not seen another valid `SignedExecutionPayloadEnvelope` for this block root from this builder.

Let `block` be the block with `envelope.beacon_block_root`.
@@ -171,7 +171,7 @@ The following validations MUST pass before forwarding the `payload_attestation_m
- _[IGNORE]_ The message's slot is for the current slot (with a `MAXIMUM_GOSSIP_CLOCK_DISPARITY` allowance), i.e. `data.slot == current_slot`.
- _[REJECT]_ The message's payload status is a valid status, i.e. `data.payload_status < PAYLOAD_INVALID_STATUS`.
- _[IGNORE]_ The `payload_attestation_message` is the first valid message received from the validator with index `payload_attestation_message.validate_index`.
- _[IGNORE]_ The message's block `data.beacon_block_root` has been seen (via both gossip and non-gossip sources) (a client MAY queue attestation for processing once the block is retrieved. Note a client might want to request payload after).
- _[IGNORE]_ The message's block `data.beacon_block_root` has been seen (via gossip or non-gossip sources) (a client MAY queue attestation for processing once the block is retrieved. Note a client might want to request payload after).
- _[REJECT]_ The message's block `data.beacon_block_root` passes validation.
- _[REJECT]_ The message's validator index is within the payload committee in `get_ptc(state, data.slot)`. The `state` is the head state corresponding to processing the block up to the current slot as determined by the fork choice.
- _[REJECT]_ The message's signature of `payload_attestation_message.signature` is valid with respect to the validator index.
2 changes: 1 addition & 1 deletion specs/_features/whisk/beacon-chain.md
Original file line number Diff line number Diff line change
@@ -54,7 +54,7 @@ This document details the beacon chain additions and changes of to support the W
| `WHISK_PROPOSER_TRACKERS_COUNT` | `uint64(2**13)` (= 8,192) | number of proposer trackers |
| `WHISK_VALIDATORS_PER_SHUFFLE` | `uint64(2**7 - 4)` (= 124) | number of validators shuffled per shuffle step |
| `WHISK_MAX_SHUFFLE_PROOF_SIZE` | `uint64(2**15)` | max size of a shuffle proof |
| `WHISK_MAX_OPENING_PROOF_SIZE` | `uint64(2**10)` | max size of a opening proof |
| `WHISK_MAX_OPENING_PROOF_SIZE` | `uint64(2**10)` | max size of an opening proof |

## Configuration

48 changes: 48 additions & 0 deletions specs/deneb/beacon-chain.md
Original file line number Diff line number Diff line change
@@ -20,6 +20,7 @@
- [`BeaconBlockBody`](#beaconblockbody)
- [`ExecutionPayload`](#executionpayload)
- [`ExecutionPayloadHeader`](#executionpayloadheader)
- [`BeaconState`](#beaconstate)
- [Helper functions](#helper-functions)
- [Misc](#misc)
- [`kzg_commitment_to_versioned_hash`](#kzg_commitment_to_versioned_hash)
@@ -171,6 +172,53 @@ class ExecutionPayloadHeader(Container):
excess_blob_gas: uint64 # [New in Deneb:EIP4844]
```

#### `BeaconState`

```python
class BeaconState(Container):
# Versioning
genesis_time: uint64
genesis_validators_root: Root
slot: Slot
fork: Fork
# History
latest_block_header: BeaconBlockHeader
block_roots: Vector[Root, SLOTS_PER_HISTORICAL_ROOT]
state_roots: Vector[Root, SLOTS_PER_HISTORICAL_ROOT]
historical_roots: List[Root, HISTORICAL_ROOTS_LIMIT]
# Eth1
eth1_data: Eth1Data
eth1_data_votes: List[Eth1Data, EPOCHS_PER_ETH1_VOTING_PERIOD * SLOTS_PER_EPOCH]
eth1_deposit_index: uint64
# Registry
validators: List[Validator, VALIDATOR_REGISTRY_LIMIT]
balances: List[Gwei, VALIDATOR_REGISTRY_LIMIT]
# Randomness
randao_mixes: Vector[Bytes32, EPOCHS_PER_HISTORICAL_VECTOR]
# Slashings
slashings: Vector[Gwei, EPOCHS_PER_SLASHINGS_VECTOR] # Per-epoch sums of slashed effective balances
# Participation
previous_epoch_participation: List[ParticipationFlags, VALIDATOR_REGISTRY_LIMIT]
current_epoch_participation: List[ParticipationFlags, VALIDATOR_REGISTRY_LIMIT]
# Finality
justification_bits: Bitvector[JUSTIFICATION_BITS_LENGTH] # Bit set for every recent justified epoch
previous_justified_checkpoint: Checkpoint
current_justified_checkpoint: Checkpoint
finalized_checkpoint: Checkpoint
# Inactivity
inactivity_scores: List[uint64, VALIDATOR_REGISTRY_LIMIT]
# Sync
current_sync_committee: SyncCommittee
next_sync_committee: SyncCommittee
# Execution
latest_execution_payload_header: ExecutionPayloadHeader # [Modified in Deneb:EIP4844]
# Withdrawals
next_withdrawal_index: WithdrawalIndex
next_withdrawal_validator_index: ValidatorIndex
# Deep history valid from Capella onwards
historical_summaries: List[HistoricalSummary, HISTORICAL_ROOTS_LIMIT]
```

## Helper functions

### Misc
4 changes: 2 additions & 2 deletions specs/deneb/p2p-interface.md
Original file line number Diff line number Diff line change
@@ -147,7 +147,7 @@ The *type* of the payload of this topic changes to the (modified) `SignedBeaconB
New 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`
i.e. validate that `len(signed_beacon_block.message.body.blob_kzg_commitments) <= MAX_BLOBS_PER_BLOCK`

###### `beacon_aggregate_and_proof`

@@ -181,7 +181,7 @@ The following validations MUST pass before forwarding the `blob_sidecar` on the
- _[IGNORE]_ The sidecar is not from a future slot (with a `MAXIMUM_GOSSIP_CLOCK_DISPARITY` allowance) -- i.e. validate that `block_header.slot <= current_slot` (a client MAY queue future sidecars for processing at the appropriate slot).
- _[IGNORE]_ The sidecar is from a slot greater than the latest finalized slot -- i.e. validate that `block_header.slot > compute_start_slot_at_epoch(store.finalized_checkpoint.epoch)`
- _[REJECT]_ The proposer signature of `blob_sidecar.signed_block_header`, is valid with respect to the `block_header.proposer_index` pubkey.
- _[IGNORE]_ The sidecar's block's parent (defined by `block_header.parent_root`) has been seen (via both gossip and non-gossip sources) (a client MAY queue sidecars for processing once the parent block is retrieved).
- _[IGNORE]_ The sidecar's block's parent (defined by `block_header.parent_root`) has been seen (via gossip or non-gossip sources) (a client MAY queue sidecars for processing once the parent block is retrieved).
- _[REJECT]_ The sidecar's block's parent (defined by `block_header.parent_root`) passes validation.
- _[REJECT]_ The sidecar is from a higher slot than the sidecar's block's parent (defined by `block_header.parent_root`).
- _[REJECT]_ The current finalized_checkpoint is an ancestor of the sidecar's block -- i.e. `get_checkpoint_block(store, block_header.parent_root, store.finalized_checkpoint.epoch) == store.finalized_checkpoint.root`.
11 changes: 10 additions & 1 deletion specs/electra/p2p-interface.md
Original file line number Diff line number Diff line change
@@ -14,6 +14,7 @@
- [Global topics](#global-topics)
- [`beacon_block`](#beacon_block)
- [`beacon_aggregate_and_proof`](#beacon_aggregate_and_proof)
- [`blob_sidecar_{subnet_id}`](#blob_sidecar_subnet_id)
- [Attestation subnets](#attestation-subnets)
- [`beacon_attestation_{subnet_id}`](#beacon_attestation_subnet_id)
- [The Req/Resp domain](#the-reqresp-domain)
@@ -66,7 +67,7 @@ The derivation of the `message-id` remains stable.
*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`
i.e. validate that `len(signed_beacon_block.message.body.blob_kzg_commitments) <= MAX_BLOBS_PER_BLOCK_ELECTRA`

###### `beacon_aggregate_and_proof`

@@ -77,6 +78,14 @@ The following validations are added:
* [REJECT] `len(committee_indices) == 1`, where `committee_indices = get_committee_indices(aggregate)`.
* [REJECT] `aggregate.data.index == 0`

###### `blob_sidecar_{subnet_id}`

*[Modified in Electra:EIP7691]*

The existing validations all apply as given from previous forks, with the following exceptions:

* Uses of `MAX_BLOBS_PER_BLOCK` in existing validations are replaced with `MAX_BLOBS_PER_BLOCK_ELECTRA`.

##### Attestation subnets

###### `beacon_attestation_{subnet_id}`
Loading