From 4a07c02dc1b28dc73d926a66b89759b9182c43d4 Mon Sep 17 00:00:00 2001 From: xream Date: Fri, 21 Feb 2025 01:44:34 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E6=94=AF=E6=8C=81=20Shadowrocket=20Sha?= =?UTF-8?q?dowsocks=20=E8=BE=93=E5=85=A5=E4=B8=AD=E7=9A=84=20Shadow=20TLS?= =?UTF-8?q?=20=E5=8F=82=E6=95=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- backend/package.json | 2 +- backend/src/core/proxy-utils/parsers/index.js | 21 +++++++++++++++++++ .../core/proxy-utils/producers/clashmeta.js | 3 +++ 3 files changed, 25 insertions(+), 1 deletion(-) diff --git a/backend/package.json b/backend/package.json index fb885f5ac..bbcf42409 100644 --- a/backend/package.json +++ b/backend/package.json @@ -1,6 +1,6 @@ { "name": "sub-store", - "version": "2.16.51", + "version": "2.16.52", "description": "Advanced Subscription Manager for QX, Loon, Surge, Stash and Shadowrocket.", "main": "src/main.js", "scripts": { diff --git a/backend/src/core/proxy-utils/parsers/index.js b/backend/src/core/proxy-utils/parsers/index.js index 584899708..14b44a5e4 100644 --- a/backend/src/core/proxy-utils/parsers/index.js +++ b/backend/src/core/proxy-utils/parsers/index.js @@ -190,6 +190,8 @@ function URI_SS() { // handle obfs const pluginMatch = content.match(/[?&]plugin=([^&]+)/); + const shadowTlsMatch = content.match(/[?&]shadow-tls=([^&]+)/); + if (pluginMatch) { const pluginInfo = ( 'plugin=' + decodeURIComponent(pluginMatch[1]) @@ -233,6 +235,25 @@ function URI_SS() { ); } } + // Shadowrocket + if (shadowTlsMatch) { + const params = JSON.parse(Base64.decode(shadowTlsMatch[1])); + const version = getIfNotBlank(params['version']); + const address = getIfNotBlank(params['address']); + const port = getIfNotBlank(params['port']); + proxy.plugin = 'shadow-tls'; + proxy['plugin-opts'] = { + host: getIfNotBlank(params['host']), + password: getIfNotBlank(params['password']), + version: version ? parseInt(version, 10) : undefined, + }; + if (address) { + proxy.server = address; + } + if (port) { + proxy.port = parseInt(port, 10); + } + } if (/(&|\?)uot=(1|true)/i.test(query)) { proxy['udp-over-tcp'] = true; } diff --git a/backend/src/core/proxy-utils/producers/clashmeta.js b/backend/src/core/proxy-utils/producers/clashmeta.js index 129fe1a72..a4ce88991 100644 --- a/backend/src/core/proxy-utils/producers/clashmeta.js +++ b/backend/src/core/proxy-utils/producers/clashmeta.js @@ -105,6 +105,9 @@ export default function ClashMeta_Producer() { password: proxy['shadow-tls-password'], version: proxy['shadow-tls-version'], }; + delete proxy['shadow-tls-password']; + delete proxy['shadow-tls-sni']; + delete proxy['shadow-tls-version']; } }