Merge branch 'dev' into 'main'
Dev Work See merge request veilid/veilid!5
This commit is contained in:
commit
1b364d6ace
872
Cargo.lock
generated
872
Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
2
external/cursive-flexi-logger-view
vendored
2
external/cursive-flexi-logger-view
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 16ac289d156b327a1a3a2feeef103e3212e453b5
|
Subproject commit fd560c499be0f34305e0d48aca7f1bc3d015a17f
|
@ -45,6 +45,7 @@ pub const PUBLIC_ADDRESS_CHANGE_DETECTION_COUNT: usize = 3;
|
|||||||
pub const PUBLIC_ADDRESS_CHECK_CACHE_SIZE: usize = 8;
|
pub const PUBLIC_ADDRESS_CHECK_CACHE_SIZE: usize = 8;
|
||||||
pub const PUBLIC_ADDRESS_CHECK_TASK_INTERVAL_SECS: u32 = 60;
|
pub const PUBLIC_ADDRESS_CHECK_TASK_INTERVAL_SECS: u32 = 60;
|
||||||
pub const PUBLIC_ADDRESS_INCONSISTENCY_TIMEOUT_US: u64 = 300_000_000u64; // 5 minutes
|
pub const PUBLIC_ADDRESS_INCONSISTENCY_TIMEOUT_US: u64 = 300_000_000u64; // 5 minutes
|
||||||
|
pub const PUBLIC_ADDRESS_INCONSISTENCY_PUNISHMENT_TIMEOUT_US: u64 = 3600_000_000u64; // 60 minutes
|
||||||
pub const BOOT_MAGIC: &[u8; 4] = b"BOOT";
|
pub const BOOT_MAGIC: &[u8; 4] = b"BOOT";
|
||||||
pub const BOOTSTRAP_TXT_VERSION: u8 = 0;
|
pub const BOOTSTRAP_TXT_VERSION: u8 = 0;
|
||||||
|
|
||||||
@ -936,6 +937,7 @@ impl NetworkManager {
|
|||||||
// should not be subject to our ability to decode it
|
// should not be subject to our ability to decode it
|
||||||
|
|
||||||
// Send receipt directly
|
// Send receipt directly
|
||||||
|
log_net!(debug "send_out_of_band_receipt: dial_info={}", dial_info);
|
||||||
network_result_value_or_log!(debug self
|
network_result_value_or_log!(debug self
|
||||||
.net()
|
.net()
|
||||||
.send_data_unbound_to_dial_info(dial_info, rcpt_data)
|
.send_data_unbound_to_dial_info(dial_info, rcpt_data)
|
||||||
@ -1651,7 +1653,7 @@ impl NetworkManager {
|
|||||||
// Determine if a local IP address has changed
|
// Determine if a local IP address has changed
|
||||||
// this means we should restart the low level network and and recreate all of our dial info
|
// this means we should restart the low level network and and recreate all of our dial info
|
||||||
// Wait until we have received confirmation from N different peers
|
// Wait until we have received confirmation from N different peers
|
||||||
pub async fn report_local_socket_address(
|
pub fn report_local_socket_address(
|
||||||
&self,
|
&self,
|
||||||
_socket_address: SocketAddress,
|
_socket_address: SocketAddress,
|
||||||
_connection_descriptor: ConnectionDescriptor,
|
_connection_descriptor: ConnectionDescriptor,
|
||||||
@ -1663,7 +1665,7 @@ impl NetworkManager {
|
|||||||
// Determine if a global IP address has changed
|
// Determine if a global IP address has changed
|
||||||
// this means we should recreate our public dial info if it is not static and rediscover it
|
// this means we should recreate our public dial info if it is not static and rediscover it
|
||||||
// Wait until we have received confirmation from N different peers
|
// Wait until we have received confirmation from N different peers
|
||||||
pub async fn report_global_socket_address(
|
pub fn report_global_socket_address(
|
||||||
&self,
|
&self,
|
||||||
socket_address: SocketAddress, // the socket address as seen by the remote peer
|
socket_address: SocketAddress, // the socket address as seen by the remote peer
|
||||||
connection_descriptor: ConnectionDescriptor, // the connection descriptor used
|
connection_descriptor: ConnectionDescriptor, // the connection descriptor used
|
||||||
@ -1672,14 +1674,15 @@ impl NetworkManager {
|
|||||||
// debug code
|
// debug code
|
||||||
//info!("report_global_socket_address\nsocket_address: {:#?}\nconnection_descriptor: {:#?}\nreporting_peer: {:#?}", socket_address, connection_descriptor, reporting_peer);
|
//info!("report_global_socket_address\nsocket_address: {:#?}\nconnection_descriptor: {:#?}\nreporting_peer: {:#?}", socket_address, connection_descriptor, reporting_peer);
|
||||||
|
|
||||||
let key = PublicAddressCheckCacheKey(
|
// Ignore these reports if we are currently detecting public dial info
|
||||||
connection_descriptor.protocol_type(),
|
let inner = &mut *self.inner.lock();
|
||||||
connection_descriptor.address_type(),
|
let net = inner.components.as_ref().unwrap().net.clone();
|
||||||
);
|
if net.doing_public_dial_info_check() {
|
||||||
|
return;
|
||||||
let (net, routing_table, detect_address_changes) = {
|
}
|
||||||
let mut inner = self.inner.lock();
|
let routing_table = inner.routing_table.as_ref().unwrap().clone();
|
||||||
let c = self.config.get();
|
let c = self.config.get();
|
||||||
|
let detect_address_changes = c.network.detect_address_changes;
|
||||||
|
|
||||||
// Get the ip(block) this report is coming from
|
// Get the ip(block) this report is coming from
|
||||||
let ip6_prefix_size = c.network.max_connections_per_ip6_prefix_size as usize;
|
let ip6_prefix_size = c.network.max_connections_per_ip6_prefix_size as usize;
|
||||||
@ -1688,20 +1691,29 @@ impl NetworkManager {
|
|||||||
connection_descriptor.remote_address().to_ip_addr(),
|
connection_descriptor.remote_address().to_ip_addr(),
|
||||||
);
|
);
|
||||||
|
|
||||||
// Store the reported address
|
// Store the reported address if it isn't denylisted
|
||||||
|
let key = PublicAddressCheckCacheKey(
|
||||||
|
connection_descriptor.protocol_type(),
|
||||||
|
connection_descriptor.address_type(),
|
||||||
|
);
|
||||||
let pacc = inner
|
let pacc = inner
|
||||||
.public_address_check_cache
|
.public_address_check_cache
|
||||||
.entry(key)
|
.entry(key)
|
||||||
.or_insert_with(|| LruCache::new(PUBLIC_ADDRESS_CHECK_CACHE_SIZE));
|
.or_insert_with(|| LruCache::new(PUBLIC_ADDRESS_CHECK_CACHE_SIZE));
|
||||||
|
let pait = inner
|
||||||
|
.public_address_inconsistencies_table
|
||||||
|
.entry(key)
|
||||||
|
.or_insert_with(|| HashMap::new());
|
||||||
|
if pait.contains_key(&ipblock) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
pacc.insert(ipblock, socket_address);
|
pacc.insert(ipblock, socket_address);
|
||||||
|
|
||||||
let net = inner.components.as_ref().unwrap().net.clone();
|
|
||||||
let routing_table = inner.routing_table.as_ref().unwrap().clone();
|
|
||||||
(net, routing_table, c.network.detect_address_changes)
|
|
||||||
};
|
|
||||||
let network_class = net.get_network_class().unwrap_or(NetworkClass::Invalid);
|
|
||||||
|
|
||||||
// Determine if our external address has likely changed
|
// Determine if our external address has likely changed
|
||||||
|
let mut bad_public_address_detection_punishment: Option<
|
||||||
|
Box<dyn FnOnce() + Send + 'static>,
|
||||||
|
> = None;
|
||||||
|
let network_class = net.get_network_class().unwrap_or(NetworkClass::Invalid);
|
||||||
let needs_public_address_detection =
|
let needs_public_address_detection =
|
||||||
if matches!(network_class, NetworkClass::InboundCapable) {
|
if matches!(network_class, NetworkClass::InboundCapable) {
|
||||||
// Get the dial info filter for this connection so we can check if we have any public dialinfo that may have changed
|
// Get the dial info filter for this connection so we can check if we have any public dialinfo that may have changed
|
||||||
@ -1719,42 +1731,50 @@ impl NetworkManager {
|
|||||||
|
|
||||||
// If we are inbound capable, but start to see inconsistent socket addresses from multiple reporting peers
|
// If we are inbound capable, but start to see inconsistent socket addresses from multiple reporting peers
|
||||||
// then we zap the network class and re-detect it
|
// then we zap the network class and re-detect it
|
||||||
let inner = &mut *self.inner.lock();
|
|
||||||
let mut inconsistencies = Vec::new();
|
let mut inconsistencies = Vec::new();
|
||||||
let mut inconsistent = false;
|
|
||||||
// Iteration goes from most recent to least recent node/address pair
|
// Iteration goes from most recent to least recent node/address pair
|
||||||
let pacc = inner
|
|
||||||
.public_address_check_cache
|
|
||||||
.entry(key)
|
|
||||||
.or_insert_with(|| LruCache::new(PUBLIC_ADDRESS_CHECK_CACHE_SIZE));
|
|
||||||
let pait = inner
|
|
||||||
.public_address_inconsistencies_table
|
|
||||||
.entry(key)
|
|
||||||
.or_insert_with(|| HashMap::new());
|
|
||||||
for (reporting_ip_block, a) in pacc {
|
for (reporting_ip_block, a) in pacc {
|
||||||
// If this address is not one of our current addresses (inconsistent)
|
// If this address is not one of our current addresses (inconsistent)
|
||||||
// and we haven't already denylisted the reporting source,
|
// and we haven't already denylisted the reporting source,
|
||||||
if !current_addresses.contains(a) && !pait.contains_key(reporting_ip_block) {
|
if !current_addresses.contains(a) && !pait.contains_key(reporting_ip_block) {
|
||||||
// Record the origin of the inconsistency
|
// Record the origin of the inconsistency
|
||||||
inconsistencies.push(*reporting_ip_block);
|
inconsistencies.push(*reporting_ip_block);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// If we have enough inconsistencies to consider changing our public dial info,
|
// If we have enough inconsistencies to consider changing our public dial info,
|
||||||
// add them to our denylist (throttling) and go ahead and check for new
|
// add them to our denylist (throttling) and go ahead and check for new
|
||||||
// public dialinfo
|
// public dialinfo
|
||||||
if inconsistencies.len() >= PUBLIC_ADDRESS_CHANGE_DETECTION_COUNT {
|
let inconsistent = if inconsistencies.len() >= PUBLIC_ADDRESS_CHANGE_DETECTION_COUNT
|
||||||
let exp_ts =
|
{
|
||||||
intf::get_timestamp() + PUBLIC_ADDRESS_INCONSISTENCY_TIMEOUT_US;
|
let exp_ts = intf::get_timestamp() + PUBLIC_ADDRESS_INCONSISTENCY_TIMEOUT_US;
|
||||||
|
for i in &inconsistencies {
|
||||||
|
pait.insert(*i, exp_ts);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Run this routine if the inconsistent nodes turn out to be lying
|
||||||
|
let this = self.clone();
|
||||||
|
bad_public_address_detection_punishment = Some(Box::new(move || {
|
||||||
|
let mut inner = this.inner.lock();
|
||||||
|
let pait = inner
|
||||||
|
.public_address_inconsistencies_table
|
||||||
|
.entry(key)
|
||||||
|
.or_insert_with(|| HashMap::new());
|
||||||
|
let exp_ts = intf::get_timestamp()
|
||||||
|
+ PUBLIC_ADDRESS_INCONSISTENCY_PUNISHMENT_TIMEOUT_US;
|
||||||
for i in inconsistencies {
|
for i in inconsistencies {
|
||||||
pait.insert(i, exp_ts);
|
pait.insert(i, exp_ts);
|
||||||
}
|
}
|
||||||
|
}));
|
||||||
|
|
||||||
|
true
|
||||||
|
} else {
|
||||||
|
false
|
||||||
|
};
|
||||||
|
|
||||||
inconsistent = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// // debug code
|
// // debug code
|
||||||
// if changed {
|
// if inconsistent {
|
||||||
// trace!("public_address_check_cache: {:#?}\ncurrent_addresses: {:#?}\ninconsistencies: {}", inner
|
// trace!("public_address_check_cache: {:#?}\ncurrent_addresses: {:#?}\ninconsistencies: {}", inner
|
||||||
// .public_address_check_cache, current_addresses, inconsistencies);
|
// .public_address_check_cache, current_addresses, inconsistencies);
|
||||||
// }
|
// }
|
||||||
@ -1765,7 +1785,6 @@ impl NetworkManager {
|
|||||||
// but if we are starting to see consistent socket address from multiple reporting peers
|
// but if we are starting to see consistent socket address from multiple reporting peers
|
||||||
// then we may be become inbound capable, so zap the network class so we can re-detect it and any public dial info
|
// then we may be become inbound capable, so zap the network class so we can re-detect it and any public dial info
|
||||||
|
|
||||||
let mut inner = self.inner.lock();
|
|
||||||
let mut consistencies = 0;
|
let mut consistencies = 0;
|
||||||
let mut consistent = false;
|
let mut consistent = false;
|
||||||
let mut current_address = Option::<SocketAddress>::None;
|
let mut current_address = Option::<SocketAddress>::None;
|
||||||
@ -1796,14 +1815,11 @@ impl NetworkManager {
|
|||||||
// Reset the address check cache now so we can start detecting fresh
|
// Reset the address check cache now so we can start detecting fresh
|
||||||
info!("Public address has changed, detecting public dial info");
|
info!("Public address has changed, detecting public dial info");
|
||||||
|
|
||||||
let mut inner = self.inner.lock();
|
|
||||||
inner.public_address_check_cache.clear();
|
inner.public_address_check_cache.clear();
|
||||||
|
|
||||||
// Reset the network class and dial info so we can re-detect it
|
// Re-detect the public dialinfo
|
||||||
routing_table.clear_dial_info_details(RoutingDomain::PublicInternet);
|
net.set_needs_public_dial_info_check(bad_public_address_detection_punishment);
|
||||||
net.reset_network_class();
|
|
||||||
} else {
|
} else {
|
||||||
let inner = self.inner.lock();
|
|
||||||
warn!("Public address may have changed. Restarting the server may be required.");
|
warn!("Public address may have changed. Restarting the server may be required.");
|
||||||
warn!("report_global_socket_address\nsocket_address: {:#?}\nconnection_descriptor: {:#?}\nreporting_peer: {:#?}", socket_address, connection_descriptor, reporting_peer);
|
warn!("report_global_socket_address\nsocket_address: {:#?}\nconnection_descriptor: {:#?}\nreporting_peer: {:#?}", socket_address, connection_descriptor, reporting_peer);
|
||||||
warn!(
|
warn!(
|
||||||
|
@ -6,6 +6,7 @@ use std::net::UdpSocket;
|
|||||||
const UPNP_GATEWAY_DETECT_TIMEOUT_MS: u32 = 5_000;
|
const UPNP_GATEWAY_DETECT_TIMEOUT_MS: u32 = 5_000;
|
||||||
const UPNP_MAPPING_LIFETIME_MS: u32 = 120_000;
|
const UPNP_MAPPING_LIFETIME_MS: u32 = 120_000;
|
||||||
const UPNP_MAPPING_ATTEMPTS: u32 = 3;
|
const UPNP_MAPPING_ATTEMPTS: u32 = 3;
|
||||||
|
const UPNP_MAPPING_LIFETIME_US:u64 = (UPNP_MAPPING_LIFETIME_MS as u64) * 1000u64;
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
struct PortMapKey {
|
struct PortMapKey {
|
||||||
@ -299,18 +300,17 @@ impl IGDManager {
|
|||||||
// If an error is received, then return false to restart the local network
|
// If an error is received, then return false to restart the local network
|
||||||
let mut full_renews: Vec<(PortMapKey, PortMapValue)> = Vec::new();
|
let mut full_renews: Vec<(PortMapKey, PortMapValue)> = Vec::new();
|
||||||
let mut renews: Vec<(PortMapKey, PortMapValue)> = Vec::new();
|
let mut renews: Vec<(PortMapKey, PortMapValue)> = Vec::new();
|
||||||
let now = intf::get_timestamp();
|
|
||||||
const UPNP_MAPPING_LIFETIME_US:u64 = (UPNP_MAPPING_LIFETIME_MS as u64) * 1000u64;
|
|
||||||
|
|
||||||
{
|
{
|
||||||
let inner = self.inner.lock();
|
let inner = self.inner.lock();
|
||||||
|
let now = intf::get_timestamp();
|
||||||
|
|
||||||
for (k, v) in &inner.port_maps {
|
for (k, v) in &inner.port_maps {
|
||||||
if (now - v.timestamp) >= UPNP_MAPPING_LIFETIME_US || v.renewal_attempts >= UPNP_MAPPING_ATTEMPTS {
|
let mapping_lifetime = now.saturating_sub(v.timestamp);
|
||||||
|
if mapping_lifetime >= UPNP_MAPPING_LIFETIME_US || v.renewal_attempts >= UPNP_MAPPING_ATTEMPTS {
|
||||||
// Past expiration time or tried N times, do a full renew and fail out if we can't
|
// Past expiration time or tried N times, do a full renew and fail out if we can't
|
||||||
full_renews.push((*k, *v));
|
full_renews.push((*k, *v));
|
||||||
}
|
}
|
||||||
else if (now - v.timestamp) >= v.renewal_lifetime {
|
else if mapping_lifetime >= v.renewal_lifetime {
|
||||||
// Attempt a normal renewal
|
// Attempt a normal renewal
|
||||||
renews.push((*k, *v));
|
renews.push((*k, *v));
|
||||||
}
|
}
|
||||||
|
@ -48,6 +48,10 @@ struct NetworkInner {
|
|||||||
enable_ipv4: bool,
|
enable_ipv4: bool,
|
||||||
enable_ipv6_global: bool,
|
enable_ipv6_global: bool,
|
||||||
enable_ipv6_local: bool,
|
enable_ipv6_local: bool,
|
||||||
|
// public dial info check
|
||||||
|
needs_public_dial_info_check: bool,
|
||||||
|
doing_public_dial_info_check: bool,
|
||||||
|
public_dial_info_check_punishment: Option<Box<dyn FnOnce() + Send + 'static>>,
|
||||||
// udp
|
// udp
|
||||||
bound_first_udp: BTreeMap<u16, Option<(socket2::Socket, socket2::Socket)>>,
|
bound_first_udp: BTreeMap<u16, Option<(socket2::Socket, socket2::Socket)>>,
|
||||||
inbound_udp_protocol_handlers: BTreeMap<SocketAddr, RawUdpProtocolHandler>,
|
inbound_udp_protocol_handlers: BTreeMap<SocketAddr, RawUdpProtocolHandler>,
|
||||||
@ -89,6 +93,9 @@ impl Network {
|
|||||||
NetworkInner {
|
NetworkInner {
|
||||||
network_started: false,
|
network_started: false,
|
||||||
network_needs_restart: false,
|
network_needs_restart: false,
|
||||||
|
needs_public_dial_info_check: false,
|
||||||
|
doing_public_dial_info_check: false,
|
||||||
|
public_dial_info_check_punishment: None,
|
||||||
protocol_config: None,
|
protocol_config: None,
|
||||||
static_public_dialinfo: ProtocolTypeSet::empty(),
|
static_public_dialinfo: ProtocolTypeSet::empty(),
|
||||||
network_class: None,
|
network_class: None,
|
||||||
@ -770,17 +777,30 @@ impl Network {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////
|
//////////////////////////////////////////
|
||||||
|
pub fn set_needs_public_dial_info_check(
|
||||||
|
&self,
|
||||||
|
punishment: Option<Box<dyn FnOnce() + Send + 'static>>,
|
||||||
|
) {
|
||||||
|
let mut inner = self.inner.lock();
|
||||||
|
inner.needs_public_dial_info_check = true;
|
||||||
|
inner.public_dial_info_check_punishment = punishment;
|
||||||
|
}
|
||||||
|
|
||||||
|
fn needs_public_dial_info_check(&self) -> bool {
|
||||||
|
let inner = self.inner.lock();
|
||||||
|
inner.needs_public_dial_info_check
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn doing_public_dial_info_check(&self) -> bool {
|
||||||
|
let inner = self.inner.lock();
|
||||||
|
inner.doing_public_dial_info_check
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_network_class(&self) -> Option<NetworkClass> {
|
pub fn get_network_class(&self) -> Option<NetworkClass> {
|
||||||
let inner = self.inner.lock();
|
let inner = self.inner.lock();
|
||||||
inner.network_class
|
inner.network_class
|
||||||
}
|
}
|
||||||
|
|
||||||
#[instrument(level = "debug", skip_all)]
|
|
||||||
pub fn reset_network_class(&self) {
|
|
||||||
let mut inner = self.inner.lock();
|
|
||||||
inner.network_class = None;
|
|
||||||
}
|
|
||||||
|
|
||||||
//////////////////////////////////////////
|
//////////////////////////////////////////
|
||||||
|
|
||||||
#[instrument(level = "trace", skip(self), err)]
|
#[instrument(level = "trace", skip(self), err)]
|
||||||
@ -842,7 +862,8 @@ impl Network {
|
|||||||
// If we need to figure out our network class, tick the task for it
|
// If we need to figure out our network class, tick the task for it
|
||||||
if detect_address_changes {
|
if detect_address_changes {
|
||||||
let network_class = self.get_network_class().unwrap_or(NetworkClass::Invalid);
|
let network_class = self.get_network_class().unwrap_or(NetworkClass::Invalid);
|
||||||
if network_class == NetworkClass::Invalid {
|
let needs_public_dial_info_check = self.needs_public_dial_info_check();
|
||||||
|
if network_class == NetworkClass::Invalid || needs_public_dial_info_check {
|
||||||
let routing_table = self.routing_table();
|
let routing_table = self.routing_table();
|
||||||
let rth = routing_table.get_routing_table_health();
|
let rth = routing_table.get_routing_table_health();
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
use super::*;
|
use super::*;
|
||||||
//use futures_util::stream::FuturesOrdered;
|
|
||||||
use futures_util::stream::FuturesUnordered;
|
use futures_util::stream::FuturesUnordered;
|
||||||
use futures_util::FutureExt;
|
use futures_util::FutureExt;
|
||||||
use stop_token::future::FutureExt as StopTokenFutureExt;
|
use stop_token::future::FutureExt as StopTokenFutureExt;
|
||||||
@ -481,22 +480,6 @@ impl Network {
|
|||||||
c.network.restricted_nat_retries
|
c.network.restricted_nat_retries
|
||||||
};
|
};
|
||||||
|
|
||||||
// See if we already have a public dialinfo of this protocol/address type
|
|
||||||
let routing_table = self.routing_table();
|
|
||||||
let dif = DialInfoFilter::global()
|
|
||||||
.with_protocol_type(protocol_type)
|
|
||||||
.with_address_type(AddressType::IPV4);
|
|
||||||
let dids =
|
|
||||||
routing_table.all_filtered_dial_info_details(Some(RoutingDomain::PublicInternet), &dif);
|
|
||||||
if !dids.is_empty() {
|
|
||||||
log_net!(debug
|
|
||||||
"Skipping detection for public dialinfo for {:?}:IPV4",
|
|
||||||
protocol_type
|
|
||||||
);
|
|
||||||
context.set_detected_network_class(NetworkClass::InboundCapable);
|
|
||||||
return Ok(());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Start doing ipv4 protocol
|
// Start doing ipv4 protocol
|
||||||
context.protocol_begin(protocol_type, AddressType::IPV4);
|
context.protocol_begin(protocol_type, AddressType::IPV4);
|
||||||
|
|
||||||
@ -554,21 +537,6 @@ impl Network {
|
|||||||
context: &DiscoveryContext,
|
context: &DiscoveryContext,
|
||||||
protocol_type: ProtocolType,
|
protocol_type: ProtocolType,
|
||||||
) -> EyreResult<()> {
|
) -> EyreResult<()> {
|
||||||
// See if we already have a public dialinfo of this protocol/address type
|
|
||||||
let routing_table = self.routing_table();
|
|
||||||
let dif = DialInfoFilter::global()
|
|
||||||
.with_protocol_type(protocol_type)
|
|
||||||
.with_address_type(AddressType::IPV6);
|
|
||||||
let dids =
|
|
||||||
routing_table.all_filtered_dial_info_details(Some(RoutingDomain::PublicInternet), &dif);
|
|
||||||
if !dids.is_empty() {
|
|
||||||
log_net!(debug
|
|
||||||
"Skipping detection for public dialinfo for {:?}:IPV6",
|
|
||||||
protocol_type
|
|
||||||
);
|
|
||||||
context.set_detected_network_class(NetworkClass::InboundCapable);
|
|
||||||
return Ok(());
|
|
||||||
}
|
|
||||||
// Start doing ipv6 protocol
|
// Start doing ipv6 protocol
|
||||||
context.protocol_begin(protocol_type, AddressType::IPV6);
|
context.protocol_begin(protocol_type, AddressType::IPV6);
|
||||||
|
|
||||||
@ -605,29 +573,31 @@ impl Network {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[instrument(level = "trace", skip(self), err)]
|
#[instrument(level = "trace", skip(self), err)]
|
||||||
pub async fn update_network_class_task_routine(
|
pub async fn do_public_dial_info_check(
|
||||||
self,
|
&self,
|
||||||
stop_token: StopToken,
|
stop_token: StopToken,
|
||||||
_l: u64,
|
_l: u64,
|
||||||
_t: u64,
|
_t: u64,
|
||||||
) -> EyreResult<()> {
|
) -> EyreResult<()> {
|
||||||
// Ensure we aren't trying to update this without clearing it first
|
// Figure out if we can optimize TCP/WS checking since they are often on the same port
|
||||||
let old_network_class = self.inner.lock().network_class;
|
let (protocol_config, existing_network_class, tcp_same_port) = {
|
||||||
assert_eq!(old_network_class, None);
|
let inner = self.inner.lock();
|
||||||
|
let protocol_config = inner.protocol_config.unwrap_or_default();
|
||||||
let protocol_config = self.inner.lock().protocol_config.unwrap_or_default();
|
let existing_network_class = inner.network_class;
|
||||||
let tcp_same_port = if protocol_config.inbound.contains(ProtocolType::TCP)
|
let tcp_same_port = if protocol_config.inbound.contains(ProtocolType::TCP)
|
||||||
&& protocol_config.inbound.contains(ProtocolType::WS)
|
&& protocol_config.inbound.contains(ProtocolType::WS)
|
||||||
{
|
{
|
||||||
let inner = self.inner.lock();
|
|
||||||
inner.tcp_port == inner.ws_port
|
inner.tcp_port == inner.ws_port
|
||||||
} else {
|
} else {
|
||||||
false
|
false
|
||||||
};
|
};
|
||||||
|
(protocol_config, existing_network_class, tcp_same_port)
|
||||||
|
};
|
||||||
|
let routing_table = self.routing_table();
|
||||||
|
let network_manager = self.network_manager();
|
||||||
|
|
||||||
|
// Process all protocol and address combinations
|
||||||
let mut futures = FuturesUnordered::new();
|
let mut futures = FuturesUnordered::new();
|
||||||
//let mut futures = FuturesOrdered::new();
|
|
||||||
|
|
||||||
// Do UDPv4+v6 at the same time as everything else
|
// Do UDPv4+v6 at the same time as everything else
|
||||||
if protocol_config.inbound.contains(ProtocolType::UDP) {
|
if protocol_config.inbound.contains(ProtocolType::UDP) {
|
||||||
// UDPv4
|
// UDPv4
|
||||||
@ -753,19 +723,19 @@ impl Network {
|
|||||||
|
|
||||||
// Wait for all discovery futures to complete and collect contexts
|
// Wait for all discovery futures to complete and collect contexts
|
||||||
let mut contexts = Vec::<DiscoveryContext>::new();
|
let mut contexts = Vec::<DiscoveryContext>::new();
|
||||||
let mut network_class = Option::<NetworkClass>::None;
|
let mut new_network_class = Option::<NetworkClass>::None;
|
||||||
loop {
|
loop {
|
||||||
match futures.next().timeout_at(stop_token.clone()).await {
|
match futures.next().timeout_at(stop_token.clone()).await {
|
||||||
Ok(Some(ctxvec)) => {
|
Ok(Some(ctxvec)) => {
|
||||||
if let Some(ctxvec) = ctxvec {
|
if let Some(ctxvec) = ctxvec {
|
||||||
for ctx in ctxvec {
|
for ctx in ctxvec {
|
||||||
if let Some(nc) = ctx.inner.lock().detected_network_class {
|
if let Some(nc) = ctx.inner.lock().detected_network_class {
|
||||||
if let Some(last_nc) = network_class {
|
if let Some(last_nc) = new_network_class {
|
||||||
if nc < last_nc {
|
if nc < last_nc {
|
||||||
network_class = Some(nc);
|
new_network_class = Some(nc);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
network_class = Some(nc);
|
new_network_class = Some(nc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -784,45 +754,108 @@ impl Network {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get best network class
|
// If a network class could be determined
|
||||||
if network_class.is_some() {
|
// see about updating our public dial info
|
||||||
// Update public dial info
|
let mut changed = false;
|
||||||
let routing_table = self.routing_table();
|
if new_network_class.is_some() {
|
||||||
let network_manager = self.network_manager();
|
// Get existing public dial info
|
||||||
|
let existing_public_dial_info: HashSet<DialInfoDetail> = routing_table
|
||||||
|
.all_filtered_dial_info_details(
|
||||||
|
Some(RoutingDomain::PublicInternet),
|
||||||
|
&DialInfoFilter::all(),
|
||||||
|
)
|
||||||
|
.into_iter()
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
// Get new public dial info and ensure it is valid
|
||||||
|
let mut new_public_dial_info: HashSet<DialInfoDetail> = HashSet::new();
|
||||||
for ctx in contexts {
|
for ctx in contexts {
|
||||||
let inner = ctx.inner.lock();
|
let inner = ctx.inner.lock();
|
||||||
if let Some(pdi) = &inner.detected_public_dial_info {
|
if let Some(pdi) = &inner.detected_public_dial_info {
|
||||||
if let Err(e) = routing_table.register_dial_info(
|
if routing_table
|
||||||
RoutingDomain::PublicInternet,
|
.ensure_dial_info_is_valid(RoutingDomain::PublicInternet, &pdi.dial_info)
|
||||||
pdi.dial_info.clone(),
|
{
|
||||||
pdi.class,
|
new_public_dial_info.insert(DialInfoDetail {
|
||||||
) {
|
class: pdi.class,
|
||||||
log_net!(warn "Failed to register detected public dial info: {}", e);
|
dial_info: pdi.dial_info.clone(),
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// duplicate for same port
|
// duplicate for same port
|
||||||
if tcp_same_port && pdi.dial_info.protocol_type() == ProtocolType::TCP {
|
if tcp_same_port && pdi.dial_info.protocol_type() == ProtocolType::TCP {
|
||||||
let ws_dial_info =
|
let ws_dial_info =
|
||||||
ctx.make_dial_info(pdi.dial_info.socket_address(), ProtocolType::WS);
|
ctx.make_dial_info(pdi.dial_info.socket_address(), ProtocolType::WS);
|
||||||
|
if routing_table
|
||||||
|
.ensure_dial_info_is_valid(RoutingDomain::PublicInternet, &ws_dial_info)
|
||||||
|
{
|
||||||
|
new_public_dial_info.insert(DialInfoDetail {
|
||||||
|
class: pdi.class,
|
||||||
|
dial_info: ws_dial_info,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Is the public dial info different?
|
||||||
|
if existing_public_dial_info != new_public_dial_info {
|
||||||
|
// If so, clear existing public dial info and re-register the new public dial info
|
||||||
|
routing_table.clear_dial_info_details(RoutingDomain::PublicInternet);
|
||||||
|
for did in new_public_dial_info {
|
||||||
if let Err(e) = routing_table.register_dial_info(
|
if let Err(e) = routing_table.register_dial_info(
|
||||||
RoutingDomain::PublicInternet,
|
RoutingDomain::PublicInternet,
|
||||||
ws_dial_info,
|
did.dial_info,
|
||||||
pdi.class,
|
did.class,
|
||||||
) {
|
) {
|
||||||
log_net!(warn "Failed to register detected public dial info: {}", e);
|
log_net!(error "Failed to register detected public dial info: {}", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
changed = true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
// Update network class
|
|
||||||
self.inner.lock().network_class = network_class;
|
|
||||||
log_net!(debug "network class changed to {:?}", network_class);
|
|
||||||
|
|
||||||
|
// Is the network class different?
|
||||||
|
if existing_network_class != new_network_class {
|
||||||
|
self.inner.lock().network_class = new_network_class;
|
||||||
|
changed = true;
|
||||||
|
log_net!(debug "network class changed to {:?}", new_network_class);
|
||||||
|
}
|
||||||
|
} else if existing_network_class.is_some() {
|
||||||
|
// Network class could not be determined
|
||||||
|
routing_table.clear_dial_info_details(RoutingDomain::PublicInternet);
|
||||||
|
self.inner.lock().network_class = None;
|
||||||
|
changed = true;
|
||||||
|
log_net!(debug "network class cleared");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Punish nodes that told us our public address had changed when it didn't
|
||||||
|
if !changed {
|
||||||
|
if let Some(punish) = self.inner.lock().public_dial_info_check_punishment.take() {
|
||||||
|
punish();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
// Send updates to everyone
|
// Send updates to everyone
|
||||||
network_manager.send_node_info_updates(true).await;
|
network_manager.send_node_info_updates(true).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
#[instrument(level = "trace", skip(self), err)]
|
||||||
|
pub async fn update_network_class_task_routine(
|
||||||
|
self,
|
||||||
|
stop_token: StopToken,
|
||||||
|
l: u64,
|
||||||
|
t: u64,
|
||||||
|
) -> EyreResult<()> {
|
||||||
|
// Note that we are doing the public dial info check
|
||||||
|
// We don't have to check this for concurrency, since this routine is run in a TickTask/SingleFuture
|
||||||
|
self.inner.lock().doing_public_dial_info_check = true;
|
||||||
|
|
||||||
|
// Do the public dial info check
|
||||||
|
let out = self.do_public_dial_info_check(stop_token, l, t).await;
|
||||||
|
|
||||||
|
// Done with public dial info check
|
||||||
|
self.inner.lock().doing_public_dial_info_check = false;
|
||||||
|
|
||||||
|
out
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -55,7 +55,7 @@ impl NetworkManager {
|
|||||||
// txt_version,min_version,max_version,nodeid,hostname,dialinfoshort*
|
// txt_version,min_version,max_version,nodeid,hostname,dialinfoshort*
|
||||||
//
|
//
|
||||||
// Split bootstrap node record by commas. Example:
|
// Split bootstrap node record by commas. Example:
|
||||||
// 0,0,0,7lxDEabK_qgjbe38RtBa3IZLrud84P6NhGP-pRTZzdQ,bootstrap-dev-alpha.veilid.net,T5150,U5150,W5150/ws
|
// 0,0,0,7lxDEabK_qgjbe38RtBa3IZLrud84P6NhGP-pRTZzdQ,bootstrap-1.dev.veilid.net,T5150,U5150,W5150/ws
|
||||||
let records: Vec<String> = bsnirecord
|
let records: Vec<String> = bsnirecord
|
||||||
.trim()
|
.trim()
|
||||||
.split(',')
|
.split(',')
|
||||||
|
@ -291,6 +291,11 @@ impl Network {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////
|
//////////////////////////////////////////
|
||||||
|
|
||||||
|
pub fn set_needs_public_dial_info_check(&self) {
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_network_class(&self) -> Option<NetworkClass> {
|
pub fn get_network_class(&self) -> Option<NetworkClass> {
|
||||||
// xxx eventually detect tor browser?
|
// xxx eventually detect tor browser?
|
||||||
return if self.inner.lock().network_started {
|
return if self.inner.lock().network_started {
|
||||||
@ -300,11 +305,6 @@ impl Network {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn reset_network_class(&self) {
|
|
||||||
//let mut inner = self.inner.lock();
|
|
||||||
//inner.network_class = None;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_protocol_config(&self) -> Option<ProtocolConfig> {
|
pub fn get_protocol_config(&self) -> Option<ProtocolConfig> {
|
||||||
self.inner.lock().protocol_config.clone()
|
self.inner.lock().protocol_config.clone()
|
||||||
}
|
}
|
||||||
|
@ -120,10 +120,11 @@ impl BucketEntryInner {
|
|||||||
&mut self,
|
&mut self,
|
||||||
signed_node_info: SignedNodeInfo,
|
signed_node_info: SignedNodeInfo,
|
||||||
allow_invalid_signature: bool,
|
allow_invalid_signature: bool,
|
||||||
) -> bool {
|
) {
|
||||||
// Don't allow invalid signatures unless we are explicitly allowing it
|
// Don't allow invalid signatures unless we are explicitly allowing it
|
||||||
if !allow_invalid_signature && !signed_node_info.signature.valid {
|
if !allow_invalid_signature && !signed_node_info.signature.valid {
|
||||||
return false;
|
log_rtab!(debug "Invalid signature on signed node info: {:?}", signed_node_info);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// See if we have an existing signed_node_info to update or not
|
// See if we have an existing signed_node_info to update or not
|
||||||
@ -131,16 +132,16 @@ impl BucketEntryInner {
|
|||||||
// If the timestamp hasn't changed or is less, ignore this update
|
// If the timestamp hasn't changed or is less, ignore this update
|
||||||
if signed_node_info.timestamp <= current_sni.timestamp {
|
if signed_node_info.timestamp <= current_sni.timestamp {
|
||||||
// If we received a node update with the same timestamp
|
// If we received a node update with the same timestamp
|
||||||
// we can try again, but only if our network hasn't changed
|
// we can make this node live again, but only if our network hasn't changed
|
||||||
if !self.updated_since_last_network_change
|
if !self.updated_since_last_network_change
|
||||||
&& signed_node_info.timestamp == current_sni.timestamp
|
&& signed_node_info.timestamp == current_sni.timestamp
|
||||||
{
|
{
|
||||||
// No need to update the signednodeinfo though since the timestamp is the same
|
// No need to update the signednodeinfo though since the timestamp is the same
|
||||||
// Just return true so we can make the node not dead
|
// Just return true so we can make the node not dead
|
||||||
self.updated_since_last_network_change = true;
|
self.updated_since_last_network_change = true;
|
||||||
return true;
|
self.touch_last_seen(intf::get_timestamp());
|
||||||
}
|
}
|
||||||
return false;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -152,9 +153,8 @@ impl BucketEntryInner {
|
|||||||
|
|
||||||
// Update the signed node info
|
// Update the signed node info
|
||||||
self.opt_signed_node_info = Some(signed_node_info);
|
self.opt_signed_node_info = Some(signed_node_info);
|
||||||
|
|
||||||
self.updated_since_last_network_change = true;
|
self.updated_since_last_network_change = true;
|
||||||
true
|
self.touch_last_seen(intf::get_timestamp());
|
||||||
}
|
}
|
||||||
pub fn update_local_node_info(&mut self, local_node_info: LocalNodeInfo) {
|
pub fn update_local_node_info(&mut self, local_node_info: LocalNodeInfo) {
|
||||||
self.opt_local_node_info = Some(local_node_info)
|
self.opt_local_node_info = Some(local_node_info)
|
||||||
|
@ -234,16 +234,7 @@ impl RoutingTable {
|
|||||||
ret
|
ret
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn register_dial_info(
|
pub fn ensure_dial_info_is_valid(&self, domain: RoutingDomain, dial_info: &DialInfo) -> bool {
|
||||||
&self,
|
|
||||||
domain: RoutingDomain,
|
|
||||||
dial_info: DialInfo,
|
|
||||||
class: DialInfoClass,
|
|
||||||
) -> EyreResult<()> {
|
|
||||||
log_rtab!(debug
|
|
||||||
"Registering dial_info with:\n domain: {:?}\n dial_info: {:?}\n class: {:?}",
|
|
||||||
domain, dial_info, class
|
|
||||||
);
|
|
||||||
let enable_local_peer_scope = {
|
let enable_local_peer_scope = {
|
||||||
let config = self.network_manager().config();
|
let config = self.network_manager().config();
|
||||||
let c = config.get();
|
let c = config.get();
|
||||||
@ -254,13 +245,28 @@ impl RoutingTable {
|
|||||||
&& matches!(domain, RoutingDomain::PublicInternet)
|
&& matches!(domain, RoutingDomain::PublicInternet)
|
||||||
&& dial_info.is_local()
|
&& dial_info.is_local()
|
||||||
{
|
{
|
||||||
bail!("shouldn't be registering local addresses as public");
|
log_rtab!(debug "shouldn't be registering local addresses as public");
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
if !dial_info.is_valid() {
|
if !dial_info.is_valid() {
|
||||||
bail!(
|
log_rtab!(debug
|
||||||
"shouldn't be registering invalid addresses: {:?}",
|
"shouldn't be registering invalid addresses: {:?}",
|
||||||
dial_info
|
dial_info
|
||||||
);
|
);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
true
|
||||||
|
}
|
||||||
|
|
||||||
|
#[instrument(level = "debug", skip(self), err)]
|
||||||
|
pub fn register_dial_info(
|
||||||
|
&self,
|
||||||
|
domain: RoutingDomain,
|
||||||
|
dial_info: DialInfo,
|
||||||
|
class: DialInfoClass,
|
||||||
|
) -> EyreResult<()> {
|
||||||
|
if !self.ensure_dial_info_is_valid(domain, &dial_info) {
|
||||||
|
return Err(eyre!("dial info is not valid"));
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut inner = self.inner.write();
|
let mut inner = self.inner.write();
|
||||||
@ -611,10 +617,7 @@ impl RoutingTable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
self.create_node_ref(node_id, |e| {
|
self.create_node_ref(node_id, |e| {
|
||||||
if e.update_signed_node_info(signed_node_info, allow_invalid_signature) {
|
e.update_signed_node_info(signed_node_info, allow_invalid_signature);
|
||||||
// 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());
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -373,7 +373,8 @@ impl RPCProcessor {
|
|||||||
let (span_id, rpcreader) = res.take_value().unwrap();
|
let (span_id, rpcreader) = res.take_value().unwrap();
|
||||||
let end_ts = intf::get_timestamp();
|
let end_ts = intf::get_timestamp();
|
||||||
|
|
||||||
Span::current().follows_from(span_id);
|
// fixme: causes crashes? "Missing otel data span extensions"??
|
||||||
|
//Span::current().follows_from(span_id);
|
||||||
|
|
||||||
(rpcreader, end_ts - start_ts)
|
(rpcreader, end_ts - start_ts)
|
||||||
}))
|
}))
|
||||||
@ -903,7 +904,8 @@ impl RPCProcessor {
|
|||||||
receiver.recv_async().timeout_at(stop_token.clone()).await
|
receiver.recv_async().timeout_at(stop_token.clone()).await
|
||||||
{
|
{
|
||||||
let rpc_worker_span = span!(parent: None, Level::TRACE, "rpc_worker");
|
let rpc_worker_span = span!(parent: None, Level::TRACE, "rpc_worker");
|
||||||
rpc_worker_span.follows_from(span_id);
|
// fixme: causes crashes? "Missing otel data span extensions"??
|
||||||
|
//rpc_worker_span.follows_from(span_id);
|
||||||
let _enter = rpc_worker_span.enter();
|
let _enter = rpc_worker_span.enter();
|
||||||
|
|
||||||
let _ = self
|
let _ = self
|
||||||
|
@ -47,24 +47,16 @@ impl RPCProcessor {
|
|||||||
match send_data_kind {
|
match send_data_kind {
|
||||||
SendDataKind::Direct(connection_descriptor) => {
|
SendDataKind::Direct(connection_descriptor) => {
|
||||||
match connection_descriptor.peer_scope() {
|
match connection_descriptor.peer_scope() {
|
||||||
PeerScope::Global => {
|
PeerScope::Global => self.network_manager().report_global_socket_address(
|
||||||
self.network_manager()
|
|
||||||
.report_global_socket_address(
|
|
||||||
socket_address,
|
socket_address,
|
||||||
connection_descriptor,
|
connection_descriptor,
|
||||||
peer,
|
peer,
|
||||||
)
|
),
|
||||||
.await;
|
PeerScope::Local => self.network_manager().report_local_socket_address(
|
||||||
}
|
|
||||||
PeerScope::Local => {
|
|
||||||
self.network_manager()
|
|
||||||
.report_local_socket_address(
|
|
||||||
socket_address,
|
socket_address,
|
||||||
connection_descriptor,
|
connection_descriptor,
|
||||||
peer,
|
peer,
|
||||||
)
|
),
|
||||||
.await;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
SendDataKind::Indirect => {
|
SendDataKind::Indirect => {
|
||||||
|
@ -323,7 +323,7 @@ pub struct SenderInfo {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Keep member order appropriate for sorting < preference
|
// Keep member order appropriate for sorting < preference
|
||||||
#[derive(Copy, Clone, Debug, Eq, PartialEq, Ord, PartialOrd, Serialize, Deserialize)]
|
#[derive(Copy, Clone, Debug, Eq, PartialEq, Ord, PartialOrd, Serialize, Deserialize, Hash)]
|
||||||
pub enum DialInfoClass {
|
pub enum DialInfoClass {
|
||||||
Direct = 0, // D = Directly reachable with public IP and no firewall, with statically configured port
|
Direct = 0, // D = Directly reachable with public IP and no firewall, with statically configured port
|
||||||
Mapped = 1, // M = Directly reachable with via portmap behind any NAT or firewalled with dynamically negotiated port
|
Mapped = 1, // M = Directly reachable with via portmap behind any NAT or firewalled with dynamically negotiated port
|
||||||
@ -357,7 +357,7 @@ impl DialInfoClass {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Keep member order appropriate for sorting < preference
|
// Keep member order appropriate for sorting < preference
|
||||||
#[derive(Debug, Clone, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize)]
|
#[derive(Debug, Clone, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize, Hash)]
|
||||||
pub struct DialInfoDetail {
|
pub struct DialInfoDetail {
|
||||||
pub class: DialInfoClass,
|
pub class: DialInfoClass,
|
||||||
pub dial_info: DialInfo,
|
pub dial_info: DialInfo,
|
||||||
@ -369,7 +369,7 @@ impl MatchesDialInfoFilter for DialInfoDetail {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Copy, Clone, Debug, Eq, PartialEq, Ord, PartialOrd, Serialize, Deserialize)]
|
#[derive(Copy, Clone, Debug, Eq, PartialEq, Ord, PartialOrd, Serialize, Deserialize, Hash)]
|
||||||
pub enum NetworkClass {
|
pub enum NetworkClass {
|
||||||
InboundCapable = 0, // I = Inbound capable without relay, may require signal
|
InboundCapable = 0, // I = Inbound capable without relay, may require signal
|
||||||
OutboundOnly = 1, // O = Outbound only, inbound relay required except with reverse connect signal
|
OutboundOnly = 1, // O = Outbound only, inbound relay required except with reverse connect signal
|
||||||
@ -856,29 +856,29 @@ pub trait MatchesDialInfoFilter {
|
|||||||
fn matches_filter(&self, filter: &DialInfoFilter) -> bool;
|
fn matches_filter(&self, filter: &DialInfoFilter) -> bool;
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Default, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize)]
|
#[derive(Clone, Default, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize, Hash)]
|
||||||
pub struct DialInfoUDP {
|
pub struct DialInfoUDP {
|
||||||
pub socket_address: SocketAddress,
|
pub socket_address: SocketAddress,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Default, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize)]
|
#[derive(Clone, Default, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize, Hash)]
|
||||||
pub struct DialInfoTCP {
|
pub struct DialInfoTCP {
|
||||||
pub socket_address: SocketAddress,
|
pub socket_address: SocketAddress,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Default, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize)]
|
#[derive(Clone, Default, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize, Hash)]
|
||||||
pub struct DialInfoWS {
|
pub struct DialInfoWS {
|
||||||
pub socket_address: SocketAddress,
|
pub socket_address: SocketAddress,
|
||||||
pub request: String,
|
pub request: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Default, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize)]
|
#[derive(Clone, Default, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize, Hash)]
|
||||||
pub struct DialInfoWSS {
|
pub struct DialInfoWSS {
|
||||||
pub socket_address: SocketAddress,
|
pub socket_address: SocketAddress,
|
||||||
pub request: String,
|
pub request: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize)]
|
#[derive(Clone, Debug, PartialEq, PartialOrd, Ord, Eq, Serialize, Deserialize, Hash)]
|
||||||
#[serde(tag = "kind")]
|
#[serde(tag = "kind")]
|
||||||
// Keep member order appropriate for sorting < preference
|
// Keep member order appropriate for sorting < preference
|
||||||
// Must match ProtocolType order
|
// Must match ProtocolType order
|
||||||
|
@ -49,8 +49,8 @@ Future<VeilidConfig> getDefaultVeilidConfig() async {
|
|||||||
nodeId: "",
|
nodeId: "",
|
||||||
nodeIdSecret: "",
|
nodeIdSecret: "",
|
||||||
bootstrap: kIsWeb
|
bootstrap: kIsWeb
|
||||||
? ["ws://bootstrap-dev.veilid.net:5150/ws"]
|
? ["ws://bootstrap.dev.veilid.net:5150/ws"]
|
||||||
: ["bootstrap-dev.veilid.net"],
|
: ["bootstrap.dev.veilid.net"],
|
||||||
bootstrapNodes: [],
|
bootstrapNodes: [],
|
||||||
routingTable: VeilidConfigRoutingTable(
|
routingTable: VeilidConfigRoutingTable(
|
||||||
limitOverAttached: 64,
|
limitOverAttached: 64,
|
||||||
|
@ -67,7 +67,7 @@ core:
|
|||||||
hole_punch_receipt_time_ms: 5000
|
hole_punch_receipt_time_ms: 5000
|
||||||
node_id: ''
|
node_id: ''
|
||||||
node_id_secret: ''
|
node_id_secret: ''
|
||||||
bootstrap: ['bootstrap-dev.veilid.net']
|
bootstrap: ['bootstrap.dev.veilid.net']
|
||||||
bootstrap_nodes: []
|
bootstrap_nodes: []
|
||||||
routing_table:
|
routing_table:
|
||||||
limit_over_attached: 64
|
limit_over_attached: 64
|
||||||
@ -1472,7 +1472,7 @@ mod tests {
|
|||||||
//
|
//
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
s.core.network.bootstrap,
|
s.core.network.bootstrap,
|
||||||
vec!["bootstrap-dev.veilid.net".to_owned()]
|
vec!["bootstrap.dev.veilid.net".to_owned()]
|
||||||
);
|
);
|
||||||
assert_eq!(s.core.network.bootstrap_nodes, vec![]);
|
assert_eq!(s.core.network.bootstrap_nodes, vec![]);
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user