From 85a20769fb9754edeeb440191f129b860add5539 Mon Sep 17 00:00:00 2001 From: nsgundy Date: Fri, 19 May 2023 15:21:59 +0000 Subject: [PATCH] Consider peers to be on same intranet if is_lan() returns true for both --- src/rendezvous_server.rs | 17 +++++++---------- 1 file changed, 7 insertions(+), 10 deletions(-) diff --git a/src/rendezvous_server.rs b/src/rendezvous_server.rs index 5aba4d4..931b1df 100644 --- a/src/rendezvous_server.rs +++ b/src/rendezvous_server.rs @@ -706,17 +706,14 @@ impl RendezvousServer { } ph.nat_type = NatType::SYMMETRIC.into(); // will force relay } - let same_intranet = !ws - && match peer_addr { - SocketAddr::V4(a) => match addr { - SocketAddr::V4(b) => a.ip() == b.ip(), + let same_intranet: bool = !ws + && (peer_is_lan && is_lan || { + match (peer_addr, addr) { + (SocketAddr::V4(a), SocketAddr::V4(b)) => a.ip() == b.ip(), + (SocketAddr::V6(a), SocketAddr::V6(b)) => a.ip() == b.ip(), _ => false, - }, - SocketAddr::V6(a) => match addr { - SocketAddr::V6(b) => a.ip() == b.ip(), - _ => false, - }, - }; + } + }); let socket_addr = AddrMangle::encode(addr).into(); if same_intranet { log::debug!(