Add payload attestation validator duty

This commit is contained in:
Eitan Seri-Levi
2026-04-27 08:48:06 +02:00
parent fae7941b2d
commit 0a1bdf840b
10 changed files with 396 additions and 13 deletions

View File

@@ -45,6 +45,7 @@ use validator_services::{
block_service::{BlockService, BlockServiceBuilder},
duties_service::{self, DutiesService, DutiesServiceBuilder},
latency_service,
payload_attestation_service::{PayloadAttestationService, PayloadAttestationServiceBuilder},
preparation_service::{PreparationService, PreparationServiceBuilder},
sync_committee_service::SyncCommitteeService,
};
@@ -83,6 +84,7 @@ pub struct ProductionValidatorClient<E: EthSpec> {
block_service: BlockService<ValidatorStore<E>, SystemTimeSlotClock>,
attestation_service: AttestationService<ValidatorStore<E>, SystemTimeSlotClock>,
sync_committee_service: SyncCommitteeService<ValidatorStore<E>, SystemTimeSlotClock>,
payload_attestation_service: PayloadAttestationService<ValidatorStore<E>, SystemTimeSlotClock>,
doppelganger_service: Option<Arc<DoppelgangerService>>,
preparation_service: PreparationService<ValidatorStore<E>, SystemTimeSlotClock>,
validator_store: Arc<ValidatorStore<E>>,
@@ -552,12 +554,22 @@ impl<E: EthSpec> ProductionValidatorClient<E> {
context.executor.clone(),
);
let payload_attestation_service = PayloadAttestationServiceBuilder::new()
.duties_service(duties_service.clone())
.validator_store(validator_store.clone())
.slot_clock(slot_clock.clone())
.beacon_nodes(beacon_nodes.clone())
.executor(context.executor.clone())
.chain_spec(context.eth2_config.spec.clone())
.build()?;
Ok(Self {
context,
duties_service,
block_service,
attestation_service,
sync_committee_service,
payload_attestation_service,
doppelganger_service,
preparation_service,
validator_store,
@@ -629,6 +641,11 @@ impl<E: EthSpec> ProductionValidatorClient<E> {
.start_update_service(&self.context.eth2_config.spec)
.map_err(|e| format!("Unable to start sync committee service: {}", e))?;
self.payload_attestation_service
.clone()
.start_update_service(&self.context.eth2_config.spec)
.map_err(|e| format!("Unable to start payload attestation service: {}", e))?;
self.preparation_service
.clone()
.start_update_service(&self.context.eth2_config.spec)