| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- const tldts = require('tldts');
- const picocolors = require('picocolors');
- const fs = require('fs');
- const path = require('path');
- const SPECIAL_SUFFIXES = new Set([
- 'linodeobjects.com', // only *.linodeobjects.com are public suffix
- 'vultrobjects.com', // only *.vultrobjects.com are public suffix
- 'dweb.link' // only *.dweb.link are public suffix
- ]);
- (async () => {
- const domainSetContent = await fs.promises.readFile(
- path.resolve(__dirname, '../List/domainset/cdn.conf'),
- { encoding: 'utf-8' }
- );
- const domainSetLines = domainSetContent.split('\n');
- for (let i = 0, len = domainSetLines.length; i < len; i++) {
- const line = domainSetLines[i];
- // starts with #
- if (line.charCodeAt(0) === 35) {
- continue;
- }
- if (line.trim().length === 0) {
- continue;
- }
- const domain = line.charCodeAt(0) === 46 ? line.slice(1) : line;
- const parsed = tldts.parse(domain, { allowPrivateDomains: true });
- if (
- (
- parsed.isPrivate
- || parsed.isIcann
- ) && domain === parsed.publicSuffix
- ) {
- console.error('Domain', picocolors.yellow(domain), picocolors.red('is in public suffix list!'));
- }
- }
- const rulesetContent = await fs.promises.readFile(
- path.resolve(__dirname, '../List/non_ip/cdn.conf'),
- { encoding: 'utf-8' }
- );
- const rulesetLines = rulesetContent.split('\n');
- for (let i = 0, len = rulesetLines.length; i < len; i++) {
- const line = rulesetLines[i];
- // starts with #
- if (line.charCodeAt(0) === 35) {
- continue;
- }
- if (line.trim().length === 0) {
- continue;
- }
- if (line.startsWith('DOMAIN-SUFFIX')) {
- const domain = line.slice(14);
- const parsed = tldts.parse(domain, { allowPrivateDomains: true });
- if (domain !== parsed.publicSuffix) {
- if (!SPECIAL_SUFFIXES.has(domain)) {
- console.error('Domain', picocolors.yellow(domain), picocolors.green('is not in public suffix list!'));
- }
- }
- }
- }
- })();
|