|  | @@ -51,6 +51,10 @@ function isPresent(value: any): boolean {
 | 
											
												
													
														|  |    return value !== null && value !== undefined;
 |  |    return value !== null && value !== undefined;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +function trimStr(str: string | undefined): string | undefined {
 | 
											
												
													
														|  | 
 |  | +  return str ? str.trim() : str;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  function isNotBlank(name: string) {
 |  |  function isNotBlank(name: string) {
 | 
											
												
													
														|  |    return name.trim().length !== 0;
 |  |    return name.trim().length !== 0;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -76,12 +80,12 @@ function decodeBase64OrOriginal(str: string): string {
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_SS(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_SS(line: string): IProxyShadowsocksConfig {
 | 
											
												
													
														|  |    // parse url
 |  |    // parse url
 | 
											
												
													
														|  |    let content = line.split("ss://")[1];
 |  |    let content = line.split("ss://")[1];
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | -    name: decodeURIComponent(line.split("#")[1]),
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxyShadowsocksConfig = {
 | 
											
												
													
														|  | 
 |  | +    name: trimStr(decodeURIComponent(line.split("#")[1])),
 | 
											
												
													
														|  |      type: "ss",
 |  |      type: "ss",
 | 
											
												
													
														|  |      server: "",
 |  |      server: "",
 | 
											
												
													
														|  |      port: 0,
 |  |      port: 0,
 | 
											
										
											
												
													
														|  | @@ -168,7 +172,7 @@ function URI_SS(line: string): IProxyConfig {
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_SSR(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_SSR(line: string): IProxyshadowsocksRConfig {
 | 
											
												
													
														|  |    line = decodeBase64OrOriginal(line.split("ssr://")[1]);
 |  |    line = decodeBase64OrOriginal(line.split("ssr://")[1]);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    // handle IPV6 & IPV4 format
 |  |    // handle IPV6 & IPV4 format
 | 
											
										
											
												
													
														|  | @@ -186,8 +190,8 @@ function URI_SSR(line: string): IProxyConfig {
 | 
											
												
													
														|  |      .substring(splitIdx + 1)
 |  |      .substring(splitIdx + 1)
 | 
											
												
													
														|  |      .split("/?")[0]
 |  |      .split("/?")[0]
 | 
											
												
													
														|  |      .split(":");
 |  |      .split(":");
 | 
											
												
													
														|  | -  let proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | -    name: "",
 |  | 
 | 
											
												
													
														|  | 
 |  | +  let proxy: IProxyshadowsocksRConfig = {
 | 
											
												
													
														|  | 
 |  | +    name: "SSR",
 | 
											
												
													
														|  |      type: "ssr",
 |  |      type: "ssr",
 | 
											
												
													
														|  |      server,
 |  |      server,
 | 
											
												
													
														|  |      port,
 |  |      port,
 | 
											
										
											
												
													
														|  | @@ -210,7 +214,7 @@ function URI_SSR(line: string): IProxyConfig {
 | 
											
												
													
														|  |    proxy = {
 |  |    proxy = {
 | 
											
												
													
														|  |      ...proxy,
 |  |      ...proxy,
 | 
											
												
													
														|  |      name: other_params.remarks
 |  |      name: other_params.remarks
 | 
											
												
													
														|  | -      ? decodeBase64OrOriginal(other_params.remarks)
 |  | 
 | 
											
												
													
														|  | 
 |  | +      ? trimStr(decodeBase64OrOriginal(other_params.remarks))
 | 
											
												
													
														|  |        : proxy.server,
 |  |        : proxy.server,
 | 
											
												
													
														|  |      "protocol-param": getIfNotBlank(
 |  |      "protocol-param": getIfNotBlank(
 | 
											
												
													
														|  |        decodeBase64OrOriginal(other_params.protoparam || "").replace(/\s/g, "")
 |  |        decodeBase64OrOriginal(other_params.protoparam || "").replace(/\s/g, "")
 | 
											
										
											
												
													
														|  | @@ -222,7 +226,7 @@ function URI_SSR(line: string): IProxyConfig {
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_VMESS(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_VMESS(line: string): IProxyVmessConfig {
 | 
											
												
													
														|  |    line = line.split("vmess://")[1];
 |  |    line = line.split("vmess://")[1];
 | 
											
												
													
														|  |    let content = decodeBase64OrOriginal(line);
 |  |    let content = decodeBase64OrOriginal(line);
 | 
											
												
													
														|  |    console.log(content);
 |  |    console.log(content);
 | 
											
										
											
												
													
														|  | @@ -238,8 +242,8 @@ function URI_VMESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | -      name: partitions[0].split("=")[0].trim(),
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const proxy: IProxyVmessConfig = {
 | 
											
												
													
														|  | 
 |  | +      name: trimStr(partitions[0].split("=")[0]),
 | 
											
												
													
														|  |        type: "vmess",
 |  |        type: "vmess",
 | 
											
												
													
														|  |        server: partitions[1],
 |  |        server: partitions[1],
 | 
											
												
													
														|  |        port: parseInt(partitions[2], 10),
 |  |        port: parseInt(partitions[2], 10),
 | 
											
										
											
												
													
														|  | @@ -308,29 +312,30 @@ function URI_VMESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  | -    console.log(params);
 |  | 
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      const server = params.add;
 |  |      const server = params.add;
 | 
											
												
													
														|  |      const port = parseInt(getIfPresent(params.port), 10);
 |  |      const port = parseInt(getIfPresent(params.port), 10);
 | 
											
												
													
														|  | -    const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const proxy: IProxyVmessConfig = {
 | 
											
												
													
														|  |        name:
 |  |        name:
 | 
											
												
													
														|  | -        params.ps ??
 |  | 
 | 
											
												
													
														|  | -        params.remarks ??
 |  | 
 | 
											
												
													
														|  | -        params.remark ??
 |  | 
 | 
											
												
													
														|  | 
 |  | +        trimStr(params.ps) ??
 | 
											
												
													
														|  | 
 |  | +        trimStr(params.remarks) ??
 | 
											
												
													
														|  | 
 |  | +        trimStr(params.remark) ??
 | 
											
												
													
														|  |          `VMess ${server}:${port}`,
 |  |          `VMess ${server}:${port}`,
 | 
											
												
													
														|  |        type: "vmess",
 |  |        type: "vmess",
 | 
											
												
													
														|  |        server,
 |  |        server,
 | 
											
												
													
														|  |        port,
 |  |        port,
 | 
											
												
													
														|  |        cipher: getIfPresent(params.scy, "auto"),
 |  |        cipher: getIfPresent(params.scy, "auto"),
 | 
											
												
													
														|  |        uuid: params.id,
 |  |        uuid: params.id,
 | 
											
												
													
														|  | -      alterId: parseInt(getIfPresent(params.aid ?? params.alterId, 0), 10),
 |  | 
 | 
											
												
													
														|  |        tls: ["tls", true, 1, "1"].includes(params.tls),
 |  |        tls: ["tls", true, 1, "1"].includes(params.tls),
 | 
											
												
													
														|  |        "skip-cert-verify": isPresent(params.verify_cert)
 |  |        "skip-cert-verify": isPresent(params.verify_cert)
 | 
											
												
													
														|  |          ? !params.verify_cert
 |  |          ? !params.verify_cert
 | 
											
												
													
														|  |          : undefined,
 |  |          : undefined,
 | 
											
												
													
														|  |      };
 |  |      };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +    proxy.alterId = parseInt(getIfPresent(params.aid ?? params.alterId, 0), 10);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      if (proxy.tls && params.sni) {
 |  |      if (proxy.tls && params.sni) {
 | 
											
												
													
														|  | -      proxy.sni = params.sni;
 |  | 
 | 
											
												
													
														|  | 
 |  | +      proxy.servername = params.sni;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      let httpupgrade = false;
 |  |      let httpupgrade = false;
 | 
											
										
											
												
													
														|  | @@ -383,7 +388,6 @@ function URI_VMESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |          if (["grpc"].includes(proxy.network)) {
 |  |          if (["grpc"].includes(proxy.network)) {
 | 
											
												
													
														|  |            proxy[`grpc-opts`] = {
 |  |            proxy[`grpc-opts`] = {
 | 
											
												
													
														|  |              "grpc-service-name": getIfNotBlank(transportPath),
 |  |              "grpc-service-name": getIfNotBlank(transportPath),
 | 
											
												
													
														|  | -            "_grpc-type": getIfNotBlank(params.type),
 |  | 
 | 
											
												
													
														|  |            };
 |  |            };
 | 
											
												
													
														|  |          } else {
 |  |          } else {
 | 
											
												
													
														|  |            const opts: Record<string, any> = {
 |  |            const opts: Record<string, any> = {
 | 
											
										
											
												
													
														|  | @@ -400,8 +404,8 @@ function URI_VMESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |          delete proxy.network;
 |  |          delete proxy.network;
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -      if (proxy.tls && !proxy.sni && transportHost) {
 |  | 
 | 
											
												
													
														|  | -        proxy.sni = transportHost;
 |  | 
 | 
											
												
													
														|  | 
 |  | +      if (proxy.tls && !proxy.servername && transportHost) {
 | 
											
												
													
														|  | 
 |  | +        proxy.servername = transportHost;
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -409,7 +413,7 @@ function URI_VMESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_VLESS(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_VLESS(line: string): IProxyVlessConfig {
 | 
											
												
													
														|  |    line = line.split("vless://")[1];
 |  |    line = line.split("vless://")[1];
 | 
											
												
													
														|  |    let isShadowrocket;
 |  |    let isShadowrocket;
 | 
											
												
													
														|  |    let parsed = /^(.*?)@(.*?):(\d+)\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 |  |    let parsed = /^(.*?)@(.*?):(\d+)\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 | 
											
										
											
												
													
														|  | @@ -428,9 +432,9 @@ function URI_VLESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |    uuid = decodeURIComponent(uuid);
 |  |    uuid = decodeURIComponent(uuid);
 | 
											
												
													
														|  |    name = decodeURIComponent(name);
 |  |    name = decodeURIComponent(name);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxyVlessConfig = {
 | 
											
												
													
														|  |      type: "vless",
 |  |      type: "vless",
 | 
											
												
													
														|  | -    name,
 |  | 
 | 
											
												
													
														|  | 
 |  | +    name: "",
 | 
											
												
													
														|  |      server,
 |  |      server,
 | 
											
												
													
														|  |      port,
 |  |      port,
 | 
											
												
													
														|  |      uuid,
 |  |      uuid,
 | 
											
										
											
												
													
														|  | @@ -444,14 +448,17 @@ function URI_VLESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    proxy.name =
 |  |    proxy.name =
 | 
											
												
													
														|  | -    name ?? params.remarks ?? params.remark ?? `VLESS ${server}:${port}`;
 |  | 
 | 
											
												
													
														|  | 
 |  | +    trimStr(name) ??
 | 
											
												
													
														|  | 
 |  | +    trimStr(params.remarks) ??
 | 
											
												
													
														|  | 
 |  | +    trimStr(params.remark) ??
 | 
											
												
													
														|  | 
 |  | +    `VLESS ${server}:${port}`;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    proxy.tls = (params.security && params.security !== "none") || undefined;
 |  |    proxy.tls = (params.security && params.security !== "none") || undefined;
 | 
											
												
													
														|  |    if (isShadowrocket && /TRUE|1/i.test(params.tls)) {
 |  |    if (isShadowrocket && /TRUE|1/i.test(params.tls)) {
 | 
											
												
													
														|  |      proxy.tls = true;
 |  |      proxy.tls = true;
 | 
											
												
													
														|  |      params.security = params.security ?? "reality";
 |  |      params.security = params.security ?? "reality";
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | -  proxy.sni = params.sni || params.peer;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  proxy.servername = params.sni || params.peer;
 | 
											
												
													
														|  |    proxy.flow = params.flow ? "xtls-rprx-vision" : undefined;
 |  |    proxy.flow = params.flow ? "xtls-rprx-vision" : undefined;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    proxy["client-fingerprint"] = params.fp as
 |  |    proxy["client-fingerprint"] = params.fp as
 | 
											
										
											
												
													
														|  | @@ -468,7 +475,7 @@ function URI_VLESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |    proxy["skip-cert-verify"] = /(TRUE)|1/i.test(params.allowInsecure);
 |  |    proxy["skip-cert-verify"] = /(TRUE)|1/i.test(params.allowInsecure);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    if (["reality"].includes(params.security)) {
 |  |    if (["reality"].includes(params.security)) {
 | 
											
												
													
														|  | -    const opts: IProxyConfig["reality-opts"] = {};
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const opts: IProxyVlessConfig["reality-opts"] = {};
 | 
											
												
													
														|  |      if (params.pbk) {
 |  |      if (params.pbk) {
 | 
											
												
													
														|  |        opts["public-key"] = params.pbk;
 |  |        opts["public-key"] = params.pbk;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
										
											
												
													
														|  | @@ -481,18 +488,17 @@ function URI_VLESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    let httpupgrade = false;
 |  |    let httpupgrade = false;
 | 
											
												
													
														|  | -  proxy.ws = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  proxy["ws-opts"] = {
 | 
											
												
													
														|  |      headers: undefined,
 |  |      headers: undefined,
 | 
											
												
													
														|  | -    "ws-service-name": undefined,
 |  | 
 | 
											
												
													
														|  |      path: undefined,
 |  |      path: undefined,
 | 
											
												
													
														|  |    };
 |  |    };
 | 
											
												
													
														|  | -  proxy.http = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  proxy["http-opts"] = {
 | 
											
												
													
														|  |      headers: undefined,
 |  |      headers: undefined,
 | 
											
												
													
														|  | -    "http-service-name": undefined,
 |  | 
 | 
											
												
													
														|  |      path: undefined,
 |  |      path: undefined,
 | 
											
												
													
														|  |    };
 |  |    };
 | 
											
												
													
														|  | -  proxy.grpc = { "_grpc-type": undefined };
 |  | 
 | 
											
												
													
														|  | -  proxy.network = params.type as "ws" | "http" | "h2" | "grpc";
 |  | 
 | 
											
												
													
														|  | 
 |  | +  proxy["grpc-opts"] = {};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |    if (params.headerType === "http") {
 |  |    if (params.headerType === "http") {
 | 
											
												
													
														|  |      proxy.network = "http";
 |  |      proxy.network = "http";
 | 
											
												
													
														|  |    } else {
 |  |    } else {
 | 
											
										
											
												
													
														|  | @@ -500,7 +506,22 @@ function URI_VLESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |      httpupgrade = true;
 |  |      httpupgrade = true;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |    if (!proxy.network && isShadowrocket && params.obfs) {
 |  |    if (!proxy.network && isShadowrocket && params.obfs) {
 | 
											
												
													
														|  | -    proxy.network = params.obfs as "ws" | "http" | "h2" | "grpc";
 |  | 
 | 
											
												
													
														|  | 
 |  | +    switch (params.type) {
 | 
											
												
													
														|  | 
 |  | +      case "sw":
 | 
											
												
													
														|  | 
 |  | +        proxy.network = "ws";
 | 
											
												
													
														|  | 
 |  | +        break;
 | 
											
												
													
														|  | 
 |  | +      case "http":
 | 
											
												
													
														|  | 
 |  | +        proxy.network = "http";
 | 
											
												
													
														|  | 
 |  | +        break;
 | 
											
												
													
														|  | 
 |  | +      case "h2":
 | 
											
												
													
														|  | 
 |  | +        proxy.network = "h2";
 | 
											
												
													
														|  | 
 |  | +        break;
 | 
											
												
													
														|  | 
 |  | +      case "grpc":
 | 
											
												
													
														|  | 
 |  | +        proxy.network = "grpc";
 | 
											
												
													
														|  | 
 |  | +        break;
 | 
											
												
													
														|  | 
 |  | +      default: {
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |    if (["websocket"].includes(proxy.network)) {
 |  |    if (["websocket"].includes(proxy.network)) {
 | 
											
												
													
														|  |      proxy.network = "ws";
 |  |      proxy.network = "ws";
 | 
											
										
											
												
													
														|  | @@ -520,20 +541,9 @@ function URI_VLESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |          opts.headers = { Host: host };
 |  |          opts.headers = { Host: host };
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  | -    if (params.serviceName) {
 |  | 
 | 
											
												
													
														|  | -      opts[`${proxy.network}-service-name`] = params.serviceName;
 |  | 
 | 
											
												
													
														|  | -    } else if (isShadowrocket && params.path) {
 |  | 
 | 
											
												
													
														|  | -      if (!["ws", "http", "h2"].includes(proxy.network)) {
 |  | 
 | 
											
												
													
														|  | -        opts[`${proxy.network}-service-name`] = params.path;
 |  | 
 | 
											
												
													
														|  | -        delete params.path;
 |  | 
 | 
											
												
													
														|  | -      }
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  |      if (params.path) {
 |  |      if (params.path) {
 | 
											
												
													
														|  |        opts.path = params.path;
 |  |        opts.path = params.path;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  | -    if (["grpc"].includes(proxy.network)) {
 |  | 
 | 
											
												
													
														|  | -      opts["_grpc-type"] = params.mode || "gun";
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  |      if (httpupgrade) {
 |  |      if (httpupgrade) {
 | 
											
												
													
														|  |        opts["v2ray-http-upgrade"] = true;
 |  |        opts["v2ray-http-upgrade"] = true;
 | 
											
												
													
														|  |        opts["v2ray-http-upgrade-fast-open"] = true;
 |  |        opts["v2ray-http-upgrade-fast-open"] = true;
 | 
											
										
											
												
													
														|  | @@ -543,25 +553,25 @@ function URI_VLESS(line: string): IProxyConfig {
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  if (proxy.tls && !proxy.sni) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  if (proxy.tls && !proxy.servername) {
 | 
											
												
													
														|  |      if (proxy.network === "ws") {
 |  |      if (proxy.network === "ws") {
 | 
											
												
													
														|  | -      proxy.sni = proxy.ws?.headers?.Host;
 |  | 
 | 
											
												
													
														|  | 
 |  | +      proxy.servername = proxy["ws-opts"]?.headers?.Host;
 | 
											
												
													
														|  |      } else if (proxy.network === "http") {
 |  |      } else if (proxy.network === "http") {
 | 
											
												
													
														|  | -      let httpHost = proxy.http?.headers?.Host;
 |  | 
 | 
											
												
													
														|  | -      proxy.sni = Array.isArray(httpHost) ? httpHost[0] : httpHost;
 |  | 
 | 
											
												
													
														|  | 
 |  | +      let httpHost = proxy["http-opts"]?.headers?.Host;
 | 
											
												
													
														|  | 
 |  | +      proxy.servername = Array.isArray(httpHost) ? httpHost[0] : httpHost;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_Trojan(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_Trojan(line: string): IProxyTrojanConfig {
 | 
											
												
													
														|  |    let [newLine, name] = line.split(/#(.+)/, 2);
 |  |    let [newLine, name] = line.split(/#(.+)/, 2);
 | 
											
												
													
														|  |    const parser = getTrojanURIParser();
 |  |    const parser = getTrojanURIParser();
 | 
											
												
													
														|  | -  const proxy = parser.parse(newLine);
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxyTrojanConfig = parser.parse(newLine);
 | 
											
												
													
														|  |    if (isNotBlank(name)) {
 |  |    if (isNotBlank(name)) {
 | 
											
												
													
														|  |      try {
 |  |      try {
 | 
											
												
													
														|  | -      proxy.name = decodeURIComponent(name);
 |  | 
 | 
											
												
													
														|  | 
 |  | +      proxy.name = trimStr(decodeURIComponent(name));
 | 
											
												
													
														|  |      } catch (e) {
 |  |      } catch (e) {
 | 
											
												
													
														|  |        throw Error("Can not get proxy name");
 |  |        throw Error("Can not get proxy name");
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
										
											
												
													
														|  | @@ -569,7 +579,7 @@ function URI_Trojan(line: string): IProxyConfig {
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_Hysteria2(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_Hysteria2(line: string): IProxyHysteria2Config {
 | 
											
												
													
														|  |    line = line.split(/(hysteria2|hy2):\/\//)[2];
 |  |    line = line.split(/(hysteria2|hy2):\/\//)[2];
 | 
											
												
													
														|  |    // eslint-disable-next-line no-unused-vars
 |  |    // eslint-disable-next-line no-unused-vars
 | 
											
												
													
														|  |    let [__, password, server, ___, port, ____, addons = "", name] =
 |  |    let [__, password, server, ___, port, ____, addons = "", name] =
 | 
											
										
											
												
													
														|  | @@ -579,12 +589,12 @@ function URI_Hysteria2(line: string): IProxyConfig {
 | 
											
												
													
														|  |      portNum = 443;
 |  |      portNum = 443;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |    password = decodeURIComponent(password);
 |  |    password = decodeURIComponent(password);
 | 
											
												
													
														|  | -  if (name != null) {
 |  | 
 | 
											
												
													
														|  | -    name = decodeURIComponent(name);
 |  | 
 | 
											
												
													
														|  | -  }
 |  | 
 | 
											
												
													
														|  | -  name = name ?? `Hysteria2 ${server}:${port}`;
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  let decodedName = trimStr(decodeURIComponent(name));
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  name = decodedName ?? `Hysteria2 ${server}:${port}`;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxyHysteria2Config = {
 | 
											
												
													
														|  |      type: "hysteria2",
 |  |      type: "hysteria2",
 | 
											
												
													
														|  |      name,
 |  |      name,
 | 
											
												
													
														|  |      server,
 |  |      server,
 | 
											
										
											
												
													
														|  | @@ -612,12 +622,12 @@ function URI_Hysteria2(line: string): IProxyConfig {
 | 
											
												
													
														|  |    proxy["obfs-password"] = params["obfs-password"];
 |  |    proxy["obfs-password"] = params["obfs-password"];
 | 
											
												
													
														|  |    proxy["skip-cert-verify"] = /(TRUE)|1/i.test(params.insecure);
 |  |    proxy["skip-cert-verify"] = /(TRUE)|1/i.test(params.insecure);
 | 
											
												
													
														|  |    proxy.tfo = /(TRUE)|1/i.test(params.fastopen);
 |  |    proxy.tfo = /(TRUE)|1/i.test(params.fastopen);
 | 
											
												
													
														|  | -  proxy["tls-fingerprint"] = params.pinSHA256;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  proxy.fingerprint = params.pinSHA256;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_Hysteria(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_Hysteria(line: string): IProxyHysteriaConfig {
 | 
											
												
													
														|  |    line = line.split(/(hysteria|hy):\/\//)[2];
 |  |    line = line.split(/(hysteria|hy):\/\//)[2];
 | 
											
												
													
														|  |    let [__, server, ___, port, ____, addons = "", name] =
 |  |    let [__, server, ___, port, ____, addons = "", name] =
 | 
											
												
													
														|  |      /^(.*?)(:(\d+))?\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 |  |      /^(.*?)(:(\d+))?\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 | 
											
										
											
												
													
														|  | @@ -625,12 +635,11 @@ function URI_Hysteria(line: string): IProxyConfig {
 | 
											
												
													
														|  |    if (isNaN(portNum)) {
 |  |    if (isNaN(portNum)) {
 | 
											
												
													
														|  |      portNum = 443;
 |  |      portNum = 443;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | -  if (name != null) {
 |  | 
 | 
											
												
													
														|  | -    name = decodeURIComponent(name);
 |  | 
 | 
											
												
													
														|  | -  }
 |  | 
 | 
											
												
													
														|  | -  name = name ?? `Hysteria ${server}:${port}`;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  let decodedName = trimStr(decodeURIComponent(name));
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  name = decodedName ?? `Hysteria ${server}:${port}`;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxyHysteriaConfig = {
 | 
											
												
													
														|  |      type: "hysteria",
 |  |      type: "hysteria",
 | 
											
												
													
														|  |      name,
 |  |      name,
 | 
											
												
													
														|  |      server,
 |  |      server,
 | 
											
										
											
												
													
														|  | @@ -713,7 +722,7 @@ function URI_Hysteria(line: string): IProxyConfig {
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_TUIC(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_TUIC(line: string): IProxyTuicConfig {
 | 
											
												
													
														|  |    line = line.split(/tuic:\/\//)[1];
 |  |    line = line.split(/tuic:\/\//)[1];
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    let [__, uuid, password, server, ___, port, ____, addons = "", name] =
 |  |    let [__, uuid, password, server, ___, port, ____, addons = "", name] =
 | 
											
										
											
												
													
														|  | @@ -724,12 +733,11 @@ function URI_TUIC(line: string): IProxyConfig {
 | 
											
												
													
														|  |      portNum = 443;
 |  |      portNum = 443;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |    password = decodeURIComponent(password);
 |  |    password = decodeURIComponent(password);
 | 
											
												
													
														|  | -  if (name != null) {
 |  | 
 | 
											
												
													
														|  | -    name = decodeURIComponent(name);
 |  | 
 | 
											
												
													
														|  | -  }
 |  | 
 | 
											
												
													
														|  | -  name = name ?? `TUIC ${server}:${port}`;
 |  | 
 | 
											
												
													
														|  | 
 |  | +  let decodedName = trimStr(decodeURIComponent(name));
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  name = decodedName ?? `TUIC ${server}:${port}`;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxyTuicConfig = {
 | 
											
												
													
														|  |      type: "tuic",
 |  |      type: "tuic",
 | 
											
												
													
														|  |      name,
 |  |      name,
 | 
											
												
													
														|  |      server,
 |  |      server,
 | 
											
										
											
												
													
														|  | @@ -794,7 +802,7 @@ function URI_TUIC(line: string): IProxyConfig {
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_Wireguard(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_Wireguard(line: string): IProxyWireguardConfig {
 | 
											
												
													
														|  |    line = line.split(/(wireguard|wg):\/\//)[2];
 |  |    line = line.split(/(wireguard|wg):\/\//)[2];
 | 
											
												
													
														|  |    let [__, ___, privateKey, server, ____, port, _____, addons = "", name] =
 |  |    let [__, ___, privateKey, server, ____, port, _____, addons = "", name] =
 | 
											
												
													
														|  |      /^((.*?)@)?(.*?)(:(\d+))?\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 |  |      /^((.*?)@)?(.*?)(:(\d+))?\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 | 
											
										
											
												
													
														|  | @@ -804,11 +812,10 @@ function URI_Wireguard(line: string): IProxyConfig {
 | 
											
												
													
														|  |      portNum = 443;
 |  |      portNum = 443;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |    privateKey = decodeURIComponent(privateKey);
 |  |    privateKey = decodeURIComponent(privateKey);
 | 
											
												
													
														|  | -  if (name != null) {
 |  | 
 | 
											
												
													
														|  | -    name = decodeURIComponent(name);
 |  | 
 | 
											
												
													
														|  | -  }
 |  | 
 | 
											
												
													
														|  | -  name = name ?? `WireGuard ${server}:${port}`;
 |  | 
 | 
											
												
													
														|  | -  const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  let decodedName = trimStr(decodeURIComponent(name));
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  name = decodedName ?? `WireGuard ${server}:${port}`;
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxyWireguardConfig = {
 | 
											
												
													
														|  |      type: "wireguard",
 |  |      type: "wireguard",
 | 
											
												
													
														|  |      name,
 |  |      name,
 | 
											
												
													
														|  |      server,
 |  |      server,
 | 
											
										
											
												
													
														|  | @@ -877,7 +884,7 @@ function URI_Wireguard(line: string): IProxyConfig {
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_HTTP(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_HTTP(line: string): IProxyHttpConfig {
 | 
											
												
													
														|  |    line = line.split(/(http|https):\/\//)[2];
 |  |    line = line.split(/(http|https):\/\//)[2];
 | 
											
												
													
														|  |    let [__, ___, auth, server, ____, port, _____, addons = "", name] =
 |  |    let [__, ___, auth, server, ____, port, _____, addons = "", name] =
 | 
											
												
													
														|  |      /^((.*?)@)?(.*?)(:(\d+))?\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 |  |      /^((.*?)@)?(.*?)(:(\d+))?\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 | 
											
										
											
												
													
														|  | @@ -889,11 +896,10 @@ function URI_HTTP(line: string): IProxyConfig {
 | 
											
												
													
														|  |    if (auth) {
 |  |    if (auth) {
 | 
											
												
													
														|  |      auth = decodeURIComponent(auth);
 |  |      auth = decodeURIComponent(auth);
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | -  if (name != null) {
 |  | 
 | 
											
												
													
														|  | -    name = decodeURIComponent(name);
 |  | 
 | 
											
												
													
														|  | -  }
 |  | 
 | 
											
												
													
														|  | -  name = name ?? `HTTP ${server}:${portNum}`;
 |  | 
 | 
											
												
													
														|  | -  const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  let decodedName = trimStr(decodeURIComponent(name));
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  name = decodedName ?? `HTTP ${server}:${portNum}`;
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxyHttpConfig = {
 | 
											
												
													
														|  |      type: "http",
 |  |      type: "http",
 | 
											
												
													
														|  |      name,
 |  |      name,
 | 
											
												
													
														|  |      server,
 |  |      server,
 | 
											
										
											
												
													
														|  | @@ -919,9 +925,6 @@ function URI_HTTP(line: string): IProxyConfig {
 | 
											
												
													
														|  |        case "skip-cert-verify":
 |  |        case "skip-cert-verify":
 | 
											
												
													
														|  |          proxy["skip-cert-verify"] = /(TRUE)|1/i.test(value);
 |  |          proxy["skip-cert-verify"] = /(TRUE)|1/i.test(value);
 | 
											
												
													
														|  |          break;
 |  |          break;
 | 
											
												
													
														|  | -      case "udp":
 |  | 
 | 
											
												
													
														|  | -        proxy["udp"] = /(TRUE)|1/i.test(value);
 |  | 
 | 
											
												
													
														|  | -        break;
 |  | 
 | 
											
												
													
														|  |        case "ip-version":
 |  |        case "ip-version":
 | 
											
												
													
														|  |          proxy["ip-version"] = value;
 |  |          proxy["ip-version"] = value;
 | 
											
												
													
														|  |          break;
 |  |          break;
 | 
											
										
											
												
													
														|  | @@ -933,7 +936,7 @@ function URI_HTTP(line: string): IProxyConfig {
 | 
											
												
													
														|  |    return proxy;
 |  |    return proxy;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -function URI_SOCKS(line: string): IProxyConfig {
 |  | 
 | 
											
												
													
														|  | 
 |  | +function URI_SOCKS(line: string): IProxySocks5Config {
 | 
											
												
													
														|  |    line = line.split(/socks5:\/\//)[1];
 |  |    line = line.split(/socks5:\/\//)[1];
 | 
											
												
													
														|  |    let [__, ___, auth, server, ____, port, _____, addons = "", name] =
 |  |    let [__, ___, auth, server, ____, port, _____, addons = "", name] =
 | 
											
												
													
														|  |      /^((.*?)@)?(.*?)(:(\d+))?\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 |  |      /^((.*?)@)?(.*?)(:(\d+))?\/?(\?(.*?))?(?:#(.*?))?$/.exec(line)!;
 | 
											
										
											
												
													
														|  | @@ -945,11 +948,9 @@ function URI_SOCKS(line: string): IProxyConfig {
 | 
											
												
													
														|  |    if (auth) {
 |  |    if (auth) {
 | 
											
												
													
														|  |      auth = decodeURIComponent(auth);
 |  |      auth = decodeURIComponent(auth);
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | -  if (name != null) {
 |  | 
 | 
											
												
													
														|  | -    name = decodeURIComponent(name);
 |  | 
 | 
											
												
													
														|  | -  }
 |  | 
 | 
											
												
													
														|  | -  name = name ?? `SOCKS5 ${server}:${portNum}`;
 |  | 
 | 
											
												
													
														|  | -  const proxy: IProxyConfig = {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  let decodedName = trimStr(decodeURIComponent(name));
 | 
											
												
													
														|  | 
 |  | +  name = decodedName ?? `SOCKS5 ${server}:${portNum}`;
 | 
											
												
													
														|  | 
 |  | +  const proxy: IProxySocks5Config = {
 | 
											
												
													
														|  |      type: "socks5",
 |  |      type: "socks5",
 | 
											
												
													
														|  |      name,
 |  |      name,
 | 
											
												
													
														|  |      server,
 |  |      server,
 |