Skip to content

Commit

Permalink
fix(autonat): Skip unparsable multiaddr (#3351)
Browse files Browse the repository at this point in the history
With this commit `libp2p-autonat` no longer discards the whole remote payload in case an addr is
unparsable, but instead logs the failure and skips the unparsable multiaddr.

See #3244 for details.
  • Loading branch information
mxinden authored Jan 20, 2023
1 parent 92a1b95 commit f54358e
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 11 deletions.
6 changes: 6 additions & 0 deletions protocols/autonat/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
# 0.9.1

- Skip unparsable multiaddr in `DialRequest::from_bytes`. See [PR 3351].

[PR 3351]: https://github.com/libp2p/rust-libp2p/pull/3351

# 0.9.0

- Update to `libp2p-core` `v0.38.0`.
Expand Down
4 changes: 2 additions & 2 deletions protocols/autonat/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ name = "libp2p-autonat"
edition = "2021"
rust-version = "1.62.0"
description = "NAT and firewall detection for libp2p"
version = "0.9.0"
version = "0.9.1"
authors = ["David Craven <david@craven.ch>", "Elena Frank <elena.frank@protonmail.com>"]
license = "MIT"
repository = "https://github.com/libp2p/rust-libp2p"
Expand Down Expand Up @@ -31,7 +31,7 @@ env_logger = "0.9"
clap = { version = "4.0.13", features = ["derive"] }
libp2p = { path = "../..", features = ["full"] }

# Passing arguments to the docsrs builder in order to properly document cfg's.
# Passing arguments to the docsrs builder in order to properly document cfg's.
# More information: https://docs.rs/about/builds#cross-compiling
[package.metadata.docs.rs]
all-features = true
Expand Down
50 changes: 41 additions & 9 deletions protocols/autonat/src/protocol.rs
Original file line number Diff line number Diff line change
Expand Up @@ -134,15 +134,16 @@ impl DialRequest {
PeerId::try_from(peer_id)
.map_err(|_| io::Error::new(io::ErrorKind::InvalidData, "invalid peer id"))?
};
let addrs = {
let mut maddrs = vec![];
for addr in addrs.into_iter() {
let maddr = Multiaddr::try_from(addr)
.map_err(|err| io::Error::new(io::ErrorKind::InvalidData, err))?;
maddrs.push(maddr);
}
maddrs
};
let addrs = addrs
.into_iter()
.filter_map(|a| match Multiaddr::try_from(a) {
Ok(a) => Some(a),
Err(e) => {
log::debug!("Unable to parse multiaddr: {e}");
None
}
})
.collect();
Ok(Self {
peer_id,
addresses: addrs,
Expand Down Expand Up @@ -333,4 +334,35 @@ mod tests {
let response2 = DialResponse::from_bytes(&bytes).unwrap();
assert_eq!(response, response2);
}

#[test]
fn test_skip_unparsable_multiaddr() {
let valid_multiaddr: Multiaddr = "/ip6/2001:db8::/tcp/1234".parse().unwrap();
let valid_multiaddr_bytes = valid_multiaddr.to_vec();

let invalid_multiaddr = {
let a = vec![255; 8];
assert!(Multiaddr::try_from(a.clone()).is_err());
a
};

let msg = structs_proto::Message {
r#type: Some(structs_proto::message::MessageType::Dial.into()),
dial: Some(structs_proto::message::Dial {
peer: Some(structs_proto::message::PeerInfo {
id: Some(PeerId::random().to_bytes()),
addrs: vec![valid_multiaddr_bytes, invalid_multiaddr],
}),
}),
dial_response: None,
};

let mut bytes = Vec::with_capacity(msg.encoded_len());
msg.encode(&mut bytes)
.expect("Vec<u8> provides capacity as needed");

let request = DialRequest::from_bytes(&bytes).expect("not to fail");

assert_eq!(request.addresses, vec![valid_multiaddr])
}
}

0 comments on commit f54358e

Please sign in to comment.