pub struct RequestManager {
    pub received_transactions: Arc<RwLock<ReceivedTransactionContainer>>,
    pub inflight_pending_transactions: Arc<RwLock<InflightPendingTransactionContainer>>,
    /* private fields */
}
Expand description

When a header or block is requested by the RequestManager, it is ensured that if it’s not fully received, its hash exists in in_flight after every function call.

The thread who removes a hash from in_flight is responsible to request it again if it’s not received.

No lock is held when we call another function in this struct, and all locks are acquired in the same order, so there should exist no deadlocks.

Fields§

§received_transactions: Arc<RwLock<ReceivedTransactionContainer>>§inflight_pending_transactions: Arc<RwLock<InflightPendingTransactionContainer>>

Implementations§

source§

impl RequestManager

source

pub fn new( protocol_config: &ProtocolConfiguration, syn: Arc<SynchronizationState>, recover_public_queue: Arc<AsyncTaskQueue<RecoverPublicTask>> ) -> Self

source

pub fn num_epochs_in_flight(&self) -> u64

source

pub fn in_flight_blocks(&self) -> HashSet<H256>

source

pub fn request_with_delay( &self, io: &dyn NetworkContext, request: Box<dyn Request>, peer: Option<NodeId>, delay: Option<Duration> )

Send request to remote peer with delay mechanism. If failed, add the request to waiting queue to resend later.

source

pub fn request_block_headers( &self, io: &dyn NetworkContext, peer_id: Option<NodeId>, hashes: Vec<H256>, delay: Option<Duration> )

source

pub fn request_epoch_hashes( &self, io: &dyn NetworkContext, peer_id: Option<NodeId>, epochs: Vec<u64>, delay: Option<Duration> )

source

pub fn request_blocks( &self, io: &dyn NetworkContext, peer_id: Option<NodeId>, hashes: Vec<H256>, with_public: bool, delay: Option<Duration>, preferred_node_type: Option<NodeType> )

source

pub fn request_transactions_from_digest( &self, io: &dyn NetworkContext, peer_id: NodeId, transaction_digests: &TransactionDigests )

source

pub fn request_transactions_from_tx_hashes( &self, io: &dyn NetworkContext, peer_id: NodeId, responded_tx_hashes: Vec<H256>, window_index: usize, tx_hashes_indices: &Vec<usize> )

source

pub fn request_compact_blocks( &self, io: &dyn NetworkContext, peer_id: Option<NodeId>, hashes: Vec<H256>, delay: Option<Duration> )

source

pub fn request_blocktxn( &self, io: &dyn NetworkContext, peer_id: NodeId, block_hash: H256, index_skips: Vec<usize>, delay: Option<Duration> )

source

pub fn send_pending_requests(&self, io: &dyn NetworkContext, peer: &NodeId)

source

pub fn resend_request_to_another_peer( &self, io: &dyn NetworkContext, req: &RequestMessage )

source

pub fn match_request( &self, peer_id: &NodeId, request_id: u64 ) -> Result<RequestMessage, Error>

source

pub fn headers_received( &self, io: &dyn NetworkContext, req_hashes: HashSet<H256>, received_headers: HashSet<H256>, delay: Option<Duration> )

Remove inflight keys when a header is received.

If a request is removed from req_hashes, it’s the caller’s responsibility to ensure that the removed request either has already received or will be requested by the caller again.

source

pub fn epochs_received( &self, io: &dyn NetworkContext, req_epochs: HashSet<u64>, received_epochs: HashSet<u64>, delay: Option<Duration> )

Remove from inflight keys when a epoch is received.

source

pub fn blocks_received( &self, io: &dyn NetworkContext, requested_hashes: HashSet<H256>, received_blocks: HashSet<H256>, ask_full_block: bool, peer: Option<NodeId>, with_public: bool, delay: Option<Duration>, preferred_node_type_for_block_request: Option<NodeType> )

Remove from inflight keys when a block is received.

If a request is removed from req_hashes, it’s the caller’s responsibility to ensure that the removed request either has already received or will be requested by the caller again (the case for Blocktxn).

source

pub fn transactions_received_from_digests( &self, io: &dyn NetworkContext, get_transactions_request: &GetTransactions, signed_transactions: Vec<Arc<SignedTransaction>> )

source

pub fn transactions_received_from_tx_hashes( &self, get_transactions_request: &GetTransactionsFromTxHashes, signed_transactions: Vec<Arc<SignedTransaction>> )

source

pub fn get_sent_transactions( &self, window_index: usize, indices: &Vec<usize> ) -> Vec<TransactionWithSignature>

source

pub fn append_sent_transactions( &self, transactions: Vec<Arc<SignedTransaction>> ) -> usize

source

pub fn append_received_transactions( &self, transactions: Vec<Arc<SignedTransaction>> )

source

pub fn resend_timeout_requests(&self, io: &dyn NetworkContext)

source

pub fn resend_waiting_requests( &self, io: &dyn NetworkContext, remove_timeout_requests: bool, prefer_archive_node_for_blocks: bool ) -> Vec<Box<dyn Request>>

Send waiting requests that their backoff delay have passes. Return the cancelled requests that have timeout too many times.

source

pub fn on_peer_connected(&self, peer: &NodeId)

source

pub fn on_peer_disconnected(&self, io: &dyn NetworkContext, peer: &NodeId)

source

pub fn remove_net_inflight_blocks<'a, I: Iterator<Item = &'a H256>>( &self, blocks: I )

Trait Implementations§

source§

impl MallocSizeOf for RequestManager

source§

fn size_of(&self, ops: &mut MallocSizeOfOps) -> usize

Measure the heap usage of all descendant heap-allocated structures, but not the space taken up by the value itself.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
source§

impl<T> ElementSatisfy<ElementNoConstrain> for T

§

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pipe for T
where T: ?Sized,

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
§

impl<T> ErasedDestructor for T
where T: 'static,

§

impl<T> MaybeSend for T
where T: Send,

§

impl<T> MaybeSendSync for T

§

impl<T> UnsafeAny for T
where T: Any,