Skip to content

Commit

Permalink
Revert "feat: disable running with admin permission and check service…
Browse files Browse the repository at this point in the history
… mode"

This reverts commit a0f9fb9.
  • Loading branch information
MystiPanda committed Jun 16, 2024
1 parent 19b6f78 commit a9ef32c
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 71 deletions.
55 changes: 9 additions & 46 deletions src-tauri/src/feat.rs
Original file line number Diff line number Diff line change
Expand Up @@ -88,37 +88,16 @@ pub fn toggle_system_proxy() {
pub fn toggle_tun_mode() {
let enable = Config::verge().data().enable_tun_mode;
let enable = enable.unwrap_or(false);

tauri::async_runtime::spawn(async move {
if !enable {
if let Ok(res) = service::check_service().await {
if res.code == 0 {
match patch_verge(IVerge {
enable_tun_mode: Some(!enable),
..IVerge::default()
})
.await
{
Ok(_) => handle::Handle::refresh_verge(),
Err(err) => log::error!(target: "app", "{err}"),
}
return;
}
}
tauri::api::dialog::message(
None::<&tauri::Window>,
"Please install and enable service mode",
"Service mode is required for Tun mode",
);
} else {
match patch_verge(IVerge {
enable_tun_mode: Some(!enable),
..IVerge::default()
})
.await
{
Ok(_) => handle::Handle::refresh_verge(),
Err(err) => log::error!(target: "app", "{err}"),
}
match patch_verge(IVerge {
enable_tun_mode: Some(!enable),
..IVerge::default()
})
.await
{
Ok(_) => handle::Handle::refresh_verge(),
Err(err) => log::error!(target: "app", "{err}"),
}
});
}
Expand Down Expand Up @@ -424,19 +403,3 @@ pub async fn test_delay(url: String) -> Result<u32> {
}
}
}

pub fn check_permission() -> Result<()> {
#[cfg(target_os = "windows")]
{
let hklm = winreg::RegKey::predef(winreg::enums::HKEY_LOCAL_MACHINE);

if let Ok(reg) = hklm.open_subkey_with_flags(
"SOFTWARE\\WOW6432Node\\Microsoft\\Windows\\CurrentVersion\\Run",
winreg::enums::KEY_SET_VALUE,
) {
reg.delete_value("Clash Verge").unwrap_or_default();
return Ok(());
}
}
Err(anyhow::anyhow!("permission denied"))
}
10 changes: 0 additions & 10 deletions src-tauri/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,6 @@ fn main() -> std::io::Result<()> {
println!("app exists");
return Ok(());
}
// 权限检测
if feat::check_permission().is_ok() {
println!("please do not run with admin permission");
tauri::api::dialog::blocking::message(
None::<&tauri::Window>,
"Please do not run with admin permission",
"If you want to use Tun mode, please enable service mode instead",
);
return Ok(());
}

#[cfg(target_os = "linux")]
std::env::set_var("WEBKIT_DISABLE_DMABUF_RENDERER", "1");
Expand Down
1 change: 0 additions & 1 deletion src/components/setting/mods/stack-mode-switch.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@ export const StackModeSwitch = (props: Props) => {
>
gVisor
</Button>

<Button
variant={value?.toLowerCase() === "mixed" ? "contained" : "outlined"}
onClick={() => onChange?.("mixed")}
Expand Down
21 changes: 7 additions & 14 deletions src/components/setting/setting-system.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,15 +22,11 @@ const SettingSystem = ({ onError }: Props) => {
const { verge, mutateVerge, patchVerge } = useVerge();

// service mode
const { data: serviceStatus, mutate: mutateCheck } = useSWR(
"checkService",
checkService,
{
revalidateIfStale: false,
shouldRetryOnError: false,
focusThrottleInterval: 36e5, // 1 hour
}
);
const { data: serviceStatus } = useSWR("checkService", checkService, {
revalidateIfStale: false,
shouldRetryOnError: false,
focusThrottleInterval: 36e5, // 1 hour
});

const serviceRef = useRef<DialogRef>(null);
const sysproxyRef = useRef<DialogRef>(null);
Expand Down Expand Up @@ -88,7 +84,7 @@ const SettingSystem = ({ onError }: Props) => {
onChange={(e) => onChangeData({ enable_tun_mode: e })}
onGuard={(e) => patchVerge({ enable_tun_mode: e })}
>
<Switch disabled={serviceStatus !== "active"} edge="end" />
<Switch edge="end" />
</GuardState>
</SettingItem>

Expand All @@ -113,10 +109,7 @@ const SettingSystem = ({ onError }: Props) => {
onCatch={onError}
onFormat={onSwitchFormat}
onChange={(e) => onChangeData({ enable_service_mode: e })}
onGuard={(e) => {
setTimeout(() => mutateCheck(), 1000);
return patchVerge({ enable_service_mode: e });
}}
onGuard={(e) => patchVerge({ enable_service_mode: e })}
>
<Switch
edge="end"
Expand Down

0 comments on commit a9ef32c

Please sign in to comment.