From 9b6ca0ee4f07669ddef221afbcafbcd1566e668f Mon Sep 17 00:00:00 2001 From: Nazar Mokrynskyi Date: Sun, 19 Nov 2023 11:34:00 +0200 Subject: [PATCH] fix(quic): fix address translation --- Cargo.toml | 2 +- transports/quic/CHANGELOG.md | 5 +++ transports/quic/Cargo.toml | 2 +- transports/quic/src/transport.rs | 3 +- transports/quic/tests/smoke.rs | 52 ++++++++++++++++++++++++++++++++ 5 files changed, 61 insertions(+), 3 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 9417876ae015..1939c195ff83 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -94,7 +94,7 @@ libp2p-perf = { version = "0.3.0", path = "protocols/perf" } libp2p-ping = { version = "0.44.0", path = "protocols/ping" } libp2p-plaintext = { version = "0.41.0", path = "transports/plaintext" } libp2p-pnet = { version = "0.24.0", path = "transports/pnet" } -libp2p-quic = { version = "0.10.1", path = "transports/quic" } +libp2p-quic = { version = "0.10.2", path = "transports/quic" } libp2p-relay = { version = "0.17.1", path = "protocols/relay" } libp2p-rendezvous = { version = "0.14.0", path = "protocols/rendezvous" } libp2p-request-response = { version = "0.26.0", path = "protocols/request-response" } diff --git a/transports/quic/CHANGELOG.md b/transports/quic/CHANGELOG.md index 2283c41262b1..b761c140bb1a 100644 --- a/transports/quic/CHANGELOG.md +++ b/transports/quic/CHANGELOG.md @@ -1,3 +1,8 @@ +## 0.10.2 - unreleased + +- Fix address translation. + See [PR 4896](https://github.com/libp2p/rust-libp2p/pull/4896). + ## 0.10.1 - Allow disabling path MTU discovery. diff --git a/transports/quic/Cargo.toml b/transports/quic/Cargo.toml index 22b241c8d8ed..d3bc69b9230a 100644 --- a/transports/quic/Cargo.toml +++ b/transports/quic/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "libp2p-quic" -version = "0.10.1" +version = "0.10.2" authors = ["Parity Technologies "] edition = "2021" rust-version = { workspace = true } diff --git a/transports/quic/src/transport.rs b/transports/quic/src/transport.rs index aea3c91093f8..7f18fa904267 100644 --- a/transports/quic/src/transport.rs +++ b/transports/quic/src/transport.rs @@ -32,6 +32,7 @@ use futures::{prelude::*, stream::SelectAll}; use if_watch::IfEvent; use libp2p_core::{ + address_translation, multiaddr::{Multiaddr, Protocol}, transport::{ListenerId, TransportError, TransportEvent}, Transport, @@ -253,7 +254,7 @@ impl Transport for GenTransport

{ { return None; } - Some(observed.clone()) + address_translation(listen, observed) } fn dial(&mut self, addr: Multiaddr) -> Result> { diff --git a/transports/quic/tests/smoke.rs b/transports/quic/tests/smoke.rs index 36fb72a5ee7e..8cea5b523548 100644 --- a/transports/quic/tests/smoke.rs +++ b/transports/quic/tests/smoke.rs @@ -19,6 +19,7 @@ use quic::Provider; use rand::RngCore; use std::future::Future; use std::io; +use std::net::Ipv4Addr; use std::num::NonZeroU8; use std::task::Poll; use std::time::Duration; @@ -236,6 +237,57 @@ fn new_tcp_quic_transport() -> (PeerId, Boxed<(PeerId, StreamMuxerBox)>) { (peer_id, transport) } +#[cfg(feature = "async-std")] +#[test] +fn test_address_translation_async_std() { + test_address_translation::() +} + +#[cfg(feature = "tokio")] +#[test] +fn test_address_translation_tokio() { + test_address_translation::() +} + +fn test_address_translation() +where + T: Provider, +{ + let (_peer_id, transport) = create_default_transport::(); + + let port = 42; + let quic_listen_addr = Multiaddr::empty() + .with(Protocol::Ip4(Ipv4Addr::new(127, 0, 0, 1))) + .with(Protocol::Udp(port)) + .with(Protocol::QuicV1); + let observed_ip = Ipv4Addr::new(123, 45, 67, 8); + let quic_observed_addr = Multiaddr::empty() + .with(Protocol::Ip4(observed_ip)) + .with(Protocol::Udp(1)) + .with(Protocol::QuicV1) + .with(Protocol::P2p(PeerId::random())); + + let translated = transport + .address_translation(&quic_listen_addr, &quic_observed_addr) + .unwrap(); + let mut iter = translated.iter(); + assert_eq!(iter.next(), Some(Protocol::Ip4(observed_ip))); + assert_eq!(iter.next(), Some(Protocol::Udp(port))); + assert_eq!(iter.next(), Some(Protocol::QuicV1)); + assert_eq!(iter.next(), None); + + let tcp_addr = Multiaddr::empty() + .with(Protocol::Ip4(Ipv4Addr::new(87, 65, 43, 21))) + .with(Protocol::Tcp(1)); + + assert!(transport + .address_translation(&quic_listen_addr, &tcp_addr) + .is_none()); + assert!(transport + .address_translation(&tcp_addr, &quic_observed_addr) + .is_none()); +} + #[cfg(feature = "async-std")] #[async_std::test] async fn tcp_and_quic() {