2022-09-06 20:49:43 +00:00
|
|
|
use super::*;
|
|
|
|
use cursive_table_view::*;
|
|
|
|
use std::cmp::Ordering;
|
|
|
|
|
|
|
|
#[derive(Copy, Clone, PartialEq, Eq, Hash)]
|
|
|
|
pub enum PeerTableColumn {
|
|
|
|
NodeId,
|
|
|
|
Address,
|
|
|
|
LatencyAvg,
|
|
|
|
TransferDownAvg,
|
|
|
|
TransferUpAvg,
|
|
|
|
}
|
|
|
|
|
|
|
|
// impl PeerTableColumn {
|
|
|
|
// fn as_str(&self) -> &str {
|
|
|
|
// match self {
|
|
|
|
// PeerTableColumn::NodeId => "Node Id",
|
|
|
|
// PeerTableColumn::Address => "Address",
|
|
|
|
// PeerTableColumn::LatencyAvg => "Latency",
|
|
|
|
// PeerTableColumn::TransferDownAvg => "Down",
|
|
|
|
// PeerTableColumn::TransferUpAvg => "Up",
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
|
2023-06-08 18:07:09 +00:00
|
|
|
fn format_ts(ts: &json::JsonValue) -> String {
|
|
|
|
if ts.is_null() {
|
|
|
|
return "---".to_owned();
|
|
|
|
}
|
|
|
|
let ts = json_str_u64(ts);
|
2022-09-06 20:49:43 +00:00
|
|
|
let secs = timestamp_to_secs(ts);
|
|
|
|
if secs >= 1.0 {
|
|
|
|
format!("{:.2}s", timestamp_to_secs(ts))
|
|
|
|
} else {
|
|
|
|
format!("{:.2}ms", timestamp_to_secs(ts) * 1000.0)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-06-08 18:07:09 +00:00
|
|
|
fn format_bps(bps: &json::JsonValue) -> String {
|
|
|
|
if bps.is_null() {
|
|
|
|
return "---".to_owned();
|
|
|
|
}
|
|
|
|
let bps = json_str_u64(bps);
|
2022-09-06 20:49:43 +00:00
|
|
|
if bps >= 1024u64 * 1024u64 * 1024u64 {
|
|
|
|
format!("{:.2}GB/s", (bps / (1024u64 * 1024u64)) as f64 / 1024.0)
|
|
|
|
} else if bps >= 1024u64 * 1024u64 {
|
|
|
|
format!("{:.2}MB/s", (bps / 1024u64) as f64 / 1024.0)
|
|
|
|
} else if bps >= 1024u64 {
|
|
|
|
format!("{:.2}KB/s", bps as f64 / 1024.0)
|
|
|
|
} else {
|
|
|
|
format!("{:.2}B/s", bps as f64)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-06-08 18:07:09 +00:00
|
|
|
impl TableViewItem<PeerTableColumn> for json::JsonValue {
|
2022-09-06 20:49:43 +00:00
|
|
|
fn to_column(&self, column: PeerTableColumn) -> String {
|
|
|
|
match column {
|
2023-06-08 18:07:09 +00:00
|
|
|
PeerTableColumn::NodeId => self["node_ids"][0].to_string(),
|
|
|
|
PeerTableColumn::Address => self["peer_address"].to_string(),
|
|
|
|
PeerTableColumn::LatencyAvg => {
|
|
|
|
format!("{}", format_ts(&self["peer_stats"]["latency"]["average"]))
|
|
|
|
}
|
|
|
|
PeerTableColumn::TransferDownAvg => {
|
|
|
|
format_bps(&self["peer_stats"]["transfer"]["down"]["average"])
|
|
|
|
}
|
|
|
|
PeerTableColumn::TransferUpAvg => {
|
|
|
|
format_bps(&self["peer_stats"]["transfer"]["up"]["average"])
|
|
|
|
}
|
2022-09-06 20:49:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn cmp(&self, other: &Self, column: PeerTableColumn) -> Ordering
|
|
|
|
where
|
|
|
|
Self: Sized,
|
|
|
|
{
|
|
|
|
match column {
|
2023-06-21 02:18:59 +00:00
|
|
|
PeerTableColumn::NodeId => self
|
|
|
|
.to_column(column)
|
|
|
|
.to_ascii_lowercase()
|
|
|
|
.cmp(&other.to_column(column).to_ascii_lowercase()),
|
|
|
|
PeerTableColumn::Address => self
|
|
|
|
.to_column(column)
|
|
|
|
.to_ascii_lowercase()
|
|
|
|
.cmp(&other.to_column(column).to_ascii_lowercase()),
|
2023-06-08 18:07:09 +00:00
|
|
|
PeerTableColumn::LatencyAvg => json_str_u64(&self["peer_stats"]["latency"]["average"])
|
|
|
|
.cmp(&json_str_u64(&other["peer_stats"]["latency"]["average"])),
|
|
|
|
PeerTableColumn::TransferDownAvg => {
|
|
|
|
json_str_u64(&self["peer_stats"]["transfer"]["down"]["average"]).cmp(&json_str_u64(
|
|
|
|
&other["peer_stats"]["transfer"]["down"]["average"],
|
|
|
|
))
|
|
|
|
}
|
|
|
|
PeerTableColumn::TransferUpAvg => {
|
|
|
|
json_str_u64(&self["peer_stats"]["transfer"]["up"]["average"]).cmp(&json_str_u64(
|
|
|
|
&other["peer_stats"]["transfer"]["up"]["average"],
|
|
|
|
))
|
|
|
|
}
|
2022-09-06 20:49:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-06-08 18:07:09 +00:00
|
|
|
pub type PeersTableView = TableView<json::JsonValue, PeerTableColumn>;
|