From 5f130dc8237badf047cb6c10ee46f5fdd1d54b08 Mon Sep 17 00:00:00 2001 From: Francis Murillo Date: Sat, 24 Jul 2021 15:20:59 +0800 Subject: [PATCH] Remove loopback and duplicate addrs in `net peers` output --- forest/src/cli/net_cmd.rs | 36 +++++++++++++++++++++++++++++++----- 1 file changed, 31 insertions(+), 5 deletions(-) diff --git a/forest/src/cli/net_cmd.rs b/forest/src/cli/net_cmd.rs index dce26122a522..00be3e947ee1 100644 --- a/forest/src/cli/net_cmd.rs +++ b/forest/src/cli/net_cmd.rs @@ -3,6 +3,7 @@ use forest_libp2p::{Multiaddr, Protocol}; use rpc_api::data_types::AddrInfo; +use std::collections::HashSet; use structopt::StructOpt; use crate::cli::cli_error_and_die; @@ -50,12 +51,37 @@ impl NetCommands { Self::Peers => match net_peers(()).await { Ok(addrs) => { let output: Vec = addrs - .iter() - .map(|info| { - let addresses: Vec = - info.addrs.iter().map(|addr| addr.to_string()).collect(); + .into_iter() + .filter_map(|info| { + let addresses: Vec = info + .addrs + .into_iter() + .filter_map(|addr| { + match addr.iter().next().unwrap() { + Protocol::Ip4(ip_addr) => { + if ip_addr.is_loopback() { + return None; + } + } + Protocol::Ip6(ip_addr) => { + if ip_addr.is_loopback() { + return None; + } + } + _ => (), + }; + + Some(addr.to_string()) + }) + .collect::>() + .into_iter() + .collect(); + + if addresses.is_empty() { + return None; + } - format!("{}, [{}]", info.id, addresses.join(", ")) + Some(format!("{}, [{}]", info.id, addresses.join(", "))) }) .collect();