use crate::intf::*; use crate::xx::*; use crate::*; #[derive(Clone, Debug)] pub struct ConnectionTableEntry { pub conn: NetworkConnection, pub established_time: u64, pub last_message_sent_time: Option, pub last_message_recv_time: Option, pub stopper: Eventual, } impl PartialEq for ConnectionTableEntry { fn eq(&self, other: &ConnectionTableEntry) -> bool { if self.conn != other.conn { return false; } if self.established_time != other.established_time { return false; } if self.last_message_sent_time != other.last_message_sent_time { return false; } if self.last_message_recv_time != other.last_message_recv_time { return false; } true } } #[derive(Debug)] pub struct ConnectionTable { conn_by_addr: BTreeMap, } impl ConnectionTable { pub fn new() -> Self { Self { conn_by_addr: BTreeMap::new(), } } pub fn add_connection( &mut self, conn: NetworkConnection, ) -> Result { let descriptor = conn.connection_descriptor(); assert_ne!( descriptor.protocol_type(), ProtocolType::UDP, "Only connection oriented protocols go in the table!" ); if self.conn_by_addr.contains_key(&descriptor) { return Err(format!( "Connection already added to table: {:?}", descriptor )); } let timestamp = get_timestamp(); let entry = ConnectionTableEntry { conn, established_time: timestamp, last_message_sent_time: None, last_message_recv_time: None, stopper: Eventual::new(), }; let res = self.conn_by_addr.insert(descriptor, entry.clone()); assert!(res.is_none()); Ok(entry) } pub fn get_connection( &self, descriptor: &ConnectionDescriptor, ) -> Option { self.conn_by_addr.get(descriptor).cloned() } pub fn connection_count(&self) -> usize { self.conn_by_addr.len() } pub fn remove_connection( &mut self, descriptor: &ConnectionDescriptor, ) -> Result { self.conn_by_addr .remove(descriptor) .ok_or_else(|| format!("Connection not in table: {:?}", descriptor)) } }