diff --git a/src-tauri/src/config/runtime.rs b/src-tauri/src/config/runtime.rs index 3b67b06f5ef6dba8eb205dbd94e9d5d8c443833a..cce376ba84bd2458ac50402b7aa34742573a9285 100644 --- a/src-tauri/src/config/runtime.rs +++ b/src-tauri/src/config/runtime.rs @@ -15,4 +15,17 @@ impl IRuntime { pub fn new() -> Self { Self::default() } + + // 这里åªæ›´æ”¹ allow-lan | ipv6 | log-level + pub fn patch_config(&mut self, patch: Mapping) { + if let Some(config) = self.config.as_mut() { + ["allow-lan", "ipv6", "log-level"] + .into_iter() + .for_each(|key| { + if let Some(value) = patch.get(key).to_owned() { + config.insert(key.into(), value.clone()); + } + }); + } + } } diff --git a/src-tauri/src/feat.rs b/src-tauri/src/feat.rs index 7ae48ca007fb4ed689427c8d87b625892c28184f..1e4911770af9dc407f8bf591865f8e2ada2a0009 100644 --- a/src-tauri/src/feat.rs +++ b/src-tauri/src/feat.rs @@ -183,6 +183,8 @@ pub async fn patch_clash(patch: Mapping) -> Result<()> { log_err!(handle::Handle::update_systray_part()); } + Config::runtime().latest().patch_config(patch); + <Result<()>>::Ok(()) } { Ok(()) => {