mirror of
https://github.com/SukkaW/Surge.git
synced 2025-12-15 10:40:33 +08:00
Chore: validate reject stat CLI
This commit is contained in:
parent
81401fe196
commit
e7681df05a
38
Build/validate-reject-stats.ts
Normal file
38
Build/validate-reject-stats.ts
Normal file
@ -0,0 +1,38 @@
|
||||
import path from 'node:path';
|
||||
import { readFileByLine } from './lib/fetch-text-by-line';
|
||||
import { OUTPUT_SURGE_DIR } from './constants/dir';
|
||||
import { processLine } from './lib/process-line';
|
||||
import tldts from 'tldts';
|
||||
import { loosTldOptWithPrivateDomains } from './constants/loose-tldts-opt';
|
||||
|
||||
(async () => {
|
||||
const rejectDomainCountMap = await runAgainstDomainset(new Map<string, number>(), path.join(OUTPUT_SURGE_DIR, 'domainset', 'reject.conf'));
|
||||
const rejectExtraDomainCountMap = await runAgainstDomainset(new Map<string, number>(), path.join(OUTPUT_SURGE_DIR, 'domainset', 'reject_extra.conf'));
|
||||
|
||||
const rejectDomainCountArr = Array.from(rejectDomainCountMap).sort((a, b) => b[1] - a[1]).filter(([, count]) => count > 20);
|
||||
const rejectExtraDomainCountArr = Array.from(rejectExtraDomainCountMap).sort((a, b) => b[1] - a[1]).filter(([, count]) => count > 20);
|
||||
|
||||
console.table(rejectDomainCountArr);
|
||||
console.table(rejectExtraDomainCountArr);
|
||||
})();
|
||||
|
||||
async function runAgainstDomainset(rejectDomainCountMap: Map<string, number>, file: string) {
|
||||
for await (const line of readFileByLine(file)) {
|
||||
if (!processLine(line)) {
|
||||
continue;
|
||||
}
|
||||
const apexDomain = tldts.getDomain(line, loosTldOptWithPrivateDomains);
|
||||
if (!apexDomain) {
|
||||
continue;
|
||||
}
|
||||
|
||||
rejectDomainCountMap.set(
|
||||
apexDomain,
|
||||
rejectDomainCountMap.has(apexDomain)
|
||||
? rejectDomainCountMap.get(apexDomain)! + 1
|
||||
: 1
|
||||
);
|
||||
}
|
||||
|
||||
return rejectDomainCountMap;
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user