From 74c7732e8b24c10a19094fda80bafad0eb2b0075 Mon Sep 17 00:00:00 2001 From: Oussama Teffahi <70609372+oteffahi@users.noreply.github.com> Date: Tue, 10 Dec 2024 14:41:59 +0100 Subject: [PATCH] Prioritize endpoint config over configuration file (#1635) * Overwrite incoming config with current endpoint config * Update affected tests * Change overwrite behavior in transport logic instead of Endpoint This reverts commit 5157987f8cb6c4eb812cf7b26baf39df63627a4f. * Remove mistakenly added files --- io/zenoh-links/zenoh-link-tls/src/utils.rs | 20 +++++++++++------ io/zenoh-transport/src/multicast/manager.rs | 12 ++++++++--- io/zenoh-transport/src/unicast/manager.rs | 24 +++++++++++++++------ zenoh/tests/tcp_buffers.rs | 14 +----------- 4 files changed, 41 insertions(+), 29 deletions(-) diff --git a/io/zenoh-links/zenoh-link-tls/src/utils.rs b/io/zenoh-links/zenoh-link-tls/src/utils.rs index e85be4573f..9d96fbda64 100644 --- a/io/zenoh-links/zenoh-link-tls/src/utils.rs +++ b/io/zenoh-links/zenoh-link-tls/src/utils.rs @@ -32,7 +32,7 @@ use secrecy::ExposeSecret; use webpki::anchor_from_trusted_cert; use zenoh_config::Config as ZenohConfig; use zenoh_link_commons::{ - tcp::TcpSocketConfig, tls::WebPkiVerifierAnyServerName, ConfigurationInspector, + tcp::TcpSocketConfig, tls::WebPkiVerifierAnyServerName, ConfigurationInspector, BIND_INTERFACE, TCP_RX_BUFFER_SIZE, TCP_TX_BUFFER_SIZE, }; use zenoh_protocol::core::{ @@ -178,7 +178,7 @@ pub(crate) struct TlsServerConfig<'a> { } impl<'a> TlsServerConfig<'a> { - pub async fn new(config: &Config<'a>) -> ZResult { + pub async fn new(config: &'a Config<'_>) -> ZResult { let tls_server_client_auth: bool = match config.get(TLS_ENABLE_MTLS) { Some(s) => s .parse() @@ -277,8 +277,11 @@ impl<'a> TlsServerConfig<'a> { server_config: sc, tls_handshake_timeout, tls_close_link_on_expiration, - // TODO: add interface binding - tcp_socket_config: TcpSocketConfig::new(tcp_tx_buffer_size, tcp_rx_buffer_size, None), + tcp_socket_config: TcpSocketConfig::new( + tcp_tx_buffer_size, + tcp_rx_buffer_size, + config.get(BIND_INTERFACE), + ), }) } @@ -310,7 +313,7 @@ pub(crate) struct TlsClientConfig<'a> { } impl<'a> TlsClientConfig<'a> { - pub async fn new(config: &Config<'a>) -> ZResult { + pub async fn new(config: &'a Config<'_>) -> ZResult { let tls_client_server_auth: bool = match config.get(TLS_ENABLE_MTLS) { Some(s) => s .parse() @@ -440,8 +443,11 @@ impl<'a> TlsClientConfig<'a> { Ok(TlsClientConfig { client_config: cc, tls_close_link_on_expiration, - // TODO: add interface binding - tcp_socket_config: TcpSocketConfig::new(tcp_tx_buffer_size, tcp_rx_buffer_size, None), + tcp_socket_config: TcpSocketConfig::new( + tcp_tx_buffer_size, + tcp_rx_buffer_size, + config.get(BIND_INTERFACE), + ), }) } diff --git a/io/zenoh-transport/src/multicast/manager.rs b/io/zenoh-transport/src/multicast/manager.rs index e2899b1d1a..8046d5bd58 100644 --- a/io/zenoh-transport/src/multicast/manager.rs +++ b/io/zenoh-transport/src/multicast/manager.rs @@ -256,9 +256,15 @@ impl TransportManager { .await?; // Fill and merge the endpoint configuration if let Some(config) = self.config.endpoints.get(endpoint.protocol().as_str()) { - endpoint - .config_mut() - .extend_from_iter(parameters::iter(config))?; + let mut config = parameters::Parameters::from(config.as_str()); + // Overwrite config with current endpoint parameters + config.extend_from_iter(endpoint.config().iter()); + endpoint = EndPoint::new( + endpoint.protocol(), + endpoint.address(), + endpoint.metadata(), + config.as_str(), + )?; } // Open the link diff --git a/io/zenoh-transport/src/unicast/manager.rs b/io/zenoh-transport/src/unicast/manager.rs index 5511451b3d..7497604757 100644 --- a/io/zenoh-transport/src/unicast/manager.rs +++ b/io/zenoh-transport/src/unicast/manager.rs @@ -385,9 +385,15 @@ impl TransportManager { .await?; // Fill and merge the endpoint configuration if let Some(config) = self.config.endpoints.get(endpoint.protocol().as_str()) { - endpoint - .config_mut() - .extend_from_iter(parameters::iter(config))?; + let mut config = parameters::Parameters::from(config.as_str()); + // Overwrite config with current endpoint parameters + config.extend_from_iter(endpoint.config().iter()); + endpoint = EndPoint::new( + endpoint.protocol(), + endpoint.address(), + endpoint.metadata(), + config.as_str(), + )?; }; manager.new_listener(endpoint).await } @@ -705,9 +711,15 @@ impl TransportManager { .await?; // Fill and merge the endpoint configuration if let Some(config) = self.config.endpoints.get(endpoint.protocol().as_str()) { - endpoint - .config_mut() - .extend_from_iter(parameters::iter(config))?; + let mut config = parameters::Parameters::from(config.as_str()); + // Overwrite config with current endpoint parameters + config.extend_from_iter(endpoint.config().iter()); + endpoint = EndPoint::new( + endpoint.protocol(), + endpoint.address(), + endpoint.metadata(), + config.as_str(), + )?; }; // Create a new link associated by calling the Link Manager diff --git a/zenoh/tests/tcp_buffers.rs b/zenoh/tests/tcp_buffers.rs index 8d75682507..c443f14894 100644 --- a/zenoh/tests/tcp_buffers.rs +++ b/zenoh/tests/tcp_buffers.rs @@ -49,20 +49,8 @@ fn buffer_size_endpoint() { zenoh::open(config).wait().unwrap(); } -#[cfg(target_os = "macos")] -#[test] -#[should_panic(expected = "Can not create a new TCP listener")] -fn buffer_size_override() { - buffer_size_config_override(); -} - -#[cfg(not(target_os = "macos"))] #[test] -fn buffer_size_override() { - buffer_size_config_override(); -} - -fn buffer_size_config_override() { +fn buffer_size_endpoint_overwrite() { let mut config = Config::default(); config .insert_json5(