diff --git a/backend/package.json b/backend/package.json index 276602e41..a642bd3f2 100644 --- a/backend/package.json +++ b/backend/package.json @@ -1,6 +1,6 @@ { "name": "sub-store", - "version": "2.14.97", + "version": "2.14.99", "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 7b89dc725..1257bc2ac 100644 --- a/backend/src/core/proxy-utils/processors/index.js +++ b/backend/src/core/proxy-utils/processors/index.js @@ -451,7 +451,9 @@ function ResolveDomainOperator({ provider }) { const limit = 15; // more than 20 concurrency may result in surge TCP connection shortage. const totalDomain = [ ...new Set( - proxies.filter((p) => !isIP(p.server)).map((c) => c.server), + proxies + .filter((p) => !isIP(p.server) && !p['no-resolve']) + .map((c) => c.server), ), ]; const totalBatch = Math.ceil(totalDomain.length / limit); @@ -475,8 +477,15 @@ function ResolveDomainOperator({ provider }) { } await Promise.all(currentBatch); } - proxies.forEach((proxy) => { - proxy.server = results[proxy.server] || proxy.server; + proxies.forEach((p) => { + if (!p['no-resolve']) { + if (results[p.server]) { + p.server = results[p.server]; + p.resolved = true; + } else { + p.resolved = false; + } + } }); return proxies;