Move peer state to a separate file
This commit is contained in:
parent
0d85eb9f2a
commit
1e478aabac
5 changed files with 33 additions and 23 deletions
|
|
@ -7,6 +7,7 @@ pub mod lengths;
|
||||||
pub mod peer_binary_protocol;
|
pub mod peer_binary_protocol;
|
||||||
pub mod peer_connection;
|
pub mod peer_connection;
|
||||||
pub mod peer_id;
|
pub mod peer_id;
|
||||||
|
pub mod peer_state;
|
||||||
pub mod serde_bencode;
|
pub mod serde_bencode;
|
||||||
pub mod spawn_utils;
|
pub mod spawn_utils;
|
||||||
pub mod torrent_manager;
|
pub mod torrent_manager;
|
||||||
|
|
|
||||||
|
|
@ -17,7 +17,8 @@ use crate::{
|
||||||
},
|
},
|
||||||
peer_id::try_decode_peer_id,
|
peer_id::try_decode_peer_id,
|
||||||
spawn_utils::{spawn, spawn_blocking},
|
spawn_utils::{spawn, spawn_blocking},
|
||||||
torrent_state::{InflightRequest, PeerHandle, TorrentState},
|
torrent_state::{InflightRequest, TorrentState},
|
||||||
|
type_aliases::PeerHandle,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
|
|
|
||||||
24
crates/librqbit/src/peer_state.rs
Normal file
24
crates/librqbit/src/peer_state.rs
Normal file
|
|
@ -0,0 +1,24 @@
|
||||||
|
use std::{collections::HashSet, net::SocketAddr, sync::Arc};
|
||||||
|
|
||||||
|
use tokio::sync::{Notify, Semaphore};
|
||||||
|
|
||||||
|
use crate::{torrent_state::InflightRequest, type_aliases::BF};
|
||||||
|
|
||||||
|
pub enum PeerState {
|
||||||
|
Connecting(SocketAddr),
|
||||||
|
Live(LivePeerState),
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct LivePeerState {
|
||||||
|
#[allow(unused)]
|
||||||
|
pub peer_id: [u8; 20],
|
||||||
|
pub i_am_choked: bool,
|
||||||
|
#[allow(unused)]
|
||||||
|
pub peer_choked: bool,
|
||||||
|
#[allow(unused)]
|
||||||
|
pub peer_interested: bool,
|
||||||
|
pub outstanding_requests: Arc<Semaphore>,
|
||||||
|
pub have_notify: Arc<Notify>,
|
||||||
|
pub bitfield: Option<BF>,
|
||||||
|
pub inflight_requests: HashSet<InflightRequest>,
|
||||||
|
}
|
||||||
|
|
@ -21,17 +21,11 @@ use crate::{
|
||||||
file_checking::update_hash_from_file,
|
file_checking::update_hash_from_file,
|
||||||
lengths::{ChunkInfo, Lengths, ValidPieceIndex},
|
lengths::{ChunkInfo, Lengths, ValidPieceIndex},
|
||||||
peer_binary_protocol::{Handshake, Message, MessageOwned, Piece},
|
peer_binary_protocol::{Handshake, Message, MessageOwned, Piece},
|
||||||
|
peer_state::{LivePeerState, PeerState},
|
||||||
torrent_metainfo::TorrentMetaV1Owned,
|
torrent_metainfo::TorrentMetaV1Owned,
|
||||||
type_aliases::BF,
|
type_aliases::{PeerHandle, BF},
|
||||||
};
|
};
|
||||||
|
|
||||||
pub type PeerHandle = SocketAddr;
|
|
||||||
|
|
||||||
pub enum PeerState {
|
|
||||||
Connecting(SocketAddr),
|
|
||||||
Live(LivePeerState),
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Hash, PartialEq, Eq)]
|
#[derive(Debug, Hash, PartialEq, Eq)]
|
||||||
pub struct InflightRequest {
|
pub struct InflightRequest {
|
||||||
pub piece: ValidPieceIndex,
|
pub piece: ValidPieceIndex,
|
||||||
|
|
@ -47,20 +41,6 @@ impl From<&ChunkInfo> for InflightRequest {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct LivePeerState {
|
|
||||||
#[allow(unused)]
|
|
||||||
pub peer_id: [u8; 20],
|
|
||||||
pub i_am_choked: bool,
|
|
||||||
#[allow(unused)]
|
|
||||||
pub peer_choked: bool,
|
|
||||||
#[allow(unused)]
|
|
||||||
pub peer_interested: bool,
|
|
||||||
pub outstanding_requests: Arc<Semaphore>,
|
|
||||||
pub have_notify: Arc<Notify>,
|
|
||||||
pub bitfield: Option<BF>,
|
|
||||||
pub inflight_requests: HashSet<InflightRequest>,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
pub struct PeerStates {
|
pub struct PeerStates {
|
||||||
states: HashMap<PeerHandle, PeerState>,
|
states: HashMap<PeerHandle, PeerState>,
|
||||||
|
|
|
||||||
|
|
@ -1 +1,5 @@
|
||||||
|
use std::net::SocketAddr;
|
||||||
|
|
||||||
pub type BF = bitvec::vec::BitVec<bitvec::order::Msb0, u8>;
|
pub type BF = bitvec::vec::BitVec<bitvec::order::Msb0, u8>;
|
||||||
|
|
||||||
|
pub type PeerHandle = SocketAddr;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue