build-domestic-ruleset.ts 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. // @ts-check
  2. import path from 'path';
  3. import { DOMESTICS } from '../Source/non_ip/domestic';
  4. import { DIRECTS } from '../Source/non_ip/direct';
  5. import { readFileIntoProcessedArray } from './lib/fetch-text-by-line';
  6. import { compareAndWriteFile, createRuleset } from './lib/create-file';
  7. import { task } from './trace';
  8. import { SHARED_DESCRIPTION } from './lib/constants';
  9. import { createMemoizedPromise } from './lib/memo-promise';
  10. export const getDomesticAndDirectDomainsRulesetPromise = createMemoizedPromise(async () => {
  11. const domestics = await readFileIntoProcessedArray(path.resolve(import.meta.dir, '../Source/non_ip/domestic.conf'));
  12. const directs = await readFileIntoProcessedArray(path.resolve(import.meta.dir, '../Source/non_ip/direct.conf'));
  13. Object.entries(DOMESTICS).forEach(([, { domains }]) => {
  14. domestics.push(...domains.map((domain) => `DOMAIN-SUFFIX,${domain}`));
  15. });
  16. Object.entries(DIRECTS).forEach(([, { domains }]) => {
  17. directs.push(...domains.map((domain) => `DOMAIN-SUFFIX,${domain}`));
  18. });
  19. return [domestics, directs] as const;
  20. });
  21. export const buildDomesticRuleset = task(import.meta.main, import.meta.path)(async (span) => {
  22. const res = await getDomesticAndDirectDomainsRulesetPromise();
  23. return Promise.all([
  24. createRuleset(
  25. span,
  26. 'Sukka\'s Ruleset - Domestic Domains',
  27. [
  28. ...SHARED_DESCRIPTION,
  29. '',
  30. 'This file contains known addresses that are avaliable in the Mainland China.'
  31. ],
  32. new Date(),
  33. res[0],
  34. 'ruleset',
  35. path.resolve(import.meta.dir, '../List/non_ip/domestic.conf'),
  36. path.resolve(import.meta.dir, '../Clash/non_ip/domestic.txt')
  37. ),
  38. createRuleset(
  39. span,
  40. 'Sukka\'s Ruleset - Direct Rules',
  41. [
  42. ...SHARED_DESCRIPTION,
  43. '',
  44. 'This file contains domains and process that should not be proxied.'
  45. ],
  46. new Date(),
  47. res[1],
  48. 'ruleset',
  49. path.resolve(import.meta.dir, '../List/non_ip/direct.conf'),
  50. path.resolve(import.meta.dir, '../Clash/non_ip/direct.txt')
  51. ),
  52. compareAndWriteFile(
  53. span,
  54. [
  55. '#!name=[Sukka] Local DNS Mapping',
  56. `#!desc=Last Updated: ${new Date().toISOString()}`,
  57. '',
  58. '[Host]',
  59. ...([...Object.entries(DOMESTICS), ...Object.entries(DIRECTS)])
  60. .flatMap(([, { domains, dns, ...rest }]) => [
  61. ...(
  62. 'hosts' in rest
  63. ? Object.entries(rest.hosts).flatMap(([dns, ips]: [dns: string, ips: string[]]) => `${dns} = ${ips.join(', ')}`)
  64. : []
  65. ),
  66. ...domains.flatMap((domain) => [
  67. `${domain} = server:${dns}`,
  68. `*.${domain} = server:${dns}`
  69. ])
  70. ])
  71. ],
  72. path.resolve(import.meta.dir, '../Modules/sukka_local_dns_mapping.sgmodule')
  73. )
  74. ]);
  75. });