Compare commits
No commits in common. "main" and "v1.3.8" have entirely different histories.
22 changed files with 31 additions and 204 deletions
6
.github/workflows/alpha.yml
vendored
6
.github/workflows/alpha.yml
vendored
|
@ -21,7 +21,7 @@ jobs:
|
||||||
if: startsWith(github.repository, 'zzzgydi')
|
if: startsWith(github.repository, 'zzzgydi')
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: install Rust stable
|
- name: install Rust stable
|
||||||
uses: dtolnay/rust-toolchain@stable
|
uses: dtolnay/rust-toolchain@stable
|
||||||
|
@ -32,7 +32,7 @@ jobs:
|
||||||
workspaces: src-tauri
|
workspaces: src-tauri
|
||||||
|
|
||||||
- name: Install Node
|
- name: Install Node
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: "16"
|
node-version: "16"
|
||||||
cache: "yarn"
|
cache: "yarn"
|
||||||
|
@ -64,7 +64,7 @@ jobs:
|
||||||
- name: Yarn install and check
|
- name: Yarn install and check
|
||||||
run: |
|
run: |
|
||||||
yarn install --network-timeout 1000000 --frozen-lockfile
|
yarn install --network-timeout 1000000 --frozen-lockfile
|
||||||
yarn run check --force
|
yarn run check
|
||||||
|
|
||||||
- name: Tauri build
|
- name: Tauri build
|
||||||
uses: tauri-apps/tauri-action@v0
|
uses: tauri-apps/tauri-action@v0
|
||||||
|
|
8
.github/workflows/ci.yml
vendored
8
.github/workflows/ci.yml
vendored
|
@ -19,7 +19,7 @@ jobs:
|
||||||
if: startsWith(github.repository, 'zzzgydi')
|
if: startsWith(github.repository, 'zzzgydi')
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: install Rust stable
|
- name: install Rust stable
|
||||||
uses: dtolnay/rust-toolchain@stable
|
uses: dtolnay/rust-toolchain@stable
|
||||||
|
@ -30,7 +30,7 @@ jobs:
|
||||||
workspaces: src-tauri
|
workspaces: src-tauri
|
||||||
|
|
||||||
- name: Install Node
|
- name: Install Node
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: "16"
|
node-version: "16"
|
||||||
cache: "yarn"
|
cache: "yarn"
|
||||||
|
@ -81,10 +81,10 @@ jobs:
|
||||||
startsWith(github.ref, 'refs/tags/v')
|
startsWith(github.ref, 'refs/tags/v')
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Install Node
|
- name: Install Node
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: "16"
|
node-version: "16"
|
||||||
cache: "yarn"
|
cache: "yarn"
|
||||||
|
|
4
.github/workflows/test.yml
vendored
4
.github/workflows/test.yml
vendored
|
@ -35,7 +35,7 @@ jobs:
|
||||||
echo ${{ github.event.inputs.os }}
|
echo ${{ github.event.inputs.os }}
|
||||||
|
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: install Rust stable
|
- name: install Rust stable
|
||||||
uses: dtolnay/rust-toolchain@stable
|
uses: dtolnay/rust-toolchain@stable
|
||||||
|
@ -46,7 +46,7 @@ jobs:
|
||||||
workspaces: src-tauri
|
workspaces: src-tauri
|
||||||
|
|
||||||
- name: Install Node
|
- name: Install Node
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: "16"
|
node-version: "16"
|
||||||
cache: "yarn"
|
cache: "yarn"
|
||||||
|
|
4
.github/workflows/updater.yml
vendored
4
.github/workflows/updater.yml
vendored
|
@ -8,10 +8,10 @@ jobs:
|
||||||
if: startsWith(github.repository, 'zzzgydi')
|
if: startsWith(github.repository, 'zzzgydi')
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Install Node
|
- name: Install Node
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: "16"
|
node-version: "16"
|
||||||
cache: "yarn"
|
cache: "yarn"
|
||||||
|
|
11
README.md
11
README.md
|
@ -60,12 +60,11 @@ A <a href="https://github.com/Dreamacro/clash">Clash</a> GUI based on <a href="h
|
||||||
|
|
||||||
Download from [release](https://github.com/zzzgydi/clash-verge/releases). Supports Windows x64, Linux x86_64 and macOS 11+
|
Download from [release](https://github.com/zzzgydi/clash-verge/releases). Supports Windows x64, Linux x86_64 and macOS 11+
|
||||||
|
|
||||||
- [Windows x64](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.8/Clash.Verge_1.3.8_x64_en-US.msi)
|
- [Windows x64](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.7/Clash.Verge_1.3.7_x64_en-US.msi)
|
||||||
- [macOS intel](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.8/Clash.Verge_1.3.8_x64.dmg)
|
- [macOS intel](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.7/Clash.Verge_1.3.7_x64.dmg)
|
||||||
- [macOS arm](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.8/Clash.Verge_1.3.8_aarch64.dmg)
|
- [macOS arm](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.7/Clash.Verge_1.3.7_aarch64.dmg)
|
||||||
- [Linux AppImage](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.8/clash-verge_1.3.8_amd64.AppImage)
|
- [Linux AppImage](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.7/clash-verge_1.3.7_amd64.AppImage)
|
||||||
- [Linux deb](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.8/clash-verge_1.3.8_amd64.deb)
|
- [Linux deb](https://github.com/zzzgydi/clash-verge/releases/download/v1.3.7/clash-verge_1.3.7_amd64.deb)
|
||||||
- [Fedora Linux](https://github.com/zzzgydi/clash-verge/issues/352)
|
|
||||||
|
|
||||||
Or you can build it yourself. Supports Windows, Linux and macOS 10.15+
|
Or you can build it yourself. Supports Windows, Linux and macOS 10.15+
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@ const SIDECAR_HOST = execSync("rustc -vV")
|
||||||
const CLASH_STORAGE_PREFIX = "https://release.dreamacro.workers.dev/";
|
const CLASH_STORAGE_PREFIX = "https://release.dreamacro.workers.dev/";
|
||||||
const CLASH_URL_PREFIX =
|
const CLASH_URL_PREFIX =
|
||||||
"https://github.com/Dreamacro/clash/releases/download/premium/";
|
"https://github.com/Dreamacro/clash/releases/download/premium/";
|
||||||
const CLASH_LATEST_DATE = "latest";
|
const CLASH_LATEST_DATE = "2023.08.17";
|
||||||
|
|
||||||
const CLASH_MAP = {
|
const CLASH_MAP = {
|
||||||
"win32-x64": "clash-windows-amd64",
|
"win32-x64": "clash-windows-amd64",
|
||||||
|
@ -300,7 +300,7 @@ const resolveGeoIP = () =>
|
||||||
});
|
});
|
||||||
|
|
||||||
const tasks = [
|
const tasks = [
|
||||||
{ name: "clash", func: () => resolveSidecar(clashS3()), retry: 5 },
|
{ name: "clash", func: resolveClash, retry: 5 },
|
||||||
{ name: "clash-meta", func: () => resolveSidecar(clashMeta()), retry: 5 },
|
{ name: "clash-meta", func: () => resolveSidecar(clashMeta()), retry: 5 },
|
||||||
{ name: "wintun", func: resolveWintun, retry: 5, winOnly: true },
|
{ name: "wintun", func: resolveWintun, retry: 5, winOnly: true },
|
||||||
{ name: "service", func: resolveService, retry: 5, winOnly: true },
|
{ name: "service", func: resolveService, retry: 5, winOnly: true },
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 3.1 KiB |
Binary file not shown.
Before Width: | Height: | Size: 1.5 KiB After Width: | Height: | Size: 1.7 KiB |
|
@ -229,17 +229,6 @@ pub fn open_web_url(url: String) -> CmdResult<()> {
|
||||||
wrap_err!(open::that(url))
|
wrap_err!(open::that(url))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tauri::command]
|
|
||||||
pub async fn clash_api_get_proxy_delay(
|
|
||||||
name: String,
|
|
||||||
url: Option<String>,
|
|
||||||
) -> CmdResult<clash_api::DelayRes> {
|
|
||||||
match clash_api::get_proxy_delay(name, url).await {
|
|
||||||
Ok(res) => Ok(res),
|
|
||||||
Err(err) => Err(format!("{}", err.to_string())),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(windows)]
|
#[cfg(windows)]
|
||||||
pub mod service {
|
pub mod service {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
|
@ -24,23 +24,11 @@ impl IClashTemp {
|
||||||
pub fn template() -> Self {
|
pub fn template() -> Self {
|
||||||
let mut map = Mapping::new();
|
let mut map = Mapping::new();
|
||||||
|
|
||||||
map.insert(
|
map.insert("mixed-port".into(), 7890.into());
|
||||||
"mixed-port".into(),
|
|
||||||
match cfg!(feature = "default-meta") {
|
|
||||||
false => 7890.into(),
|
|
||||||
true => 7898.into(),
|
|
||||||
},
|
|
||||||
);
|
|
||||||
map.insert("log-level".into(), "info".into());
|
map.insert("log-level".into(), "info".into());
|
||||||
map.insert("allow-lan".into(), false.into());
|
map.insert("allow-lan".into(), false.into());
|
||||||
map.insert("mode".into(), "rule".into());
|
map.insert("mode".into(), "rule".into());
|
||||||
map.insert(
|
map.insert("external-controller".into(), "127.0.0.1:9090".into());
|
||||||
"external-controller".into(),
|
|
||||||
match cfg!(feature = "default-meta") {
|
|
||||||
false => "127.0.0.1:9090".into(),
|
|
||||||
true => "127.0.0.1:9098".into(),
|
|
||||||
},
|
|
||||||
);
|
|
||||||
map.insert("secret".into(), "".into());
|
map.insert("secret".into(), "".into());
|
||||||
|
|
||||||
Self(map)
|
Self(map)
|
||||||
|
|
|
@ -83,10 +83,6 @@ pub struct IVerge {
|
||||||
/// proxy 页面布局 列数
|
/// proxy 页面布局 列数
|
||||||
pub proxy_layout_column: Option<i32>,
|
pub proxy_layout_column: Option<i32>,
|
||||||
|
|
||||||
/// 日志清理
|
|
||||||
/// 0: 不清理; 1: 7天; 2: 30天; 3: 90天
|
|
||||||
pub auto_log_clean: Option<i32>,
|
|
||||||
|
|
||||||
/// window size and position
|
/// window size and position
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
pub window_size_position: Option<Vec<f64>>,
|
pub window_size_position: Option<Vec<f64>>,
|
||||||
|
@ -141,7 +137,6 @@ impl IVerge {
|
||||||
auto_close_connection: Some(true),
|
auto_close_connection: Some(true),
|
||||||
enable_builtin_enhanced: Some(true),
|
enable_builtin_enhanced: Some(true),
|
||||||
enable_clash_fields: Some(true),
|
enable_clash_fields: Some(true),
|
||||||
auto_log_clean: Some(3),
|
|
||||||
..Self::default()
|
..Self::default()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -188,7 +183,7 @@ impl IVerge {
|
||||||
patch!(enable_builtin_enhanced);
|
patch!(enable_builtin_enhanced);
|
||||||
patch!(proxy_layout_column);
|
patch!(proxy_layout_column);
|
||||||
patch!(enable_clash_fields);
|
patch!(enable_clash_fields);
|
||||||
patch!(auto_log_clean);
|
|
||||||
patch!(window_size_position);
|
patch!(window_size_position);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
use crate::config::Config;
|
use crate::config::Config;
|
||||||
use anyhow::{bail, Result};
|
use anyhow::{bail, Result};
|
||||||
use reqwest::header::HeaderMap;
|
use reqwest::header::HeaderMap;
|
||||||
use serde::{Deserialize, Serialize};
|
|
||||||
use serde_yaml::Mapping;
|
use serde_yaml::Mapping;
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
|
||||||
|
@ -37,32 +36,6 @@ pub async fn patch_configs(config: &Mapping) -> Result<()> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default, Debug, Clone, Deserialize, Serialize)]
|
|
||||||
pub struct DelayRes {
|
|
||||||
delay: u64,
|
|
||||||
}
|
|
||||||
|
|
||||||
/// GET /proxies/{name}/delay
|
|
||||||
/// 获取代理延迟
|
|
||||||
pub async fn get_proxy_delay(name: String, test_url: Option<String>) -> Result<DelayRes> {
|
|
||||||
let (url, headers) = clash_client_info()?;
|
|
||||||
let url = format!("{url}/proxies/{name}/delay");
|
|
||||||
|
|
||||||
let default_url = "http://www.gstatic.com/generate_204";
|
|
||||||
let test_url = test_url
|
|
||||||
.map(|s| if s.is_empty() { default_url.into() } else { s })
|
|
||||||
.unwrap_or(default_url.into());
|
|
||||||
|
|
||||||
let client = reqwest::ClientBuilder::new().no_proxy().build()?;
|
|
||||||
let builder = client
|
|
||||||
.get(&url)
|
|
||||||
.headers(headers)
|
|
||||||
.query(&[("timeout", "10000"), ("url", &test_url)]);
|
|
||||||
let response = builder.send().await?;
|
|
||||||
|
|
||||||
Ok(response.json::<DelayRes>().await?)
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 根据clash info获取clash服务地址和请求头
|
/// 根据clash info获取clash服务地址和请求头
|
||||||
fn clash_client_info() -> Result<(String, HeaderMap)> {
|
fn clash_client_info() -> Result<(String, HeaderMap)> {
|
||||||
let client = { Config::clash().data().get_client_info() };
|
let client = { Config::clash().data().get_client_info() };
|
||||||
|
|
|
@ -66,8 +66,6 @@ fn main() -> std::io::Result<()> {
|
||||||
cmds::service::check_service,
|
cmds::service::check_service,
|
||||||
cmds::service::install_service,
|
cmds::service::install_service,
|
||||||
cmds::service::uninstall_service,
|
cmds::service::uninstall_service,
|
||||||
// clash api
|
|
||||||
cmds::clash_api_get_proxy_delay
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
#[cfg(target_os = "macos")]
|
#[cfg(target_os = "macos")]
|
||||||
|
|
|
@ -1,14 +1,13 @@
|
||||||
use crate::config::*;
|
use crate::config::*;
|
||||||
use crate::utils::{dirs, help};
|
use crate::utils::{dirs, help};
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use chrono::{DateTime, Local};
|
use chrono::Local;
|
||||||
use log::LevelFilter;
|
use log::LevelFilter;
|
||||||
use log4rs::append::console::ConsoleAppender;
|
use log4rs::append::console::ConsoleAppender;
|
||||||
use log4rs::append::file::FileAppender;
|
use log4rs::append::file::FileAppender;
|
||||||
use log4rs::config::{Appender, Logger, Root};
|
use log4rs::config::{Appender, Logger, Root};
|
||||||
use log4rs::encode::pattern::PatternEncoder;
|
use log4rs::encode::pattern::PatternEncoder;
|
||||||
use std::fs::{self, DirEntry};
|
use std::fs;
|
||||||
use std::str::FromStr;
|
|
||||||
use tauri::PackageInfo;
|
use tauri::PackageInfo;
|
||||||
|
|
||||||
/// initialize this instance's log file
|
/// initialize this instance's log file
|
||||||
|
@ -70,72 +69,6 @@ fn init_log() -> Result<()> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 删除log文件
|
|
||||||
pub fn delete_log() -> Result<()> {
|
|
||||||
let log_dir = dirs::app_logs_dir()?;
|
|
||||||
if !log_dir.exists() {
|
|
||||||
return Ok(());
|
|
||||||
}
|
|
||||||
|
|
||||||
let auto_log_clean = {
|
|
||||||
let verge = Config::verge();
|
|
||||||
let verge = verge.data();
|
|
||||||
verge.auto_log_clean.clone().unwrap_or(0)
|
|
||||||
};
|
|
||||||
|
|
||||||
let day = match auto_log_clean {
|
|
||||||
1 => 7,
|
|
||||||
2 => 30,
|
|
||||||
3 => 90,
|
|
||||||
_ => return Ok(()),
|
|
||||||
};
|
|
||||||
|
|
||||||
log::debug!(target: "app", "try to delete log files, day: {day}");
|
|
||||||
|
|
||||||
// %Y-%m-%d to NaiveDateTime
|
|
||||||
let parse_time_str = |s: &str| {
|
|
||||||
let sa: Vec<&str> = s.split('-').collect();
|
|
||||||
if sa.len() != 4 {
|
|
||||||
return Err(anyhow::anyhow!("invalid time str"));
|
|
||||||
}
|
|
||||||
|
|
||||||
let year = i32::from_str(sa[0])?;
|
|
||||||
let month = u32::from_str(sa[1])?;
|
|
||||||
let day = u32::from_str(sa[2])?;
|
|
||||||
let time = chrono::NaiveDate::from_ymd_opt(year, month, day)
|
|
||||||
.ok_or(anyhow::anyhow!("invalid time str"))?
|
|
||||||
.and_hms_opt(0, 0, 0)
|
|
||||||
.ok_or(anyhow::anyhow!("invalid time str"))?;
|
|
||||||
Ok(time)
|
|
||||||
};
|
|
||||||
|
|
||||||
let process_file = |file: DirEntry| -> Result<()> {
|
|
||||||
let file_name = file.file_name();
|
|
||||||
let file_name = file_name.to_str().unwrap_or_default();
|
|
||||||
|
|
||||||
if file_name.ends_with(".log") {
|
|
||||||
let now = Local::now();
|
|
||||||
let created_time = parse_time_str(&file_name[0..file_name.len() - 4])?;
|
|
||||||
let file_time = DateTime::<Local>::from_local(created_time, now.offset().clone());
|
|
||||||
|
|
||||||
let duration = now.signed_duration_since(file_time);
|
|
||||||
if duration.num_days() > day {
|
|
||||||
let file_path = file.path();
|
|
||||||
let _ = fs::remove_file(file_path);
|
|
||||||
log::info!(target: "app", "delete log file: {file_name}");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Ok(())
|
|
||||||
};
|
|
||||||
|
|
||||||
for file in fs::read_dir(&log_dir)? {
|
|
||||||
if let Ok(file) = file {
|
|
||||||
let _ = process_file(file);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Initialize all the config files
|
/// Initialize all the config files
|
||||||
/// before tauri setup
|
/// before tauri setup
|
||||||
pub fn init_config() -> Result<()> {
|
pub fn init_config() -> Result<()> {
|
||||||
|
@ -145,7 +78,6 @@ pub fn init_config() -> Result<()> {
|
||||||
}
|
}
|
||||||
|
|
||||||
let _ = init_log();
|
let _ = init_log();
|
||||||
let _ = delete_log();
|
|
||||||
|
|
||||||
crate::log_err!(dirs::app_home_dir().map(|app_dir| {
|
crate::log_err!(dirs::app_home_dir().map(|app_dir| {
|
||||||
if !app_dir.exists() {
|
if !app_dir.exists() {
|
||||||
|
|
|
@ -75,7 +75,7 @@
|
||||||
},
|
},
|
||||||
"windows": [],
|
"windows": [],
|
||||||
"security": {
|
"security": {
|
||||||
"csp": "script-src 'unsafe-eval' 'self'; default-src blob: data: filesystem: ws: wss: http: https: tauri: 'unsafe-eval' 'unsafe-inline' 'self'; img-src data: 'self';"
|
"csp": "connect-src 'self' ws:; script-src 'unsafe-eval' 'self'; default-src blob: data: filesystem: ws: wss: http: https: tauri: 'unsafe-eval' 'unsafe-inline' 'self'; img-src data: 'self';"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,6 @@ export const MiscViewer = forwardRef<DialogRef>((props, ref) => {
|
||||||
enableBuiltinEnhanced: true,
|
enableBuiltinEnhanced: true,
|
||||||
proxyLayoutColumn: 6,
|
proxyLayoutColumn: 6,
|
||||||
defaultLatencyTest: "",
|
defaultLatencyTest: "",
|
||||||
autoLogClean: 0,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
useImperativeHandle(ref, () => ({
|
useImperativeHandle(ref, () => ({
|
||||||
|
@ -38,7 +37,6 @@ export const MiscViewer = forwardRef<DialogRef>((props, ref) => {
|
||||||
enableBuiltinEnhanced: verge?.enable_builtin_enhanced ?? true,
|
enableBuiltinEnhanced: verge?.enable_builtin_enhanced ?? true,
|
||||||
proxyLayoutColumn: verge?.proxy_layout_column || 6,
|
proxyLayoutColumn: verge?.proxy_layout_column || 6,
|
||||||
defaultLatencyTest: verge?.default_latency_test || "",
|
defaultLatencyTest: verge?.default_latency_test || "",
|
||||||
autoLogClean: verge?.auto_log_clean || 0,
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
close: () => setOpen(false),
|
close: () => setOpen(false),
|
||||||
|
@ -53,7 +51,6 @@ export const MiscViewer = forwardRef<DialogRef>((props, ref) => {
|
||||||
enable_builtin_enhanced: values.enableBuiltinEnhanced,
|
enable_builtin_enhanced: values.enableBuiltinEnhanced,
|
||||||
proxy_layout_column: values.proxyLayoutColumn,
|
proxy_layout_column: values.proxyLayoutColumn,
|
||||||
default_latency_test: values.defaultLatencyTest,
|
default_latency_test: values.defaultLatencyTest,
|
||||||
auto_log_clean: values.autoLogClean as any,
|
|
||||||
});
|
});
|
||||||
setOpen(false);
|
setOpen(false);
|
||||||
} catch (err: any) {
|
} catch (err: any) {
|
||||||
|
@ -131,7 +128,7 @@ export const MiscViewer = forwardRef<DialogRef>((props, ref) => {
|
||||||
<ListItemText primary={t("Proxy Layout Column")} />
|
<ListItemText primary={t("Proxy Layout Column")} />
|
||||||
<Select
|
<Select
|
||||||
size="small"
|
size="small"
|
||||||
sx={{ width: 135, "> div": { py: "7.5px" } }}
|
sx={{ width: 100, "> div": { py: "7.5px" } }}
|
||||||
value={values.proxyLayoutColumn}
|
value={values.proxyLayoutColumn}
|
||||||
onChange={(e) => {
|
onChange={(e) => {
|
||||||
setValues((v) => ({
|
setValues((v) => ({
|
||||||
|
@ -151,32 +148,6 @@ export const MiscViewer = forwardRef<DialogRef>((props, ref) => {
|
||||||
</Select>
|
</Select>
|
||||||
</ListItem>
|
</ListItem>
|
||||||
|
|
||||||
<ListItem sx={{ padding: "5px 2px" }}>
|
|
||||||
<ListItemText primary={t("Auto Log Clean")} />
|
|
||||||
<Select
|
|
||||||
size="small"
|
|
||||||
sx={{ width: 135, "> div": { py: "7.5px" } }}
|
|
||||||
value={values.autoLogClean}
|
|
||||||
onChange={(e) => {
|
|
||||||
setValues((v) => ({
|
|
||||||
...v,
|
|
||||||
autoLogClean: e.target.value as number,
|
|
||||||
}));
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
{[
|
|
||||||
{ key: "Never Clean", value: 0 },
|
|
||||||
{ key: "Retain 7 Days", value: 1 },
|
|
||||||
{ key: "Retain 30 Days", value: 2 },
|
|
||||||
{ key: "Retain 90 Days", value: 3 },
|
|
||||||
].map((i) => (
|
|
||||||
<MenuItem key={i.value} value={i.value}>
|
|
||||||
{t(i.key)}
|
|
||||||
</MenuItem>
|
|
||||||
))}
|
|
||||||
</Select>
|
|
||||||
</ListItem>
|
|
||||||
|
|
||||||
<ListItem sx={{ padding: "5px 2px" }}>
|
<ListItem sx={{ padding: "5px 2px" }}>
|
||||||
<ListItemText primary={t("Default Latency Test")} />
|
<ListItemText primary={t("Default Latency Test")} />
|
||||||
<TextField
|
<TextField
|
||||||
|
|
|
@ -125,11 +125,5 @@
|
||||||
"Enable Clash Fields Filter": "Enable Clash Fields Filter",
|
"Enable Clash Fields Filter": "Enable Clash Fields Filter",
|
||||||
"Enable Builtin Enhanced": "Enable Builtin Enhanced",
|
"Enable Builtin Enhanced": "Enable Builtin Enhanced",
|
||||||
"Proxy Layout Column": "Proxy Layout Column",
|
"Proxy Layout Column": "Proxy Layout Column",
|
||||||
"Default Latency Test": "Default Latency Test",
|
"Default Latency Test": "Default Latency Test"
|
||||||
|
|
||||||
"Auto Log Clean": "Auto Log Clean",
|
|
||||||
"Never Clean": "Never Clean",
|
|
||||||
"Retain 7 Days": "Retain 7 Days",
|
|
||||||
"Retain 30 Days": "Retain 30 Days",
|
|
||||||
"Retain 90 Days": "Retain 90 Days"
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -125,11 +125,5 @@
|
||||||
"Enable Clash Fields Filter": "开启Clash字段过滤",
|
"Enable Clash Fields Filter": "开启Clash字段过滤",
|
||||||
"Enable Builtin Enhanced": "开启内建增强功能",
|
"Enable Builtin Enhanced": "开启内建增强功能",
|
||||||
"Proxy Layout Column": "代理页布局列数",
|
"Proxy Layout Column": "代理页布局列数",
|
||||||
"Default Latency Test": "默认测试链接",
|
"Default Latency Test": "默认测试链接"
|
||||||
|
|
||||||
"Auto Log Clean": "自动清理日志",
|
|
||||||
"Never Clean": "不清理",
|
|
||||||
"Retain 7 Days": "保留7天",
|
|
||||||
"Retain 30 Days": "保留30天",
|
|
||||||
"Retain 90 Days": "保留90天"
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,7 +65,7 @@ export const getRules = async () => {
|
||||||
/// Get Proxy delay
|
/// Get Proxy delay
|
||||||
export const getProxyDelay = async (name: string, url?: string) => {
|
export const getProxyDelay = async (name: string, url?: string) => {
|
||||||
const params = {
|
const params = {
|
||||||
timeout: 10000,
|
timeout: 5000,
|
||||||
url: url || "http://www.gstatic.com/generate_204",
|
url: url || "http://www.gstatic.com/generate_204",
|
||||||
};
|
};
|
||||||
const instance = await getAxios();
|
const instance = await getAxios();
|
||||||
|
|
|
@ -153,11 +153,6 @@ export async function openWebUrl(url: string) {
|
||||||
return invoke<void>("open_web_url", { url });
|
return invoke<void>("open_web_url", { url });
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function cmdGetProxyDelay(name: string, url?: string) {
|
|
||||||
name = encodeURIComponent(name);
|
|
||||||
return invoke<{ delay: number }>("clash_api_get_proxy_delay", { name, url });
|
|
||||||
}
|
|
||||||
|
|
||||||
/// service mode
|
/// service mode
|
||||||
|
|
||||||
export async function checkService() {
|
export async function checkService() {
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { cmdGetProxyDelay } from "./cmds";
|
import { getProxyDelay } from "./api";
|
||||||
|
|
||||||
const hashKey = (name: string, group: string) => `${group ?? ""}::${name}`;
|
const hashKey = (name: string, group: string) => `${group ?? ""}::${name}`;
|
||||||
|
|
||||||
|
@ -74,7 +74,7 @@ class DelayManager {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const url = this.getUrl(group);
|
const url = this.getUrl(group);
|
||||||
const result = await cmdGetProxyDelay(name, url);
|
const result = await getProxyDelay(name, url);
|
||||||
delay = result.delay;
|
delay = result.delay;
|
||||||
} catch {
|
} catch {
|
||||||
delay = 1e6; // error
|
delay = 1e6; // error
|
||||||
|
@ -84,7 +84,7 @@ class DelayManager {
|
||||||
return delay;
|
return delay;
|
||||||
}
|
}
|
||||||
|
|
||||||
async checkListDelay(nameList: string[], group: string, concurrency = 36) {
|
async checkListDelay(nameList: string[], group: string, concurrency = 6) {
|
||||||
const names = nameList.filter(Boolean);
|
const names = nameList.filter(Boolean);
|
||||||
// 设置正在延迟测试中
|
// 设置正在延迟测试中
|
||||||
names.forEach((name) => this.setDelay(name, group, -2));
|
names.forEach((name) => this.setDelay(name, group, -2));
|
||||||
|
|
1
src/services/types.d.ts
vendored
1
src/services/types.d.ts
vendored
|
@ -186,7 +186,6 @@ interface IVergeConfig {
|
||||||
default_latency_test?: string;
|
default_latency_test?: string;
|
||||||
enable_clash_fields?: boolean;
|
enable_clash_fields?: boolean;
|
||||||
enable_builtin_enhanced?: boolean;
|
enable_builtin_enhanced?: boolean;
|
||||||
auto_log_clean?: 0 | 1 | 2 | 3;
|
|
||||||
proxy_layout_column?: number;
|
proxy_layout_column?: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue