allow tunnel listener alloc port after listen

This commit is contained in:
sijie.sun
2024-04-27 21:20:23 +08:00
committed by Sijie.Sun
parent a3e85a1270
commit 3a965efab2
4 changed files with 79 additions and 0 deletions
+20
View File
@@ -120,6 +120,11 @@ impl TunnelListener for QUICTunnelListener {
let (endpoint, server_cert) = make_server_endpoint(addr).unwrap(); let (endpoint, server_cert) = make_server_endpoint(addr).unwrap();
self.endpoint = Some(endpoint); self.endpoint = Some(endpoint);
self.server_cert = Some(server_cert); self.server_cert = Some(server_cert);
self.addr
.set_port(Some(self.endpoint.as_ref().unwrap().local_addr()?.port()))
.unwrap();
Ok(()) Ok(())
} }
@@ -267,4 +272,19 @@ mod tests {
connector.set_ip_version(IpVersion::V4); connector.set_ip_version(IpVersion::V4);
_tunnel_pingpong(listener, connector).await; _tunnel_pingpong(listener, connector).await;
} }
#[tokio::test]
async fn test_alloc_port() {
// v4
let mut listener = QUICTunnelListener::new("quic://0.0.0.0:0".parse().unwrap());
listener.listen().await.unwrap();
let port = listener.local_url().port().unwrap();
assert!(port > 0);
// v6
let mut listener = QUICTunnelListener::new("quic://[::]:0".parse().unwrap());
listener.listen().await.unwrap();
let port = listener.local_url().port().unwrap();
assert!(port > 0);
}
} }
+19
View File
@@ -45,6 +45,10 @@ impl TunnelListener for TcpTunnelListener {
// socket.set_reuseport(true)?; // socket.set_reuseport(true)?;
socket.bind(addr)?; socket.bind(addr)?;
self.addr
.set_port(Some(socket.local_addr()?.port()))
.unwrap();
self.listener = Some(socket.listen(1024)?); self.listener = Some(socket.listen(1024)?);
Ok(()) Ok(())
} }
@@ -232,4 +236,19 @@ mod tests {
connector.set_ip_version(IpVersion::V4); connector.set_ip_version(IpVersion::V4);
_tunnel_pingpong(listener, connector).await; _tunnel_pingpong(listener, connector).await;
} }
#[tokio::test]
async fn test_alloc_port() {
// v4
let mut listener = TcpTunnelListener::new("tcp://0.0.0.0:0".parse().unwrap());
listener.listen().await.unwrap();
let port = listener.local_url().port().unwrap();
assert!(port > 0);
// v6
let mut listener = TcpTunnelListener::new("tcp://[::]:0".parse().unwrap());
listener.listen().await.unwrap();
let port = listener.local_url().port().unwrap();
assert!(port > 0);
}
} }
+19
View File
@@ -388,6 +388,10 @@ impl TunnelListener for UdpTunnelListener {
self.socket = Some(Arc::new(UdpSocket::from_std(socket2_socket.into())?)); self.socket = Some(Arc::new(UdpSocket::from_std(socket2_socket.into())?));
self.data.socket = self.socket.clone(); self.data.socket = self.socket.clone();
self.addr
.set_port(Some(self.socket.as_ref().unwrap().local_addr()?.port()))
.unwrap();
self.forward_tasks self.forward_tasks
.lock() .lock()
.unwrap() .unwrap()
@@ -884,4 +888,19 @@ mod tests {
connector.set_ip_version(IpVersion::V4); connector.set_ip_version(IpVersion::V4);
_tunnel_pingpong(listener, connector).await; _tunnel_pingpong(listener, connector).await;
} }
#[tokio::test]
async fn test_alloc_port() {
// v4
let mut listener = UdpTunnelListener::new("udp://0.0.0.0:0".parse().unwrap());
listener.listen().await.unwrap();
let port = listener.local_url().port().unwrap();
assert!(port > 0);
// v6
let mut listener = UdpTunnelListener::new("udp://[::]:0".parse().unwrap());
listener.listen().await.unwrap();
let port = listener.local_url().port().unwrap();
assert!(port > 0);
}
} }
+21
View File
@@ -537,6 +537,10 @@ impl TunnelListener for WgTunnelListener {
} }
self.udp = Some(Arc::new(UdpSocket::from_std(socket2_socket.into())?)); self.udp = Some(Arc::new(UdpSocket::from_std(socket2_socket.into())?));
self.addr
.set_port(Some(self.udp.as_ref().unwrap().local_addr()?.port()))
.unwrap();
self.tasks.spawn(Self::handle_udp_incoming( self.tasks.spawn(Self::handle_udp_incoming(
self.get_udp_socket(), self.get_udp_socket(),
self.config.clone(), self.config.clone(),
@@ -868,4 +872,21 @@ pub mod tests {
connector.set_ip_version(IpVersion::V4); connector.set_ip_version(IpVersion::V4);
_tunnel_pingpong(listener, connector).await; _tunnel_pingpong(listener, connector).await;
} }
#[tokio::test]
async fn test_alloc_port() {
// v4
let (server_cfg, _client_cfg) = create_wg_config();
let mut listener = WgTunnelListener::new("wg://0.0.0.0:0".parse().unwrap(), server_cfg);
listener.listen().await.unwrap();
let port = listener.local_url().port().unwrap();
assert!(port > 0);
// v6
let (server_cfg, _client_cfg) = create_wg_config();
let mut listener = WgTunnelListener::new("wg://[::]:0".parse().unwrap(), server_cfg);
listener.listen().await.unwrap();
let port = listener.local_url().port().unwrap();
assert!(port > 0);
}
} }