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_connection;
pub mod peer_id;
pub mod peer_state;
pub mod serde_bencode;
pub mod spawn_utils;
pub mod torrent_manager;

View file

@ -17,7 +17,8 @@ use crate::{
},
peer_id::try_decode_peer_id,
spawn_utils::{spawn, spawn_blocking},
torrent_state::{InflightRequest, PeerHandle, TorrentState},
torrent_state::{InflightRequest, TorrentState},
type_aliases::PeerHandle,
};
#[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,
lengths::{ChunkInfo, Lengths, ValidPieceIndex},
peer_binary_protocol::{Handshake, Message, MessageOwned, Piece},
peer_state::{LivePeerState, PeerState},
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)]
pub struct InflightRequest {
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)]
pub struct PeerStates {
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 PeerHandle = SocketAddr;