checkpoint
This commit is contained in:
		| @@ -120,7 +120,7 @@ pub(crate) enum NodeContactMethod { | |||||||
|     Direct(DialInfo), |     Direct(DialInfo), | ||||||
|     /// Request via signal the node connect back directly (relay, target) |     /// Request via signal the node connect back directly (relay, target) | ||||||
|     SignalReverse(NodeRef, NodeRef), |     SignalReverse(NodeRef, NodeRef), | ||||||
|     /// Request via signal the node negotiate a hole punch (relay, target_node) |     /// Request via signal the node negotiate a hole punch (relay, target) | ||||||
|     SignalHolePunch(NodeRef, NodeRef), |     SignalHolePunch(NodeRef, NodeRef), | ||||||
|     /// Must use an inbound relay to reach the node |     /// Must use an inbound relay to reach the node | ||||||
|     InboundRelay(NodeRef), |     InboundRelay(NodeRef), | ||||||
|   | |||||||
| @@ -122,6 +122,14 @@ impl RoutingTableUnlockedInner { | |||||||
|         tks |         tks | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     pub fn node_id_typed_key_pairs(&self) -> Vec<TypedKeyPair> { | ||||||
|  |         let mut tkps = Vec::new(); | ||||||
|  |         for (ck, v) in &self.node_id_keypairs { | ||||||
|  |             tkps.push(TypedKeyPair::new(*ck, v.key, v.secret)); | ||||||
|  |         } | ||||||
|  |         tkps | ||||||
|  |     } | ||||||
|  |  | ||||||
|     pub fn node_id_secret(&self, kind: CryptoKind) -> SecretKey { |     pub fn node_id_secret(&self, kind: CryptoKind) -> SecretKey { | ||||||
|         self.node_id_keypairs.get(&kind).unwrap().secret |         self.node_id_keypairs.get(&kind).unwrap().secret | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -102,7 +102,7 @@ impl RoutingDomainEditor { | |||||||
|  |  | ||||||
|         let mut changed = false; |         let mut changed = false; | ||||||
|         { |         { | ||||||
|             let node_id = self.routing_table.node_id(); |             let node_ids = self.routing_table.node_ids(); | ||||||
|  |  | ||||||
|             let mut inner = self.routing_table.inner.write(); |             let mut inner = self.routing_table.inner.write(); | ||||||
|             inner.with_routing_domain_mut(self.routing_domain, |detail| { |             inner.with_routing_domain_mut(self.routing_domain, |detail| { | ||||||
| @@ -134,9 +134,7 @@ impl RoutingDomainEditor { | |||||||
|  |  | ||||||
|                             info!( |                             info!( | ||||||
|                                 "{:?} Dial Info: {}@{}", |                                 "{:?} Dial Info: {}@{}", | ||||||
|                                 self.routing_domain, |                                 self.routing_domain, node_ids, dial_info_detail.dial_info | ||||||
|                                 NodeId::new(node_id), |  | ||||||
|                                 dial_info_detail.dial_info |  | ||||||
|                             ); |                             ); | ||||||
|                             changed = true; |                             changed = true; | ||||||
|                         } |                         } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ pub enum ContactMethod { | |||||||
|     Direct(DialInfo), |     Direct(DialInfo), | ||||||
|     /// Request via signal the node connect back directly (relay, target) |     /// Request via signal the node connect back directly (relay, target) | ||||||
|     SignalReverse(TypedKey, TypedKey), |     SignalReverse(TypedKey, TypedKey), | ||||||
|     /// Request via signal the node negotiate a hole punch (relay, target_node) |     /// Request via signal the node negotiate a hole punch (relay, target) | ||||||
|     SignalHolePunch(TypedKey, TypedKey), |     SignalHolePunch(TypedKey, TypedKey), | ||||||
|     /// Must use an inbound relay to reach the node |     /// Must use an inbound relay to reach the node | ||||||
|     InboundRelay(TypedKey), |     InboundRelay(TypedKey), | ||||||
| @@ -106,8 +106,8 @@ impl RoutingDomainDetailCommon { | |||||||
|             network_class: self.network_class.unwrap_or(NetworkClass::Invalid), |             network_class: self.network_class.unwrap_or(NetworkClass::Invalid), | ||||||
|             outbound_protocols: self.outbound_protocols, |             outbound_protocols: self.outbound_protocols, | ||||||
|             address_types: self.address_types, |             address_types: self.address_types, | ||||||
|             min_version: MIN_CRYPTO_VERSION, |             envelope_support: VALID_ENVELOPE_VERSIONS.to_vec(), | ||||||
|             max_version: MAX_CRYPTO_VERSION, |             crypto_support: VALID_CRYPTO_KINDS.to_vec(), | ||||||
|             dial_info_detail_list: self.dial_info_details.clone(), |             dial_info_detail_list: self.dial_info_details.clone(), | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
| @@ -118,7 +118,7 @@ impl RoutingDomainDetailCommon { | |||||||
|                 let opt_relay_pi = rn.locked(rti).make_peer_info(self.routing_domain); |                 let opt_relay_pi = rn.locked(rti).make_peer_info(self.routing_domain); | ||||||
|                 if let Some(relay_pi) = opt_relay_pi { |                 if let Some(relay_pi) = opt_relay_pi { | ||||||
|                     match relay_pi.signed_node_info { |                     match relay_pi.signed_node_info { | ||||||
|                         SignedNodeInfo::Direct(d) => Some((relay_pi.node_id, d)),  |                         SignedNodeInfo::Direct(d) => Some((relay_pi.node_ids, d)),  | ||||||
|                         SignedNodeInfo::Relayed(_) => { |                         SignedNodeInfo::Relayed(_) => { | ||||||
|                             warn!("relay node should not have a relay itself! if this happens, a relay updated its signed node info and became a relay, which should cause the relay to be dropped"); |                             warn!("relay node should not have a relay itself! if this happens, a relay updated its signed node info and became a relay, which should cause the relay to be dropped"); | ||||||
|                             None |                             None | ||||||
| @@ -130,27 +130,27 @@ impl RoutingDomainDetailCommon { | |||||||
|             }); |             }); | ||||||
|  |  | ||||||
|         let signed_node_info = match relay_info { |         let signed_node_info = match relay_info { | ||||||
|             Some((relay_id, relay_sdni)) => SignedNodeInfo::Relayed( |             Some((relay_ids, relay_sdni)) => SignedNodeInfo::Relayed( | ||||||
|                 SignedRelayedNodeInfo::make_signatures( |                 SignedRelayedNodeInfo::make_signatures( | ||||||
|                     NodeId::new(rti.unlocked_inner.node_id), |                     rti.unlocked_inner.crypto(), | ||||||
|  |                     rti.unlocked_inner.node_id_typed_key_pairs(), | ||||||
|                     node_info, |                     node_info, | ||||||
|                     relay_id, |                     relay_ids, | ||||||
|                     relay_sdni,                     |                     relay_sdni,                     | ||||||
|                     &rti.unlocked_inner.node_id_secret, |  | ||||||
|                 ) |                 ) | ||||||
|                 .unwrap(), |                 .unwrap(), | ||||||
|             ), |             ), | ||||||
|             None => SignedNodeInfo::Direct( |             None => SignedNodeInfo::Direct( | ||||||
|                 SignedDirectNodeInfo::with_secret( |                 SignedDirectNodeInfo::make_signatures( | ||||||
|                     NodeId::new(rti.unlocked_inner.node_id), |                     rti.unlocked_inner.crypto(), | ||||||
|  |                     rti.unlocked_inner.node_id_typed_key_pairs(), | ||||||
|                     node_info, |                     node_info, | ||||||
|                     &rti.unlocked_inner.node_id_secret, |  | ||||||
|                 ) |                 ) | ||||||
|                 .unwrap() |                 .unwrap() | ||||||
|             ), |             ), | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         PeerInfo::new(NodeId::new(rti.unlocked_inner.node_id), signed_node_info) |         PeerInfo::new(rti.unlocked_inner.node_ids(), signed_node_info) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub fn with_peer_info<F, R>(&self, rti: &RoutingTableInner, f: F) -> R |     pub fn with_peer_info<F, R>(&self, rti: &RoutingTableInner, f: F) -> R | ||||||
| @@ -281,6 +281,15 @@ impl RoutingDomainDetail for PublicInternetRoutingDomainDetail { | |||||||
|         let node_a = peer_a.signed_node_info.node_info(); |         let node_a = peer_a.signed_node_info.node_info(); | ||||||
|         let node_b = peer_b.signed_node_info.node_info(); |         let node_b = peer_b.signed_node_info.node_info(); | ||||||
|  |  | ||||||
|  |         // Get the node ids that would be used between these peers | ||||||
|  |         let cck = common_crypto_kinds(&peer_a.node_ids.kinds(), &peer_b.node_ids.kinds()); | ||||||
|  |         let Some(best_ck) = cck.first().copied() else { | ||||||
|  |             // No common crypto kinds between these nodes, can't contact | ||||||
|  |             return ContactMethod::Unreachable; | ||||||
|  |         }; | ||||||
|  |         let node_a_id = peer_a.node_ids.get(best_ck).unwrap(); | ||||||
|  |         let node_b_id = peer_b.node_ids.get(best_ck).unwrap(); | ||||||
|  |  | ||||||
|         // Get the best match dial info for node B if we have it |         // Get the best match dial info for node B if we have it | ||||||
|         if let Some(target_did) = |         if let Some(target_did) = | ||||||
|             first_filtered_dial_info_detail(node_a, node_b, &dial_info_filter, sequencing) |             first_filtered_dial_info_detail(node_a, node_b, &dial_info_filter, sequencing) | ||||||
| @@ -293,15 +302,20 @@ impl RoutingDomainDetail for PublicInternetRoutingDomainDetail { | |||||||
|  |  | ||||||
|             // Get the target's inbound relay, it must have one or it is not reachable |             // Get the target's inbound relay, it must have one or it is not reachable | ||||||
|             if let Some(node_b_relay) = peer_b.signed_node_info.relay_info() { |             if let Some(node_b_relay) = peer_b.signed_node_info.relay_info() { | ||||||
|                 let node_b_relay_id = peer_b.signed_node_info.relay_id().unwrap(); |  | ||||||
|  |  | ||||||
|                 // Note that relay_peer_info could be node_a, in which case a connection already exists |                 // Note that relay_peer_info could be node_a, in which case a connection already exists | ||||||
|                 // and we only get here if the connection had dropped, in which case node_a is unreachable until |                 // and we only get here if the connection had dropped, in which case node_a is unreachable until | ||||||
|                 // it gets a new relay connection up |                 // it gets a new relay connection up | ||||||
|                 if node_b_relay_id.key == peer_a.node_id.key { |                 if peer_b.signed_node_info.relay_ids().contains_any(&peer_a.node_ids) { | ||||||
|                     return ContactMethod::Existing; |                     return ContactMethod::Existing; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|  |                 // Get best node id to contact relay with | ||||||
|  |                 let Some(node_b_relay_id) = peer_b.signed_node_info.relay_ids().get(best_ck) else { | ||||||
|  |                     // No best relay id | ||||||
|  |                     return ContactMethod::Unreachable; | ||||||
|  |                 }; | ||||||
|  |  | ||||||
|                 // Can node A reach the inbound relay directly? |                 // Can node A reach the inbound relay directly? | ||||||
|                 if first_filtered_dial_info_detail( |                 if first_filtered_dial_info_detail( | ||||||
|                     node_a, |                     node_a, | ||||||
| @@ -329,8 +343,8 @@ impl RoutingDomainDetail for PublicInternetRoutingDomainDetail { | |||||||
|                                 // Can we receive a direct reverse connection? |                                 // Can we receive a direct reverse connection? | ||||||
|                                 if !reverse_did.class.requires_signal() { |                                 if !reverse_did.class.requires_signal() { | ||||||
|                                     return ContactMethod::SignalReverse( |                                     return ContactMethod::SignalReverse( | ||||||
|                                         node_b_relay_id.key, |                                         node_b_relay_id, | ||||||
|                                         peer_b.node_id.key, |                                         node_b_id, | ||||||
|                                     ); |                                     ); | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
| @@ -361,8 +375,8 @@ impl RoutingDomainDetail for PublicInternetRoutingDomainDetail { | |||||||
|                                 { |                                 { | ||||||
|                                     // The target and ourselves have a udp dialinfo that they can reach |                                     // The target and ourselves have a udp dialinfo that they can reach | ||||||
|                                     return ContactMethod::SignalHolePunch( |                                     return ContactMethod::SignalHolePunch( | ||||||
|                                         node_b_relay_id.key, |                                         node_b_relay_id, | ||||||
|                                         peer_a.node_id.key, |                                         node_b_id, | ||||||
|                                     ); |                                     ); | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
| @@ -370,21 +384,26 @@ impl RoutingDomainDetail for PublicInternetRoutingDomainDetail { | |||||||
|                         // Otherwise we have to inbound relay |                         // Otherwise we have to inbound relay | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     return ContactMethod::InboundRelay(node_b_relay_id.key); |                     return ContactMethod::InboundRelay(node_b_relay_id); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         // If the node B has no direct dial info, it needs to have an inbound relay |         // If the node B has no direct dial info, it needs to have an inbound relay | ||||||
|         else if let Some(node_b_relay) = peer_b.signed_node_info.relay_info() { |         else if let Some(node_b_relay) = peer_b.signed_node_info.relay_info() { | ||||||
|             let node_b_relay_id = peer_b.signed_node_info.relay_id().unwrap(); |  | ||||||
|  |  | ||||||
|             // Note that relay_peer_info could be node_a, in which case a connection already exists |             // Note that relay_peer_info could be node_a, in which case a connection already exists | ||||||
|             // and we only get here if the connection had dropped, in which case node_a is unreachable until |             // and we only get here if the connection had dropped, in which case node_a is unreachable until | ||||||
|             // it gets a new relay connection up |             // it gets a new relay connection up | ||||||
|             if node_b_relay_id.key == peer_a.node_id.key { |             if peer_b.signed_node_info.relay_ids().contains_any(&peer_a.node_ids) { | ||||||
|                 return ContactMethod::Existing; |                 return ContactMethod::Existing; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             // Get best node id to contact relay with | ||||||
|  |             let Some(node_b_relay_id) = peer_b.signed_node_info.relay_ids().get(best_ck) else { | ||||||
|  |                 // No best relay id | ||||||
|  |                 return ContactMethod::Unreachable; | ||||||
|  |             }; | ||||||
|  |  | ||||||
|             // Can we reach the full relay? |             // Can we reach the full relay? | ||||||
|             if first_filtered_dial_info_detail( |             if first_filtered_dial_info_detail( | ||||||
|                 node_a, |                 node_a, | ||||||
| @@ -394,13 +413,13 @@ impl RoutingDomainDetail for PublicInternetRoutingDomainDetail { | |||||||
|             ) |             ) | ||||||
|             .is_some() |             .is_some() | ||||||
|             { |             { | ||||||
|                 return ContactMethod::InboundRelay(node_b_relay_id.key); |                 return ContactMethod::InboundRelay(node_b_relay_id); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // If node A can't reach the node by other means, it may need to use its own relay |         // If node A can't reach the node by other means, it may need to use its own relay | ||||||
|         if let Some(node_a_relay_id) = peer_a.signed_node_info.relay_id() { |         if let Some(node_a_relay_id) = peer_a.signed_node_info.relay_ids().get(best_ck) { | ||||||
|             return ContactMethod::OutboundRelay(node_a_relay_id.key); |             return ContactMethod::OutboundRelay(node_a_relay_id); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         ContactMethod::Unreachable |         ContactMethod::Unreachable | ||||||
|   | |||||||
| @@ -1967,10 +1967,10 @@ impl SignedRelayedNodeInfo { | |||||||
|  |  | ||||||
|     pub fn make_signatures( |     pub fn make_signatures( | ||||||
|         crypto: Crypto, |         crypto: Crypto, | ||||||
|  |         typed_key_pairs: Vec<TypedKeyPair>, | ||||||
|         node_info: NodeInfo, |         node_info: NodeInfo, | ||||||
|         relay_ids: TypedKeySet, |         relay_ids: TypedKeySet, | ||||||
|         relay_info: SignedDirectNodeInfo, |         relay_info: SignedDirectNodeInfo, | ||||||
|         typed_key_pairs: Vec<TypedKeyPair>, |  | ||||||
|     ) -> Result<Self, VeilidAPIError> { |     ) -> Result<Self, VeilidAPIError> { | ||||||
|         let timestamp = get_aligned_timestamp(); |         let timestamp = get_aligned_timestamp(); | ||||||
|         let node_info_bytes = |         let node_info_bytes = | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user