From 60c46485301b6312e2d502571e47842059b60e04 Mon Sep 17 00:00:00 2001 From: John Smith Date: Fri, 4 Nov 2022 12:58:13 -0400 Subject: [PATCH] fix signed node info --- veilid-core/src/routing_table/bucket_entry.rs | 29 ++++++++++--------- veilid-core/src/rpc_processor/rpc_status.rs | 2 +- 2 files changed, 17 insertions(+), 14 deletions(-) diff --git a/veilid-core/src/routing_table/bucket_entry.rs b/veilid-core/src/routing_table/bucket_entry.rs index f858fbd7..6bad7999 100644 --- a/veilid-core/src/routing_table/bucket_entry.rs +++ b/veilid-core/src/routing_table/bucket_entry.rs @@ -181,20 +181,23 @@ impl BucketEntryInner { // See if we have an existing signed_node_info to update or not if let Some(current_sni) = opt_current_sni { - // If the timestamp hasn't changed or is less, ignore this update - if signed_node_info.timestamp <= current_sni.timestamp { - // If we received a node update with the same timestamp - // we can make this node live again, but only if our network has recently changed - // which may make nodes that were unreachable now reachable with the same dialinfo - if !self.updated_since_last_network_change - && signed_node_info.timestamp == current_sni.timestamp - { - // No need to update the signednodeinfo though since the timestamp is the same - // Touch the node and let it try to live again - self.updated_since_last_network_change = true; - self.touch_last_seen(intf::get_timestamp()); + // Always allow overwriting invalid/unsigned node + if current_sni.has_valid_signature() { + // If the timestamp hasn't changed or is less, ignore this update + if signed_node_info.timestamp <= current_sni.timestamp { + // If we received a node update with the same timestamp + // we can make this node live again, but only if our network has recently changed + // which may make nodes that were unreachable now reachable with the same dialinfo + if !self.updated_since_last_network_change + && signed_node_info.timestamp == current_sni.timestamp + { + // No need to update the signednodeinfo though since the timestamp is the same + // Touch the node and let it try to live again + self.updated_since_last_network_change = true; + self.touch_last_seen(intf::get_timestamp()); + } + return; } - return; } } diff --git a/veilid-core/src/rpc_processor/rpc_status.rs b/veilid-core/src/rpc_processor/rpc_status.rs index ab8b83d8..6725ddfa 100644 --- a/veilid-core/src/rpc_processor/rpc_status.rs +++ b/veilid-core/src/rpc_processor/rpc_status.rs @@ -149,7 +149,6 @@ impl RPCProcessor { ) } } - opt_sender_info = Some(sender_info.clone()); } SendDataKind::Indirect => { // Do nothing in this case, as the socket address returned here would be for any node other than ours @@ -158,6 +157,7 @@ impl RPCProcessor { // Do nothing in this case, as an existing connection could not have a different public address or it would have been reset } }; + opt_sender_info = Some(sender_info.clone()); } } }