fix timeout

This commit is contained in:
soruh 2023-01-25 22:28:39 +01:00
parent 6a3324563c
commit ca06a02306
2 changed files with 11 additions and 6 deletions

View File

@ -465,11 +465,11 @@ async fn connection_handler(
break Result::Packet { packet } break Result::Packet { packet }
} }
}, },
_ = sleep(now.saturating_duration_since(last_ping_sent_at).saturating_sub(SEND_PING_INTERVAL)) => { _ = sleep(SEND_PING_INTERVAL.saturating_sub(now.saturating_duration_since(last_ping_sent_at))) => {
writer.write_all(bytemuck::bytes_of(& Header { kind: PacketKind::Ping.raw(), length: 0 })).await?; writer.write_all(bytemuck::bytes_of(& Header { kind: PacketKind::Ping.raw(), length: 0 })).await?;
last_ping_sent_at = now; last_ping_sent_at = now;
} }
_ = sleep(now.saturating_duration_since(last_ping_received_at).saturating_sub(PING_TIMEOUT)) => { _ = sleep(PING_TIMEOUT.saturating_sub(now.saturating_duration_since(last_ping_received_at))) => {
writer.write_all(REJECT_TIMEOUT).await?; writer.write_all(REJECT_TIMEOUT).await?;
return Ok(()); return Ok(());
} }

View File

@ -157,6 +157,8 @@ impl Packet {
} }
pub async fn dyn_ip_update(number: u32, pin: u16, port: u16) -> anyhow::Result<std::net::Ipv4Addr> { pub async fn dyn_ip_update(number: u32, pin: u16, port: u16) -> anyhow::Result<std::net::Ipv4Addr> {
println!("dyn ip update: number={number} port={port}...");
let mut packet = Packet::default(); let mut packet = Packet::default();
packet.header = Header { packet.header = Header {
kind: PacketKind::DynIpUpdate.raw(), kind: PacketKind::DynIpUpdate.raw(),
@ -169,8 +171,7 @@ pub async fn dyn_ip_update(number: u32, pin: u16, port: u16) -> anyhow::Result<s
packet.data.extend_from_slice(&pin.to_le_bytes()); packet.data.extend_from_slice(&pin.to_le_bytes());
packet.data.extend_from_slice(&port.to_le_bytes()); packet.data.extend_from_slice(&port.to_le_bytes());
let mut socket = tokio::net::TcpStream::connect(("tlnserv.teleprinter.net", 11811)).await?; let mut socket = tokio::net::TcpStream::connect(("127.0.0.1", 11811)).await?;
// 127.0.0.1
let (mut reader, mut writer) = socket.split(); let (mut reader, mut writer) = socket.split();
@ -178,7 +179,7 @@ pub async fn dyn_ip_update(number: u32, pin: u16, port: u16) -> anyhow::Result<s
packet.recv_into(&mut reader).await?; packet.recv_into(&mut reader).await?;
match packet.kind() { let res = match packet.kind() {
PacketKind::DynIpUpdateResponse => Ok(<[u8; 4]>::try_from(packet.data) PacketKind::DynIpUpdateResponse => Ok(<[u8; 4]>::try_from(packet.data)
.map_err(|err| { .map_err(|err| {
anyhow::anyhow!( anyhow::anyhow!(
@ -205,5 +206,9 @@ pub async fn dyn_ip_update(number: u32, pin: u16, port: u16) -> anyhow::Result<s
} }
_ => bail!("server returned unexpected packet"), _ => bail!("server returned unexpected packet"),
} };
println!("dyn ip update result: {res:?}");
res
} }