[−][src]Struct ipfs_bitswap::Bitswap
Network behaviour that handles sending and receiving IPFS blocks.
Fields
connected_peers: HashMap<PeerId, Ledger>
Ledger
queued_blocks: UnboundedSender<(PeerId, Block)>
Blocks queued to be sent
stats: HashMap<PeerId, Arc<Stats>>
Statistics related to peers.
Implementations
impl Bitswap
[src]
pub fn local_wantlist(&self) -> Vec<(Cid, Priority)>
[src]
Return the wantlist of the local node
pub fn peer_wantlist(&self, peer: &PeerId) -> Option<Vec<(Cid, Priority)>>
[src]
Return the wantlist of a peer, if known
pub fn stats(&self) -> Stats
[src]
pub fn peers(&self) -> Vec<PeerId>
[src]
pub fn connect(&mut self, peer_id: PeerId)
[src]
Connect to peer.
Called from Kademlia behaviour.
pub fn send_block(&mut self, peer_id: PeerId, block: Block)
[src]
Sends a block to the peer.
Called from a Strategy.
pub fn want_block(&mut self, cid: Cid, priority: Priority)
[src]
Queues the wanted block for all peers.
A user request
pub fn cancel_block(&mut self, cid: &Cid)
[src]
Removes the block from our want list and updates all peers.
Can be either a user request or be called when the block was received.
Trait Implementations
impl Default for Bitswap
[src]
impl NetworkBehaviour for Bitswap
[src]
type ProtocolsHandler = OneShotHandler<BitswapConfig, Message, MessageWrapper>
Handler for all the protocols the network behaviour supports.
type OutEvent = BitswapEvent
Event generated by the NetworkBehaviour
and that the swarm will report back.
fn new_handler(&mut self) -> Self::ProtocolsHandler
[src]
fn addresses_of_peer(&mut self, _peer_id: &PeerId) -> Vec<Multiaddr>
[src]
fn inject_connected(&mut self, peer_id: &PeerId)
[src]
fn inject_disconnected(&mut self, peer_id: &PeerId)
[src]
fn inject_event(
&mut self,
source: PeerId,
_connection: ConnectionId,
message: MessageWrapper
)
[src]
&mut self,
source: PeerId,
_connection: ConnectionId,
message: MessageWrapper
)
fn poll(
&mut self,
ctx: &mut Context<'_>,
_: &mut impl PollParameters
) -> Poll<NetworkBehaviourAction<<<Self::ProtocolsHandler as IntoProtocolsHandler>::Handler as ProtocolsHandler>::InEvent, Self::OutEvent>>
[src]
&mut self,
ctx: &mut Context<'_>,
_: &mut impl PollParameters
) -> Poll<NetworkBehaviourAction<<<Self::ProtocolsHandler as IntoProtocolsHandler>::Handler as ProtocolsHandler>::InEvent, Self::OutEvent>>
fn inject_connection_established(
&mut self,
&PeerId,
&ConnectionId,
&ConnectedPoint
)
[src]
&mut self,
&PeerId,
&ConnectionId,
&ConnectedPoint
)
fn inject_connection_closed(&mut self, &PeerId, &ConnectionId, &ConnectedPoint)
[src]
fn inject_address_change(
&mut self,
&PeerId,
&ConnectionId,
_old: &ConnectedPoint,
_new: &ConnectedPoint
)
[src]
&mut self,
&PeerId,
&ConnectionId,
_old: &ConnectedPoint,
_new: &ConnectedPoint
)
fn inject_addr_reach_failure(
&mut self,
_peer_id: Option<&PeerId>,
_addr: &Multiaddr,
_error: &dyn Error
)
[src]
&mut self,
_peer_id: Option<&PeerId>,
_addr: &Multiaddr,
_error: &dyn Error
)
fn inject_dial_failure(&mut self, _peer_id: &PeerId)
[src]
fn inject_new_listen_addr(&mut self, _addr: &Multiaddr)
[src]
fn inject_expired_listen_addr(&mut self, _addr: &Multiaddr)
[src]
fn inject_new_external_addr(&mut self, _addr: &Multiaddr)
[src]
fn inject_listener_error(
&mut self,
_id: ListenerId,
_err: &(dyn Error + 'static)
)
[src]
&mut self,
_id: ListenerId,
_err: &(dyn Error + 'static)
)
fn inject_listener_closed(
&mut self,
_id: ListenerId,
_reason: Result<(), &Error>
)
[src]
&mut self,
_id: ListenerId,
_reason: Result<(), &Error>
)
Auto Trait Implementations
impl !RefUnwindSafe for Bitswap
impl Send for Bitswap
impl Sync for Bitswap
impl Unpin for Bitswap
impl !UnwindSafe for Bitswap
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,