From 8cd054502337432f9d4e9c24dc56cd746977ec7a Mon Sep 17 00:00:00 2001 From: xream Date: Mon, 3 Jun 2024 00:34:03 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20ws,=20http,=20h2=20=E4=BC=A0=E8=BE=93?= =?UTF-8?q?=E5=B1=82=E8=A1=A5=E5=85=A8=20path?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- backend/package.json | 2 +- backend/src/core/proxy-utils/index.js | 18 ++++++++++++++++++ 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/backend/package.json b/backend/package.json index bd84d54d9..2b6851fbd 100644 --- a/backend/package.json +++ b/backend/package.json @@ -1,6 +1,6 @@ { "name": "sub-store", - "version": "2.14.331", + "version": "2.14.332", "description": "Advanced Subscription Manager for QX, Loon, Surge, Stash and ShadowRocket.", "main": "src/main.js", "scripts": { diff --git a/backend/src/core/proxy-utils/index.js b/backend/src/core/proxy-utils/index.js index 792d42279..099fcfcf7 100644 --- a/backend/src/core/proxy-utils/index.js +++ b/backend/src/core/proxy-utils/index.js @@ -438,6 +438,24 @@ function lastParse(proxy) { } } } + if (['ws', 'http', 'h2'].includes(proxy.network)) { + if ( + ['ws', 'h2'].includes(proxy.network) && + !proxy[`${proxy.network}-opts`]?.path + ) { + proxy[`${proxy.network}-opts`] = + proxy[`${proxy.network}-opts`] || {}; + proxy[`${proxy.network}-opts`].path = '/'; + } else if ( + proxy.network === 'http' && + (!Array.isArray(proxy[`${proxy.network}-opts`]?.path) || + proxy[`${proxy.network}-opts`]?.path.every((i) => !i)) + ) { + proxy[`${proxy.network}-opts`] = + proxy[`${proxy.network}-opts`] || {}; + proxy[`${proxy.network}-opts`].path = ['/']; + } + } if (['', 'off'].includes(proxy.sni)) { proxy['disable-sni'] = true; }