mirror of
https://github.com/sigp/lighthouse.git
synced 2026-03-11 18:04:18 +00:00
get it to compile
This commit is contained in:
@@ -39,7 +39,7 @@ use super::network_context::SyncNetworkContext;
|
||||
use super::peer_sync_info::{remote_sync_type, PeerSyncType};
|
||||
use super::range_sync::{RangeSync, RangeSyncType, EPOCHS_PER_BATCH};
|
||||
use crate::beacon_processor::{ChainSegmentProcessId, WorkEvent as BeaconWorkEvent};
|
||||
use crate::service::{NetworkMessage, RequestId};
|
||||
use crate::service::NetworkMessage;
|
||||
use crate::status::ToStatusMessage;
|
||||
use beacon_chain::{BeaconChain, BeaconChainTypes, BlockError, EngineState};
|
||||
use futures::StreamExt;
|
||||
@@ -68,6 +68,17 @@ pub const SLOT_IMPORT_TOLERANCE: usize = 32;
|
||||
|
||||
pub type Id = u32;
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct SeansBlob {}
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct SeansBlock {}
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct SeansBlockBlob {
|
||||
blob: SeansBlob,
|
||||
block: SeansBlock,
|
||||
}
|
||||
/// Id of rpc requests sent by sync to the network.
|
||||
#[derive(Debug, Hash, PartialEq, Eq, Clone, Copy)]
|
||||
pub enum RequestId {
|
||||
@@ -312,8 +323,7 @@ impl<T: BeaconChainTypes> SyncManager<T> {
|
||||
}
|
||||
}
|
||||
RequestId::RangeBlockBlob { id } => {
|
||||
if let Some((chain_id, batch_id)) = self.network.fail_block_bob_request(request_id)
|
||||
{
|
||||
if let Some((chain_id, batch_id)) = self.network.fail_block_bob_request(id) {
|
||||
self.range_sync.inject_error(
|
||||
&mut self.network,
|
||||
peer_id,
|
||||
@@ -617,6 +627,18 @@ impl<T: BeaconChainTypes> SyncManager<T> {
|
||||
.block_lookups
|
||||
.parent_chain_processed(chain_hash, result, &mut self.network),
|
||||
},
|
||||
SyncMessage::RpcBlob {
|
||||
request_id,
|
||||
peer_id,
|
||||
blob_sidecar,
|
||||
seen_timestamp,
|
||||
} => todo!(),
|
||||
SyncMessage::RpcBlockAndBlob {
|
||||
request_id,
|
||||
peer_id,
|
||||
block_and_blobs,
|
||||
seen_timestamp,
|
||||
} => todo!(),
|
||||
}
|
||||
}
|
||||
|
||||
@@ -736,7 +758,7 @@ impl<T: BeaconChainTypes> SyncManager<T> {
|
||||
}
|
||||
RequestId::RangeBlockBlob { id } => {
|
||||
// do stuff
|
||||
self.network.block_blob_block_response(id, block);
|
||||
// self.network.block_blob_block_response(id, block);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -749,10 +771,9 @@ impl<T: BeaconChainTypes> SyncManager<T> {
|
||||
seen_timestamp: Duration,
|
||||
) {
|
||||
let RequestId::RangeBlockBlob { id } = request_id else {
|
||||
return error!("bad stuff");
|
||||
panic!("Wrong things going on ");
|
||||
};
|
||||
// get the paired block blob from the network context and send it to range
|
||||
self.network.block_blob_blob_response(request_id, blob)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -178,10 +178,10 @@ impl<T: BeaconChainTypes> SyncNetworkContext<T> {
|
||||
request: blocks_request,
|
||||
request_id,
|
||||
})
|
||||
.and_then(|| {
|
||||
.and_then(|_| {
|
||||
self.send_network_msg(NetworkMessage::SendRequest {
|
||||
peer_id,
|
||||
request: blocks_request,
|
||||
request: blobs_request,
|
||||
request_id,
|
||||
})
|
||||
})?;
|
||||
@@ -247,55 +247,57 @@ impl<T: BeaconChainTypes> SyncNetworkContext<T> {
|
||||
request_id: Id,
|
||||
block: Option<SeansBlock>,
|
||||
) -> Option<(ChainId, BatchId, Option<SeansBlockBlob>)> {
|
||||
let (chain_id, batch_id, info) = self.block_blob_requests.get_mut(&request_id)?;
|
||||
let response = match block {
|
||||
Some(block) => match info.accumulated_blobs.pop_front() {
|
||||
Some(blob) => Some(SeansBlockBlob { block, blob }),
|
||||
None => {
|
||||
// accumulate the block
|
||||
info.accumulated_blocks.push_back(block);
|
||||
None
|
||||
}
|
||||
},
|
||||
None => {
|
||||
info.is_blocks_rpc_finished = true;
|
||||
|
||||
if info.is_blobs_rpc_finished && info.is_blocks_rpc_finished {
|
||||
// this is the coupled stream termination
|
||||
Some((chain_id, batch_id, None))
|
||||
} else {
|
||||
None
|
||||
}
|
||||
}
|
||||
};
|
||||
unimplemented!()
|
||||
// let (chain_id, batch_id, info) = self.block_blob_requests.get_mut(&request_id)?;
|
||||
// match block {
|
||||
// Some(block) => match info.accumulated_blobs.pop_front() {
|
||||
// Some(blob) => Some(SeansBlockBlob { block, blob }),
|
||||
// None => {
|
||||
// // accumulate the block
|
||||
// info.accumulated_blocks.push_back(block);
|
||||
// None
|
||||
// }
|
||||
// },
|
||||
// None => {
|
||||
// info.is_blocks_rpc_finished = true;
|
||||
//
|
||||
// if info.is_blobs_rpc_finished && info.is_blocks_rpc_finished {
|
||||
// // this is the coupled stream termination
|
||||
// Some((chain_id, batch_id, None))
|
||||
// } else {
|
||||
// None
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
}
|
||||
|
||||
pub fn block_blob_blob_response(
|
||||
&mut self,
|
||||
request_id: Id,
|
||||
blob: Option<SeansBlob>,
|
||||
) -> Option<(ChainId, Option<SeansBlockBlob>)> {
|
||||
let (chain_id, info) = self.block_blob_requests.get_mut(&request_id)?;
|
||||
let response = match blob {
|
||||
Some(blob) => match info.accumulated_blocks.pop_front() {
|
||||
Some(block) => Some(SeansBlockBlob { block, blob }),
|
||||
None => {
|
||||
// accumulate the blob
|
||||
info.accumulated_blobs.push_back(blob);
|
||||
None
|
||||
}
|
||||
},
|
||||
None => {
|
||||
info.is_blobs_rpc_finished = true;
|
||||
|
||||
if info.is_blobs_rpc_finished && info.is_blocks_rpc_finished {
|
||||
// this is the coupled stream termination
|
||||
Some((chain_id, batch_id, None))
|
||||
} else {
|
||||
None
|
||||
}
|
||||
}
|
||||
};
|
||||
) -> Option<(ChainId, BatchId, Option<SeansBlockBlob>)> {
|
||||
// let (batch_id, chain_id, info) = self.block_blob_requests.get_mut(&request_id)?;
|
||||
// match blob {
|
||||
// Some(blob) => match info.accumulated_blocks.pop_front() {
|
||||
// Some(block) => Some(SeansBlockBlob { block, blob }),
|
||||
// None => {
|
||||
// // accumulate the blob
|
||||
// info.accumulated_blobs.push_back(blob);
|
||||
// None
|
||||
// }
|
||||
// },
|
||||
// None => {
|
||||
// info.is_blobs_rpc_finished = true;
|
||||
//
|
||||
// if info.is_blobs_rpc_finished && info.is_blocks_rpc_finished {
|
||||
// // this is the coupled stream termination
|
||||
// Some((chain_id, batch_id, None))
|
||||
// } else {
|
||||
// None
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
unimplemented!("do it")
|
||||
}
|
||||
|
||||
/// Received a blocks by range response.
|
||||
|
||||
Reference in New Issue
Block a user