fix crash

This commit is contained in:
John Smith 2022-08-23 18:12:15 -04:00
parent 1b59633d73
commit fbe02e605b
2 changed files with 17 additions and 7 deletions

View File

@ -103,6 +103,7 @@ pub struct RawTcpProtocolHandler
where where
Self: ProtocolAcceptHandler, Self: ProtocolAcceptHandler,
{ {
connection_initial_timeout_ms: u32,
inner: Arc<Mutex<RawTcpProtocolHandlerInner>>, inner: Arc<Mutex<RawTcpProtocolHandlerInner>>,
} }
@ -111,22 +112,31 @@ impl RawTcpProtocolHandler {
RawTcpProtocolHandlerInner { local_address } RawTcpProtocolHandlerInner { local_address }
} }
pub fn new(local_address: SocketAddr) -> Self { pub fn new(config: VeilidConfig, local_address: SocketAddr) -> Self {
let c = config.get();
let connection_initial_timeout_ms = c.network.connection_initial_timeout_ms;
Self { Self {
connection_initial_timeout_ms,
inner: Arc::new(Mutex::new(Self::new_inner(local_address))), inner: Arc::new(Mutex::new(Self::new_inner(local_address))),
} }
} }
#[instrument(level = "trace", err, skip(self, stream))] #[instrument(level = "trace", err, skip(self, ps))]
async fn on_accept_async( async fn on_accept_async(
self, self,
stream: AsyncPeekStream, ps: AsyncPeekStream,
socket_addr: SocketAddr, socket_addr: SocketAddr,
) -> io::Result<Option<ProtocolNetworkConnection>> { ) -> io::Result<Option<ProtocolNetworkConnection>> {
log_net!("TCP: on_accept_async: enter"); log_net!("TCP: on_accept_async: enter");
let mut peekbuf: [u8; PEEK_DETECT_LEN] = [0u8; PEEK_DETECT_LEN]; let mut peekbuf: [u8; PEEK_DETECT_LEN] = [0u8; PEEK_DETECT_LEN];
let peeklen = stream.peek(&mut peekbuf).await?; if let Err(_) = timeout(
assert_eq!(peeklen, PEEK_DETECT_LEN); self.connection_initial_timeout_ms,
ps.peek_exact(&mut peekbuf),
)
.await
{
return Ok(None);
}
let peer_addr = PeerAddress::new( let peer_addr = PeerAddress::new(
SocketAddress::from_socket_addr(socket_addr), SocketAddress::from_socket_addr(socket_addr),
@ -136,7 +146,7 @@ impl RawTcpProtocolHandler {
let conn = ProtocolNetworkConnection::RawTcp(RawTcpNetworkConnection::new( let conn = ProtocolNetworkConnection::RawTcp(RawTcpNetworkConnection::new(
ConnectionDescriptor::new(peer_addr, SocketAddress::from_socket_addr(local_address)) ConnectionDescriptor::new(peer_addr, SocketAddress::from_socket_addr(local_address))
.map_err(|e| io::Error::new(io::ErrorKind::AddrNotAvailable, e))?, .map_err(|e| io::Error::new(io::ErrorKind::AddrNotAvailable, e))?,
stream, ps,
)); ));
log_net!(debug "TCP: on_accept_async from: {}", socket_addr); log_net!(debug "TCP: on_accept_async from: {}", socket_addr);

View File

@ -611,7 +611,7 @@ impl Network {
ip_addrs, ip_addrs,
tcp_port, tcp_port,
false, false,
Box::new(|_, _, a| Box::new(RawTcpProtocolHandler::new(a))), Box::new(move |c, _, a| Box::new(RawTcpProtocolHandler::new(c, a))),
) )
.await?; .await?;
trace!("TCP: listener started on {:#?}", socket_addresses); trace!("TCP: listener started on {:#?}", socket_addresses);