mirror of
https://github.com/status-im/eth2.0-specs.git
synced 2025-01-20 23:49:54 +00:00
Pass execution requests to Engine API as a list of bytes
This commit is contained in:
parent
01b262553f
commit
a44071a9a5
@ -10,6 +10,7 @@ class ElectraSpecBuilder(BaseSpecBuilder):
|
||||
def imports(cls, preset_name: str):
|
||||
return f'''
|
||||
from eth2spec.deneb import {preset_name} as deneb
|
||||
from eth2spec.utils.ssz.ssz_impl import serialize
|
||||
'''
|
||||
|
||||
@classmethod
|
||||
@ -28,7 +29,7 @@ class NoopExecutionEngine(ExecutionEngine):
|
||||
|
||||
def notify_new_payload(self: ExecutionEngine,
|
||||
execution_payload: ExecutionPayload,
|
||||
execution_requests: ExecutionRequests,
|
||||
execution_requests_list: list[bytes],
|
||||
parent_beacon_block_root: Root) -> bool:
|
||||
return True
|
||||
|
||||
|
@ -990,7 +990,7 @@ class NewPayloadRequest(object):
|
||||
```python
|
||||
def notify_new_payload(self: ExecutionEngine,
|
||||
execution_payload: ExecutionPayload,
|
||||
execution_requests: ExecutionRequests,
|
||||
execution_requests_list: list[bytes],
|
||||
parent_beacon_block_root: Root) -> bool:
|
||||
"""
|
||||
Return ``True`` if and only if ``execution_payload`` and ``execution_requests``
|
||||
@ -1011,7 +1011,7 @@ def verify_and_notify_new_payload(self: ExecutionEngine,
|
||||
Return ``True`` if and only if ``new_payload_request`` is valid with respect to ``self.execution_state``.
|
||||
"""
|
||||
execution_payload = new_payload_request.execution_payload
|
||||
execution_requests = new_payload_request.execution_requests # [New in Electra]
|
||||
execution_requests_list = get_execution_requests_list(new_payload_request.execution_requests) # [New in Electra]
|
||||
parent_beacon_block_root = new_payload_request.parent_beacon_block_root
|
||||
|
||||
if not self.is_valid_block_hash(execution_payload, parent_beacon_block_root):
|
||||
@ -1023,7 +1023,7 @@ def verify_and_notify_new_payload(self: ExecutionEngine,
|
||||
# [Modified in Electra]
|
||||
if not self.notify_new_payload(
|
||||
execution_payload,
|
||||
execution_requests,
|
||||
execution_requests_list,
|
||||
parent_beacon_block_root):
|
||||
return False
|
||||
|
||||
@ -1139,6 +1139,19 @@ def process_withdrawals(state: BeaconState, payload: ExecutionPayload) -> None:
|
||||
|
||||
#### Execution payload
|
||||
|
||||
##### New `get_execution_requests_list`
|
||||
|
||||
*Note*: Encodes execution requests as defined by [EIP-7685](https://eips.ethereum.org/EIPS/eip-7685).
|
||||
|
||||
```python
|
||||
def get_execution_requests_list(execution_requests: ExecutionRequests) -> list[bytes]:
|
||||
deposit_bytes = serialize(execution_requests.deposits)
|
||||
withdrawal_bytes = serialize(execution_requests.withdrawals)
|
||||
consolidation_bytes = serialize(execution_requests.consolidations)
|
||||
|
||||
return [deposit_bytes, withdrawal_bytes, consolidation_bytes]
|
||||
```
|
||||
|
||||
##### Modified `process_execution_payload`
|
||||
|
||||
*Note*: The function `process_execution_payload` is modified to pass `execution_requests` into `execution_engine.verify_and_notify_new_payload` (via the updated `NewPayloadRequest`).
|
||||
|
Loading…
x
Reference in New Issue
Block a user