Surge_by_SukkaW/Build/build-anti-bogus-domain.js
2023-06-14 23:15:28 +08:00

62 lines
1.9 KiB
JavaScript

// @ts-check
const fs = require('fs');
const path = require('path');
const { isIPv4, isIPv6 } = require('net');
const { compareAndWriteFile } = require('./lib/string-array-compare');
const { withBannerArray } = require('./lib/with-banner');
const { fetchRemoteTextAndCreateReadlineInterface } = require('./lib/fetch-remote-text-by-line');
(async () => {
console.time('Total Time - build-anti-bogus-domain');
console.time('* Download bogus-nxdomain-list');
const rl = await fetchRemoteTextAndCreateReadlineInterface('https://raw.githubusercontent.com/felixonmars/dnsmasq-china-list/master/bogus-nxdomain.china.conf');
/** @type {string[]} */
const res = [];
for await (const line of rl) {
if (line.startsWith('bogus-nxdomain=')) {
res.push(line.replace('bogus-nxdomain=', ''));
}
}
console.timeEnd('* Download bogus-nxdomain-list')
const filePath = path.resolve(__dirname, '../Source/ip/reject.conf');
const resultPath = path.resolve(__dirname, '../List/ip/reject.conf');
const content = (await fs.promises.readFile(filePath, 'utf-8'))
.replace(
'# --- [Anti Bogus Domain Replace Me] ---',
res.map(ip => {
if (isIPv4(ip)) {
return `IP-CIDR,${ip}/32,no-resolve`
}
if (isIPv6(ip)) {
return `IP-CIDR6,${ip}/128,no-resolve`
}
return ''
}).join('\n')
);
await compareAndWriteFile(
withBannerArray(
'Sukka\'s Surge Rules - Anti Bogus Domain',
[
'License: AGPL 3.0',
'Homepage: https://ruleset.skk.moe',
'GitHub: https://github.com/SukkaW/Surge',
'',
'This file contains known addresses that are hijacking NXDOMAIN results returned by DNS servers.',
'',
'Data from:',
' - https://github.com/felixonmars/dnsmasq-china-list'
],
new Date(),
content.split('\n')
),
resultPath
)
console.timeEnd('Total Time - build-anti-bogus-domain');
})();