From c5a7b35ac16f9ab6ec86417243f002770f235155 Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Mon, 16 Sep 2024 10:03:51 +0200 Subject: [PATCH 01/15] Hide `zenoh_config` internals --- Cargo.lock | 5 +- commons/zenoh-config/Cargo.toml | 1 - commons/zenoh-config/src/lib.rs | 249 +----------------- commons/zenoh-macros/src/lib.rs | 21 ++ examples/src/lib.rs | 8 +- zenoh-ext/Cargo.toml | 1 + zenoh-ext/examples/Cargo.toml | 1 + zenoh-ext/examples/examples/z_pub_cache.rs | 6 +- zenoh-ext/examples/src/lib.rs | 8 +- zenoh-ext/src/querying_subscriber.rs | 6 +- zenoh-ext/src/session_ext.rs | 6 +- zenoh-ext/src/subscriber_ext.rs | 12 +- zenoh-ext/tests/liveliness.rs | 31 +-- zenoh/Cargo.toml | 2 + zenoh/src/api/builders/publisher.rs | 4 +- zenoh/src/api/config.rs | 200 ++++++++++++++ zenoh/src/api/info.rs | 14 +- zenoh/src/api/key_expr.rs | 2 +- zenoh/src/api/liveliness.rs | 36 +-- zenoh/src/api/mod.rs | 1 + zenoh/src/api/publisher.rs | 37 ++- zenoh/src/api/query.rs | 8 +- zenoh/src/api/queryable.rs | 18 +- zenoh/src/api/scouting.rs | 35 +-- zenoh/src/api/session.rs | 56 ++-- zenoh/src/api/subscriber.rs | 18 +- zenoh/src/lib.rs | 20 +- .../src/net/routing/hat/linkstate_peer/mod.rs | 5 +- zenoh/src/net/routing/hat/p2p_peer/mod.rs | 5 +- zenoh/src/net/routing/hat/router/mod.rs | 5 +- zenoh/src/net/runtime/adminspace.rs | 8 +- zenoh/src/net/runtime/mod.rs | 13 +- zenoh/src/net/runtime/orchestrator.rs | 29 +- zenoh/tests/acl.rs | 36 ++- zenoh/tests/authentication.rs | 108 ++++++-- zenoh/tests/connection_retry.rs | 11 +- zenoh/tests/events.rs | 7 +- zenoh/tests/interceptors.rs | 9 +- zenoh/tests/liveliness.rs | 42 ++- zenoh/tests/matching.rs | 23 +- zenoh/tests/open_time.rs | 6 +- zenoh/tests/qos.rs | 4 +- zenoh/tests/routing.rs | 10 +- zenoh/tests/session.rs | 17 +- zenoh/tests/shm.rs | 9 +- zenoh/tests/unicity.rs | 47 +++- zenohd/Cargo.toml | 1 + zenohd/src/main.rs | 6 +- 48 files changed, 659 insertions(+), 548 deletions(-) create mode 100644 zenoh/src/api/config.rs diff --git a/Cargo.lock b/Cargo.lock index 7c140c1c31..cae6e9d4ee 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -5350,6 +5350,7 @@ dependencies = [ "tracing", "uhlc", "unwrap-infallible", + "validated_struct", "vec_map", "zenoh-buffers", "zenoh-codec", @@ -5413,7 +5414,6 @@ version = "1.0.0-dev" name = "zenoh-config" version = "1.0.0-dev" dependencies = [ - "flume", "json5", "num_cpus", "secrecy", @@ -5479,6 +5479,7 @@ dependencies = [ "tokio", "tracing", "zenoh", + "zenoh-config", "zenoh-macros", "zenoh-util", ] @@ -5491,6 +5492,7 @@ dependencies = [ "futures", "tokio", "zenoh", + "zenoh-config", "zenoh-ext", ] @@ -5987,6 +5989,7 @@ dependencies = [ "tracing-subscriber", "url", "zenoh", + "zenoh-config", "zenoh-util", ] diff --git a/commons/zenoh-config/Cargo.toml b/commons/zenoh-config/Cargo.toml index 2bd4c83211..43472626d4 100644 --- a/commons/zenoh-config/Cargo.toml +++ b/commons/zenoh-config/Cargo.toml @@ -28,7 +28,6 @@ internal = [] [dependencies] tracing = { workspace = true } -flume = { workspace = true } json5 = { workspace = true } num_cpus = { workspace = true } serde = { workspace = true, features = ["default"] } diff --git a/commons/zenoh-config/src/lib.rs b/commons/zenoh-config/src/lib.rs index b57c62edde..49cc343695 100644 --- a/commons/zenoh-config/src/lib.rs +++ b/commons/zenoh-config/src/lib.rs @@ -20,13 +20,7 @@ pub mod wrappers; #[allow(unused_imports)] use std::convert::TryFrom; // This is a false positive from the rust analyser use std::{ - any::Any, - collections::HashSet, - fmt, - io::Read, - net::SocketAddr, - path::Path, - sync::{Arc, Mutex, MutexGuard, Weak}, + any::Any, collections::HashSet, fmt, io::Read, net::SocketAddr, ops, path::Path, sync::Weak, }; use include::recursive_include; @@ -36,7 +30,6 @@ use serde_json::{Map, Value}; use validated_struct::ValidatedMapAssociatedTypes; pub use validated_struct::{GetError, ValidatedMap}; pub use wrappers::ZenohId; -use zenoh_core::zlock; pub use zenoh_protocol::core::{ whatami, EndPoint, Locator, WhatAmI, WhatAmIMatcher, WhatAmIMatcherVisitor, }; @@ -57,7 +50,7 @@ pub use connection_retry::*; #[derive(serde::Serialize, serde::Deserialize, Debug, Clone)] pub struct SecretString(String); -impl Deref for SecretString { +impl ops::Deref for SecretString { type Target = String; fn deref(&self) -> &Self::Target { @@ -229,16 +222,12 @@ fn config_keys() { } validated_struct::validator! { - /// The main configuration structure for Zenoh. - /// - /// Most fields are optional as a way to keep defaults flexible. Some of the fields have different default values depending on the rest of the configuration. - /// - /// To construct a configuration, we advise that you use a configuration file (JSON, JSON5 and YAML are currently supported, please use the proper extension for your format as the deserializer will be picked according to it). #[derive(Default)] #[recursive_attrs] #[derive(serde::Deserialize, serde::Serialize, Clone, Debug)] #[serde(default)] #[serde(deny_unknown_fields)] + #[doc(hidden)] Config { /// The Zenoh ID of the instance. This ID MUST be unique throughout your Zenoh infrastructure and cannot exceed 16 bytes of length. If left unset, a random u128 will be generated. id: ZenohId, @@ -708,10 +697,7 @@ impl Config { pub fn remove>(&mut self, key: K) -> ZResult<()> { let key = key.as_ref(); - self._remove(key) - } - fn _remove(&mut self, key: &str) -> ZResult<()> { let key = key.strip_prefix('/').unwrap_or(key); if !key.starts_with("plugins/") { bail!( @@ -720,6 +706,14 @@ impl Config { } self.plugins.remove(&key["plugins/".len()..]) } + + pub fn get_retry_config( + &self, + endpoint: Option<&EndPoint>, + listen: bool, + ) -> ConnectionRetryConf { + get_retry_config(self, endpoint, listen) + } } #[derive(Debug)] @@ -820,227 +814,6 @@ fn config_from_json() { println!("{}", serde_json::to_string_pretty(&config).unwrap()); } -pub type Notification = Arc; - -struct NotifierInner { - inner: Mutex, - subscribers: Mutex>>, -} -pub struct Notifier { - inner: Arc>, -} -impl Clone for Notifier { - fn clone(&self) -> Self { - Self { - inner: self.inner.clone(), - } - } -} -impl Notifier { - pub fn remove>(&self, key: K) -> ZResult<()> { - let key = key.as_ref(); - self._remove(key) - } - - fn _remove(&self, key: &str) -> ZResult<()> { - { - let mut guard = zlock!(self.inner.inner); - guard.remove(key)?; - } - self.notify(key); - Ok(()) - } -} -impl Notifier { - pub fn new(inner: T) -> Self { - Notifier { - inner: Arc::new(NotifierInner { - inner: Mutex::new(inner), - subscribers: Mutex::new(Vec::new()), - }), - } - } - pub fn subscribe(&self) -> flume::Receiver { - let (tx, rx) = flume::unbounded(); - { - zlock!(self.inner.subscribers).push(tx); - } - rx - } - pub fn notify>(&self, key: K) { - let key = key.as_ref(); - self._notify(key); - } - fn _notify(&self, key: &str) { - let key: Arc = Arc::from(key); - let mut marked = Vec::new(); - let mut guard = zlock!(self.inner.subscribers); - for (i, sub) in guard.iter().enumerate() { - if sub.send(key.clone()).is_err() { - marked.push(i) - } - } - for i in marked.into_iter().rev() { - guard.swap_remove(i); - } - } - - pub fn lock(&self) -> MutexGuard { - zlock!(self.inner.inner) - } -} - -impl<'a, T: 'a> ValidatedMapAssociatedTypes<'a> for Notifier { - type Accessor = GetGuard<'a, T>; -} -impl<'a, T: 'a> ValidatedMapAssociatedTypes<'a> for &Notifier { - type Accessor = GetGuard<'a, T>; -} -impl ValidatedMap for Notifier -where - T: for<'a> ValidatedMapAssociatedTypes<'a, Accessor = &'a dyn Any>, -{ - fn insert<'d, D: serde::Deserializer<'d>>( - &mut self, - key: &str, - value: D, - ) -> Result<(), validated_struct::InsertionError> - where - validated_struct::InsertionError: From, - { - { - let mut guard = zlock!(self.inner.inner); - guard.insert(key, value)?; - } - self.notify(key); - Ok(()) - } - fn get<'a>( - &'a self, - key: &str, - ) -> Result<>::Accessor, GetError> - { - let guard: MutexGuard<'a, T> = zlock!(self.inner.inner); - // SAFETY: MutexGuard pins the mutex behind which the value is held. - let subref = guard.get(key.as_ref())? as *const _; - Ok(GetGuard { - _guard: guard, - subref, - }) - } - fn get_json(&self, key: &str) -> Result { - self.lock().get_json(key) - } - type Keys = T::Keys; - fn keys(&self) -> Self::Keys { - self.lock().keys() - } -} -impl ValidatedMap for &Notifier -where - T: for<'a> ValidatedMapAssociatedTypes<'a, Accessor = &'a dyn Any>, -{ - fn insert<'d, D: serde::Deserializer<'d>>( - &mut self, - key: &str, - value: D, - ) -> Result<(), validated_struct::InsertionError> - where - validated_struct::InsertionError: From, - { - { - let mut guard = zlock!(self.inner.inner); - guard.insert(key, value)?; - } - self.notify(key); - Ok(()) - } - fn get<'a>( - &'a self, - key: &str, - ) -> Result<>::Accessor, GetError> - { - let guard: MutexGuard<'a, T> = zlock!(self.inner.inner); - // SAFETY: MutexGuard pins the mutex behind which the value is held. - let subref = guard.get(key.as_ref())? as *const _; - Ok(GetGuard { - _guard: guard, - subref, - }) - } - fn get_json(&self, key: &str) -> Result { - self.lock().get_json(key) - } - type Keys = T::Keys; - fn keys(&self) -> Self::Keys { - self.lock().keys() - } -} -impl Notifier -where - T: for<'a> ValidatedMapAssociatedTypes<'a, Accessor = &'a dyn Any>, -{ - pub fn insert<'d, D: serde::Deserializer<'d>>( - &self, - key: &str, - value: D, - ) -> Result<(), validated_struct::InsertionError> - where - validated_struct::InsertionError: From, - { - self.lock().insert(key, value)?; - self.notify(key); - Ok(()) - } - - pub fn get( - &self, - key: &str, - ) -> Result<::Accessor, GetError> { - let guard = zlock!(self.inner.inner); - // SAFETY: MutexGuard pins the mutex behind which the value is held. - let subref = guard.get(key.as_ref())? as *const _; - Ok(GetGuard { - _guard: guard, - subref, - }) - } - - pub fn get_json(&self, key: &str) -> Result { - self.lock().get_json(key) - } - - pub fn insert_json5( - &self, - key: &str, - value: &str, - ) -> Result<(), validated_struct::InsertionError> { - self.insert(key, &mut json5::Deserializer::from_str(value)?) - } - - pub fn keys(&self) -> impl Iterator { - self.lock().keys().into_iter() - } -} - -pub struct GetGuard<'a, T> { - _guard: MutexGuard<'a, T>, - subref: *const dyn Any, -} -use std::ops::Deref; -impl<'a, T> Deref for GetGuard<'a, T> { - type Target = dyn Any; - - fn deref(&self) -> &Self::Target { - unsafe { &*self.subref } - } -} -impl<'a, T> AsRef for GetGuard<'a, T> { - fn as_ref(&self) -> &dyn Any { - self.deref() - } -} - fn sequence_number_resolution_validator(b: &Bits) -> bool { b <= &Bits::from(TransportSn::MAX) } diff --git a/commons/zenoh-macros/src/lib.rs b/commons/zenoh-macros/src/lib.rs index f3533a6aea..da007e1f18 100644 --- a/commons/zenoh-macros/src/lib.rs +++ b/commons/zenoh-macros/src/lib.rs @@ -181,6 +181,27 @@ pub fn unstable(attr: TokenStream, tokens: TokenStream) -> TokenStream { TokenStream::from(item.to_token_stream()) } +// FIXME(fuzzypixelz): refactor `unstable` macro to accept arguments +#[proc_macro_attribute] +pub fn unstable_config(args: TokenStream, tokens: TokenStream) -> TokenStream { + let tokens = unstable_doc(args, tokens); + let mut item = match parse_annotable_item!(tokens) { + Ok(item) => item, + Err(err) => return err.into_compile_error().into(), + }; + + let attrs = match item.attributes_mut() { + Ok(attrs) => attrs, + Err(err) => return err.into_compile_error().into(), + }; + + let feature_gate: Attribute = + parse_quote!(#[cfg(any(feature = "unstable", feature = "unstable_config"))]); + attrs.push(feature_gate); + + TokenStream::from(item.to_token_stream()) +} + #[proc_macro_attribute] /// Adds a `#[cfg(feature = "internal")]` and `#[doc(hidden)]` attributes to the item. pub fn internal(_attr: TokenStream, tokens: TokenStream) -> TokenStream { diff --git a/examples/src/lib.rs b/examples/src/lib.rs index 20409b4f85..7766d379d2 100644 --- a/examples/src/lib.rs +++ b/examples/src/lib.rs @@ -3,7 +3,7 @@ //! Check ../README.md for usage. //! -use zenoh::config::Config; +use zenoh::{config::WhatAmI, Config}; #[derive(clap::ValueEnum, Clone, Copy, PartialEq, Eq, Hash, Debug)] pub enum Wai { @@ -59,9 +59,9 @@ impl From<&CommonArgs> for Config { None => Config::default(), }; match args.mode { - Some(Wai::Peer) => config.set_mode(Some(zenoh::config::WhatAmI::Peer)), - Some(Wai::Client) => config.set_mode(Some(zenoh::config::WhatAmI::Client)), - Some(Wai::Router) => config.set_mode(Some(zenoh::config::WhatAmI::Router)), + Some(Wai::Peer) => config.set_mode(Some(WhatAmI::Peer)), + Some(Wai::Client) => config.set_mode(Some(WhatAmI::Client)), + Some(Wai::Router) => config.set_mode(Some(WhatAmI::Router)), None => Ok(None), } .unwrap(); diff --git a/zenoh-ext/Cargo.toml b/zenoh-ext/Cargo.toml index 63516bb253..4b06a97264 100644 --- a/zenoh-ext/Cargo.toml +++ b/zenoh-ext/Cargo.toml @@ -50,6 +50,7 @@ zenoh-macros = { workspace = true } [dev-dependencies] zenoh = { workspace = true, features = ["unstable"], default-features = true } +zenoh-config = { workspace = true } [package.metadata.docs.rs] features = ["unstable"] diff --git a/zenoh-ext/examples/Cargo.toml b/zenoh-ext/examples/Cargo.toml index 8dae03e596..de8c5ad49a 100644 --- a/zenoh-ext/examples/Cargo.toml +++ b/zenoh-ext/examples/Cargo.toml @@ -39,6 +39,7 @@ clap = { workspace = true, features = ["derive"] } zenoh-ext = { workspace = true } [dev-dependencies] +zenoh-config = { workspace = true } [[example]] name = "z_query_sub" diff --git a/zenoh-ext/examples/examples/z_pub_cache.rs b/zenoh-ext/examples/examples/z_pub_cache.rs index 6c47fb0862..d8e13faec4 100644 --- a/zenoh-ext/examples/examples/z_pub_cache.rs +++ b/zenoh-ext/examples/examples/z_pub_cache.rs @@ -14,10 +14,8 @@ use std::time::Duration; use clap::{arg, Parser}; -use zenoh::{ - config::{Config, ModeDependentValue}, - key_expr::KeyExpr, -}; +use zenoh::{config::Config, key_expr::KeyExpr}; +use zenoh_config::ModeDependentValue; use zenoh_ext::*; use zenoh_ext_examples::CommonArgs; diff --git a/zenoh-ext/examples/src/lib.rs b/zenoh-ext/examples/src/lib.rs index 881d60c138..04d1223022 100644 --- a/zenoh-ext/examples/src/lib.rs +++ b/zenoh-ext/examples/src/lib.rs @@ -2,7 +2,7 @@ //! See the code in ../examples/ //! Check ../README.md for usage. //! -use zenoh::config::Config; +use zenoh::{config::WhatAmI, Config}; #[derive(clap::ValueEnum, Clone, Copy, PartialEq, Eq, Hash, Debug)] pub enum Wai { @@ -43,9 +43,9 @@ impl From<&CommonArgs> for Config { None => Config::default(), }; match value.mode { - Some(Wai::Peer) => config.set_mode(Some(zenoh::config::WhatAmI::Peer)), - Some(Wai::Client) => config.set_mode(Some(zenoh::config::WhatAmI::Client)), - Some(Wai::Router) => config.set_mode(Some(zenoh::config::WhatAmI::Router)), + Some(Wai::Peer) => config.set_mode(Some(WhatAmI::Peer)), + Some(Wai::Client) => config.set_mode(Some(WhatAmI::Client)), + Some(Wai::Router) => config.set_mode(Some(WhatAmI::Router)), None => Ok(None), } .unwrap(); diff --git a/zenoh-ext/src/querying_subscriber.rs b/zenoh-ext/src/querying_subscriber.rs index 625494a757..f35c2ecbdb 100644 --- a/zenoh-ext/src/querying_subscriber.rs +++ b/zenoh-ext/src/querying_subscriber.rs @@ -633,7 +633,7 @@ where /// use zenoh::Wait; /// use zenoh_ext::*; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expr") /// .fetching( |cb| { @@ -777,7 +777,7 @@ impl FetchingSubscriber { /// use zenoh::Wait; /// use zenoh_ext::*; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut subscriber = session /// .declare_subscriber("key/expr") /// .fetching( |cb| { @@ -855,7 +855,7 @@ impl Drop for RepliesHandler { /// # use zenoh::Wait; /// # use zenoh_ext::*; /// # -/// # let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// # let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// # let mut fetching_subscriber = session /// # .declare_subscriber("key/expr") /// # .fetching( |cb| { diff --git a/zenoh-ext/src/session_ext.rs b/zenoh-ext/src/session_ext.rs index 7c68f88ddb..facf0ebed1 100644 --- a/zenoh-ext/src/session_ext.rs +++ b/zenoh-ext/src/session_ext.rs @@ -18,14 +18,16 @@ use super::PublicationCacheBuilder; /// Some extensions to the [`zenoh::Session`](zenoh::Session) pub trait SessionExt<'s, 'a> { + // REVIEW(fuzzypixelz): this doc test is the only one to use the programmatic configuration API.. /// Examples: /// ``` /// # #[tokio::main] /// # async fn main() { - /// use zenoh::config::ModeDependentValue::Unique; /// use zenoh_ext::SessionExt; + /// use zenoh_config::ModeDependentValue::Unique; /// - /// let mut config = zenoh::config::default(); + /// + /// let mut config = zenoh::Config::default(); /// config.timestamping.set_enabled(Some(Unique(true))); /// let session = zenoh::open(config).await.unwrap(); /// let publication_cache = session.declare_publication_cache("key/expression").await.unwrap(); diff --git a/zenoh-ext/src/subscriber_ext.rs b/zenoh-ext/src/subscriber_ext.rs index a48c4fe500..1c14f31b82 100644 --- a/zenoh-ext/src/subscriber_ext.rs +++ b/zenoh-ext/src/subscriber_ext.rs @@ -63,7 +63,7 @@ pub trait SubscriberBuilderExt<'a, 'b, Handler> { /// use zenoh::Wait; /// use zenoh_ext::*; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expr") /// .fetching( |cb| { @@ -106,7 +106,7 @@ pub trait SubscriberBuilderExt<'a, 'b, Handler> { /// # async fn main() { /// use zenoh_ext::*; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expr") /// .querying() @@ -140,7 +140,7 @@ impl<'a, 'b, Handler> SubscriberBuilderExt<'a, 'b, Handler> for SubscriberBuilde /// use zenoh::Wait; /// use zenoh_ext::*; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expr") /// .fetching( |cb| { @@ -195,7 +195,7 @@ impl<'a, 'b, Handler> SubscriberBuilderExt<'a, 'b, Handler> for SubscriberBuilde /// # async fn main() { /// use zenoh_ext::*; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expr") /// .querying() @@ -249,7 +249,7 @@ impl<'a, 'b, Handler> SubscriberBuilderExt<'a, 'b, Handler> /// use zenoh::Wait; /// use zenoh_ext::*; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .liveliness() /// .declare_subscriber("key/expr") @@ -307,7 +307,7 @@ impl<'a, 'b, Handler> SubscriberBuilderExt<'a, 'b, Handler> /// # async fn main() { /// use zenoh_ext::*; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .liveliness() /// .declare_subscriber("key/expr") diff --git a/zenoh-ext/tests/liveliness.rs b/zenoh-ext/tests/liveliness.rs index d211505c4c..14b6101f79 100644 --- a/zenoh-ext/tests/liveliness.rs +++ b/zenoh-ext/tests/liveliness.rs @@ -12,11 +12,8 @@ // ZettaScale Zenoh Team, // -use zenoh::{ - config::{self, EndPoint, WhatAmI}, - sample::SampleKind, - Wait, -}; +use zenoh::{sample::SampleKind, Wait}; +use zenoh_config::{EndPoint, WhatAmI}; #[tokio::test(flavor = "multi_thread", worker_threads = 4)] async fn test_liveliness_querying_subscriber_clique() { @@ -36,7 +33,7 @@ async fn test_liveliness_querying_subscriber_clique() { zenoh_util::init_log_from_env_or("error"); let peer1 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) @@ -49,7 +46,7 @@ async fn test_liveliness_querying_subscriber_clique() { }; let peer2 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) @@ -114,7 +111,7 @@ async fn test_liveliness_querying_subscriber_brokered() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -127,7 +124,7 @@ async fn test_liveliness_querying_subscriber_brokered() { }; let client1 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -140,7 +137,7 @@ async fn test_liveliness_querying_subscriber_brokered() { }; let client2 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -153,7 +150,7 @@ async fn test_liveliness_querying_subscriber_brokered() { }; let client3 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -220,7 +217,7 @@ async fn test_liveliness_fetching_subscriber_clique() { zenoh_util::init_log_from_env_or("error"); let peer1 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) @@ -233,7 +230,7 @@ async fn test_liveliness_fetching_subscriber_clique() { }; let peer2 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) @@ -302,7 +299,7 @@ async fn test_liveliness_fetching_subscriber_brokered() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -315,7 +312,7 @@ async fn test_liveliness_fetching_subscriber_brokered() { }; let client1 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -328,7 +325,7 @@ async fn test_liveliness_fetching_subscriber_brokered() { }; let client2 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -341,7 +338,7 @@ async fn test_liveliness_fetching_subscriber_brokered() { }; let client3 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) diff --git a/zenoh/Cargo.toml b/zenoh/Cargo.toml index 32371823e1..1d557b8530 100644 --- a/zenoh/Cargo.toml +++ b/zenoh/Cargo.toml @@ -64,6 +64,7 @@ transport_unixsock-stream = ["zenoh-transport/transport_unixsock-stream"] transport_ws = ["zenoh-transport/transport_ws"] transport_vsock = ["zenoh-transport/transport_vsock"] unstable = ["zenoh-keyexpr/unstable"] +unstable_config = [] [dependencies] tokio = { workspace = true, features = ["rt", "macros", "time"] } @@ -108,6 +109,7 @@ zenoh-util = { workspace = true } zenoh-runtime = { workspace = true } zenoh-task = { workspace = true } once_cell = { workspace = true } +validated_struct = { workspace = true } [dev-dependencies] tokio = { workspace = true } diff --git a/zenoh/src/api/builders/publisher.rs b/zenoh/src/api/builders/publisher.rs index 1eef911fd9..40389ff546 100644 --- a/zenoh/src/api/builders/publisher.rs +++ b/zenoh/src/api/builders/publisher.rs @@ -61,7 +61,7 @@ pub struct PublicationBuilderDelete; /// # async fn main() { /// use zenoh::{bytes::Encoding, qos::CongestionControl}; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// session /// .put("key/expression", "payload") /// .encoding(Encoding::TEXT_PLAIN) @@ -253,7 +253,7 @@ impl IntoFuture for PublicationBuilder, PublicationBuil /// # async fn main() { /// use zenoh::qos::CongestionControl; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session /// .declare_publisher("key/expression") /// .congestion_control(CongestionControl::Block) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs new file mode 100644 index 0000000000..ddbd33ccc2 --- /dev/null +++ b/zenoh/src/api/config.rs @@ -0,0 +1,200 @@ +use std::{ + any::Any, + error::Error, + fmt, + ops::{self, Deref}, + path::Path, + sync::{Arc, Mutex, MutexGuard}, +}; + +use zenoh_result::ZResult; + +/// Zenoh configuration. +/// +/// Most options are optional as a way to keep defaults flexible. Some of the options have different +/// default values depending on the rest of the configuration. +/// +/// To construct a configuration, we advise that you use a configuration file (JSON, JSON5 and YAML +/// are currently supported, please use the proper extension for your format as the deserializer +/// will be picked according to it). +#[derive(Default, Debug, Clone)] +pub struct Config(pub(crate) zenoh_config::Config); + +impl Config { + pub fn from_env() -> ZResult { + Ok(Config(zenoh_config::Config::from_env()?)) + } + + pub fn from_file>(path: P) -> ZResult { + Ok(Config(zenoh_config::Config::from_file(path)?)) + } + + pub fn insert_json5(&mut self, key: &str, value: &str) -> Result<(), InsertionError> { + ::insert_json5( + &mut self.0, + key, + value, + ) + .map_err(InsertionError) + } + + pub fn get<'a>(&'a self, key: &str) -> Result<&'a dyn Any, LookupError> { + ::get(&self.0, key) + .map_err(LookupError) + } + + pub fn remove>(&mut self, key: K) -> ZResult<()> { + self.0.remove(key) + } +} + +#[derive(Debug)] +pub struct InsertionError(validated_struct::InsertionError); + +impl fmt::Display for InsertionError { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + write!(f, "{}", &self.0) + } +} + +impl Error for InsertionError {} + +#[derive(Debug)] +pub struct LookupError(validated_struct::GetError); + +impl fmt::Display for LookupError { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + write!(f, "{}", &self.0) + } +} + +impl Error for LookupError {} + +#[zenoh_macros::unstable_config] +impl std::ops::Deref for Config { + type Target = zenoh_config::Config; + + fn deref(&self) -> &Self::Target { + &self.0 + } +} + +#[zenoh_macros::unstable_config] +impl std::ops::DerefMut for Config { + fn deref_mut(&mut self) -> &mut ::Target { + &mut self.0 + } +} + +impl fmt::Display for Config { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + write!(f, "{}", &self.0) + } +} + +pub type Notification = Arc; + +struct NotifierInner { + inner: Mutex, + subscribers: Mutex>>, +} +pub struct Notifier { + inner: Arc>, +} +impl Clone for Notifier { + fn clone(&self) -> Self { + Self { + inner: self.inner.clone(), + } + } +} +impl Notifier { + pub fn new(inner: Config) -> Self { + Notifier { + inner: Arc::new(NotifierInner { + inner: Mutex::new(inner), + subscribers: Mutex::new(Vec::new()), + }), + } + } + + pub fn subscribe(&self) -> flume::Receiver { + let (tx, rx) = flume::unbounded(); + self.lock_subscribers().push(tx); + rx + } + + pub fn notify>(&self, key: K) { + let key = key.as_ref(); + let key: Arc = Arc::from(key); + let mut marked = Vec::new(); + let mut subscribers = self.lock_subscribers(); + + for (i, sub) in subscribers.iter().enumerate() { + if sub.send(key.clone()).is_err() { + marked.push(i) + } + } + + for i in marked.into_iter().rev() { + subscribers.swap_remove(i); + } + } + + pub fn lock(&self) -> MutexGuard { + self.lock_config() + } + + fn lock_subscribers(&self) -> MutexGuard>> { + self.inner + .subscribers + .lock() + .expect("acquiring Notifier's subscribers Mutex should not fail") + } + + fn lock_config(&self) -> MutexGuard { + self.inner + .inner + .lock() + .expect("acquiring Notifier's Config Mutex should not fail") + } + + pub fn remove>(&self, key: K) -> ZResult<()> { + self.lock_config().remove(key.as_ref())?; + self.notify(key); + Ok(()) + } + + pub fn insert_json5(&self, key: &str, value: &str) -> Result<(), InsertionError> { + self.lock_config().insert_json5(key, value) + } + + pub fn get<'a>(&'a self, key: &str) -> Result, LookupError> { + let config = self.lock_config(); + // SAFETY: MutexGuard pins the mutex behind which the value is held. + let subref = config.get(key.as_ref())? as *const _; + Ok(LookupGuard { + _guard: config, + subref, + }) + } +} + +pub struct LookupGuard<'a, T> { + _guard: MutexGuard<'a, T>, + subref: *const dyn Any, +} + +impl<'a, T> ops::Deref for LookupGuard<'a, T> { + type Target = dyn Any; + + fn deref(&self) -> &Self::Target { + unsafe { &*self.subref } + } +} + +impl<'a, T> AsRef for LookupGuard<'a, T> { + fn as_ref(&self) -> &dyn Any { + self.deref() + } +} diff --git a/zenoh/src/api/info.rs b/zenoh/src/api/info.rs index a63797c86c..95131eb6c6 100644 --- a/zenoh/src/api/info.rs +++ b/zenoh/src/api/info.rs @@ -29,7 +29,7 @@ use crate::net::runtime::Runtime; /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let zid = session.info().zid().await; /// # } /// ``` @@ -66,7 +66,7 @@ impl<'a> IntoFuture for ZenohIdBuilder<'a> { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut routers_zid = session.info().routers_zid().await; /// while let Some(router_zid) = routers_zid.next() {} /// # } @@ -113,7 +113,7 @@ impl<'a> IntoFuture for RoutersZenohIdBuilder<'a> { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let zid = session.info().zid().await; /// let mut peers_zid = session.info().peers_zid().await; /// while let Some(peer_zid) = peers_zid.next() {} @@ -161,7 +161,7 @@ impl<'a> IntoFuture for PeersZenohIdBuilder<'a> { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let info = session.info(); /// let zid = info.zid().await; /// # } @@ -178,7 +178,7 @@ impl SessionInfo { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let zid = session.info().zid().await; /// # } /// ``` @@ -196,7 +196,7 @@ impl SessionInfo { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut routers_zid = session.info().routers_zid().await; /// while let Some(router_zid) = routers_zid.next() {} /// # } @@ -214,7 +214,7 @@ impl SessionInfo { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut peers_zid = session.info().peers_zid().await; /// while let Some(peer_zid) = peers_zid.next() {} /// # } diff --git a/zenoh/src/api/key_expr.rs b/zenoh/src/api/key_expr.rs index fff40a5286..e94e61d6be 100644 --- a/zenoh/src/api/key_expr.rs +++ b/zenoh/src/api/key_expr.rs @@ -567,7 +567,7 @@ impl<'a> UndeclarableSealed<&'a Session> for KeyExpr<'a> { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let key_expr = session.declare_keyexpr("key/expression").await.unwrap(); /// session.undeclare(key_expr).await.unwrap(); /// # } diff --git a/zenoh/src/api/liveliness.rs b/zenoh/src/api/liveliness.rs index c8a0b6f194..b5acc52bb7 100644 --- a/zenoh/src/api/liveliness.rs +++ b/zenoh/src/api/liveliness.rs @@ -52,7 +52,7 @@ use crate::api::session::WeakSession; /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let liveliness = session /// .liveliness() /// .declare_token("key/expression") @@ -66,7 +66,7 @@ use crate::api::session::WeakSession; /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let replies = session.liveliness().get("key/**").await.unwrap(); /// while let Ok(reply) = replies.recv_async().await { /// if let Ok(sample) = reply.result() { @@ -82,7 +82,7 @@ use crate::api::session::WeakSession; /// # async fn main() { /// use zenoh::sample::SampleKind; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session.liveliness().declare_subscriber("key/**").await.unwrap(); /// while let Ok(sample) = subscriber.recv_async().await { /// match sample.kind() { @@ -110,7 +110,7 @@ impl<'a> Liveliness<'a> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let liveliness = session /// .liveliness() /// .declare_token("key/expression") @@ -145,7 +145,7 @@ impl<'a> Liveliness<'a> { /// # async fn main() { /// use zenoh::sample::SampleKind; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session.liveliness().declare_subscriber("key/expression").await.unwrap(); /// while let Ok(sample) = subscriber.recv_async().await { /// match sample.kind() { @@ -184,7 +184,7 @@ impl<'a> Liveliness<'a> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let replies = session.liveliness().get("key/expression").await.unwrap(); /// while let Ok(reply) = replies.recv_async().await { /// if let Ok(sample) = reply.result() { @@ -223,7 +223,7 @@ impl<'a> Liveliness<'a> { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let liveliness = session /// .liveliness() /// .declare_token("key/expression") @@ -295,7 +295,7 @@ pub(crate) struct LivelinessTokenState { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let liveliness = session /// .liveliness() /// .declare_token("key/expression") @@ -318,7 +318,7 @@ pub struct LivelinessToken { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let liveliness = session /// .liveliness() /// .declare_token("key/expression") @@ -363,7 +363,7 @@ impl LivelinessToken { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let liveliness = session /// .liveliness() /// .declare_token("key/expression") @@ -412,7 +412,7 @@ impl Drop for LivelinessToken { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .liveliness() /// .declare_subscriber("key/expression") @@ -446,7 +446,7 @@ impl<'a, 'b> LivelinessSubscriberBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .liveliness() /// .declare_subscriber("key/expression") @@ -480,7 +480,7 @@ impl<'a, 'b> LivelinessSubscriberBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut n = 0; /// let subscriber = session /// .liveliness() @@ -509,7 +509,7 @@ impl<'a, 'b> LivelinessSubscriberBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .liveliness() /// .declare_subscriber("key/expression") @@ -631,7 +631,7 @@ where /// # async fn main() { /// # use std::convert::TryFrom; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let tokens = session /// .liveliness() /// .get("key/expression") @@ -662,7 +662,7 @@ impl<'a, 'b> LivelinessGetBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session /// .liveliness() /// .get("key/expression") @@ -689,7 +689,7 @@ impl<'a, 'b> LivelinessGetBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut n = 0; /// let queryable = session /// .liveliness() @@ -717,7 +717,7 @@ impl<'a, 'b> LivelinessGetBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let replies = session /// .liveliness() /// .get("key/expression") diff --git a/zenoh/src/api/mod.rs b/zenoh/src/api/mod.rs index d3053cb3c9..c755a45f26 100644 --- a/zenoh/src/api/mod.rs +++ b/zenoh/src/api/mod.rs @@ -17,6 +17,7 @@ pub(crate) type Id = u32; pub(crate) mod admin; pub(crate) mod builders; pub(crate) mod bytes; +pub(crate) mod config; pub(crate) mod encoding; pub(crate) mod handlers; pub(crate) mod info; diff --git a/zenoh/src/api/publisher.rs b/zenoh/src/api/publisher.rs index 4870fac445..7db74eb89d 100644 --- a/zenoh/src/api/publisher.rs +++ b/zenoh/src/api/publisher.rs @@ -75,7 +75,7 @@ impl fmt::Debug for PublisherState { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// publisher.put("value").await.unwrap(); /// # } @@ -89,7 +89,7 @@ impl fmt::Debug for PublisherState { /// # async fn main() { /// use futures::StreamExt; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut subscriber = session.declare_subscriber("key/expression").await.unwrap(); /// let publisher = session.declare_publisher("another/key/expression").await.unwrap(); /// subscriber.stream().map(Ok).forward(publisher).await.unwrap(); @@ -120,7 +120,7 @@ impl<'a> Publisher<'a> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression") /// .await /// .unwrap(); @@ -173,7 +173,7 @@ impl<'a> Publisher<'a> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// publisher.put("value").await.unwrap(); /// # } @@ -203,7 +203,7 @@ impl<'a> Publisher<'a> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// publisher.delete().await.unwrap(); /// # } @@ -229,7 +229,7 @@ impl<'a> Publisher<'a> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_subscribers: bool = publisher /// .matching_status() @@ -256,7 +256,7 @@ impl<'a> Publisher<'a> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_listener = publisher.matching_listener().await.unwrap(); /// while let Ok(matching_status) = matching_listener.recv_async().await { @@ -284,7 +284,7 @@ impl<'a> Publisher<'a> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// publisher.undeclare().await.unwrap(); /// # } @@ -322,7 +322,7 @@ impl<'a> UndeclarableSealed<()> for Publisher<'a> { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// publisher.undeclare().await.unwrap(); /// # } @@ -503,7 +503,7 @@ impl TryFrom for Priority { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_status = publisher.matching_status().await.unwrap(); /// # } @@ -523,7 +523,7 @@ impl MatchingStatus { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_subscribers: bool = publisher /// .matching_status() @@ -555,7 +555,7 @@ impl<'a, 'b> MatchingListenerBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_listener = publisher /// .matching_listener() @@ -587,7 +587,7 @@ impl<'a, 'b> MatchingListenerBuilder<'a, 'b, DefaultHandler> { /// # async fn main() { /// /// let mut n = 0; - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_listener = publisher /// .matching_listener() @@ -615,7 +615,7 @@ impl<'a, 'b> MatchingListenerBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_listener = publisher /// .matching_listener() @@ -754,7 +754,7 @@ pub(crate) struct MatchingListenerInner { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_listener = publisher.matching_listener().await.unwrap(); /// while let Ok(matching_status) = matching_listener.recv_async().await { @@ -781,7 +781,7 @@ impl MatchingListener { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression").await.unwrap(); /// let matching_listener = publisher.matching_listener().await.unwrap(); /// matching_listener.undeclare().await.unwrap(); @@ -856,10 +856,7 @@ impl IntoFuture for MatchingListenerUndeclaration { #[cfg(test)] mod tests { - use zenoh_config::Config; - use zenoh_core::Wait; - - use crate::api::sample::SampleKind; + use crate::{sample::SampleKind, Config, Wait}; #[cfg(feature = "internal")] #[test] diff --git a/zenoh/src/api/query.rs b/zenoh/src/api/query.rs index 7cb8d5eb84..ff9aba7520 100644 --- a/zenoh/src/api/query.rs +++ b/zenoh/src/api/query.rs @@ -180,7 +180,7 @@ impl QueryState { /// # async fn main() { /// use zenoh::{query::{ConsolidationMode, QueryTarget}}; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let replies = session /// .get("key/expression?value>1") /// .target(QueryTarget::All) @@ -266,7 +266,7 @@ impl<'a, 'b> SessionGetBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session /// .get("key/expression") /// .callback(|reply| {println!("Received {:?}", reply.result());}) @@ -292,7 +292,7 @@ impl<'a, 'b> SessionGetBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut n = 0; /// let queryable = session /// .get("key/expression") @@ -319,7 +319,7 @@ impl<'a, 'b> SessionGetBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let replies = session /// .get("key/expression") /// .with(flume::bounded(32)) diff --git a/zenoh/src/api/queryable.rs b/zenoh/src/api/queryable.rs index 97675336b7..cca8558cef 100644 --- a/zenoh/src/api/queryable.rs +++ b/zenoh/src/api/queryable.rs @@ -558,7 +558,7 @@ pub(crate) struct QueryableInner { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session.declare_queryable("key/expression").await.unwrap(); /// queryable.undeclare().await.unwrap(); /// # } @@ -592,7 +592,7 @@ impl IntoFuture for QueryableUndeclaration { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session.declare_queryable("key/expression").await.unwrap(); /// # } /// ``` @@ -621,7 +621,7 @@ impl<'a, 'b> QueryableBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session /// .declare_queryable("key/expression") /// .callback(|query| {println!(">> Handling query '{}'", query.selector());}) @@ -650,7 +650,7 @@ impl<'a, 'b> QueryableBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut n = 0; /// let queryable = session /// .declare_queryable("key/expression") @@ -677,7 +677,7 @@ impl<'a, 'b> QueryableBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session /// .declare_queryable("key/expression") /// .with(flume::bounded(32)) @@ -759,7 +759,7 @@ impl QueryableBuilder<'_, '_, Handler> { /// # async fn main() { /// use futures::prelude::*; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let (tx, rx) = flume::bounded(32); /// session /// .declare_queryable("key/expression") @@ -781,7 +781,7 @@ impl QueryableBuilder<'_, '_, Handler> { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session /// .declare_queryable("key/expression") /// .with(flume::bounded(32)) @@ -811,7 +811,7 @@ impl Queryable { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session.declare_queryable("key/expression") /// .await /// .unwrap(); @@ -848,7 +848,7 @@ impl Queryable { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session.declare_queryable("key/expression") /// .await /// .unwrap(); diff --git a/zenoh/src/api/scouting.rs b/zenoh/src/api/scouting.rs index 73c0afcbdf..5f0f081075 100644 --- a/zenoh/src/api/scouting.rs +++ b/zenoh/src/api/scouting.rs @@ -29,6 +29,7 @@ use zenoh_task::TerminatableTask; use crate::{ api::handlers::{locked, Callback, DefaultHandler, IntoHandler}, net::runtime::{orchestrator::Loop, Runtime}, + Config, }; /// A builder for initializing a [`Scout`]. @@ -39,7 +40,7 @@ use crate::{ /// # async fn main() { /// use zenoh::config::WhatAmI; /// -/// let receiver = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::config::default()) +/// let receiver = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::Config::default()) /// .await /// .unwrap(); /// while let Ok(hello) = receiver.recv_async().await { @@ -64,7 +65,7 @@ impl ScoutBuilder { /// # async fn main() { /// use zenoh::config::WhatAmI; /// - /// let scout = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::config::default()) + /// let scout = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::Config::default()) /// .callback(|hello| { println!("{}", hello); }) /// .await /// .unwrap(); @@ -90,7 +91,7 @@ impl ScoutBuilder { /// use zenoh::config::WhatAmI; /// /// let mut n = 0; - /// let scout = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::config::default()) + /// let scout = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::Config::default()) /// .callback_mut(move |_hello| { n += 1; }) /// .await /// .unwrap(); @@ -115,7 +116,7 @@ impl ScoutBuilder { /// # async fn main() { /// use zenoh::config::WhatAmI; /// - /// let receiver = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::config::default()) + /// let receiver = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::Config::default()) /// .with(flume::bounded(32)) /// .await /// .unwrap(); @@ -182,7 +183,7 @@ where /// # async fn main() { /// use zenoh::config::WhatAmI; /// -/// let scout = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::config::default()) +/// let scout = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::Config::default()) /// .callback(|hello| { println!("{}", hello); }) /// .await /// .unwrap(); @@ -202,7 +203,7 @@ impl ScoutInner { /// # async fn main() { /// use zenoh::config::WhatAmI; /// - /// let scout = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::config::default()) + /// let scout = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::Config::default()) /// .callback(|hello| { println!("{}", hello); }) /// .await /// .unwrap(); @@ -237,7 +238,7 @@ impl fmt::Debug for ScoutInner { /// # async fn main() { /// use zenoh::config::WhatAmI; /// -/// let receiver = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::config::default()) +/// let receiver = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::Config::default()) /// .with(flume::bounded(32)) /// .await /// .unwrap(); @@ -270,7 +271,7 @@ impl Scout { /// # async fn main() { /// use zenoh::config::WhatAmI; /// - /// let scout = zenoh::scout(WhatAmI::Router, zenoh::config::default()) + /// let scout = zenoh::scout(WhatAmI::Router, zenoh::Config::default()) /// .with(flume::bounded(32)) /// .await /// .unwrap(); @@ -283,21 +284,23 @@ impl Scout { } } -fn _scout( - what: WhatAmIMatcher, - config: zenoh_config::Config, - callback: Callback, -) -> ZResult { +fn _scout(what: WhatAmIMatcher, config: Config, callback: Callback) -> ZResult { tracing::trace!("scout({}, {})", what, &config); let default_addr = SocketAddr::from(zenoh_config::defaults::scouting::multicast::address); - let addr = config.scouting.multicast.address().unwrap_or(default_addr); + let addr = config + .0 + .scouting + .multicast + .address() + .unwrap_or(default_addr); let default_multicast_ttl = zenoh_config::defaults::scouting::multicast::ttl; let multicast_ttl = config + .0 .scouting .multicast .ttl .unwrap_or(default_multicast_ttl); - let ifaces = config.scouting.multicast.interface().as_ref().map_or( + let ifaces = config.0.scouting.multicast.interface().as_ref().map_or( zenoh_config::defaults::scouting::multicast::interface, |s| s.as_ref(), ); @@ -352,7 +355,7 @@ fn _scout( /// # async fn main() { /// use zenoh::config::WhatAmI; /// -/// let receiver = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::config::default()) +/// let receiver = zenoh::scout(WhatAmI::Peer | WhatAmI::Router, zenoh::Config::default()) /// .await /// .unwrap(); /// while let Ok(hello) = receiver.recv_async().await { diff --git a/zenoh/src/api/session.rs b/zenoh/src/api/session.rs index f703b3fcaf..d6b04343c2 100644 --- a/zenoh/src/api/session.rs +++ b/zenoh/src/api/session.rs @@ -32,7 +32,7 @@ use uhlc::Timestamp; use uhlc::HLC; use zenoh_buffers::ZBuf; use zenoh_collections::SingleOrVec; -use zenoh_config::{unwrap_or_default, wrappers::ZenohId, Config, Notifier}; +use zenoh_config::{unwrap_or_default, wrappers::ZenohId}; use zenoh_core::{zconfigurable, zread, Resolvable, Resolve, ResolveClosure, ResolveFuture, Wait}; #[cfg(feature = "unstable")] use zenoh_protocol::network::{ @@ -77,6 +77,7 @@ use super::{ SessionPutBuilder, }, bytes::ZBytes, + config::Notifier, encoding::Encoding, handlers::{Callback, DefaultHandler}, info::SessionInfo, @@ -102,10 +103,13 @@ use super::{ }; #[cfg(feature = "unstable")] use crate::api::selector::ZenohParameters; -use crate::net::{ - primitives::Primitives, - routing::dispatcher::face::Face, - runtime::{Runtime, RuntimeBuilder}, +use crate::{ + net::{ + primitives::Primitives, + routing::dispatcher::face::Face, + runtime::{Runtime, RuntimeBuilder}, + }, + Config, }; zconfigurable! { @@ -426,7 +430,7 @@ impl fmt::Debug for SessionInner { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// session.put("key/expression", "value").await.unwrap(); /// # } pub struct Session(pub(crate) Arc); @@ -580,7 +584,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expression") /// .await @@ -607,7 +611,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// assert!(!session.is_closed()); /// session.close().await.unwrap(); /// assert!(session.is_closed()); @@ -636,7 +640,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let peers = session.config().get("connect/endpoints").unwrap(); /// # } /// ``` @@ -646,7 +650,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let _ = session.config().insert_json5("connect/endpoints", r#"["tcp/127.0.0.1/7447"]"#); /// # } /// ``` @@ -664,7 +668,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let timestamp = session.new_timestamp(); /// # } /// ``` @@ -695,7 +699,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let info = session.info(); /// # } /// ``` @@ -716,7 +720,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session.declare_subscriber("key/expression") /// .await /// .unwrap(); @@ -756,7 +760,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let queryable = session.declare_queryable("key/expression") /// .await /// .unwrap(); @@ -799,7 +803,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let publisher = session.declare_publisher("key/expression") /// .await /// .unwrap(); @@ -834,7 +838,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let liveliness = session /// .liveliness() /// .declare_token("key/expression") @@ -859,7 +863,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let key_expr = session.declare_keyexpr("key/expression").await.unwrap(); /// # } /// ``` @@ -914,7 +918,7 @@ impl Session { /// # async fn main() { /// use zenoh::bytes::Encoding; /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// session /// .put("key/expression", "payload") /// .encoding(Encoding::TEXT_PLAIN) @@ -957,7 +961,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// session.delete("key/expression").await.unwrap(); /// # } /// ``` @@ -993,7 +997,7 @@ impl Session { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let replies = session.get("key/expression").await.unwrap(); /// while let Ok(reply) = replies.recv_async().await { /// println!(">> Received {:?}", reply.result()); @@ -1010,7 +1014,7 @@ impl Session { { let selector = selector.try_into().map_err(Into::into); let timeout = { - let conf = self.0.runtime.config().lock(); + let conf = &self.0.runtime.config().lock().0; Duration::from_millis(unwrap_or_default!(conf.queries_default_timeout())) }; let qos: QoS = request::ext::QoSType::REQUEST.into(); @@ -1039,8 +1043,8 @@ impl Session { ) -> impl Resolve> { ResolveFuture::new(async move { tracing::debug!("Config: {:?}", &config); - let aggregated_subscribers = config.aggregation().subscribers().clone(); - let aggregated_publishers = config.aggregation().publishers().clone(); + let aggregated_subscribers = config.0.aggregation().subscribers().clone(); + let aggregated_publishers = config.0.aggregation().publishers().clone(); #[allow(unused_mut)] // Required for shared-memory let mut runtime = RuntimeBuilder::new(config); #[cfg(feature = "shared-memory")] @@ -2812,7 +2816,7 @@ impl crate::net::primitives::EPrimitives for WeakSession { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// # } /// ``` /// @@ -2822,7 +2826,7 @@ impl crate::net::primitives::EPrimitives for WeakSession { /// use std::str::FromStr; /// use zenoh::session::ZenohId; /// -/// let mut config = zenoh::config::peer(); +/// let mut config = zenoh::Config::default(); /// config.set_id(ZenohId::from_str("221b72df20924c15b8794c6bdb471150").unwrap()); /// config.connect.endpoints.set( /// ["tcp/10.10.10.10:7447", "tcp/11.11.11.11:7447"].iter().map(|s|s.parse().unwrap()).collect()); @@ -2849,7 +2853,7 @@ where /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// # } /// ``` #[must_use = "Resolvables do nothing unless you resolve them using the `res` method from either `SyncResolve` or `AsyncResolve`"] diff --git a/zenoh/src/api/subscriber.rs b/zenoh/src/api/subscriber.rs index 3cbe16044e..dbe1b63dc0 100644 --- a/zenoh/src/api/subscriber.rs +++ b/zenoh/src/api/subscriber.rs @@ -69,7 +69,7 @@ pub(crate) struct SubscriberInner { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expression") /// .await @@ -106,7 +106,7 @@ impl IntoFuture for SubscriberUndeclaration { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expression") /// .await @@ -156,7 +156,7 @@ impl<'a, 'b> SubscriberBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expression") /// .callback(|sample| { println!("Received: {} {:?}", sample.key_expr(), sample.payload()); }) @@ -185,7 +185,7 @@ impl<'a, 'b> SubscriberBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let mut n = 0; /// let subscriber = session /// .declare_subscriber("key/expression") @@ -212,7 +212,7 @@ impl<'a, 'b> SubscriberBuilder<'a, 'b, DefaultHandler> { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expression") /// .with(flume::bounded(32)) @@ -364,7 +364,7 @@ where /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// session /// .declare_subscriber("key/expression") /// .callback(|sample| { println!("Received: {} {:?}", sample.key_expr(), sample.payload()) }) @@ -379,7 +379,7 @@ where /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session /// .declare_subscriber("key/expression") /// .with(flume::bounded(32)) @@ -406,7 +406,7 @@ impl Subscriber { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session.declare_subscriber("key/expression") /// .await /// .unwrap(); @@ -448,7 +448,7 @@ impl Subscriber { /// # #[tokio::main] /// # async fn main() { /// - /// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); + /// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session.declare_subscriber("key/expression") /// .await /// .unwrap(); diff --git a/zenoh/src/lib.rs b/zenoh/src/lib.rs index 72a3e46140..00b899dab5 100644 --- a/zenoh/src/lib.rs +++ b/zenoh/src/lib.rs @@ -37,7 +37,7 @@ //! //! #[tokio::main] //! async fn main() { -//! let session = zenoh::open(zenoh::config::default()).await.unwrap(); +//! let session = zenoh::open(zenoh::Config::default()).await.unwrap(); //! session.put("key/expression", "value").await.unwrap(); //! session.close().await.unwrap(); //! } @@ -50,7 +50,7 @@ //! //! #[tokio::main] //! async fn main() { -//! let session = zenoh::open(zenoh::config::default()).await.unwrap(); +//! let session = zenoh::open(zenoh::Config::default()).await.unwrap(); //! let subscriber = session.declare_subscriber("key/expression").await.unwrap(); //! while let Ok(sample) = subscriber.recv_async().await { //! println!("Received: {:?}", sample); @@ -66,7 +66,7 @@ //! //! #[tokio::main] //! async fn main() { -//! let session = zenoh::open(zenoh::config::default()).await.unwrap(); +//! let session = zenoh::open(zenoh::Config::default()).await.unwrap(); //! let replies = session.get("key/expression").await.unwrap(); //! while let Ok(reply) = replies.recv_async().await { //! println!(">> Received {:?}", reply.result()); @@ -296,7 +296,7 @@ pub mod scouting { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let liveliness = session /// .liveliness() /// .declare_token("key/expression") @@ -310,7 +310,7 @@ pub mod scouting { /// # #[tokio::main] /// # async fn main() { /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let replies = session.liveliness().get("key/**").await.unwrap(); /// while let Ok(reply) = replies.recv_async().await { /// if let Ok(sample) = reply.result() { @@ -326,7 +326,7 @@ pub mod scouting { /// # async fn main() { /// use zenoh::sample::SampleKind; /// -/// let session = zenoh::open(zenoh::config::peer()).await.unwrap(); +/// let session = zenoh::open(zenoh::Config::default()).await.unwrap(); /// let subscriber = session.liveliness().declare_subscriber("key/**").await.unwrap(); /// while let Ok(sample) = subscriber.recv_async().await { /// match sample.kind() { @@ -351,11 +351,9 @@ pub mod time { /// Configuration to pass to [`open`] and [`scout`] functions and associated constants pub mod config { - // pub use zenoh_config::{ - // client, default, peer, Config, EndPoint, Locator, ModeDependentValue, PermissionsConf, - // PluginLoad, ValidatedMap, ZenohId, - // }; - pub use zenoh_config::*; + pub use zenoh_config::{WhatAmI, WhatAmIMatcher}; + + pub use crate::api::config::{Config, InsertionError, LookupError, LookupGuard, Notifier}; } #[cfg(all( diff --git a/zenoh/src/net/routing/hat/linkstate_peer/mod.rs b/zenoh/src/net/routing/hat/linkstate_peer/mod.rs index f9e1674c3e..3dedbfa462 100644 --- a/zenoh/src/net/routing/hat/linkstate_peer/mod.rs +++ b/zenoh/src/net/routing/hat/linkstate_peer/mod.rs @@ -180,7 +180,8 @@ pub(crate) struct HatCode {} impl HatBaseTrait for HatCode { fn init(&self, tables: &mut Tables, runtime: Runtime) { - let config = runtime.config().lock(); + let config_guard = runtime.config().lock(); + let config = &config_guard.0; let whatami = tables.whatami; let gossip = unwrap_or_default!(config.scouting().gossip().enabled()); let gossip_multihop = unwrap_or_default!(config.scouting().gossip().multihop()); @@ -194,7 +195,7 @@ impl HatBaseTrait for HatCode { unwrap_or_default!(config.routing().peer().mode()) == *"linkstate"; let router_peers_failover_brokering = unwrap_or_default!(config.routing().router().peers_failover_brokering()); - drop(config); + drop(config_guard); hat_mut!(tables).linkstatepeers_net = Some(Network::new( "[Peers network]".to_string(), diff --git a/zenoh/src/net/routing/hat/p2p_peer/mod.rs b/zenoh/src/net/routing/hat/p2p_peer/mod.rs index e68c2232fc..91367e5d9d 100644 --- a/zenoh/src/net/routing/hat/p2p_peer/mod.rs +++ b/zenoh/src/net/routing/hat/p2p_peer/mod.rs @@ -107,7 +107,8 @@ pub(crate) struct HatCode {} impl HatBaseTrait for HatCode { fn init(&self, tables: &mut Tables, runtime: Runtime) { - let config = runtime.config().lock(); + let config_guard = runtime.config().lock(); + let config = &config_guard.0; let whatami = tables.whatami; let gossip = unwrap_or_default!(config.scouting().gossip().enabled()); let gossip_multihop = unwrap_or_default!(config.scouting().gossip().multihop()); @@ -118,7 +119,7 @@ impl HatBaseTrait for HatCode { }; let router_peers_failover_brokering = unwrap_or_default!(config.routing().router().peers_failover_brokering()); - drop(config); + drop(config_guard); hat_mut!(tables).gossip = Some(Network::new( "[Gossip]".to_string(), diff --git a/zenoh/src/net/routing/hat/router/mod.rs b/zenoh/src/net/routing/hat/router/mod.rs index a2d3c66aa3..7ffc568d5c 100644 --- a/zenoh/src/net/routing/hat/router/mod.rs +++ b/zenoh/src/net/routing/hat/router/mod.rs @@ -307,7 +307,8 @@ pub(crate) struct HatCode {} impl HatBaseTrait for HatCode { fn init(&self, tables: &mut Tables, runtime: Runtime) { - let config = runtime.config().lock(); + let config_guard = runtime.config().lock(); + let config = &config_guard.0; let whatami = tables.whatami; let gossip = unwrap_or_default!(config.scouting().gossip().enabled()); let gossip_multihop = unwrap_or_default!(config.scouting().gossip().multihop()); @@ -322,7 +323,7 @@ impl HatBaseTrait for HatCode { unwrap_or_default!(config.routing().peer().mode()) == *"linkstate"; let router_peers_failover_brokering = unwrap_or_default!(config.routing().router().peers_failover_brokering()); - drop(config); + drop(config_guard); if router_full_linkstate | gossip { hat_mut!(tables).routers_net = Some(Network::new( diff --git a/zenoh/src/net/runtime/adminspace.rs b/zenoh/src/net/runtime/adminspace.rs index e38847c249..2841f99dd4 100644 --- a/zenoh/src/net/runtime/adminspace.rs +++ b/zenoh/src/net/runtime/adminspace.rs @@ -157,7 +157,7 @@ impl AdminSpace { pub async fn start(runtime: &Runtime, version: String) { let zid_str = runtime.state.zid.to_string(); let whatami_str = runtime.state.whatami.to_str(); - let mut config = runtime.config().lock(); + let config = &mut runtime.config().lock().0; let root_key: OwnedKeyExpr = format!("@/{zid_str}/{whatami_str}").try_into().unwrap(); let mut handlers: HashMap<_, Handler> = HashMap::new(); @@ -374,7 +374,7 @@ impl Primitives for AdminSpace { fn send_push(&self, msg: Push, _reliability: Reliability) { trace!("recv Push {:?}", msg); { - let conf = self.context.runtime.state.config.lock(); + let conf = &self.context.runtime.state.config.lock().0; if !conf.adminspace.permissions().write { tracing::error!( "Received PUT on '{}' but adminspace.permissions.write=false in configuration", @@ -435,7 +435,7 @@ impl Primitives for AdminSpace { RequestBody::Query(query) => { let primitives = zlock!(self.primitives).as_ref().unwrap().clone(); { - let conf = self.context.runtime.state.config.lock(); + let conf = &self.context.runtime.state.config.lock().0; if !conf.adminspace.permissions().read { tracing::error!( "Received GET on '{}' but adminspace.permissions.read=false in configuration", @@ -602,7 +602,7 @@ fn local_data(context: &AdminContext, query: Query) { let mut json = json!({ "zid": context.runtime.state.zid, "version": context.version, - "metadata": context.runtime.config().lock().metadata(), + "metadata": context.runtime.config().lock().0.metadata(), "locators": locators, "sessions": transports, "plugins": plugins, diff --git a/zenoh/src/net/runtime/mod.rs b/zenoh/src/net/runtime/mod.rs index 1a02513494..293e047ea0 100644 --- a/zenoh/src/net/runtime/mod.rs +++ b/zenoh/src/net/runtime/mod.rs @@ -36,7 +36,7 @@ use futures::{stream::StreamExt, Future}; use tokio::task::JoinHandle; use tokio_util::sync::CancellationToken; use uhlc::{HLCBuilder, HLC}; -use zenoh_config::wrappers::ZenohId; +use zenoh_config::{unwrap_or_default, ModeDependent, ZenohId}; use zenoh_link::{EndPoint, Link}; use zenoh_plugin_trait::{PluginStartArgs, StructVersion}; use zenoh_protocol::{ @@ -61,10 +61,7 @@ use super::{primitives::DeMux, routing, routing::router::Router}; use crate::api::loader::{load_plugins, start_plugins}; #[cfg(feature = "plugins")] use crate::api::plugins::PluginsManager; -use crate::{ - config::{unwrap_or_default, Config, ModeDependent, Notifier}, - GIT_VERSION, LONG_VERSION, -}; +use crate::{config::Notifier, Config, GIT_VERSION, LONG_VERSION}; pub(crate) struct RuntimeState { zid: ZenohId, @@ -93,7 +90,7 @@ impl WeakRuntime { } pub struct RuntimeBuilder { - config: Config, + config: zenoh_config::Config, #[cfg(feature = "plugins")] plugins_manager: Option, #[cfg(feature = "shared-memory")] @@ -103,7 +100,7 @@ pub struct RuntimeBuilder { impl RuntimeBuilder { pub fn new(config: Config) -> Self { Self { - config, + config: config.0, #[cfg(feature = "plugins")] plugins_manager: None, #[cfg(feature = "shared-memory")] @@ -166,7 +163,7 @@ impl RuntimeBuilder { // Admin space creation flag let start_admin_space = *config.adminspace.enabled(); - let config = Notifier::new(config); + let config = Notifier::new(crate::config::Config(config)); let runtime = Runtime { state: Arc::new(RuntimeState { zid: zid.into(), diff --git a/zenoh/src/net/runtime/orchestrator.rs b/zenoh/src/net/runtime/orchestrator.rs index 6bff4e75be..979a84fa03 100644 --- a/zenoh/src/net/runtime/orchestrator.rs +++ b/zenoh/src/net/runtime/orchestrator.rs @@ -127,7 +127,7 @@ impl Runtime { async fn start_client(&self) -> ZResult<()> { let (peers, scouting, addr, ifaces, timeout, multicast_ttl) = { - let guard = self.state.config.lock(); + let guard = &self.state.config.lock().0; ( guard .connect() @@ -171,7 +171,7 @@ impl Runtime { async fn start_peer(&self) -> ZResult<()> { let (listeners, peers, scouting, listen, autoconnect, addr, ifaces, delay, linkstate) = { - let guard = &self.state.config.lock(); + let guard = &self.state.config.lock().0; ( guard.listen().endpoints().peer().unwrap_or(&vec![]).clone(), guard @@ -213,7 +213,7 @@ impl Runtime { async fn start_router(&self) -> ZResult<()> { let (listeners, peers, scouting, listen, autoconnect, addr, ifaces, delay) = { - let guard = self.state.config.lock(); + let guard = &self.state.config.lock().0; ( guard .listen() @@ -256,8 +256,9 @@ impl Runtime { ifaces: String, ) -> ZResult<()> { let multicast_ttl = { - let guard = self.state.config.lock(); - unwrap_or_default!(guard.scouting().multicast().ttl()) + let config_guard = self.config().lock(); + let config = &config_guard.0; + unwrap_or_default!(config.scouting().multicast().ttl()) }; let ifaces = Runtime::get_interfaces(&ifaces); let mcast_socket = Runtime::bind_mcast_port(&addr, &ifaces, multicast_ttl).await?; @@ -408,6 +409,7 @@ impl Runtime { self.state .config .lock() + .0 .connect() .endpoints() .get(self.state.whatami) @@ -462,27 +464,27 @@ impl Runtime { } fn get_listen_retry_config(&self, endpoint: &EndPoint) -> zenoh_config::ConnectionRetryConf { - let guard = &self.state.config.lock(); + let guard = &self.state.config.lock().0; zenoh_config::get_retry_config(guard, Some(endpoint), true) } fn get_connect_retry_config(&self, endpoint: &EndPoint) -> zenoh_config::ConnectionRetryConf { - let guard = &self.state.config.lock(); + let guard = &self.state.config.lock().0; zenoh_config::get_retry_config(guard, Some(endpoint), false) } fn get_global_connect_retry_config(&self) -> zenoh_config::ConnectionRetryConf { - let guard = &self.state.config.lock(); + let guard = &self.state.config.lock().0; zenoh_config::get_retry_config(guard, None, false) } fn get_global_listener_timeout(&self) -> std::time::Duration { - let guard = &self.state.config.lock(); + let guard = &self.state.config.lock().0; get_global_listener_timeout(guard) } fn get_global_connect_timeout(&self) -> std::time::Duration { - let guard = &self.state.config.lock(); + let guard = &self.state.config.lock().0; get_global_connect_timeout(guard) } @@ -746,9 +748,10 @@ impl Runtime { { let this = self.clone(); let idx = self.state.start_conditions.add_peer_connector().await; - let config = this.config().lock(); + let config_guard = this.config().lock(); + let config = &config_guard.0; let gossip = unwrap_or_default!(config.scouting().gossip().enabled()); - drop(config); + drop(config_guard); self.spawn(async move { if let Ok(zid) = this.peer_connector_retry(peer).await { this.state @@ -919,6 +922,7 @@ impl Runtime { .state .config .lock() + .0 .connect() .endpoints() .get(self.whatami()) @@ -1180,6 +1184,7 @@ impl Runtime { .state .config .lock() + .0 .connect() .endpoints() .get(session.runtime.state.whatami) diff --git a/zenoh/tests/acl.rs b/zenoh/tests/acl.rs index 285e68b254..618b9dde96 100644 --- a/zenoh/tests/acl.rs +++ b/zenoh/tests/acl.rs @@ -11,6 +11,8 @@ // Contributors: // ZettaScale Zenoh Team, // + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] #![cfg(target_family = "unix")] mod test { use std::{ @@ -19,12 +21,8 @@ mod test { }; use tokio::runtime::Handle; - use zenoh::{ - config, - config::{EndPoint, WhatAmI}, - sample::SampleKind, - Config, Session, - }; + use zenoh::{config::WhatAmI, sample::SampleKind, Config, Session}; + use zenoh_config::{EndPoint, ModeDependentValue}; use zenoh_core::{zlock, ztimeout}; const TIMEOUT: Duration = Duration::from_secs(60); @@ -59,7 +57,7 @@ mod test { } async fn get_basic_router_config(port: u16) -> Config { - let mut config = config::default(); + let mut config = Config::default(); config.set_mode(Some(WhatAmI::Router)).unwrap(); config .listen @@ -77,9 +75,29 @@ mod test { async fn get_client_sessions(port: u16) -> (Session, Session) { println!("Opening client sessions"); - let config = config::client([format!("tcp/127.0.0.1:{port}").parse::().unwrap()]); + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "tcp/127.0.0.1:{port}" + ) + .parse::() + .unwrap()])) + .unwrap(); + let s01 = ztimeout!(zenoh::open(config)).unwrap(); - let config = config::client([format!("tcp/127.0.0.1:{port}").parse::().unwrap()]); + + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "tcp/127.0.0.1:{port}" + ) + .parse::() + .unwrap()])) + .unwrap(); let s02 = ztimeout!(zenoh::open(config)).unwrap(); (s01, s02) } diff --git a/zenoh/tests/authentication.rs b/zenoh/tests/authentication.rs index 63ddfcc03c..a70c9d773a 100644 --- a/zenoh/tests/authentication.rs +++ b/zenoh/tests/authentication.rs @@ -11,6 +11,9 @@ // Contributors: // ZettaScale Zenoh Team, // + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] + mod test { use std::{ fs, @@ -21,11 +24,8 @@ mod test { use once_cell::sync::Lazy; use tokio::runtime::Handle; - use zenoh::{ - config, - config::{EndPoint, WhatAmI}, - Config, Session, - }; + use zenoh::{config::WhatAmI, Config, Session}; + use zenoh_config::{EndPoint, ModeDependentValue}; use zenoh_core::{zlock, ztimeout}; const TIMEOUT: Duration = Duration::from_secs(60); @@ -270,7 +270,7 @@ client2name:client2passwd"; async fn get_basic_router_config_tls(port: u16, lowlatency: bool) -> Config { let cert_path = TESTFILES_PATH.to_string_lossy(); - let mut config = config::default(); + let mut config = zenoh::Config::default(); config.set_mode(Some(WhatAmI::Router)).unwrap(); config .listen @@ -323,7 +323,7 @@ client2name:client2passwd"; } async fn get_basic_router_config_quic(port: u16) -> Config { let cert_path = TESTFILES_PATH.to_string_lossy(); - let mut config = config::default(); + let mut config = zenoh::Config::default(); config.set_mode(Some(WhatAmI::Router)).unwrap(); config .listen @@ -369,7 +369,7 @@ client2name:client2passwd"; } async fn get_basic_router_config_usrpswd(port: u16) -> Config { - let mut config = config::default(); + let mut config = zenoh::Config::default(); config.set_mode(Some(WhatAmI::Router)).unwrap(); config .listen @@ -408,7 +408,7 @@ client2name:client2passwd"; async fn get_basic_router_config_quic_usrpswd(port: u16) -> Config { let cert_path = TESTFILES_PATH.to_string_lossy(); - let mut config = config::default(); + let mut config = zenoh::Config::default(); config.set_mode(Some(WhatAmI::Router)).unwrap(); config .listen @@ -474,9 +474,16 @@ client2name:client2passwd"; async fn get_client_sessions_tls(port: u16, lowlatency: bool) -> (Session, Session) { let cert_path = TESTFILES_PATH.to_string_lossy(); println!("Opening client sessions"); - let mut config = config::client([format!("tls/127.0.0.1:{}", port) + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "tls/127.0.0.1:{port}" + ) .parse::() - .unwrap()]); + .unwrap()])) + .unwrap(); config .insert_json5( "transport", @@ -520,9 +527,16 @@ client2name:client2passwd"; .unwrap(); let s01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::client([format!("tls/127.0.0.1:{}", port) + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "tls/127.0.0.1:{port}" + ) .parse::() - .unwrap()]); + .unwrap()])) + .unwrap(); config .insert_json5( "transport", @@ -571,9 +585,16 @@ client2name:client2passwd"; async fn get_client_sessions_quic(port: u16) -> (Session, Session) { let cert_path = TESTFILES_PATH.to_string_lossy(); println!("Opening client sessions"); - let mut config = config::client([format!("quic/127.0.0.1:{}", port) + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "quic/127.0.0.1:{port}" + ) .parse::() - .unwrap()]); + .unwrap()])) + .unwrap(); config .insert_json5( "transport", @@ -609,9 +630,16 @@ client2name:client2passwd"; .set_root_ca_certificate(Some(format!("{}/ca.pem", cert_path))) .unwrap(); let s01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::client([format!("quic/127.0.0.1:{}", port) + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "quic/127.0.0.1:{port}" + ) .parse::() - .unwrap()]); + .unwrap()])) + .unwrap(); config .insert_json5( "transport", @@ -652,8 +680,16 @@ client2name:client2passwd"; async fn get_client_sessions_usrpswd(port: u16) -> (Session, Session) { println!("Opening client sessions"); - let mut config = - config::client([format!("tcp/127.0.0.1:{port}").parse::().unwrap()]); + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "tcp/127.0.0.1:{port}" + ) + .parse::() + .unwrap()])) + .unwrap(); config .insert_json5( "transport", @@ -668,8 +704,16 @@ client2name:client2passwd"; ) .unwrap(); let s01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = - config::client([format!("tcp/127.0.0.1:{port}").parse::().unwrap()]); + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "tcp/127.0.0.1:{port}" + ) + .parse::() + .unwrap()])) + .unwrap(); config .insert_json5( "transport", @@ -690,9 +734,16 @@ client2name:client2passwd"; async fn get_client_sessions_quic_usrpswd(port: u16) -> (Session, Session) { let cert_path = TESTFILES_PATH.to_string_lossy(); println!("Opening client sessions"); - let mut config = config::client([format!("quic/127.0.0.1:{port}") + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "quic/127.0.0.1:{port}" + ) .parse::() - .unwrap()]); + .unwrap()])) + .unwrap(); config .insert_json5( "transport", @@ -735,9 +786,16 @@ client2name:client2passwd"; .unwrap(); let s01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::client([format!("quic/127.0.0.1:{}", port) + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec![format!( + "quic/127.0.0.1:{port}" + ) .parse::() - .unwrap()]); + .unwrap()])) + .unwrap(); config .insert_json5( "transport", diff --git a/zenoh/tests/connection_retry.rs b/zenoh/tests/connection_retry.rs index 6bb655851b..2252a62322 100644 --- a/zenoh/tests/connection_retry.rs +++ b/zenoh/tests/connection_retry.rs @@ -11,10 +11,11 @@ // Contributors: // ZettaScale Zenoh Team, // -use zenoh::{ - config::{ConnectionRetryConf, EndPoint, ModeDependent}, - Config, Wait, -}; + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] + +use zenoh::{Config, Wait}; +use zenoh_config::{ConnectionRetryConf, EndPoint, ModeDependent}; #[test] fn retry_config_overriding() { @@ -157,7 +158,7 @@ fn retry_config_infinite_period() { .unwrap(); let endpoint: EndPoint = "tcp/[::]:0".parse().unwrap(); - let retry_config = zenoh_config::get_retry_config(&config, Some(&endpoint), true); + let retry_config = &config.get_retry_config(Some(&endpoint), true); let mut period = retry_config.period(); diff --git a/zenoh/tests/events.rs b/zenoh/tests/events.rs index e3a4d61656..6354346da7 100644 --- a/zenoh/tests/events.rs +++ b/zenoh/tests/events.rs @@ -11,15 +11,18 @@ // Contributors: // ZettaScale Zenoh Team, // + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] + use std::time::Duration; -use zenoh::{config, query::Reply, sample::SampleKind, Session}; +use zenoh::{query::Reply, sample::SampleKind, Session}; use zenoh_core::ztimeout; const TIMEOUT: Duration = Duration::from_secs(10); async fn open_session(listen: &[&str], connect: &[&str]) -> Session { - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints diff --git a/zenoh/tests/interceptors.rs b/zenoh/tests/interceptors.rs index 57ba51d5ba..57d47e2890 100644 --- a/zenoh/tests/interceptors.rs +++ b/zenoh/tests/interceptors.rs @@ -11,6 +11,8 @@ // Contributors: // ZettaScale Zenoh Team, // + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] #![cfg(unix)] use std::{ @@ -21,11 +23,8 @@ use std::{ }, }; -use zenoh::{ - config::{DownsamplingItemConf, DownsamplingRuleConf, InterceptorFlow}, - key_expr::KeyExpr, - Config, Wait, -}; +use zenoh::{key_expr::KeyExpr, Config, Wait}; +use zenoh_config::{DownsamplingItemConf, DownsamplingRuleConf, InterceptorFlow}; // Tokio's time granularity on different platforms #[cfg(target_os = "windows")] diff --git a/zenoh/tests/liveliness.rs b/zenoh/tests/liveliness.rs index df19865ce7..14b5f33206 100644 --- a/zenoh/tests/liveliness.rs +++ b/zenoh/tests/liveliness.rs @@ -19,9 +19,8 @@ use zenoh_core::ztimeout; async fn test_liveliness_subscriber_clique() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; - use zenoh_config::WhatAmI; - use zenoh_link::EndPoint; + use zenoh::{config::WhatAmI, sample::SampleKind}; + use zenoh_config::EndPoint; const TIMEOUT: Duration = Duration::from_secs(60); const SLEEP: Duration = Duration::from_secs(1); const PEER1_ENDPOINT: &str = "tcp/localhost:47447"; @@ -30,10 +29,10 @@ async fn test_liveliness_subscriber_clique() { zenoh_util::init_log_from_env_or("error"); let peer1 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints - .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) + .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) .unwrap(); c.scouting.multicast.set_enabled(Some(false)).unwrap(); let _ = c.set_mode(Some(WhatAmI::Peer)); @@ -43,7 +42,7 @@ async fn test_liveliness_subscriber_clique() { }; let peer2 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) @@ -83,7 +82,7 @@ async fn test_liveliness_subscriber_clique() { async fn test_liveliness_query_clique() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; const TIMEOUT: Duration = Duration::from_secs(60); @@ -94,7 +93,7 @@ async fn test_liveliness_query_clique() { zenoh_util::init_log_from_env_or("error"); let peer1 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) @@ -107,7 +106,7 @@ async fn test_liveliness_query_clique() { }; let peer2 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER1_ENDPOINT.parse::().unwrap()]) @@ -140,7 +139,7 @@ async fn test_liveliness_query_clique() { async fn test_liveliness_subscriber_brokered() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -152,7 +151,7 @@ async fn test_liveliness_subscriber_brokered() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -165,7 +164,7 @@ async fn test_liveliness_subscriber_brokered() { }; let client1 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -178,7 +177,7 @@ async fn test_liveliness_subscriber_brokered() { }; let client2 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -219,7 +218,7 @@ async fn test_liveliness_subscriber_brokered() { async fn test_liveliness_query_brokered() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; const TIMEOUT: Duration = Duration::from_secs(60); @@ -230,7 +229,7 @@ async fn test_liveliness_query_brokered() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -243,7 +242,7 @@ async fn test_liveliness_query_brokered() { }; let client1 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -256,7 +255,7 @@ async fn test_liveliness_query_brokered() { }; let client2 = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -290,7 +289,7 @@ async fn test_liveliness_query_brokered() { async fn test_liveliness_subscriber_local() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; const TIMEOUT: Duration = Duration::from_secs(60); const SLEEP: Duration = Duration::from_secs(1); @@ -299,7 +298,7 @@ async fn test_liveliness_subscriber_local() { zenoh_util::init_log_from_env_or("error"); let peer = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.scouting.multicast.set_enabled(Some(false)).unwrap(); let _ = c.set_mode(Some(WhatAmI::Peer)); let s = ztimeout!(zenoh::open(c)).unwrap(); @@ -333,8 +332,7 @@ async fn test_liveliness_subscriber_local() { async fn test_liveliness_query_local() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; - use zenoh_config::WhatAmI; + use zenoh::{config::WhatAmI, sample::SampleKind}; const TIMEOUT: Duration = Duration::from_secs(60); const SLEEP: Duration = Duration::from_secs(1); const LIVELINESS_KEYEXPR: &str = "test/liveliness/query/local"; @@ -342,7 +340,7 @@ async fn test_liveliness_query_local() { zenoh_util::init_log_from_env_or("error"); let peer = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.scouting.multicast.set_enabled(Some(false)).unwrap(); let _ = c.set_mode(Some(WhatAmI::Peer)); let s = ztimeout!(zenoh::open(c)).unwrap(); diff --git a/zenoh/tests/matching.rs b/zenoh/tests/matching.rs index d7825e85b8..efa377863d 100644 --- a/zenoh/tests/matching.rs +++ b/zenoh/tests/matching.rs @@ -12,10 +12,12 @@ // ZettaScale Zenoh Team, // #![cfg(feature = "unstable")] -use std::{str::FromStr, time::Duration}; + +use std::time::Duration; use flume::RecvTimeoutError; -use zenoh::{config, config::Locator, sample::Locality, Result as ZResult, Session}; +use zenoh::{sample::Locality, Result as ZResult, Session}; +use zenoh_config::{ModeDependentValue, WhatAmI}; use zenoh_core::ztimeout; const TIMEOUT: Duration = Duration::from_secs(60); @@ -23,7 +25,7 @@ const RECV_TIMEOUT: Duration = Duration::from_secs(1); async fn create_session_pair(locator: &str) -> (Session, Session) { let config1 = { - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config.scouting.multicast.set_enabled(Some(false)).unwrap(); config .listen @@ -32,7 +34,12 @@ async fn create_session_pair(locator: &str) -> (Session, Session) { .unwrap(); config }; - let config2 = config::client([Locator::from_str(locator).unwrap()]); + let mut config2 = zenoh::Config::default(); + config2.set_mode(Some(WhatAmI::Client)).unwrap(); + config2 + .connect + .set_endpoints(ModeDependentValue::Unique(vec![locator.parse().unwrap()])) + .unwrap(); let session1 = ztimeout!(zenoh::open(config1)).unwrap(); let session2 = ztimeout!(zenoh::open(config2)).unwrap(); @@ -95,8 +102,8 @@ async fn zenoh_matching_status_any() -> ZResult<()> { async fn zenoh_matching_status_remote() -> ZResult<()> { zenoh_util::init_log_from_env_or("error"); - let session1 = ztimeout!(zenoh::open(config::peer())).unwrap(); - let session2 = ztimeout!(zenoh::open(config::peer())).unwrap(); + let session1 = ztimeout!(zenoh::open(zenoh::Config::default())).unwrap(); + let session2 = ztimeout!(zenoh::open(zenoh::Config::default())).unwrap(); let publisher1 = ztimeout!(session1 .declare_publisher("zenoh_matching_status_remote_test") @@ -150,8 +157,8 @@ async fn zenoh_matching_status_remote() -> ZResult<()> { async fn zenoh_matching_status_local() -> ZResult<()> { zenoh_util::init_log_from_env_or("error"); - let session1 = ztimeout!(zenoh::open(zenoh::config::peer())).unwrap(); - let session2 = ztimeout!(zenoh::open(zenoh::config::peer())).unwrap(); + let session1 = ztimeout!(zenoh::open(zenoh::Config::default())).unwrap(); + let session2 = ztimeout!(zenoh::open(zenoh::Config::default())).unwrap(); let publisher1 = ztimeout!(session1 .declare_publisher("zenoh_matching_status_local_test") diff --git a/zenoh/tests/open_time.rs b/zenoh/tests/open_time.rs index 98714c39c5..1ce68a300a 100644 --- a/zenoh/tests/open_time.rs +++ b/zenoh/tests/open_time.rs @@ -11,6 +11,8 @@ // Contributors: // ZettaScale Zenoh Team, // + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] #![allow(unused)] use std::{ future::IntoFuture, @@ -37,7 +39,7 @@ async fn time_open( lowlatency: bool, ) { /* [ROUTER] */ - let mut router_config = Config::default(); + let mut router_config = zenoh::Config::default(); router_config.set_mode(Some(WhatAmI::Router)).unwrap(); router_config .listen @@ -67,7 +69,7 @@ async fn time_open( ); /* [APP] */ - let mut app_config = Config::default(); + let mut app_config = zenoh::Config::default(); app_config.set_mode(Some(connect_mode)).unwrap(); app_config .connect diff --git a/zenoh/tests/qos.rs b/zenoh/tests/qos.rs index 2ba3226310..4995d05e70 100644 --- a/zenoh/tests/qos.rs +++ b/zenoh/tests/qos.rs @@ -24,8 +24,8 @@ const SLEEP: Duration = Duration::from_secs(1); #[tokio::test(flavor = "multi_thread", worker_threads = 4)] async fn qos_pubsub() { - let session1 = ztimeout!(zenoh::open(zenoh_config::peer())).unwrap(); - let session2 = ztimeout!(zenoh::open(zenoh_config::peer())).unwrap(); + let session1 = ztimeout!(zenoh::open(zenoh::Config::default())).unwrap(); + let session2 = ztimeout!(zenoh::open(zenoh::Config::default())).unwrap(); let publisher1 = ztimeout!(session1 .declare_publisher("test/qos") diff --git a/zenoh/tests/routing.rs b/zenoh/tests/routing.rs index e9c8fd899f..12ec0a52fc 100644 --- a/zenoh/tests/routing.rs +++ b/zenoh/tests/routing.rs @@ -11,6 +11,9 @@ // Contributors: // ZettaScale Zenoh Team, // + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] + use std::{ sync::{ atomic::{AtomicUsize, Ordering}, @@ -20,11 +23,8 @@ use std::{ }; use tokio_util::sync::CancellationToken; -use zenoh::{ - config::{ModeDependentValue, WhatAmI, WhatAmIMatcher}, - qos::CongestionControl, - Config, Result, Session, -}; +use zenoh::{config::WhatAmI, qos::CongestionControl, Config, Result, Session}; +use zenoh_config::{ModeDependentValue, WhatAmIMatcher}; use zenoh_core::ztimeout; use zenoh_result::bail; diff --git a/zenoh/tests/session.rs b/zenoh/tests/session.rs index 04f3bde4f9..36efe42d8d 100644 --- a/zenoh/tests/session.rs +++ b/zenoh/tests/session.rs @@ -11,6 +11,9 @@ // Contributors: // ZettaScale Zenoh Team, // + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] + use std::{ sync::{ atomic::{AtomicUsize, Ordering}, @@ -23,7 +26,7 @@ use std::{ use zenoh::internal::runtime::{Runtime, RuntimeBuilder}; #[cfg(feature = "unstable")] use zenoh::pubsub::Reliability; -use zenoh::{config, key_expr::KeyExpr, qos::CongestionControl, sample::SampleKind, Session}; +use zenoh::{key_expr::KeyExpr, qos::CongestionControl, sample::SampleKind, Session}; use zenoh_core::ztimeout; #[cfg(not(feature = "unstable"))] use zenoh_protocol::core::Reliability; @@ -36,7 +39,7 @@ const MSG_SIZE: [usize; 2] = [1_024, 100_000]; async fn open_session_unicast(endpoints: &[&str]) -> (Session, Session) { // Open the sessions - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints @@ -51,7 +54,7 @@ async fn open_session_unicast(endpoints: &[&str]) -> (Session, Session) { println!("[ ][01a] Opening peer01 session: {:?}", endpoints); let peer01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .connect .endpoints @@ -71,7 +74,7 @@ async fn open_session_unicast(endpoints: &[&str]) -> (Session, Session) { async fn open_session_multicast(endpoint01: &str, endpoint02: &str) -> (Session, Session) { // Open the sessions - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints @@ -81,7 +84,7 @@ async fn open_session_multicast(endpoint01: &str, endpoint02: &str) -> (Session, println!("[ ][01a] Opening peer01 session: {}", endpoint01); let peer01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints @@ -286,7 +289,7 @@ async fn zenoh_session_multicast() { #[cfg(feature = "internal")] async fn open_session_unicast_runtime(endpoints: &[&str]) -> (Runtime, Runtime) { // Open the sessions - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints @@ -302,7 +305,7 @@ async fn open_session_unicast_runtime(endpoints: &[&str]) -> (Runtime, Runtime) let mut r1 = RuntimeBuilder::new(config).build().await.unwrap(); r1.start().await.unwrap(); - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .connect .endpoints diff --git a/zenoh/tests/shm.rs b/zenoh/tests/shm.rs index 8e1205f711..ace7a0ce49 100644 --- a/zenoh/tests/shm.rs +++ b/zenoh/tests/shm.rs @@ -21,7 +21,6 @@ use std::{ }; use zenoh::{ - config, pubsub::Reliability, qos::CongestionControl, shm::{ @@ -40,7 +39,7 @@ const MSG_SIZE: [usize; 2] = [1_024, 100_000]; async fn open_session_unicast(endpoints: &[&str]) -> (Session, Session) { // Open the sessions - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints @@ -55,7 +54,7 @@ async fn open_session_unicast(endpoints: &[&str]) -> (Session, Session) { println!("[ ][01a] Opening peer01 session: {:?}", endpoints); let peer01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .connect .endpoints @@ -75,7 +74,7 @@ async fn open_session_unicast(endpoints: &[&str]) -> (Session, Session) { async fn open_session_multicast(endpoint01: &str, endpoint02: &str) -> (Session, Session) { // Open the sessions - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints @@ -85,7 +84,7 @@ async fn open_session_multicast(endpoint01: &str, endpoint02: &str) -> (Session, println!("[ ][01a] Opening peer01 session: {}", endpoint01); let peer01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints diff --git a/zenoh/tests/unicity.rs b/zenoh/tests/unicity.rs index de63b0a97e..7a984d5564 100644 --- a/zenoh/tests/unicity.rs +++ b/zenoh/tests/unicity.rs @@ -11,6 +11,9 @@ // Contributors: // ZettaScale Zenoh Team, // + +#![cfg(any(feature = "unstable", feature = "unstable_config"))] + use std::{ sync::{ atomic::{AtomicUsize, Ordering}, @@ -20,13 +23,8 @@ use std::{ }; use tokio::runtime::Handle; -use zenoh::{ - config, - config::{EndPoint, WhatAmI}, - key_expr::KeyExpr, - qos::CongestionControl, - Session, -}; +use zenoh::{config::WhatAmI, key_expr::KeyExpr, qos::CongestionControl, Session}; +use zenoh_config::{EndPoint, ModeDependentValue}; use zenoh_core::ztimeout; const TIMEOUT: Duration = Duration::from_secs(60); @@ -36,7 +34,7 @@ const MSG_SIZE: [usize; 2] = [1_024, 100_000]; async fn open_p2p_sessions() -> (Session, Session, Session) { // Open the sessions - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints @@ -46,7 +44,7 @@ async fn open_p2p_sessions() -> (Session, Session, Session) { println!("[ ][01a] Opening s01 session"); let s01 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .listen .endpoints @@ -61,7 +59,7 @@ async fn open_p2p_sessions() -> (Session, Session, Session) { println!("[ ][02a] Opening s02 session"); let s02 = ztimeout!(zenoh::open(config)).unwrap(); - let mut config = config::peer(); + let mut config = zenoh::Config::default(); config .connect .endpoints @@ -79,7 +77,7 @@ async fn open_p2p_sessions() -> (Session, Session, Session) { async fn open_router_session() -> Session { // Open the sessions - let mut config = config::default(); + let mut config = zenoh::Config::default(); config.set_mode(Some(WhatAmI::Router)).unwrap(); config .listen @@ -98,15 +96,36 @@ async fn close_router_session(s: Session) { async fn open_client_sessions() -> (Session, Session, Session) { // Open the sessions - let config = config::client(["tcp/127.0.0.1:37447".parse::().unwrap()]); + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec!["tcp/127.0.0.1:37447" + .parse::() + .unwrap()])) + .unwrap(); println!("[ ][01a] Opening s01 session"); let s01 = ztimeout!(zenoh::open(config)).unwrap(); - let config = config::client(["tcp/127.0.0.1:37447".parse::().unwrap()]); + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec!["tcp/127.0.0.1:37447" + .parse::() + .unwrap()])) + .unwrap(); println!("[ ][02a] Opening s02 session"); let s02 = ztimeout!(zenoh::open(config)).unwrap(); - let config = config::client(["tcp/127.0.0.1:37447".parse::().unwrap()]); + let mut config = zenoh::Config::default(); + config.set_mode(Some(WhatAmI::Client)).unwrap(); + config + .connect + .set_endpoints(ModeDependentValue::Unique(vec!["tcp/127.0.0.1:37447" + .parse::() + .unwrap()])) + .unwrap(); println!("[ ][03a] Opening s03 session"); let s03 = ztimeout!(zenoh::open(config)).unwrap(); diff --git a/zenohd/Cargo.toml b/zenohd/Cargo.toml index b0320ce648..9347c7f8ee 100644 --- a/zenohd/Cargo.toml +++ b/zenohd/Cargo.toml @@ -43,6 +43,7 @@ tracing-subscriber = {workspace = true} tracing-loki = {workspace = true, optional = true } url = {workspace = true, optional = true } zenoh = { workspace = true, features = ["unstable", "internal", "plugins"] } +zenoh-config = { workspace = true } [dev-dependencies] rand = { workspace = true, features = ["default"] } diff --git a/zenohd/src/main.rs b/zenohd/src/main.rs index 85a063e3a2..e618b6f3db 100644 --- a/zenohd/src/main.rs +++ b/zenohd/src/main.rs @@ -17,10 +17,8 @@ use git_version::git_version; use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt, EnvFilter}; #[cfg(feature = "loki")] use url::Url; -use zenoh::{ - config::{Config, EndPoint, ModeDependentValue, PermissionsConf, WhatAmI}, - Result, -}; +use zenoh::{config::WhatAmI, Config, Result}; +use zenoh_config::{EndPoint, ModeDependentValue, PermissionsConf}; use zenoh_util::LibSearchDirs; #[cfg(feature = "loki")] From 3258131b2c5e005717b516e053161969416923bf Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Mon, 16 Sep 2024 17:54:32 +0200 Subject: [PATCH 02/15] Auto-enable `unstable_config` if `unstable` is enabled --- commons/zenoh-macros/src/lib.rs | 3 +-- zenoh/Cargo.toml | 2 +- zenoh/tests/acl.rs | 2 +- zenoh/tests/authentication.rs | 2 +- zenoh/tests/connection_retry.rs | 2 +- zenoh/tests/events.rs | 2 +- zenoh/tests/interceptors.rs | 2 +- zenoh/tests/open_time.rs | 2 +- zenoh/tests/routing.rs | 2 +- zenoh/tests/session.rs | 2 +- zenoh/tests/unicity.rs | 2 +- 11 files changed, 11 insertions(+), 12 deletions(-) diff --git a/commons/zenoh-macros/src/lib.rs b/commons/zenoh-macros/src/lib.rs index da007e1f18..87b6f67374 100644 --- a/commons/zenoh-macros/src/lib.rs +++ b/commons/zenoh-macros/src/lib.rs @@ -195,8 +195,7 @@ pub fn unstable_config(args: TokenStream, tokens: TokenStream) -> TokenStream { Err(err) => return err.into_compile_error().into(), }; - let feature_gate: Attribute = - parse_quote!(#[cfg(any(feature = "unstable", feature = "unstable_config"))]); + let feature_gate: Attribute = parse_quote!(#[cfg(feature = "unstable_config")]); attrs.push(feature_gate); TokenStream::from(item.to_token_stream()) diff --git a/zenoh/Cargo.toml b/zenoh/Cargo.toml index 1d557b8530..810689a993 100644 --- a/zenoh/Cargo.toml +++ b/zenoh/Cargo.toml @@ -63,7 +63,7 @@ transport_udp = ["zenoh-transport/transport_udp"] transport_unixsock-stream = ["zenoh-transport/transport_unixsock-stream"] transport_ws = ["zenoh-transport/transport_ws"] transport_vsock = ["zenoh-transport/transport_vsock"] -unstable = ["zenoh-keyexpr/unstable"] +unstable = ["unstable_config", "zenoh-keyexpr/unstable"] unstable_config = [] [dependencies] diff --git a/zenoh/tests/acl.rs b/zenoh/tests/acl.rs index 618b9dde96..b3ba4240db 100644 --- a/zenoh/tests/acl.rs +++ b/zenoh/tests/acl.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] #![cfg(target_family = "unix")] mod test { use std::{ diff --git a/zenoh/tests/authentication.rs b/zenoh/tests/authentication.rs index a70c9d773a..f2a3339084 100644 --- a/zenoh/tests/authentication.rs +++ b/zenoh/tests/authentication.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] mod test { use std::{ diff --git a/zenoh/tests/connection_retry.rs b/zenoh/tests/connection_retry.rs index 2252a62322..071194452e 100644 --- a/zenoh/tests/connection_retry.rs +++ b/zenoh/tests/connection_retry.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] use zenoh::{Config, Wait}; use zenoh_config::{ConnectionRetryConf, EndPoint, ModeDependent}; diff --git a/zenoh/tests/events.rs b/zenoh/tests/events.rs index 6354346da7..fcd7872599 100644 --- a/zenoh/tests/events.rs +++ b/zenoh/tests/events.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] use std::time::Duration; diff --git a/zenoh/tests/interceptors.rs b/zenoh/tests/interceptors.rs index 57d47e2890..1040ba915c 100644 --- a/zenoh/tests/interceptors.rs +++ b/zenoh/tests/interceptors.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] #![cfg(unix)] use std::{ diff --git a/zenoh/tests/open_time.rs b/zenoh/tests/open_time.rs index 1ce68a300a..83802d8ea1 100644 --- a/zenoh/tests/open_time.rs +++ b/zenoh/tests/open_time.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] #![allow(unused)] use std::{ future::IntoFuture, diff --git a/zenoh/tests/routing.rs b/zenoh/tests/routing.rs index 12ec0a52fc..79b122784f 100644 --- a/zenoh/tests/routing.rs +++ b/zenoh/tests/routing.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] use std::{ sync::{ diff --git a/zenoh/tests/session.rs b/zenoh/tests/session.rs index 36efe42d8d..4c8d227a70 100644 --- a/zenoh/tests/session.rs +++ b/zenoh/tests/session.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] use std::{ sync::{ diff --git a/zenoh/tests/unicity.rs b/zenoh/tests/unicity.rs index 7a984d5564..df582315d2 100644 --- a/zenoh/tests/unicity.rs +++ b/zenoh/tests/unicity.rs @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // -#![cfg(any(feature = "unstable", feature = "unstable_config"))] +#![cfg(feature = "unstable_config")] use std::{ sync::{ From 5101f1a6914dbbc7f0f1519ace3f74e92b546d81 Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Mon, 16 Sep 2024 18:01:36 +0200 Subject: [PATCH 03/15] Mark questionable API items as `unstable` --- zenoh/src/api/config.rs | 5 +++++ zenoh/src/api/session.rs | 4 ++-- zenoh/src/lib.rs | 5 ++++- 3 files changed, 11 insertions(+), 3 deletions(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index ddbd33ccc2..0777253520 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -38,11 +38,13 @@ impl Config { .map_err(InsertionError) } + #[zenoh_macros::unstable] pub fn get<'a>(&'a self, key: &str) -> Result<&'a dyn Any, LookupError> { ::get(&self.0, key) .map_err(LookupError) } + #[zenoh_macros::unstable] pub fn remove>(&mut self, key: K) -> ZResult<()> { self.0.remove(key) } @@ -98,9 +100,11 @@ struct NotifierInner { inner: Mutex, subscribers: Mutex>>, } + pub struct Notifier { inner: Arc>, } + impl Clone for Notifier { fn clone(&self) -> Self { Self { @@ -108,6 +112,7 @@ impl Clone for Notifier { } } } + impl Notifier { pub fn new(inner: Config) -> Self { Notifier { diff --git a/zenoh/src/api/session.rs b/zenoh/src/api/session.rs index d6b04343c2..8b3685898c 100644 --- a/zenoh/src/api/session.rs +++ b/zenoh/src/api/session.rs @@ -77,7 +77,6 @@ use super::{ SessionPutBuilder, }, bytes::ZBytes, - config::Notifier, encoding::Encoding, handlers::{Callback, DefaultHandler}, info::SessionInfo, @@ -654,7 +653,8 @@ impl Session { /// let _ = session.config().insert_json5("connect/endpoints", r#"["tcp/127.0.0.1/7447"]"#); /// # } /// ``` - pub fn config(&self) -> &Notifier { + #[zenoh_macros::unstable] + pub fn config(&self) -> &crate::config::Notifier { self.0.runtime.config() } diff --git a/zenoh/src/lib.rs b/zenoh/src/lib.rs index 00b899dab5..4072f229b5 100644 --- a/zenoh/src/lib.rs +++ b/zenoh/src/lib.rs @@ -353,7 +353,10 @@ pub mod time { pub mod config { pub use zenoh_config::{WhatAmI, WhatAmIMatcher}; - pub use crate::api::config::{Config, InsertionError, LookupError, LookupGuard, Notifier}; + pub use crate::api::config::{Config, InsertionError}; + + #[zenoh_macros::unstable] + pub use crate::api::config::{LookupError, LookupGuard, Notifier}; } #[cfg(all( From f1588365182f81a35787e4d638d7bcba2638d0bb Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 07:45:22 +0000 Subject: [PATCH 04/15] Add (De)Serialize impls --- zenoh/src/api/config.rs | 18 +++++++++++++++--- zenoh/src/lib.rs | 1 - zenoh/src/net/runtime/mod.rs | 5 ++++- 3 files changed, 19 insertions(+), 5 deletions(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index 0777253520..3d2ac45780 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -7,6 +7,7 @@ use std::{ sync::{Arc, Mutex, MutexGuard}, }; +use serde::{Deserialize, Serialize}; use zenoh_result::ZResult; /// Zenoh configuration. @@ -17,7 +18,7 @@ use zenoh_result::ZResult; /// To construct a configuration, we advise that you use a configuration file (JSON, JSON5 and YAML /// are currently supported, please use the proper extension for your format as the deserializer /// will be picked according to it). -#[derive(Default, Debug, Clone)] +#[derive(Default, Debug, Clone, Serialize, Deserialize)] pub struct Config(pub(crate) zenoh_config::Config); impl Config { @@ -48,6 +49,16 @@ impl Config { pub fn remove>(&mut self, key: K) -> ZResult<()> { self.0.remove(key) } + + #[zenoh_macros::unstable] + pub fn from_deserializer<'d, D: serde::Deserializer<'d>>( + d: D, + ) -> Result> + where + Self: serde::Deserialize<'d>, + { + Ok(Config(zenoh_config::Config::from_deserializer(d)?)) + } } #[derive(Debug)] @@ -165,7 +176,7 @@ impl Notifier { } pub fn remove>(&self, key: K) -> ZResult<()> { - self.lock_config().remove(key.as_ref())?; + self.lock_config().0.remove(key.as_ref())?; self.notify(key); Ok(()) } @@ -174,10 +185,11 @@ impl Notifier { self.lock_config().insert_json5(key, value) } + #[allow(dead_code)] pub fn get<'a>(&'a self, key: &str) -> Result, LookupError> { let config = self.lock_config(); // SAFETY: MutexGuard pins the mutex behind which the value is held. - let subref = config.get(key.as_ref())? as *const _; + let subref = config.0.get(key.as_ref()).map_err(LookupError)? as *const _; Ok(LookupGuard { _guard: config, subref, diff --git a/zenoh/src/lib.rs b/zenoh/src/lib.rs index 4072f229b5..c3f696121d 100644 --- a/zenoh/src/lib.rs +++ b/zenoh/src/lib.rs @@ -354,7 +354,6 @@ pub mod config { pub use zenoh_config::{WhatAmI, WhatAmIMatcher}; pub use crate::api::config::{Config, InsertionError}; - #[zenoh_macros::unstable] pub use crate::api::config::{LookupError, LookupGuard, Notifier}; } diff --git a/zenoh/src/net/runtime/mod.rs b/zenoh/src/net/runtime/mod.rs index 293e047ea0..4955790d04 100644 --- a/zenoh/src/net/runtime/mod.rs +++ b/zenoh/src/net/runtime/mod.rs @@ -61,7 +61,10 @@ use super::{primitives::DeMux, routing, routing::router::Router}; use crate::api::loader::{load_plugins, start_plugins}; #[cfg(feature = "plugins")] use crate::api::plugins::PluginsManager; -use crate::{config::Notifier, Config, GIT_VERSION, LONG_VERSION}; +use crate::{ + api::config::{Config, Notifier}, + GIT_VERSION, LONG_VERSION, +}; pub(crate) struct RuntimeState { zid: ZenohId, From 15a660f40be07eff0a5aa1a93bd7365cfe199a65 Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 07:58:40 +0000 Subject: [PATCH 05/15] Fix `Config::from_deserializer` --- zenoh/src/api/config.rs | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index 3d2ac45780..ca1eba4e0c 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -50,6 +50,8 @@ impl Config { self.0.remove(key) } + // REVIEW(fuzzypixelz): the error variant of the Result is a Result because this does + // deserialization AND validation. #[zenoh_macros::unstable] pub fn from_deserializer<'d, D: serde::Deserializer<'d>>( d: D, @@ -57,7 +59,13 @@ impl Config { where Self: serde::Deserialize<'d>, { - Ok(Config(zenoh_config::Config::from_deserializer(d)?)) + match zenoh_config::Config::from_deserializer(d) { + Ok(config) => Ok(Config(config)), + Err(result) => match result { + Ok(config) => Err(Ok(Config(config))), + Err(err) => Err(Err(err)), + }, + } } } From 69fdad3b8385e8b4234d220ba6ce1a603670ddfa Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 08:17:56 +0000 Subject: [PATCH 06/15] Update `zenoh/tests/liveliness.rs` --- zenoh/tests/liveliness.rs | 300 +++++++++++++++++++------------------- 1 file changed, 150 insertions(+), 150 deletions(-) diff --git a/zenoh/tests/liveliness.rs b/zenoh/tests/liveliness.rs index 14b5f33206..90c092f7c6 100644 --- a/zenoh/tests/liveliness.rs +++ b/zenoh/tests/liveliness.rs @@ -371,7 +371,7 @@ async fn test_liveliness_query_local() { async fn test_liveliness_subscriber_double_client_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -383,7 +383,7 @@ async fn test_liveliness_subscriber_double_client_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -396,7 +396,7 @@ async fn test_liveliness_subscriber_double_client_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -412,7 +412,7 @@ async fn test_liveliness_subscriber_double_client_before() { tokio::time::sleep(SLEEP).await; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -466,7 +466,7 @@ async fn test_liveliness_subscriber_double_client_before() { async fn test_liveliness_subscriber_double_client_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -478,7 +478,7 @@ async fn test_liveliness_subscriber_double_client_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -491,7 +491,7 @@ async fn test_liveliness_subscriber_double_client_middle() { }; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -510,7 +510,7 @@ async fn test_liveliness_subscriber_double_client_middle() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -564,7 +564,7 @@ async fn test_liveliness_subscriber_double_client_middle() { async fn test_liveliness_subscriber_double_client_after() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -576,7 +576,7 @@ async fn test_liveliness_subscriber_double_client_after() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -589,7 +589,7 @@ async fn test_liveliness_subscriber_double_client_after() { }; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -613,7 +613,7 @@ async fn test_liveliness_subscriber_double_client_after() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -664,7 +664,7 @@ async fn test_liveliness_subscriber_double_client_after() { async fn test_liveliness_subscriber_double_client_history_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -676,7 +676,7 @@ async fn test_liveliness_subscriber_double_client_history_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -689,7 +689,7 @@ async fn test_liveliness_subscriber_double_client_history_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -705,7 +705,7 @@ async fn test_liveliness_subscriber_double_client_history_before() { tokio::time::sleep(SLEEP).await; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -767,7 +767,7 @@ async fn test_liveliness_subscriber_double_client_history_before() { async fn test_liveliness_subscriber_double_client_history_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -779,7 +779,7 @@ async fn test_liveliness_subscriber_double_client_history_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -792,7 +792,7 @@ async fn test_liveliness_subscriber_double_client_history_middle() { }; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -812,7 +812,7 @@ async fn test_liveliness_subscriber_double_client_history_middle() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -870,7 +870,7 @@ async fn test_liveliness_subscriber_double_client_history_middle() { async fn test_liveliness_subscriber_double_client_history_after() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -882,7 +882,7 @@ async fn test_liveliness_subscriber_double_client_history_after() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -895,7 +895,7 @@ async fn test_liveliness_subscriber_double_client_history_after() { }; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -921,7 +921,7 @@ async fn test_liveliness_subscriber_double_client_history_after() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -976,7 +976,7 @@ async fn test_liveliness_subscriber_double_client_history_after() { async fn test_liveliness_subscriber_double_peer_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -988,7 +988,7 @@ async fn test_liveliness_subscriber_double_peer_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1001,7 +1001,7 @@ async fn test_liveliness_subscriber_double_peer_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1017,7 +1017,7 @@ async fn test_liveliness_subscriber_double_peer_before() { tokio::time::sleep(SLEEP).await; let peer_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1065,7 +1065,7 @@ async fn test_liveliness_subscriber_double_peer_before() { async fn test_liveliness_subscriber_double_peer_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1077,7 +1077,7 @@ async fn test_liveliness_subscriber_double_peer_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1090,7 +1090,7 @@ async fn test_liveliness_subscriber_double_peer_middle() { }; let peer_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1106,7 +1106,7 @@ async fn test_liveliness_subscriber_double_peer_middle() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1157,7 +1157,7 @@ async fn test_liveliness_subscriber_double_peer_middle() { async fn test_liveliness_subscriber_double_peer_after() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1169,7 +1169,7 @@ async fn test_liveliness_subscriber_double_peer_after() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1182,7 +1182,7 @@ async fn test_liveliness_subscriber_double_peer_after() { }; let peer_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1200,7 +1200,7 @@ async fn test_liveliness_subscriber_double_peer_after() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1251,7 +1251,7 @@ async fn test_liveliness_subscriber_double_peer_after() { async fn test_liveliness_subscriber_double_peer_history_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1263,7 +1263,7 @@ async fn test_liveliness_subscriber_double_peer_history_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1276,7 +1276,7 @@ async fn test_liveliness_subscriber_double_peer_history_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1292,7 +1292,7 @@ async fn test_liveliness_subscriber_double_peer_history_before() { tokio::time::sleep(SLEEP).await; let peer_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1354,7 +1354,7 @@ async fn test_liveliness_subscriber_double_peer_history_before() { async fn test_liveliness_subscriber_double_peer_history_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1366,7 +1366,7 @@ async fn test_liveliness_subscriber_double_peer_history_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1379,7 +1379,7 @@ async fn test_liveliness_subscriber_double_peer_history_middle() { }; let peer_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1399,7 +1399,7 @@ async fn test_liveliness_subscriber_double_peer_history_middle() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1457,7 +1457,7 @@ async fn test_liveliness_subscriber_double_peer_history_middle() { async fn test_liveliness_subscriber_double_peer_history_after() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1469,7 +1469,7 @@ async fn test_liveliness_subscriber_double_peer_history_after() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1482,7 +1482,7 @@ async fn test_liveliness_subscriber_double_peer_history_after() { }; let peer_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1508,7 +1508,7 @@ async fn test_liveliness_subscriber_double_peer_history_after() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1563,7 +1563,7 @@ async fn test_liveliness_subscriber_double_peer_history_after() { async fn test_liveliness_subscriber_double_router_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1576,7 +1576,7 @@ async fn test_liveliness_subscriber_double_router_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1589,7 +1589,7 @@ async fn test_liveliness_subscriber_double_router_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1605,7 +1605,7 @@ async fn test_liveliness_subscriber_double_router_before() { tokio::time::sleep(SLEEP).await; let router_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUB_ENDPOINT.parse::().unwrap()]) @@ -1663,7 +1663,7 @@ async fn test_liveliness_subscriber_double_router_before() { async fn test_liveliness_subscriber_double_router_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1676,7 +1676,7 @@ async fn test_liveliness_subscriber_double_router_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1689,7 +1689,7 @@ async fn test_liveliness_subscriber_double_router_middle() { }; let router_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUB_ENDPOINT.parse::().unwrap()]) @@ -1712,7 +1712,7 @@ async fn test_liveliness_subscriber_double_router_middle() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1766,7 +1766,7 @@ async fn test_liveliness_subscriber_double_router_middle() { async fn test_liveliness_subscriber_double_router_after() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1779,7 +1779,7 @@ async fn test_liveliness_subscriber_double_router_after() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1792,7 +1792,7 @@ async fn test_liveliness_subscriber_double_router_after() { }; let router_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUB_ENDPOINT.parse::().unwrap()]) @@ -1820,7 +1820,7 @@ async fn test_liveliness_subscriber_double_router_after() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1871,7 +1871,7 @@ async fn test_liveliness_subscriber_double_router_after() { async fn test_liveliness_subscriber_double_router_history_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1884,7 +1884,7 @@ async fn test_liveliness_subscriber_double_router_history_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1897,7 +1897,7 @@ async fn test_liveliness_subscriber_double_router_history_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -1913,7 +1913,7 @@ async fn test_liveliness_subscriber_double_router_history_before() { tokio::time::sleep(SLEEP).await; let router_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUB_ENDPOINT.parse::().unwrap()]) @@ -1979,7 +1979,7 @@ async fn test_liveliness_subscriber_double_router_history_before() { async fn test_liveliness_subscriber_double_router_history_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -1992,7 +1992,7 @@ async fn test_liveliness_subscriber_double_router_history_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2005,7 +2005,7 @@ async fn test_liveliness_subscriber_double_router_history_middle() { }; let router_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUB_ENDPOINT.parse::().unwrap()]) @@ -2029,7 +2029,7 @@ async fn test_liveliness_subscriber_double_router_history_middle() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2087,7 +2087,7 @@ async fn test_liveliness_subscriber_double_router_history_middle() { async fn test_liveliness_subscriber_double_router_history_after() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -2100,7 +2100,7 @@ async fn test_liveliness_subscriber_double_router_history_after() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2113,7 +2113,7 @@ async fn test_liveliness_subscriber_double_router_history_after() { }; let router_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUB_ENDPOINT.parse::().unwrap()]) @@ -2143,7 +2143,7 @@ async fn test_liveliness_subscriber_double_router_history_after() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2198,7 +2198,7 @@ async fn test_liveliness_subscriber_double_router_history_after() { async fn test_liveliness_subscriber_double_clientviapeer_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -2211,7 +2211,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2224,7 +2224,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_before() { }; let peer_dummy = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2241,7 +2241,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2257,7 +2257,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_before() { tokio::time::sleep(SLEEP).await; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2312,7 +2312,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_before() { async fn test_liveliness_subscriber_double_clientviapeer_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -2325,7 +2325,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2338,7 +2338,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_middle() { }; let peer_dummy = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2355,7 +2355,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_middle() { }; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2374,7 +2374,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_middle() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2429,7 +2429,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_middle() { async fn test_liveliness_subscriber_double_clientviapeer_after() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -2442,7 +2442,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_after() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2455,7 +2455,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_after() { }; let peer_dummy = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2472,7 +2472,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_after() { }; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2496,7 +2496,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_after() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2548,7 +2548,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_after() { async fn test_liveliness_subscriber_double_clientviapeer_history_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -2562,7 +2562,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2575,7 +2575,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_before() { }; let peer_dummy = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2592,7 +2592,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2608,7 +2608,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_before() { tokio::time::sleep(SLEEP).await; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2671,7 +2671,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_before() { async fn test_liveliness_subscriber_double_clientviapeer_history_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -2685,7 +2685,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2698,7 +2698,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_middle() { }; let peer_dummy = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2715,7 +2715,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_middle() { }; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2735,7 +2735,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_middle() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2794,7 +2794,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_middle() { async fn test_liveliness_subscriber_double_clientviapeer_history_after() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -2808,7 +2808,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_after() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2821,7 +2821,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_after() { }; let peer_dummy = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2838,7 +2838,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_after() { }; let client_sub = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![PEER_DUMMY_ENDPOINT.parse::().unwrap()]) @@ -2864,7 +2864,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_after() { tokio::time::sleep(SLEEP).await; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2920,7 +2920,7 @@ async fn test_liveliness_subscriber_double_clientviapeer_history_after() { async fn test_liveliness_subget_client_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -2932,7 +2932,7 @@ async fn test_liveliness_subget_client_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2945,7 +2945,7 @@ async fn test_liveliness_subget_client_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -2961,7 +2961,7 @@ async fn test_liveliness_subget_client_before() { tokio::time::sleep(SLEEP).await; let client_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3013,7 +3013,7 @@ async fn test_liveliness_subget_client_before() { async fn test_liveliness_subget_client_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3025,7 +3025,7 @@ async fn test_liveliness_subget_client_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3038,7 +3038,7 @@ async fn test_liveliness_subget_client_middle() { }; let client_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3059,7 +3059,7 @@ async fn test_liveliness_subget_client_middle() { assert!(sub.try_recv().is_err()); let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3111,7 +3111,7 @@ async fn test_liveliness_subget_client_middle() { async fn test_liveliness_subget_client_history_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3123,7 +3123,7 @@ async fn test_liveliness_subget_client_history_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3136,7 +3136,7 @@ async fn test_liveliness_subget_client_history_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3152,7 +3152,7 @@ async fn test_liveliness_subget_client_history_before() { tokio::time::sleep(SLEEP).await; let client_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3208,7 +3208,7 @@ async fn test_liveliness_subget_client_history_before() { async fn test_liveliness_subget_client_history_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3220,7 +3220,7 @@ async fn test_liveliness_subget_client_history_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3233,7 +3233,7 @@ async fn test_liveliness_subget_client_history_middle() { }; let client_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3255,7 +3255,7 @@ async fn test_liveliness_subget_client_history_middle() { assert!(sub.try_recv().is_err()); let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3311,7 +3311,7 @@ async fn test_liveliness_subget_client_history_middle() { async fn test_liveliness_subget_peer_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3323,7 +3323,7 @@ async fn test_liveliness_subget_peer_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3336,7 +3336,7 @@ async fn test_liveliness_subget_peer_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3352,7 +3352,7 @@ async fn test_liveliness_subget_peer_before() { tokio::time::sleep(SLEEP).await; let peer_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3404,7 +3404,7 @@ async fn test_liveliness_subget_peer_before() { async fn test_liveliness_subget_peer_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3416,7 +3416,7 @@ async fn test_liveliness_subget_peer_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3429,7 +3429,7 @@ async fn test_liveliness_subget_peer_middle() { }; let peer_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3450,7 +3450,7 @@ async fn test_liveliness_subget_peer_middle() { assert!(sub.try_recv().is_err()); let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3502,7 +3502,7 @@ async fn test_liveliness_subget_peer_middle() { async fn test_liveliness_subget_peer_history_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3514,7 +3514,7 @@ async fn test_liveliness_subget_peer_history_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3527,7 +3527,7 @@ async fn test_liveliness_subget_peer_history_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3543,7 +3543,7 @@ async fn test_liveliness_subget_peer_history_before() { tokio::time::sleep(SLEEP).await; let peer_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3599,7 +3599,7 @@ async fn test_liveliness_subget_peer_history_before() { async fn test_liveliness_subget_peer_history_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3611,7 +3611,7 @@ async fn test_liveliness_subget_peer_history_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3624,7 +3624,7 @@ async fn test_liveliness_subget_peer_history_middle() { }; let peer_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3646,7 +3646,7 @@ async fn test_liveliness_subget_peer_history_middle() { assert!(sub.try_recv().is_err()); let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3702,7 +3702,7 @@ async fn test_liveliness_subget_peer_history_middle() { async fn test_liveliness_subget_router_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3715,7 +3715,7 @@ async fn test_liveliness_subget_router_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3728,7 +3728,7 @@ async fn test_liveliness_subget_router_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3744,7 +3744,7 @@ async fn test_liveliness_subget_router_before() { tokio::time::sleep(SLEEP).await; let router_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUBGET_ENDPOINT.parse::().unwrap()]) @@ -3800,7 +3800,7 @@ async fn test_liveliness_subget_router_before() { async fn test_liveliness_subget_router_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3813,7 +3813,7 @@ async fn test_liveliness_subget_router_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3826,7 +3826,7 @@ async fn test_liveliness_subget_router_middle() { }; let router_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUBGET_ENDPOINT.parse::().unwrap()]) @@ -3851,7 +3851,7 @@ async fn test_liveliness_subget_router_middle() { assert!(sub.try_recv().is_err()); let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3903,7 +3903,7 @@ async fn test_liveliness_subget_router_middle() { async fn test_liveliness_subget_router_history_before() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -3916,7 +3916,7 @@ async fn test_liveliness_subget_router_history_before() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3929,7 +3929,7 @@ async fn test_liveliness_subget_router_history_before() { }; let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -3945,7 +3945,7 @@ async fn test_liveliness_subget_router_history_before() { tokio::time::sleep(SLEEP).await; let router_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUBGET_ENDPOINT.parse::().unwrap()]) @@ -4005,7 +4005,7 @@ async fn test_liveliness_subget_router_history_before() { async fn test_liveliness_subget_router_history_middle() { use std::time::Duration; - use zenoh::{config, sample::SampleKind}; + use zenoh::sample::SampleKind; use zenoh_config::WhatAmI; use zenoh_link::EndPoint; @@ -4018,7 +4018,7 @@ async fn test_liveliness_subget_router_history_middle() { zenoh_util::init_log_from_env_or("error"); let router = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) @@ -4031,7 +4031,7 @@ async fn test_liveliness_subget_router_history_middle() { }; let router_subget = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.listen .endpoints .set(vec![ROUTER_SUBGET_ENDPOINT.parse::().unwrap()]) @@ -4057,7 +4057,7 @@ async fn test_liveliness_subget_router_history_middle() { assert!(sub.try_recv().is_err()); let client_tok = { - let mut c = config::default(); + let mut c = zenoh::Config::default(); c.connect .endpoints .set(vec![ROUTER_ENDPOINT.parse::().unwrap()]) From fb0f4ead6283df9f74b79a9d5e06cc3227a34256 Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 08:38:26 +0000 Subject: [PATCH 07/15] Add `Config::get_json` --- zenoh/src/api/config.rs | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index ca1eba4e0c..7a1d4ae3c1 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -31,18 +31,17 @@ impl Config { } pub fn insert_json5(&mut self, key: &str, value: &str) -> Result<(), InsertionError> { - ::insert_json5( - &mut self.0, - key, - value, - ) - .map_err(InsertionError) + self.0.insert_json5(key, value).map_err(InsertionError) } #[zenoh_macros::unstable] pub fn get<'a>(&'a self, key: &str) -> Result<&'a dyn Any, LookupError> { - ::get(&self.0, key) - .map_err(LookupError) + self.0.get(key).map_err(LookupError) + } + + #[zenoh_macros::unstable] + pub fn get_json(&self, key: &str) -> Result { + self.0.get_json(key).map_err(LookupError) } #[zenoh_macros::unstable] From 78d8780d2c083820f9c7be91281ceb02c30ff616 Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 12:58:30 +0000 Subject: [PATCH 08/15] Add `Config::from_json5` and docs --- Cargo.lock | 1 + commons/zenoh-config/src/defaults.rs | 2 -- commons/zenoh-config/src/lib.rs | 6 ---- zenoh/Cargo.toml | 1 + zenoh/src/api/config.rs | 45 +++++++++++++++++++++------- 5 files changed, 36 insertions(+), 19 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index cae6e9d4ee..4eb8251dba 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -5332,6 +5332,7 @@ dependencies = [ "futures", "git-version", "itertools 0.13.0", + "json5", "lazy_static", "once_cell", "paste", diff --git a/commons/zenoh-config/src/defaults.rs b/commons/zenoh-config/src/defaults.rs index cc6bf5854a..7c98098d97 100644 --- a/commons/zenoh-config/src/defaults.rs +++ b/commons/zenoh-config/src/defaults.rs @@ -13,8 +13,6 @@ // use super::*; -pub const ENV: &str = "ZENOH_CONFIG"; - macro_rules! mode_accessor { ($type:ty) => { #[inline] diff --git a/commons/zenoh-config/src/lib.rs b/commons/zenoh-config/src/lib.rs index 49cc343695..fcda6e951a 100644 --- a/commons/zenoh-config/src/lib.rs +++ b/commons/zenoh-config/src/lib.rs @@ -737,12 +737,6 @@ impl std::fmt::Display for ConfigOpenErr { } impl std::error::Error for ConfigOpenErr {} impl Config { - pub fn from_env() -> ZResult { - let path = std::env::var(defaults::ENV) - .map_err(|e| zerror!("Invalid ENV variable ({}): {}", defaults::ENV, e))?; - Self::from_file(path.as_str()) - } - pub fn from_file>(path: P) -> ZResult { let path = path.as_ref(); let mut config = Self::_from_file(path)?; diff --git a/zenoh/Cargo.toml b/zenoh/Cargo.toml index 810689a993..6fb3315c16 100644 --- a/zenoh/Cargo.toml +++ b/zenoh/Cargo.toml @@ -76,6 +76,7 @@ flume = { workspace = true } futures = { workspace = true } git-version = { workspace = true } itertools = { workspace = true } +json5 = { workspace = true } lazy_static = { workspace = true } tracing = { workspace = true } paste = { workspace = true } diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index 7a1d4ae3c1..3e36017df4 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -1,5 +1,19 @@ +// +// Copyright (c) 2024 ZettaScale Technology +// +// This program and the accompanying materials are made available under the +// terms of the Eclipse Public License 2.0 which is available at +// http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0 +// which is available at https://www.apache.org/licenses/LICENSE-2.0. +// +// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 +// +// Contributors: +// ZettaScale Zenoh Team, +// use std::{ any::Any, + env, error::Error, fmt, ops::{self, Deref}, @@ -22,21 +36,35 @@ use zenoh_result::ZResult; pub struct Config(pub(crate) zenoh_config::Config); impl Config { + /// Default envrionment variable containing the file path used in [`Config::from_env`]. + pub const DEFAULT_CONFIG_PATH_ENV: &'static str = "ZENOH_CONFIG"; + + /// Load configuration from the file path specified in the [`Self::DEFAULT_CONFIG_PATH_ENV`] + /// environment variable. pub fn from_env() -> ZResult { - Ok(Config(zenoh_config::Config::from_env()?)) + let path = env::var(Self::DEFAULT_CONFIG_PATH_ENV)?; + Ok(Config(zenoh_config::Config::from_file(Path::new(&path)?)?)) } + /// Load configuration from the file at `path`. pub fn from_file>(path: P) -> ZResult { Ok(Config(zenoh_config::Config::from_file(path)?)) } - pub fn insert_json5(&mut self, key: &str, value: &str) -> Result<(), InsertionError> { - self.0.insert_json5(key, value).map_err(InsertionError) + /// Load configuration from the JSON5 string `input`. + pub fn from_json5(input: &str) -> ZResult { + match zenoh_config::Config::from_deserializer(&mut json5::Deserializer::from_str(input)?) { + Ok(config) => Ok(Config(config)), + Err(Ok(config)) => { + Err(zerror!("The config was correctly deserialized yet it's invalid").into()) + } + Err(Err(err)) => Err(err.into()), + } } - #[zenoh_macros::unstable] - pub fn get<'a>(&'a self, key: &str) -> Result<&'a dyn Any, LookupError> { - self.0.get(key).map_err(LookupError) + /// Inserts configuration value `value` at path `key`. + pub fn insert_json5(&mut self, key: &str, value: &str) -> Result<(), InsertionError> { + self.0.insert_json5(key, value).map_err(InsertionError) } #[zenoh_macros::unstable] @@ -44,11 +72,6 @@ impl Config { self.0.get_json(key).map_err(LookupError) } - #[zenoh_macros::unstable] - pub fn remove>(&mut self, key: K) -> ZResult<()> { - self.0.remove(key) - } - // REVIEW(fuzzypixelz): the error variant of the Result is a Result because this does // deserialization AND validation. #[zenoh_macros::unstable] From b3d53e69b372d3b1cb73f275eb52c81644b9de0e Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 13:00:06 +0000 Subject: [PATCH 09/15] Fix typo --- zenoh/src/api/config.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index 3e36017df4..17a19e3802 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -36,7 +36,7 @@ use zenoh_result::ZResult; pub struct Config(pub(crate) zenoh_config::Config); impl Config { - /// Default envrionment variable containing the file path used in [`Config::from_env`]. + /// Default environment variable containing the file path used in [`Config::from_env`]. pub const DEFAULT_CONFIG_PATH_ENV: &'static str = "ZENOH_CONFIG"; /// Load configuration from the file path specified in the [`Self::DEFAULT_CONFIG_PATH_ENV`] From f053c77d391f21472f6677d53a65dc5d31c81762 Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 13:03:26 +0000 Subject: [PATCH 10/15] Fix silly errors --- zenoh/src/api/config.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index 17a19e3802..d164a4c6a2 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -43,7 +43,7 @@ impl Config { /// environment variable. pub fn from_env() -> ZResult { let path = env::var(Self::DEFAULT_CONFIG_PATH_ENV)?; - Ok(Config(zenoh_config::Config::from_file(Path::new(&path)?)?)) + Ok(Config(zenoh_config::Config::from_file(Path::new(&path))?)) } /// Load configuration from the file at `path`. @@ -55,7 +55,7 @@ impl Config { pub fn from_json5(input: &str) -> ZResult { match zenoh_config::Config::from_deserializer(&mut json5::Deserializer::from_str(input)?) { Ok(config) => Ok(Config(config)), - Err(Ok(config)) => { + Err(Ok(_)) => { Err(zerror!("The config was correctly deserialized yet it's invalid").into()) } Err(Err(err)) => Err(err.into()), From 7ef636ac28a00b4e98c4efcb768717c92b52d76f Mon Sep 17 00:00:00 2001 From: Luca Cominardi Date: Tue, 17 Sep 2024 15:15:03 +0200 Subject: [PATCH 11/15] Fix Config::from_json5 error message --- zenoh/src/api/config.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index d164a4c6a2..bfb0078d13 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -56,7 +56,7 @@ impl Config { match zenoh_config::Config::from_deserializer(&mut json5::Deserializer::from_str(input)?) { Ok(config) => Ok(Config(config)), Err(Ok(_)) => { - Err(zerror!("The config was correctly deserialized yet it's invalid").into()) + Err(zerror!("The config was correctly deserialized but it is invalid").into()) } Err(Err(err)) => Err(err.into()), } From 8e78d8ce22cbce1d5963a08cf1494ba9a319f8f8 Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 13:46:40 +0000 Subject: [PATCH 12/15] Use `ZResult` everywhere, make `Config::get_json` stable --- zenoh/src/api/config.rs | 49 ++++++++--------------------------------- 1 file changed, 9 insertions(+), 40 deletions(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index bfb0078d13..384faaf839 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -62,14 +62,16 @@ impl Config { } } - /// Inserts configuration value `value` at path `key`. - pub fn insert_json5(&mut self, key: &str, value: &str) -> Result<(), InsertionError> { - self.0.insert_json5(key, value).map_err(InsertionError) + /// Inserts configuration value `value` at `key`. + pub fn insert_json5(&mut self, key: &str, value: &str) -> ZResult<()> { + self.0 + .insert_json5(key, value) + .map_err(|err| zerror!("{err}").into()) } - #[zenoh_macros::unstable] - pub fn get_json(&self, key: &str) -> Result { - self.0.get_json(key).map_err(LookupError) + /// Returns a JSON string containing the configuration at `key`. + pub fn get_json(&self, key: &str) -> ZResult { + self.0.get_json(key).map_err(|err| zerror!("{err}").into()) } // REVIEW(fuzzypixelz): the error variant of the Result is a Result because this does @@ -91,28 +93,6 @@ impl Config { } } -#[derive(Debug)] -pub struct InsertionError(validated_struct::InsertionError); - -impl fmt::Display for InsertionError { - fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { - write!(f, "{}", &self.0) - } -} - -impl Error for InsertionError {} - -#[derive(Debug)] -pub struct LookupError(validated_struct::GetError); - -impl fmt::Display for LookupError { - fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { - write!(f, "{}", &self.0) - } -} - -impl Error for LookupError {} - #[zenoh_macros::unstable_config] impl std::ops::Deref for Config { type Target = zenoh_config::Config; @@ -211,20 +191,9 @@ impl Notifier { Ok(()) } - pub fn insert_json5(&self, key: &str, value: &str) -> Result<(), InsertionError> { + pub fn insert_json5(&self, key: &str, value: &str) -> ZResult<()> { self.lock_config().insert_json5(key, value) } - - #[allow(dead_code)] - pub fn get<'a>(&'a self, key: &str) -> Result, LookupError> { - let config = self.lock_config(); - // SAFETY: MutexGuard pins the mutex behind which the value is held. - let subref = config.0.get(key.as_ref()).map_err(LookupError)? as *const _; - Ok(LookupGuard { - _guard: config, - subref, - }) - } } pub struct LookupGuard<'a, T> { From 01f270742d6785b56660ee4e7a01a79ff353642d Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 13:53:34 +0000 Subject: [PATCH 13/15] Remove LookupGuard --- zenoh/src/api/config.rs | 25 +------------------------ zenoh/src/lib.rs | 4 ++-- 2 files changed, 3 insertions(+), 26 deletions(-) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index 384faaf839..47c65ff3ae 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -12,11 +12,7 @@ // ZettaScale Zenoh Team, // use std::{ - any::Any, - env, - error::Error, - fmt, - ops::{self, Deref}, + env, fmt, path::Path, sync::{Arc, Mutex, MutexGuard}, }; @@ -195,22 +191,3 @@ impl Notifier { self.lock_config().insert_json5(key, value) } } - -pub struct LookupGuard<'a, T> { - _guard: MutexGuard<'a, T>, - subref: *const dyn Any, -} - -impl<'a, T> ops::Deref for LookupGuard<'a, T> { - type Target = dyn Any; - - fn deref(&self) -> &Self::Target { - unsafe { &*self.subref } - } -} - -impl<'a, T> AsRef for LookupGuard<'a, T> { - fn as_ref(&self) -> &dyn Any { - self.deref() - } -} diff --git a/zenoh/src/lib.rs b/zenoh/src/lib.rs index 904353389e..e09ca91f34 100644 --- a/zenoh/src/lib.rs +++ b/zenoh/src/lib.rs @@ -353,9 +353,9 @@ pub mod time { pub mod config { pub use zenoh_config::{WhatAmI, WhatAmIMatcher}; - pub use crate::api::config::{Config, InsertionError}; + pub use crate::api::config::Config; #[zenoh_macros::unstable] - pub use crate::api::config::{LookupError, LookupGuard, Notifier}; + pub use crate::api::config::Notifier; } #[cfg(all( From c4012d516bd5ba294b0d2a770fd9ba29cab4c61c Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 14:30:59 +0000 Subject: [PATCH 14/15] Add back `Notifier::get` --- zenoh/src/api/config.rs | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/zenoh/src/api/config.rs b/zenoh/src/api/config.rs index 47c65ff3ae..1388ac8110 100644 --- a/zenoh/src/api/config.rs +++ b/zenoh/src/api/config.rs @@ -12,7 +12,9 @@ // ZettaScale Zenoh Team, // use std::{ + any::Any, env, fmt, + ops::Deref, path::Path, sync::{Arc, Mutex, MutexGuard}, }; @@ -190,4 +192,34 @@ impl Notifier { pub fn insert_json5(&self, key: &str, value: &str) -> ZResult<()> { self.lock_config().insert_json5(key, value) } + + #[allow(dead_code)] + pub fn get<'a>(&'a self, key: &str) -> ZResult> { + let config = self.lock_config(); + let subref = config.0.get(key.as_ref()).map_err(|err| zerror!("{err}"))? as *const _; + Ok(LookupGuard { + _guard: config, + subref, + }) + } +} + +pub struct LookupGuard<'a, T> { + _guard: MutexGuard<'a, T>, + subref: *const dyn Any, +} + +impl<'a, T> Deref for LookupGuard<'a, T> { + type Target = dyn Any; + + fn deref(&self) -> &Self::Target { + // SAFETY: MutexGuard pins the mutex behind which the value is held. + unsafe { &*self.subref } + } +} + +impl<'a, T> AsRef for LookupGuard<'a, T> { + fn as_ref(&self) -> &dyn Any { + self.deref() + } } From 069ce6f0c2c13f5341507b3285880f9d1f9cf7fa Mon Sep 17 00:00:00 2001 From: Mahmoud Mazouz Date: Tue, 17 Sep 2024 14:44:34 +0000 Subject: [PATCH 15/15] Remove `validated_struct` dependency --- zenoh/Cargo.toml | 1 - 1 file changed, 1 deletion(-) diff --git a/zenoh/Cargo.toml b/zenoh/Cargo.toml index 6fb3315c16..9080ae7b40 100644 --- a/zenoh/Cargo.toml +++ b/zenoh/Cargo.toml @@ -110,7 +110,6 @@ zenoh-util = { workspace = true } zenoh-runtime = { workspace = true } zenoh-task = { workspace = true } once_cell = { workspace = true } -validated_struct = { workspace = true } [dev-dependencies] tokio = { workspace = true }