domain-deduper.ts 807 B

1234567891011121314151617181920212223242526272829303132
  1. import { createTrie } from './trie';
  2. export function domainDeduper(inputDomains: string[], toArray?: true): string[];
  3. export function domainDeduper(inputDomains: string[], toArray: false): Set<string>;
  4. export function domainDeduper(inputDomains: string[], toArray = true): string[] | Set<string> {
  5. const trie = createTrie(inputDomains);
  6. const sets = new Set(inputDomains);
  7. for (let i = 0, len = inputDomains.length; i < len; i++) {
  8. const d = inputDomains[i];
  9. if (d[0] !== '.') {
  10. continue;
  11. }
  12. const found = trie.find(d, true);
  13. for (let j = 0, len = found.length; j < len; j++) {
  14. sets.delete(found[j]);
  15. }
  16. const a: string = d.slice(1);
  17. if (sets.has(a)) {
  18. sets.delete(a);
  19. }
  20. }
  21. if (toArray) {
  22. return Array.from(sets);
  23. }
  24. return sets;
  25. }