diff --git a/transports/quic/CHANGELOG.md b/transports/quic/CHANGELOG.md index 2283c41262b..b761c140bb1 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/src/transport.rs b/transports/quic/src/transport.rs index aea3c91093f..7f18fa90426 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 36fb72a5ee7..8cea5b52354 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() {