Skip to content

Commit

Permalink
Fix AdGuardHome & Clash Output
Browse files Browse the repository at this point in the history
  • Loading branch information
SukkaW committed Dec 14, 2024
1 parent 9c82e53 commit e25bf90
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 25 deletions.
10 changes: 7 additions & 3 deletions Build/lib/rules/base.ts
Original file line number Diff line number Diff line change
Expand Up @@ -242,7 +242,7 @@ export abstract class RuleOutput<TPreprocessed = unknown> {
return this;
}

protected abstract preprocess(): NonNullable<TPreprocessed>;
protected abstract preprocess(): TPreprocessed extends null ? null : NonNullable<TPreprocessed>;

async done() {
await this.pendingPromise;
Expand All @@ -258,13 +258,17 @@ export abstract class RuleOutput<TPreprocessed = unknown> {
}

private $$preprocessed: TPreprocessed | null = null;
get $preprocessed() {
protected runPreprocess() {
if (this.$$preprocessed === null) {
this.guardPendingPromise();

this.$$preprocessed = this.span.traceChildSync('preprocess', () => this.preprocess());
}
return this.$$preprocessed;
}

get $preprocessed(): TPreprocessed extends null ? null : NonNullable<TPreprocessed> {
this.runPreprocess();
return this.$$preprocessed as any;
}

async writeClash(outputDir?: null | string) {
Expand Down
44 changes: 22 additions & 22 deletions Build/lib/rules/domainset.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,9 @@ export class DomainsetOutput extends RuleOutput<string[]> {
private $clash: string[] = ['this_ruleset_is_made_by_sukkaw.ruleset.skk.moe'];
private $singbox_domains: string[] = ['this_ruleset_is_made_by_sukkaw.ruleset.skk.moe'];
private $singbox_domains_suffixes: string[] = ['this_ruleset_is_made_by_sukkaw.ruleset.skk.moe'];

private $adguardhome: string[] = [];
preprocess() {
const kwfilter = createKeywordFilter(this.domainKeywords);
const results: string[] = [];

this.domainTrie.dumpWithoutDot((domain, subdomain) => {
if (kwfilter(domain)) {
Expand All @@ -29,21 +28,29 @@ export class DomainsetOutput extends RuleOutput<string[]> {
this.$clash.push(subdomain ? `+.${domain}` : domain);
(subdomain ? this.$singbox_domains : this.$singbox_domains_suffixes).push(domain);

results.push(domain);
if (subdomain) {
this.$adguardhome.push(`||${domain}^`);
} else {
this.$adguardhome.push(`|${domain}^`);
}
}, true);

return results;
return this.$surge;
}

surge(): string[] {
this.runPreprocess();
return this.$surge;
}

clash(): string[] {
this.runPreprocess();
return this.$clash;
}

singbox(): string[] {
this.runPreprocess();

return RuleOutput.jsonToLines({
version: 2,
rules: [{
Expand All @@ -55,6 +62,8 @@ export class DomainsetOutput extends RuleOutput<string[]> {

protected apexDomainMap: Map<string, string> | null = null;
getStatMap() {
this.runPreprocess();

invariant(this.$preprocessed, 'Non dumped yet');

if (!this.apexDomainMap) {
Expand Down Expand Up @@ -90,7 +99,7 @@ export class DomainsetOutput extends RuleOutput<string[]> {
mitmSgmodule = undefined;

adguardhome(): string[] {
const results: string[] = [];
this.runPreprocess();

// const whitelistArray = sortDomains(Array.from(whitelist));
// for (let i = 0, len = whitelistArray.length; i < len; i++) {
Expand All @@ -102,51 +111,42 @@ export class DomainsetOutput extends RuleOutput<string[]> {
// }
// }

for (let i = 0, len = this.$preprocessed.length; i < len; i++) {
const domain = this.$preprocessed[i];
if (domain[0] === '.') {
results.push(`||${domain.slice(1)}^`);
} else {
results.push(`|${domain}^`);
}
}

for (const wildcard of this.domainWildcard) {
const processed = wildcard.replaceAll('?', '*');
if (processed.startsWith('*.')) {
results.push(`||${processed.slice(2)}^`);
this.$adguardhome.push(`||${processed.slice(2)}^`);
} else {
results.push(`|${processed}^`);
this.$adguardhome.push(`|${processed}^`);
}
}

for (const keyword of this.domainKeywords) {
// Use regex to match keyword
results.push(`/${escapeStringRegexp(keyword)}/`);
this.$adguardhome.push(`/${escapeStringRegexp(keyword)}/`);
}

for (const ipGroup of [this.ipcidr, this.ipcidrNoResolve]) {
for (const ipcidr of ipGroup) {
if (ipcidr.endsWith('/32')) {
results.push(`||${ipcidr.slice(0, -3)}`);
this.$adguardhome.push(`||${ipcidr.slice(0, -3)}`);
/* else if (ipcidr.endsWith('.0/24')) {
results.push(`||${ipcidr.slice(0, -6)}.*`);
} */
} else {
results.push(`||${ipcidr}^`);
this.$adguardhome.push(`||${ipcidr}^`);
}
}
}
for (const ipGroup of [this.ipcidr6, this.ipcidr6NoResolve]) {
for (const ipcidr of ipGroup) {
if (ipcidr.endsWith('/128')) {
results.push(`||${ipcidr.slice(0, -4)}`);
this.$adguardhome.push(`||${ipcidr.slice(0, -4)}`);
} else {
results.push(`||${ipcidr}`);
this.$adguardhome.push(`||${ipcidr}`);
}
}
}

return results;
return this.$adguardhome;
}
}

0 comments on commit e25bf90

Please sign in to comment.