liveness tweaks

This commit is contained in:
John Smith
2022-08-05 18:07:32 -04:00
parent 63aa0dc1f6
commit ef096eb310
4 changed files with 51 additions and 31 deletions

View File

@@ -108,14 +108,15 @@ impl BucketEntryInner {
move |e1, e2| Self::cmp_fastest_reliable(cur_ts, e1, e2)
}
pub fn update_node_info(&mut self, signed_node_info: SignedNodeInfo) {
// Retuns true if the node info changed
pub fn update_node_info(&mut self, signed_node_info: SignedNodeInfo) -> bool {
// Don't update with older node info, or something less valid
if let Some(current_sni) = &self.opt_signed_node_info {
if current_sni.signature.valid && !signed_node_info.signature.valid {
return;
return false;
}
if signed_node_info.timestamp < current_sni.timestamp {
return;
return false;
}
}
self.min_max_version = Some((
@@ -123,6 +124,8 @@ impl BucketEntryInner {
signed_node_info.node_info.max_version,
));
self.opt_signed_node_info = Some(signed_node_info);
true
}
pub fn update_local_node_info(&mut self, local_node_info: LocalNodeInfo) {
self.opt_local_node_info = Some(local_node_info)

View File

@@ -581,7 +581,10 @@ impl RoutingTable {
}
self.create_node_ref(node_id, |e| {
e.update_node_info(signed_node_info);
if e.update_node_info(signed_node_info) {
// at least someone thought this node was live and its node info changed so lets try to contact it
e.touch_last_seen(intf::get_timestamp());
}
})
}
@@ -596,6 +599,9 @@ impl RoutingTable {
self.create_node_ref(node_id, |e| {
// set the most recent node address for connection finding and udp replies
e.set_last_connection(descriptor, timestamp);
// this node is live because it literally just connected to us
e.touch_last_seen(timestamp);
})
}