Move peer state to a separate file

This commit is contained in:
Igor Katson 2021-06-28 14:23:28 +01:00
parent 0d85eb9f2a
commit 1e478aabac
5 changed files with 33 additions and 23 deletions

View file

@ -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;

View file

@ -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)]

View 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>,
}

View file

@ -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>,

View file

@ -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;