index.ts 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. import process from 'node:process';
  2. import os from 'node:os';
  3. import { downloadPreviousBuild } from './download-previous-build';
  4. import { buildCommon } from './build-common';
  5. import { buildRejectIPList } from './build-reject-ip-list';
  6. import { buildAppleCdn } from './build-apple-cdn';
  7. import { buildCdnDownloadConf } from './build-cdn-download-conf';
  8. import { buildRejectDomainSet } from './build-reject-domainset';
  9. import { buildTelegramCIDR } from './build-telegram-cidr';
  10. import { buildChnCidr } from './build-chn-cidr';
  11. import { buildSpeedtestDomainSet } from './build-speedtest-domainset';
  12. import { buildInternalReverseChnCIDR } from './build-internal-reverse-chn-cidr';
  13. import { buildDomesticRuleset } from './build-domestic-direct-lan-ruleset-dns-mapping-module';
  14. import { buildStreamService } from './build-stream-service';
  15. import { buildRedirectModule } from './build-sgmodule-redirect';
  16. import { buildAlwaysRealIPModule } from './build-sgmodule-always-realip';
  17. import { buildMicrosoftCdn } from './build-microsoft-cdn';
  18. import { buildSSPanelUIMAppProfile } from './build-sspanel-appprofile';
  19. import { buildPublic } from './build-public';
  20. import { downloadMockAssets } from './download-mock-assets';
  21. import { buildCloudMounterRules } from './build-cloudmounter-rules';
  22. import { createSpan, printTraceResult, whyIsNodeRunning } from './trace';
  23. import { buildDeprecateFiles } from './build-deprecate-files';
  24. import { cacheGc } from './lib/make-fetch-happen';
  25. process.on('uncaughtException', (error) => {
  26. console.error('Uncaught exception:', error);
  27. process.exit(1);
  28. });
  29. process.on('unhandledRejection', (reason) => {
  30. console.error('Unhandled rejection:', reason);
  31. process.exit(1);
  32. });
  33. (async () => {
  34. console.log('Version:', process.version);
  35. console.log(`OS: ${os.type()} ${os.release()} ${os.arch()}`);
  36. console.log(`Node.js: ${process.versions.node}`);
  37. console.log(`V8: ${process.versions.v8}`);
  38. const cpus = os.cpus()
  39. .reduce<Record<string, number>>((o, cpu) => {
  40. o[cpu.model] = (o[cpu.model] || 0) + 1;
  41. return o;
  42. }, {});
  43. console.log(`CPU: ${
  44. Object.keys(cpus)
  45. .map((key) => `${key} x ${cpus[key]}`)
  46. .join('\n')
  47. }`);
  48. console.log(`Memory: ${os.totalmem() / (1024 * 1024)} MiB`);
  49. const rootSpan = createSpan('root');
  50. try {
  51. const downloadPreviousBuildPromise = downloadPreviousBuild(rootSpan);
  52. const buildCommonPromise = downloadPreviousBuildPromise.then(() => buildCommon(rootSpan));
  53. const buildRejectIPListPromise = downloadPreviousBuildPromise.then(() => buildRejectIPList(rootSpan));
  54. const buildAppleCdnPromise = downloadPreviousBuildPromise.then(() => buildAppleCdn(rootSpan));
  55. const buildCdnConfPromise = downloadPreviousBuildPromise.then(() => buildCdnDownloadConf(rootSpan));
  56. const buildRejectDomainSetPromise = downloadPreviousBuildPromise.then(() => buildRejectDomainSet(rootSpan));
  57. const buildTelegramCIDRPromise = downloadPreviousBuildPromise.then(() => buildTelegramCIDR(rootSpan));
  58. const buildChnCidrPromise = downloadPreviousBuildPromise.then(() => buildChnCidr(rootSpan));
  59. const buildSpeedtestDomainSetPromise = downloadPreviousBuildPromise.then(() => buildSpeedtestDomainSet(rootSpan));
  60. const buildInternalReverseChnCIDRPromise = buildInternalReverseChnCIDR(rootSpan);
  61. // const buildInternalChnDomainsPromise = buildInternalChnDomains();
  62. const buildDomesticRulesetPromise = downloadPreviousBuildPromise.then(() => buildDomesticRuleset(rootSpan));
  63. const buildRedirectModulePromise = downloadPreviousBuildPromise.then(() => buildRedirectModule(rootSpan));
  64. const buildAlwaysRealIPModulePromise = downloadPreviousBuildPromise.then(() => buildAlwaysRealIPModule(rootSpan));
  65. const buildStreamServicePromise = downloadPreviousBuildPromise.then(() => buildStreamService(rootSpan));
  66. const buildMicrosoftCdnPromise = downloadPreviousBuildPromise.then(() => buildMicrosoftCdn(rootSpan));
  67. const buildSSPanelUIMAppProfilePromise = downloadPreviousBuildPromise.then(() => buildSSPanelUIMAppProfile(rootSpan));
  68. const downloadMockAssetsPromise = downloadMockAssets(rootSpan);
  69. const buildCloudMounterRulesPromise = downloadPreviousBuildPromise.then(() => buildCloudMounterRules(rootSpan));
  70. await Promise.all([
  71. downloadPreviousBuildPromise,
  72. buildCommonPromise,
  73. buildRejectIPListPromise,
  74. buildAppleCdnPromise,
  75. buildCdnConfPromise,
  76. buildRejectDomainSetPromise,
  77. buildTelegramCIDRPromise,
  78. buildChnCidrPromise,
  79. buildSpeedtestDomainSetPromise,
  80. buildInternalReverseChnCIDRPromise,
  81. buildInternalReverseChnCIDRPromise,
  82. // buildInternalChnDomainsPromise,
  83. buildDomesticRulesetPromise,
  84. buildRedirectModulePromise,
  85. buildAlwaysRealIPModulePromise,
  86. buildStreamServicePromise,
  87. buildMicrosoftCdnPromise,
  88. buildSSPanelUIMAppProfilePromise,
  89. buildCloudMounterRulesPromise,
  90. downloadMockAssetsPromise
  91. ]);
  92. await Promise.all([
  93. buildDeprecateFiles(rootSpan).then(() => buildPublic(rootSpan)),
  94. cacheGc(rootSpan)
  95. ]);
  96. rootSpan.stop();
  97. printTraceResult(rootSpan.traceResult);
  98. // Finish the build to avoid leaking timer/fetch ref
  99. await whyIsNodeRunning();
  100. process.exit(0);
  101. } catch (e) {
  102. console.error('Something went wrong!');
  103. console.trace(e);
  104. process.exit(1);
  105. }
  106. })();