From cb691b4c27ba9412d14376ffc663114fecc8777b Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 17:31:11 +0800 Subject: [PATCH 1/9] feat: align `fn root` semantics; fix missing root for some services --- core/src/raw/adapters/kv/backend.rs | 9 ++++++++- core/src/services/atomicserver/backend.rs | 2 +- core/src/services/azblob/backend.rs | 8 +++++--- core/src/services/azdls/backend.rs | 8 +++++--- core/src/services/azfile/backend.rs | 8 +++++--- core/src/services/cloudflare_kv/backend.rs | 11 +++++++---- core/src/services/cos/backend.rs | 8 +++++--- core/src/services/d1/backend.rs | 11 +++++++---- core/src/services/dbfs/backend.rs | 8 +++++--- core/src/services/dropbox/builder.rs | 7 ++++++- core/src/services/etcd/backend.rs | 11 +++++++---- core/src/services/foundationdb/backend.rs | 2 +- core/src/services/gcs/backend.rs | 8 +++++--- core/src/services/gdrive/builder.rs | 7 ++++++- core/src/services/ghac/backend.rs | 8 +++++--- core/src/services/gridfs/backend.rs | 19 +++++++++++++++---- core/src/services/huggingface/backend.rs | 9 ++++++--- core/src/services/ipfs/backend.rs | 8 +++++--- core/src/services/libsql/backend.rs | 11 +++++++---- core/src/services/memcached/backend.rs | 2 +- core/src/services/mongodb/backend.rs | 19 ++++++++++++++----- core/src/services/mysql/backend.rs | 11 +++++++---- core/src/services/postgresql/backend.rs | 11 +++++++---- core/src/services/redis/backend.rs | 13 ++++++++----- core/src/services/rocksdb/backend.rs | 19 +++++++++++++++---- core/src/services/sled/backend.rs | 7 ++++++- core/src/services/sqlite/backend.rs | 2 +- core/src/services/surrealdb/backend.rs | 2 +- 28 files changed, 171 insertions(+), 78 deletions(-) diff --git a/core/src/raw/adapters/kv/backend.rs b/core/src/raw/adapters/kv/backend.rs index 55de6b5c2c97..96f41b00bc94 100644 --- a/core/src/raw/adapters/kv/backend.rs +++ b/core/src/raw/adapters/kv/backend.rs @@ -51,7 +51,14 @@ where /// Configure root within this backend. pub fn with_root(mut self, root: &str) -> Self { - self.root = normalize_root(root); + self.with_normalized_root(normalize_root(root)) + } + + /// Configure root within this backend. + /// + /// This method asssume root is normalized. + pub(crate) fn with_normalized_root(mut self, root: String) -> Self { + self.root = root; self } } diff --git a/core/src/services/atomicserver/backend.rs b/core/src/services/atomicserver/backend.rs index eb61f612832f..e6e415674ba7 100644 --- a/core/src/services/atomicserver/backend.rs +++ b/core/src/services/atomicserver/backend.rs @@ -155,7 +155,7 @@ impl Builder for AtomicserverBuilder { .with_context("service", Scheme::Atomicserver) })?, }) - .with_root(&root)) + .with_normalized_root(root)) } } diff --git a/core/src/services/azblob/backend.rs b/core/src/services/azblob/backend.rs index d97f5b84053f..ad59f5254185 100644 --- a/core/src/services/azblob/backend.rs +++ b/core/src/services/azblob/backend.rs @@ -150,9 +150,11 @@ impl AzblobBuilder { /// /// All operations will happen under this root. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/azdls/backend.rs b/core/src/services/azdls/backend.rs index baa68ae14f55..0af18e2819df 100644 --- a/core/src/services/azdls/backend.rs +++ b/core/src/services/azdls/backend.rs @@ -113,9 +113,11 @@ impl AzdlsBuilder { /// /// All operations will happen under this root. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/azfile/backend.rs b/core/src/services/azfile/backend.rs index 5390e0255695..9f6d386b35a2 100644 --- a/core/src/services/azfile/backend.rs +++ b/core/src/services/azfile/backend.rs @@ -111,9 +111,11 @@ impl AzfileBuilder { /// /// All operations will happen under this root. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/cloudflare_kv/backend.rs b/core/src/services/cloudflare_kv/backend.rs index 7184ce0e9ef4..f97bca593a5f 100644 --- a/core/src/services/cloudflare_kv/backend.rs +++ b/core/src/services/cloudflare_kv/backend.rs @@ -115,9 +115,12 @@ impl CloudflareKvBuilder { /// Set the root within this backend. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } } @@ -175,7 +178,7 @@ impl Builder for CloudflareKvBuilder { client, url_prefix, }) - .with_root(&root)) + .with_normalized_root(root)) } } diff --git a/core/src/services/cos/backend.rs b/core/src/services/cos/backend.rs index a900aba741e5..478aecb38608 100644 --- a/core/src/services/cos/backend.rs +++ b/core/src/services/cos/backend.rs @@ -97,9 +97,11 @@ impl CosBuilder { /// /// All operations will happen under this root. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/d1/backend.rs b/core/src/services/d1/backend.rs index e6aaa6da4e56..c30b622a3a06 100644 --- a/core/src/services/d1/backend.rs +++ b/core/src/services/d1/backend.rs @@ -129,9 +129,12 @@ impl D1Builder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } @@ -231,7 +234,7 @@ impl Builder for D1Builder { key_field, value_field, }) - .with_root(&root)) + .with_normalized_root(root)) } } diff --git a/core/src/services/dbfs/backend.rs b/core/src/services/dbfs/backend.rs index 542722a3e0dc..1f5b16ff37af 100644 --- a/core/src/services/dbfs/backend.rs +++ b/core/src/services/dbfs/backend.rs @@ -87,9 +87,11 @@ impl DbfsBuilder { /// /// All operations will happen under this root. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/dropbox/builder.rs b/core/src/services/dropbox/builder.rs index bef4e2421e58..5b73de42003b 100644 --- a/core/src/services/dropbox/builder.rs +++ b/core/src/services/dropbox/builder.rs @@ -88,7 +88,12 @@ impl DropboxBuilder { /// /// Default to `/` if not set. pub fn root(mut self, root: &str) -> Self { - self.config.root = Some(root.to_string()); + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } diff --git a/core/src/services/etcd/backend.rs b/core/src/services/etcd/backend.rs index 3344a951cf0e..fa7fb348207c 100644 --- a/core/src/services/etcd/backend.rs +++ b/core/src/services/etcd/backend.rs @@ -159,9 +159,12 @@ impl EtcdBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } @@ -246,7 +249,7 @@ impl Builder for EtcdBuilder { client, options, }) - .with_root(root.as_str())) + .with_normalized_root(root)) } } diff --git a/core/src/services/foundationdb/backend.rs b/core/src/services/foundationdb/backend.rs index 2a83bffdeb31..55dcb81841e1 100644 --- a/core/src/services/foundationdb/backend.rs +++ b/core/src/services/foundationdb/backend.rs @@ -113,7 +113,7 @@ impl Builder for FoundationdbBuilder { .as_str(), ); - Ok(FoundationdbBackend::new(Adapter { db, _network }).with_root(&root)) + Ok(FoundationdbBackend::new(Adapter { db, _network }).with_normalized_root(&root)) } } diff --git a/core/src/services/gcs/backend.rs b/core/src/services/gcs/backend.rs index 8861b22202f5..df3fab369f5a 100644 --- a/core/src/services/gcs/backend.rs +++ b/core/src/services/gcs/backend.rs @@ -124,9 +124,11 @@ impl Debug for GcsBuilder { impl GcsBuilder { /// set the working directory root of backend pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/gdrive/builder.rs b/core/src/services/gdrive/builder.rs index fc3b9b8385c5..3628488b819e 100644 --- a/core/src/services/gdrive/builder.rs +++ b/core/src/services/gdrive/builder.rs @@ -92,7 +92,12 @@ impl Debug for GdriveBuilder { impl GdriveBuilder { /// Set root path of GoogleDrive folder. pub fn root(mut self, root: &str) -> Self { - self.config.root = Some(root.to_string()); + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } diff --git a/core/src/services/ghac/backend.rs b/core/src/services/ghac/backend.rs index 4698de168f3e..5a6fc305451a 100644 --- a/core/src/services/ghac/backend.rs +++ b/core/src/services/ghac/backend.rs @@ -117,9 +117,11 @@ pub struct GhacBuilder { impl GhacBuilder { /// set the working directory root of backend pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/gridfs/backend.rs b/core/src/services/gridfs/backend.rs index 6c36776fa421..7f8c6e7b1adb 100644 --- a/core/src/services/gridfs/backend.rs +++ b/core/src/services/gridfs/backend.rs @@ -114,9 +114,12 @@ impl GridFsBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } @@ -176,13 +179,21 @@ impl Builder for GridFsBuilder { }; let chunk_size = self.config.chunk_size.unwrap_or(255); + let root = normalize_root( + self.config + .root + .clone() + .unwrap_or_else(|| "/".to_string()) + .as_str(), + ); + Ok(GridFsBackend::new(Adapter { connection_string: conn, database, bucket, chunk_size, bucket_instance: OnceCell::new(), - })) + }).with_normalized_root(root)) } } diff --git a/core/src/services/huggingface/backend.rs b/core/src/services/huggingface/backend.rs index 712c895edf46..1e9742154336 100644 --- a/core/src/services/huggingface/backend.rs +++ b/core/src/services/huggingface/backend.rs @@ -159,9 +159,12 @@ impl HuggingfaceBuilder { /// /// All operations will happen under this root. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } diff --git a/core/src/services/ipfs/backend.rs b/core/src/services/ipfs/backend.rs index 3eeda15b9727..5589db79a99a 100644 --- a/core/src/services/ipfs/backend.rs +++ b/core/src/services/ipfs/backend.rs @@ -70,9 +70,11 @@ impl IpfsBuilder { /// - `/ipfs/bafybeibozpulxtpv5nhfa2ue3dcjx23ndh3gwr5vwllk7ptoyfwnfjjr4q/` (IPFS with CID v1) /// - `/ipns/opendal.apache.org/` (IPNS) pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/libsql/backend.rs b/core/src/services/libsql/backend.rs index 70bdfb921923..8df0c9426635 100644 --- a/core/src/services/libsql/backend.rs +++ b/core/src/services/libsql/backend.rs @@ -137,9 +137,12 @@ impl LibsqlBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } @@ -215,7 +218,7 @@ impl Builder for LibsqlBuilder { key_field, value_field, }) - .with_root(&root)) + .with_normalized_root(root)) } } diff --git a/core/src/services/memcached/backend.rs b/core/src/services/memcached/backend.rs index 4f516bfc8269..f74eb3bacb29 100644 --- a/core/src/services/memcached/backend.rs +++ b/core/src/services/memcached/backend.rs @@ -172,7 +172,7 @@ impl Builder for MemcachedBuilder { conn, default_ttl: self.config.default_ttl, }) - .with_root(&root)) + .with_normalized_root(root)) } } diff --git a/core/src/services/mongodb/backend.rs b/core/src/services/mongodb/backend.rs index d700b08d382c..8a58b0ede6ba 100644 --- a/core/src/services/mongodb/backend.rs +++ b/core/src/services/mongodb/backend.rs @@ -114,9 +114,12 @@ impl MongodbBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } @@ -195,7 +198,13 @@ impl Builder for MongodbBuilder { Some(v) => v.clone(), None => "value".to_string(), }; - + let root = normalize_root( + config + .root + .clone() + .unwrap_or_else(|| "/".to_string()) + .as_str(), + ); Ok(MongodbBackend::new(Adapter { connection_string: conn, database, @@ -203,7 +212,7 @@ impl Builder for MongodbBuilder { collection_instance: OnceCell::new(), key_field, value_field, - })) + }).with_normalized_root(root)) } } diff --git a/core/src/services/mysql/backend.rs b/core/src/services/mysql/backend.rs index e3bd1f02dc0f..cdf9c90b6893 100644 --- a/core/src/services/mysql/backend.rs +++ b/core/src/services/mysql/backend.rs @@ -108,9 +108,12 @@ impl MysqlBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } @@ -195,7 +198,7 @@ impl Builder for MysqlBuilder { key_field, value_field, }) - .with_root(&root)) + .with_normalized_root(root)) } } diff --git a/core/src/services/postgresql/backend.rs b/core/src/services/postgresql/backend.rs index fa053562a756..e049eae0d1a7 100644 --- a/core/src/services/postgresql/backend.rs +++ b/core/src/services/postgresql/backend.rs @@ -133,9 +133,12 @@ impl PostgresqlBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } @@ -219,7 +222,7 @@ impl Builder for PostgresqlBuilder { key_field, value_field, }) - .with_root(&root)) + .with_normalized_root(root)) } } diff --git a/core/src/services/redis/backend.rs b/core/src/services/redis/backend.rs index 9f840f3ca73f..59e3e09571ae 100644 --- a/core/src/services/redis/backend.rs +++ b/core/src/services/redis/backend.rs @@ -191,9 +191,12 @@ impl RedisBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } } @@ -234,7 +237,7 @@ impl Builder for RedisBuilder { conn, default_ttl: self.config.default_ttl, }) - .with_root(&root)) + .with_normalized_root(root)) } else { let endpoint = self .config @@ -259,7 +262,7 @@ impl Builder for RedisBuilder { conn, default_ttl: self.config.default_ttl, }) - .with_root(&root)) + .with_normalized_root(root)) } } } diff --git a/core/src/services/rocksdb/backend.rs b/core/src/services/rocksdb/backend.rs index 130b785bbdf0..e117b41aaee0 100644 --- a/core/src/services/rocksdb/backend.rs +++ b/core/src/services/rocksdb/backend.rs @@ -67,9 +67,12 @@ impl RocksdbBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } } @@ -90,7 +93,15 @@ impl Builder for RocksdbBuilder { .set_source(e) })?; - Ok(RocksdbBackend::new(Adapter { db: Arc::new(db) })) + let root = normalize_root( + self.config + .root + .clone() + .unwrap_or_else(|| "/".to_string()) + .as_str(), + ); + + Ok(RocksdbBackend::new(Adapter { db: Arc::new(db) }).with_normalized_root(root)) } } diff --git a/core/src/services/sled/backend.rs b/core/src/services/sled/backend.rs index e04488a15a0e..a3cc3fc0a4e0 100644 --- a/core/src/services/sled/backend.rs +++ b/core/src/services/sled/backend.rs @@ -88,7 +88,12 @@ impl SledBuilder { /// Set the root for sled. pub fn root(mut self, path: &str) -> Self { - self.config.root = Some(path.into()); + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } diff --git a/core/src/services/sqlite/backend.rs b/core/src/services/sqlite/backend.rs index 1229ca2eaa81..6bf0a325f445 100644 --- a/core/src/services/sqlite/backend.rs +++ b/core/src/services/sqlite/backend.rs @@ -204,7 +204,7 @@ impl Builder for SqliteBuilder { key_field, value_field, }) - .with_root(&root)) + .with_normalized_root(&root)) } } diff --git a/core/src/services/surrealdb/backend.rs b/core/src/services/surrealdb/backend.rs index b7482f6cdfa5..92a0e8236d2f 100644 --- a/core/src/services/surrealdb/backend.rs +++ b/core/src/services/surrealdb/backend.rs @@ -251,7 +251,7 @@ impl Builder for SurrealdbBuilder { key_field, value_field, }) - .with_root(&root)) + .with_normalized_root(&root)) } } From 724d3fd3c0d696bc96f507ce6ddffdc551b9aa3a Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 17:33:53 +0800 Subject: [PATCH 2/9] typo and fmt --- core/src/raw/adapters/kv/backend.rs | 2 +- core/src/services/gridfs/backend.rs | 3 ++- core/src/services/mongodb/backend.rs | 3 ++- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/core/src/raw/adapters/kv/backend.rs b/core/src/raw/adapters/kv/backend.rs index 96f41b00bc94..412d1861d20a 100644 --- a/core/src/raw/adapters/kv/backend.rs +++ b/core/src/raw/adapters/kv/backend.rs @@ -56,7 +56,7 @@ where /// Configure root within this backend. /// - /// This method asssume root is normalized. + /// This method assumes root is normalized. pub(crate) fn with_normalized_root(mut self, root: String) -> Self { self.root = root; self diff --git a/core/src/services/gridfs/backend.rs b/core/src/services/gridfs/backend.rs index 7f8c6e7b1adb..b454d06338a3 100644 --- a/core/src/services/gridfs/backend.rs +++ b/core/src/services/gridfs/backend.rs @@ -193,7 +193,8 @@ impl Builder for GridFsBuilder { bucket, chunk_size, bucket_instance: OnceCell::new(), - }).with_normalized_root(root)) + }) + .with_normalized_root(root)) } } diff --git a/core/src/services/mongodb/backend.rs b/core/src/services/mongodb/backend.rs index 8a58b0ede6ba..88bef6ce9928 100644 --- a/core/src/services/mongodb/backend.rs +++ b/core/src/services/mongodb/backend.rs @@ -212,7 +212,8 @@ impl Builder for MongodbBuilder { collection_instance: OnceCell::new(), key_field, value_field, - }).with_normalized_root(root)) + }) + .with_normalized_root(root)) } } From d23caab043c0a6aa9d137b8abaf30aba01a995b9 Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 17:36:47 +0800 Subject: [PATCH 3/9] chore --- core/src/raw/adapters/kv/backend.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/src/raw/adapters/kv/backend.rs b/core/src/raw/adapters/kv/backend.rs index 412d1861d20a..a4a878924c7c 100644 --- a/core/src/raw/adapters/kv/backend.rs +++ b/core/src/raw/adapters/kv/backend.rs @@ -50,7 +50,7 @@ where } /// Configure root within this backend. - pub fn with_root(mut self, root: &str) -> Self { + pub fn with_root(self, root: &str) -> Self { self.with_normalized_root(normalize_root(root)) } From 91c9b44faec41961668aabf9282656e544a4acdd Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 17:43:56 +0800 Subject: [PATCH 4/9] fix name --- core/src/services/sled/backend.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/src/services/sled/backend.rs b/core/src/services/sled/backend.rs index a3cc3fc0a4e0..b100c4e6877b 100644 --- a/core/src/services/sled/backend.rs +++ b/core/src/services/sled/backend.rs @@ -87,7 +87,7 @@ impl SledBuilder { } /// Set the root for sled. - pub fn root(mut self, path: &str) -> Self { + pub fn root(mut self, root: &str) -> Self { self.config.root = if root.is_empty() { None } else { From e2301f6cf40f76cae31f1a7579947917c2eb21a0 Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 17:50:05 +0800 Subject: [PATCH 5/9] align more roots --- core/src/services/fs/backend.rs | 10 +++++----- core/src/services/memcached/backend.rs | 9 +++++---- core/src/services/obs/backend.rs | 8 +++++--- core/src/services/onedrive/builder.rs | 7 ++++++- core/src/services/sqlite/backend.rs | 9 ++++++--- core/src/services/surrealdb/backend.rs | 9 ++++++--- core/src/services/swift/backend.rs | 8 +++++--- core/src/services/webhdfs/backend.rs | 8 +++++--- 8 files changed, 43 insertions(+), 25 deletions(-) diff --git a/core/src/services/fs/backend.rs b/core/src/services/fs/backend.rs index 151e35aef6c9..ad90a6457b8e 100644 --- a/core/src/services/fs/backend.rs +++ b/core/src/services/fs/backend.rs @@ -62,11 +62,11 @@ pub struct FsBuilder { impl FsBuilder { /// Set root for backend. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()); - } - - self + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; } /// Set temp dir for atomic write. diff --git a/core/src/services/memcached/backend.rs b/core/src/services/memcached/backend.rs index f74eb3bacb29..2fe649aa6bcc 100644 --- a/core/src/services/memcached/backend.rs +++ b/core/src/services/memcached/backend.rs @@ -78,10 +78,11 @@ impl MemcachedBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } - self + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; } /// set the username. diff --git a/core/src/services/obs/backend.rs b/core/src/services/obs/backend.rs index 071a0cda0167..20433c8854cb 100644 --- a/core/src/services/obs/backend.rs +++ b/core/src/services/obs/backend.rs @@ -97,9 +97,11 @@ impl ObsBuilder { /// /// All operations will happen under this root. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/onedrive/builder.rs b/core/src/services/onedrive/builder.rs index 4f0ae806d64d..5b3fb36739bd 100644 --- a/core/src/services/onedrive/builder.rs +++ b/core/src/services/onedrive/builder.rs @@ -85,7 +85,12 @@ impl OnedriveBuilder { /// Set root path of OneDrive folder. pub fn root(mut self, root: &str) -> Self { - self.config.root = Some(root.to_string()); + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } diff --git a/core/src/services/sqlite/backend.rs b/core/src/services/sqlite/backend.rs index 6bf0a325f445..eb2442d4a7c1 100644 --- a/core/src/services/sqlite/backend.rs +++ b/core/src/services/sqlite/backend.rs @@ -121,9 +121,12 @@ impl SqliteBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_owned()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } diff --git a/core/src/services/surrealdb/backend.rs b/core/src/services/surrealdb/backend.rs index 92a0e8236d2f..9b0742e34168 100644 --- a/core/src/services/surrealdb/backend.rs +++ b/core/src/services/surrealdb/backend.rs @@ -116,9 +116,12 @@ impl SurrealdbBuilder { /// /// default: "/" pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()); - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; + self } diff --git a/core/src/services/swift/backend.rs b/core/src/services/swift/backend.rs index e0170db0b943..89a1f83d1993 100644 --- a/core/src/services/swift/backend.rs +++ b/core/src/services/swift/backend.rs @@ -123,9 +123,11 @@ impl SwiftBuilder { /// /// All operations will happen under this root. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } diff --git a/core/src/services/webhdfs/backend.rs b/core/src/services/webhdfs/backend.rs index 2e32b03f7b9a..0354f3659d4d 100644 --- a/core/src/services/webhdfs/backend.rs +++ b/core/src/services/webhdfs/backend.rs @@ -100,9 +100,11 @@ impl WebhdfsBuilder { /// /// The root will be automatically created if not exists. pub fn root(mut self, root: &str) -> Self { - if !root.is_empty() { - self.config.root = Some(root.to_string()) - } + self.config.root = if root.is_empty() { + None + } else { + Some(root.to_string()) + }; self } From 05f98bc2008b4de22e7ccedb712d5ec36463de32 Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 17:51:40 +0800 Subject: [PATCH 6/9] fix --- core/src/services/gridfs/backend.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/src/services/gridfs/backend.rs b/core/src/services/gridfs/backend.rs index b454d06338a3..7abfa0d79764 100644 --- a/core/src/services/gridfs/backend.rs +++ b/core/src/services/gridfs/backend.rs @@ -30,7 +30,7 @@ use tokio::sync::OnceCell; use crate::raw::adapters::kv; use crate::raw::new_std_io_error; -use crate::raw::Access; +use crate::raw::*; use crate::*; /// Config for Grid file system support. From 3aa65b2e60bc92aea0c5521ff58c721fe6db40d1 Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 18:21:11 +0800 Subject: [PATCH 7/9] fix --- core/src/services/fs/backend.rs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/core/src/services/fs/backend.rs b/core/src/services/fs/backend.rs index ad90a6457b8e..af1f163187c8 100644 --- a/core/src/services/fs/backend.rs +++ b/core/src/services/fs/backend.rs @@ -67,6 +67,8 @@ impl FsBuilder { } else { Some(root.to_string()) }; + + self } /// Set temp dir for atomic write. From 4df105205db6d3275ecbd5e4d8b565991ce744ad Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 18:27:30 +0800 Subject: [PATCH 8/9] fix --- core/src/services/memcached/backend.rs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/core/src/services/memcached/backend.rs b/core/src/services/memcached/backend.rs index 2fe649aa6bcc..2e8526c0cbf7 100644 --- a/core/src/services/memcached/backend.rs +++ b/core/src/services/memcached/backend.rs @@ -83,6 +83,8 @@ impl MemcachedBuilder { } else { Some(root.to_string()) }; + + self } /// set the username. From a8a165130d61cbc25d067dd7201f66c4428dba0c Mon Sep 17 00:00:00 2001 From: yjhmelody Date: Thu, 22 Aug 2024 18:40:36 +0800 Subject: [PATCH 9/9] fix --- core/src/services/foundationdb/backend.rs | 2 +- core/src/services/mongodb/backend.rs | 4 ++-- core/src/services/sqlite/backend.rs | 2 +- core/src/services/surrealdb/backend.rs | 2 +- 4 files changed, 5 insertions(+), 5 deletions(-) diff --git a/core/src/services/foundationdb/backend.rs b/core/src/services/foundationdb/backend.rs index 55dcb81841e1..553b6a06087d 100644 --- a/core/src/services/foundationdb/backend.rs +++ b/core/src/services/foundationdb/backend.rs @@ -113,7 +113,7 @@ impl Builder for FoundationdbBuilder { .as_str(), ); - Ok(FoundationdbBackend::new(Adapter { db, _network }).with_normalized_root(&root)) + Ok(FoundationdbBackend::new(Adapter { db, _network }).with_normalized_root(root)) } } diff --git a/core/src/services/mongodb/backend.rs b/core/src/services/mongodb/backend.rs index 88bef6ce9928..8c7cb893c157 100644 --- a/core/src/services/mongodb/backend.rs +++ b/core/src/services/mongodb/backend.rs @@ -27,7 +27,7 @@ use serde::Serialize; use tokio::sync::OnceCell; use crate::raw::adapters::kv; -use crate::raw::Access; +use crate::raw::*; use crate::*; /// Config for Mongodb service support. @@ -199,7 +199,7 @@ impl Builder for MongodbBuilder { None => "value".to_string(), }; let root = normalize_root( - config + self.config .root .clone() .unwrap_or_else(|| "/".to_string()) diff --git a/core/src/services/sqlite/backend.rs b/core/src/services/sqlite/backend.rs index eb2442d4a7c1..4e9538509cb4 100644 --- a/core/src/services/sqlite/backend.rs +++ b/core/src/services/sqlite/backend.rs @@ -207,7 +207,7 @@ impl Builder for SqliteBuilder { key_field, value_field, }) - .with_normalized_root(&root)) + .with_normalized_root(root)) } } diff --git a/core/src/services/surrealdb/backend.rs b/core/src/services/surrealdb/backend.rs index 9b0742e34168..b1129b40366e 100644 --- a/core/src/services/surrealdb/backend.rs +++ b/core/src/services/surrealdb/backend.rs @@ -254,7 +254,7 @@ impl Builder for SurrealdbBuilder { key_field, value_field, }) - .with_normalized_root(&root)) + .with_normalized_root(root)) } }