|  | @@ -1,30 +1,22 @@
 | 
											
												
													
														|  | 
 |  | +import axios, { AxiosInstance } from "axios";
 | 
											
												
													
														|  |  import { getClashInfo } from "./cmds";
 |  |  import { getClashInfo } from "./cmds";
 | 
											
												
													
														|  | -import {
 |  | 
 | 
											
												
													
														|  | -  fetch as tauriFetch,
 |  | 
 | 
											
												
													
														|  | -  HttpVerb,
 |  | 
 | 
											
												
													
														|  | -  Body,
 |  | 
 | 
											
												
													
														|  | -  Response,
 |  | 
 | 
											
												
													
														|  | -} from "@tauri-apps/api/http";
 |  | 
 | 
											
												
													
														|  | -let clashInfo: IClashInfo | null;
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -export const refreshClashInfo = async () => {
 |  | 
 | 
											
												
													
														|  | -  clashInfo = await getClashInfo();
 |  | 
 | 
											
												
													
														|  | -  return clashInfo;
 |  | 
 | 
											
												
													
														|  | -};
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -export const fetch = async (
 |  | 
 | 
											
												
													
														|  | -  path: string,
 |  | 
 | 
											
												
													
														|  | -  method: HttpVerb,
 |  | 
 | 
											
												
													
														|  | -  body?: any
 |  | 
 | 
											
												
													
														|  | -): Promise<Response<any>> => {
 |  | 
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +let axiosIns: AxiosInstance = null!;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/// initialize some information
 | 
											
												
													
														|  | 
 |  | +/// enable force update axiosIns
 | 
											
												
													
														|  | 
 |  | +export const getAxios = async (force: boolean = false) => {
 | 
											
												
													
														|  | 
 |  | +  if (axiosIns && !force) return axiosIns;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |    let server = "";
 |  |    let server = "";
 | 
											
												
													
														|  |    let secret = "";
 |  |    let secret = "";
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    try {
 |  |    try {
 | 
											
												
													
														|  | -    const info = clashInfo ?? (await refreshClashInfo());
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const info = await getClashInfo();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      if (info?.server) {
 |  |      if (info?.server) {
 | 
											
												
													
														|  |        server = info.server;
 |  |        server = info.server;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |        // compatible width `external-controller`
 |  |        // compatible width `external-controller`
 | 
											
												
													
														|  |        if (server.startsWith(":")) server = `127.0.0.1${server}`;
 |  |        if (server.startsWith(":")) server = `127.0.0.1${server}`;
 | 
											
												
													
														|  |        else if (/^\d+$/.test(server)) server = `127.0.0.1:${server}`;
 |  |        else if (/^\d+$/.test(server)) server = `127.0.0.1:${server}`;
 | 
											
										
											
												
													
														|  | @@ -32,18 +24,19 @@ export const fetch = async (
 | 
											
												
													
														|  |      if (info?.secret) secret = info?.secret;
 |  |      if (info?.secret) secret = info?.secret;
 | 
											
												
													
														|  |    } catch {}
 |  |    } catch {}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  return tauriFetch(`http://${server}${path}`, {
 |  | 
 | 
											
												
													
														|  | -    method,
 |  | 
 | 
											
												
													
														|  | 
 |  | +  axiosIns = axios.create({
 | 
											
												
													
														|  | 
 |  | +    baseURL: `http://${server}`,
 | 
											
												
													
														|  |      headers: secret ? { Authorization: `Bearer ${secret}` } : {},
 |  |      headers: secret ? { Authorization: `Bearer ${secret}` } : {},
 | 
											
												
													
														|  |      timeout: 15000,
 |  |      timeout: 15000,
 | 
											
												
													
														|  | -    body: body ? Body.json(body) : undefined,
 |  | 
 | 
											
												
													
														|  |    });
 |  |    });
 | 
											
												
													
														|  | 
 |  | +  axiosIns.interceptors.response.use((r) => r.data);
 | 
											
												
													
														|  | 
 |  | +  return axiosIns;
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Get Version
 |  |  /// Get Version
 | 
											
												
													
														|  |  export const getVersion = async () => {
 |  |  export const getVersion = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/version", "GET");
 |  | 
 | 
											
												
													
														|  | -  return res.data as Promise<{
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  return instance.get("/version") as Promise<{
 | 
											
												
													
														|  |      premium: boolean;
 |  |      premium: boolean;
 | 
											
												
													
														|  |      meta?: boolean;
 |  |      meta?: boolean;
 | 
											
												
													
														|  |      version: string;
 |  |      version: string;
 | 
											
										
											
												
													
														|  | @@ -52,32 +45,33 @@ export const getVersion = async () => {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Get current base configs
 |  |  /// Get current base configs
 | 
											
												
													
														|  |  export const getClashConfig = async () => {
 |  |  export const getClashConfig = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/configs", "GET");
 |  | 
 | 
											
												
													
														|  | -  return res.data as Promise<IConfigData>;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  return instance.get("/configs") as Promise<IConfigData>;
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Update current configs
 |  |  /// Update current configs
 | 
											
												
													
														|  |  export const updateConfigs = async (config: Partial<IConfigData>) => {
 |  |  export const updateConfigs = async (config: Partial<IConfigData>) => {
 | 
											
												
													
														|  | -  const res = await fetch("/configs", "PATCH", config);
 |  | 
 | 
											
												
													
														|  | -  return res;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  return instance.patch("/configs", config);
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Update geo data
 |  |  /// Update geo data
 | 
											
												
													
														|  |  export const updateGeoData = async () => {
 |  |  export const updateGeoData = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/configs/geo", "POST");
 |  | 
 | 
											
												
													
														|  | -  return res;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  return instance.post("/configs/geo");
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Upgrade clash core
 |  |  /// Upgrade clash core
 | 
											
												
													
														|  |  export const upgradeCore = async () => {
 |  |  export const upgradeCore = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/upgrade", "POST");
 |  | 
 | 
											
												
													
														|  | -  return res;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  return instance.post("/upgrade");
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Get current rules
 |  |  /// Get current rules
 | 
											
												
													
														|  |  export const getRules = async () => {
 |  |  export const getRules = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/rules", "GET");
 |  | 
 | 
											
												
													
														|  | -  return res?.data?.rules as IRuleItem[];
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  const response = await instance.get<any, any>("/rules");
 | 
											
												
													
														|  | 
 |  | +  return response?.rules as IRuleItem[];
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Get Proxy delay
 |  |  /// Get Proxy delay
 | 
											
										
											
												
													
														|  | @@ -86,26 +80,25 @@ export const getProxyDelay = async (name: string, url?: string) => {
 | 
											
												
													
														|  |      timeout: 10000,
 |  |      timeout: 10000,
 | 
											
												
													
														|  |      url: url || "http://1.1.1.1",
 |  |      url: url || "http://1.1.1.1",
 | 
											
												
													
														|  |    };
 |  |    };
 | 
											
												
													
														|  | -  const result = await fetch(
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  const result = await instance.get(
 | 
											
												
													
														|  |      `/proxies/${encodeURIComponent(name)}/delay`,
 |  |      `/proxies/${encodeURIComponent(name)}/delay`,
 | 
											
												
													
														|  | -    "GET",
 |  | 
 | 
											
												
													
														|  |      { params }
 |  |      { params }
 | 
											
												
													
														|  |    );
 |  |    );
 | 
											
												
													
														|  | -  return result.data as any as { delay: number };
 |  | 
 | 
											
												
													
														|  | 
 |  | +  return result as any as { delay: number };
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Update the Proxy Choose
 |  |  /// Update the Proxy Choose
 | 
											
												
													
														|  |  export const updateProxy = async (group: string, proxy: string) => {
 |  |  export const updateProxy = async (group: string, proxy: string) => {
 | 
											
												
													
														|  | -  const res = await fetch(`/proxies/${encodeURIComponent(group)}`, "PUT", {
 |  | 
 | 
											
												
													
														|  | -    name: proxy,
 |  | 
 | 
											
												
													
														|  | -  });
 |  | 
 | 
											
												
													
														|  | -  return res;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  return instance.put(`/proxies/${encodeURIComponent(group)}`, { name: proxy });
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // get proxy
 |  |  // get proxy
 | 
											
												
													
														|  |  export const getProxiesInner = async () => {
 |  |  export const getProxiesInner = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/proxies", "GET");
 |  | 
 | 
											
												
													
														|  | -  return (res?.data?.proxies || {}) as Record<string, IProxyItem>;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  const response = await instance.get<any, any>("/proxies");
 | 
											
												
													
														|  | 
 |  | +  return (response?.proxies || {}) as Record<string, IProxyItem>;
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  /// Get the Proxy information
 |  |  /// Get the Proxy information
 | 
											
										
											
												
													
														|  | @@ -174,8 +167,10 @@ export const getProxies = async () => {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // get proxy providers
 |  |  // get proxy providers
 | 
											
												
													
														|  |  export const getProviders = async () => {
 |  |  export const getProviders = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/providers/proxies", "GET");
 |  | 
 | 
											
												
													
														|  | -  const providers = (res.data.providers || {}) as Record<string, IProviderItem>;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  const response = await instance.get<any, any>("/providers/proxies");
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  const providers = (response.providers || {}) as Record<string, IProviderItem>;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    return Object.fromEntries(
 |  |    return Object.fromEntries(
 | 
											
												
													
														|  |      Object.entries(providers).filter(([key, item]) => {
 |  |      Object.entries(providers).filter(([key, item]) => {
 | 
											
										
											
												
													
														|  | @@ -187,34 +182,31 @@ export const getProviders = async () => {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // proxy providers health check
 |  |  // proxy providers health check
 | 
											
												
													
														|  |  export const providerHealthCheck = async (name: string) => {
 |  |  export const providerHealthCheck = async (name: string) => {
 | 
											
												
													
														|  | -  const res = await fetch(
 |  | 
 | 
											
												
													
														|  | -    `/providers/proxies/${encodeURIComponent(name)}/healthcheck`,
 |  | 
 | 
											
												
													
														|  | -    "GET"
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  return instance.get(
 | 
											
												
													
														|  | 
 |  | +    `/providers/proxies/${encodeURIComponent(name)}/healthcheck`
 | 
											
												
													
														|  |    );
 |  |    );
 | 
											
												
													
														|  | -  return res;
 |  | 
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  export const providerUpdate = async (name: string) => {
 |  |  export const providerUpdate = async (name: string) => {
 | 
											
												
													
														|  | -  const res = await fetch(
 |  | 
 | 
											
												
													
														|  | -    `/providers/proxies/${encodeURIComponent(name)}`,
 |  | 
 | 
											
												
													
														|  | -    "PUT"
 |  | 
 | 
											
												
													
														|  | -  );
 |  | 
 | 
											
												
													
														|  | -  return res;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  return instance.put(`/providers/proxies/${encodeURIComponent(name)}`);
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  export const getConnections = async () => {
 |  |  export const getConnections = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/connections", "GET");
 |  | 
 | 
											
												
													
														|  | -  return res.data as any as IConnections;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  const result = await instance.get("/connections");
 | 
											
												
													
														|  | 
 |  | +  return result as any as IConnections;
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // Close specific connection
 |  |  // Close specific connection
 | 
											
												
													
														|  |  export const deleteConnection = async (id: string) => {
 |  |  export const deleteConnection = async (id: string) => {
 | 
											
												
													
														|  | -  const res = await fetch(`/connections/${encodeURIComponent(id)}`, "DELETE");
 |  | 
 | 
											
												
													
														|  | -  return res;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  await instance.delete<any, any>(`/connections/${encodeURIComponent(id)}`);
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // Close all connections
 |  |  // Close all connections
 | 
											
												
													
														|  |  export const closeAllConnections = async () => {
 |  |  export const closeAllConnections = async () => {
 | 
											
												
													
														|  | -  const res = await fetch("/connections", "DELETE");
 |  | 
 | 
											
												
													
														|  | -  return res;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const instance = await getAxios();
 | 
											
												
													
														|  | 
 |  | +  await instance.delete<any, any>(`/connections`);
 | 
											
												
													
														|  |  };
 |  |  };
 |