build-anti-bogus-domain.ts 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. // @ts-check
  2. import path from 'path';
  3. import { createRuleset } from './lib/create-file';
  4. import { fetchRemoteTextByLine, readFileByLine } from './lib/fetch-text-by-line';
  5. import { processLine } from './lib/process-line';
  6. import { task } from './trace';
  7. import { SHARED_DESCRIPTION } from './lib/constants';
  8. import { isProbablyIpv4, isProbablyIpv6 } from './lib/is-fast-ip';
  9. import { TTL, deserializeArray, fsCache, serializeArray } from './lib/cache-filesystem';
  10. const URL = 'https://raw.githubusercontent.com/felixonmars/dnsmasq-china-list/master/bogus-nxdomain.china.conf';
  11. const getBogusNxDomainIPsPromise = fsCache.apply(
  12. URL,
  13. async () => {
  14. const result: string[] = [];
  15. for await (const line of await fetchRemoteTextByLine(URL)) {
  16. if (line && line.startsWith('bogus-nxdomain=')) {
  17. const ip = line.slice(15).trim();
  18. if (isProbablyIpv4(ip)) {
  19. result.push(`IP-CIDR,${ip}/32,no-resolve`);
  20. } else if (isProbablyIpv6(ip)) {
  21. result.push(`IP-CIDR6,${ip}/128,no-resolve`);
  22. }
  23. }
  24. }
  25. return result;
  26. },
  27. {
  28. ttl: TTL.ONE_WEEK(),
  29. serializer: serializeArray,
  30. deserializer: deserializeArray
  31. }
  32. );
  33. export const buildAntiBogusDomain = task(import.meta.path, async (span) => {
  34. const result: string[] = [];
  35. for await (const line of readFileByLine(path.resolve(import.meta.dir, '../Source/ip/reject.conf'))) {
  36. const l = processLine(line);
  37. if (l) {
  38. result.push(l);
  39. }
  40. }
  41. result.push(...(await getBogusNxDomainIPsPromise));
  42. const description = [
  43. ...SHARED_DESCRIPTION,
  44. '',
  45. 'This file contains known addresses that are hijacking NXDOMAIN results returned by DNS servers.',
  46. '',
  47. 'Data from:',
  48. ' - https://github.com/felixonmars/dnsmasq-china-list'
  49. ];
  50. return createRuleset(
  51. span,
  52. 'Sukka\'s Ruleset - Anti Bogus Domain',
  53. description,
  54. new Date(),
  55. result,
  56. 'ruleset',
  57. path.resolve(import.meta.dir, '../List/ip/reject.conf'),
  58. path.resolve(import.meta.dir, '../Clash/ip/reject.txt')
  59. );
  60. });
  61. if (import.meta.main) {
  62. buildAntiBogusDomain();
  63. }