diff --git a/backend/package.json b/backend/package.json index 88225d0e5..fe46f3a5f 100644 --- a/backend/package.json +++ b/backend/package.json @@ -1,6 +1,6 @@ { "name": "sub-store", - "version": "2.14.321", + "version": "2.14.322", "description": "Advanced Subscription Manager for QX, Loon, Surge, Stash and ShadowRocket.", "main": "src/main.js", "scripts": { diff --git a/backend/src/core/proxy-utils/processors/index.js b/backend/src/core/proxy-utils/processors/index.js index 2e8d84f24..7f1ecbbb0 100644 --- a/backend/src/core/proxy-utils/processors/index.js +++ b/backend/src/core/proxy-utils/processors/index.js @@ -512,12 +512,17 @@ function ResolveDomainOperator({ provider, type: _type, filter, cache }) { return { name: 'Resolve Domain Operator', func: async (proxies) => { + proxies.forEach((p, i) => { + if (!p['_no-resolve'] && p['no-resolve']) { + proxies[i]['_no-resolve'] = p['no-resolve']; + } + }); const results = {}; const limit = 15; // more than 20 concurrency may result in surge TCP connection shortage. const totalDomain = [ ...new Set( proxies - .filter((p) => !isIP(p.server) && !p['no-resolve']) + .filter((p) => !isIP(p.server) && !p['_no-resolve']) .map((c) => c.server), ), ]; @@ -543,7 +548,7 @@ function ResolveDomainOperator({ provider, type: _type, filter, cache }) { await Promise.all(currentBatch); } proxies.forEach((p) => { - if (!p['no-resolve']) { + if (!p['_no-resolve']) { if (results[p.server]) { if (_type === 'IP4P') { const { server, port } = parseIP4P( @@ -578,7 +583,7 @@ function ResolveDomainOperator({ provider, type: _type, filter, cache }) { return proxies.filter((p) => { if (filter === 'removeFailed') { - return isIP(p.server) || p['no-resolve'] || p.resolved; + return isIP(p.server) || p['_no-resolve'] || p.resolved; } else if (filter === 'IPOnly') { return isIP(p.server); } else if (filter === 'IPv4Only') { diff --git a/backend/src/core/proxy-utils/producers/clash.js b/backend/src/core/proxy-utils/producers/clash.js index 800532c70..eeb95ff9b 100644 --- a/backend/src/core/proxy-utils/producers/clash.js +++ b/backend/src/core/proxy-utils/producers/clash.js @@ -158,6 +158,7 @@ export default function Clash_Producer() { delete proxy.collectionName; delete proxy.id; delete proxy.resolved; + delete proxy['no-resolve']; for (const key in proxy) { if (proxy[key] == null || /^_/i.test(key)) { delete proxy[key]; diff --git a/backend/src/core/proxy-utils/producers/clashmeta.js b/backend/src/core/proxy-utils/producers/clashmeta.js index 54680cb6d..bb8376c96 100644 --- a/backend/src/core/proxy-utils/producers/clashmeta.js +++ b/backend/src/core/proxy-utils/producers/clashmeta.js @@ -173,6 +173,7 @@ export default function ClashMeta_Producer() { delete proxy.collectionName; delete proxy.id; delete proxy.resolved; + delete proxy['no-resolve']; for (const key in proxy) { if (proxy[key] == null || /^_/i.test(key)) { delete proxy[key]; diff --git a/backend/src/core/proxy-utils/producers/shadowrocket.js b/backend/src/core/proxy-utils/producers/shadowrocket.js index 6f4709398..041e06a8d 100644 --- a/backend/src/core/proxy-utils/producers/shadowrocket.js +++ b/backend/src/core/proxy-utils/producers/shadowrocket.js @@ -176,6 +176,7 @@ export default function ShadowRocket_Producer() { delete proxy.collectionName; delete proxy.id; delete proxy.resolved; + delete proxy['no-resolve']; for (const key in proxy) { if (proxy[key] == null || /^_/i.test(key)) { delete proxy[key]; diff --git a/backend/src/core/proxy-utils/producers/stash.js b/backend/src/core/proxy-utils/producers/stash.js index 5c6343047..b6585ac0e 100644 --- a/backend/src/core/proxy-utils/producers/stash.js +++ b/backend/src/core/proxy-utils/producers/stash.js @@ -265,6 +265,7 @@ export default function Stash_Producer() { delete proxy.collectionName; delete proxy.id; delete proxy.resolved; + delete proxy['no-resolve']; for (const key in proxy) { if (proxy[key] == null || /^_/i.test(key)) { delete proxy[key]; diff --git a/backend/src/core/proxy-utils/producers/uri.js b/backend/src/core/proxy-utils/producers/uri.js index c2150ec56..a0410b81d 100644 --- a/backend/src/core/proxy-utils/producers/uri.js +++ b/backend/src/core/proxy-utils/producers/uri.js @@ -10,6 +10,7 @@ export default function URI_Producer() { delete proxy.collectionName; delete proxy.id; delete proxy.resolved; + delete proxy['no-resolve']; for (const key in proxy) { if (proxy[key] == null || /^_/i.test(key)) { delete proxy[key]; diff --git a/scripts/demo.js b/scripts/demo.js index 92b879b4d..0d790f423 100644 --- a/scripts/demo.js +++ b/scripts/demo.js @@ -7,7 +7,7 @@ function operator(proxies = [], targetPlatform, context) { // proxies 为传入的内部节点数组 // 结构大致参考了 Clash.Meta(mihomo) 有私货 // 可在预览界面点击节点查看 JSON 结构 或查看 `target=JSON` 的通用订阅 - // 1. `no-resolve` 为不解析域名 + // 1. `_no-resolve` 为不解析域名 // 2. 域名解析后 会多一个 `_resolved` 字段 // 3. 域名解析后会有`_IPv4`, `_IPv6`, `_IP`(若有多个步骤, 只取第一次成功的 v4 或 v6 数据), `_domain` 字段 // 4. 节点字段 `exec` 为 `ssr-local` 路径, 默认 `/usr/local/bin/ssr-local`; 端口从 10000 开始递增(暂不支持配置)