mirror of
https://github.com/EasyTier/EasyTier.git
synced 2026-05-07 18:24:36 +00:00
23f69ce6a4
* support ipv6 stun * show interface and public ip in cli node info * direct conn should keep trying unless already direct connected * peer should use conn with smallest latency * deprecate ipv6_listener, use -l instead
118 lines
3.0 KiB
Rust
118 lines
3.0 KiB
Rust
include!(concat!(env!("OUT_DIR"), "/cli.rs"));
|
|
|
|
impl PeerRoutePair {
|
|
pub fn get_latency_ms(&self) -> Option<f64> {
|
|
let mut ret = u64::MAX;
|
|
let p = self.peer.as_ref()?;
|
|
let default_conn_id = p.default_conn_id.map(|id| id.to_string());
|
|
for conn in p.conns.iter() {
|
|
let Some(stats) = &conn.stats else {
|
|
continue;
|
|
};
|
|
if default_conn_id == Some(conn.conn_id.to_string()) {
|
|
return Some(f64::from(stats.latency_us as u32) / 1000.0);
|
|
}
|
|
ret = ret.min(stats.latency_us);
|
|
}
|
|
|
|
if ret == u64::MAX {
|
|
None
|
|
} else {
|
|
Some(f64::from(ret as u32) / 1000.0)
|
|
}
|
|
}
|
|
|
|
pub fn get_rx_bytes(&self) -> Option<u64> {
|
|
let mut ret = 0;
|
|
let p = self.peer.as_ref()?;
|
|
for conn in p.conns.iter() {
|
|
let Some(stats) = &conn.stats else {
|
|
continue;
|
|
};
|
|
ret += stats.rx_bytes;
|
|
}
|
|
|
|
if ret == 0 {
|
|
None
|
|
} else {
|
|
Some(ret)
|
|
}
|
|
}
|
|
|
|
pub fn get_tx_bytes(&self) -> Option<u64> {
|
|
let mut ret = 0;
|
|
let p = self.peer.as_ref()?;
|
|
for conn in p.conns.iter() {
|
|
let Some(stats) = &conn.stats else {
|
|
continue;
|
|
};
|
|
ret += stats.tx_bytes;
|
|
}
|
|
|
|
if ret == 0 {
|
|
None
|
|
} else {
|
|
Some(ret)
|
|
}
|
|
}
|
|
|
|
pub fn get_loss_rate(&self) -> Option<f64> {
|
|
let mut ret = 0.0;
|
|
let p = self.peer.as_ref()?;
|
|
for conn in p.conns.iter() {
|
|
ret += conn.loss_rate;
|
|
}
|
|
|
|
if ret == 0.0 {
|
|
None
|
|
} else {
|
|
Some(ret as f64)
|
|
}
|
|
}
|
|
|
|
pub fn get_conn_protos(&self) -> Option<Vec<String>> {
|
|
let mut ret = vec![];
|
|
let p = self.peer.as_ref()?;
|
|
for conn in p.conns.iter() {
|
|
let Some(tunnel_info) = &conn.tunnel else {
|
|
continue;
|
|
};
|
|
// insert if not exists
|
|
if !ret.contains(&tunnel_info.tunnel_type) {
|
|
ret.push(tunnel_info.tunnel_type.clone());
|
|
}
|
|
}
|
|
|
|
if ret.is_empty() {
|
|
None
|
|
} else {
|
|
Some(ret)
|
|
}
|
|
}
|
|
|
|
pub fn get_udp_nat_type(self: &Self) -> String {
|
|
use crate::proto::common::NatType;
|
|
let mut ret = NatType::Unknown;
|
|
if let Some(r) = &self.route.clone().unwrap_or_default().stun_info {
|
|
ret = NatType::try_from(r.udp_nat_type).unwrap();
|
|
}
|
|
format!("{:?}", ret)
|
|
}
|
|
}
|
|
|
|
pub fn list_peer_route_pair(peers: Vec<PeerInfo>, routes: Vec<Route>) -> Vec<PeerRoutePair> {
|
|
let mut pairs: Vec<PeerRoutePair> = vec![];
|
|
|
|
for route in routes.iter() {
|
|
let peer = peers.iter().find(|peer| peer.peer_id == route.peer_id);
|
|
let pair = PeerRoutePair {
|
|
route: Some(route.clone()),
|
|
peer: peer.cloned(),
|
|
};
|
|
|
|
pairs.push(pair);
|
|
}
|
|
|
|
pairs
|
|
}
|