mirror of
https://github.com/SukkaW/Surge.git
synced 2026-01-28 17:41:54 +08:00
Mark more URL redirect rules as uBO uritransform-able
This commit is contained in:
@@ -5,7 +5,7 @@ import { getHostname } from 'tldts-experimental';
|
|||||||
import { OUTPUT_INTERNAL_DIR, OUTPUT_MODULES_DIR } from './constants/dir';
|
import { OUTPUT_INTERNAL_DIR, OUTPUT_MODULES_DIR } from './constants/dir';
|
||||||
import { escapeRegexp } from 'fast-escape-regexp';
|
import { escapeRegexp } from 'fast-escape-regexp';
|
||||||
|
|
||||||
const REDIRECT_MIRROR_HEADER = [
|
const REDIRECT_MIRROR_HEADER: Array<[from: string, to: string, canUboUriTransform?: boolean]> = [
|
||||||
// Gravatar
|
// Gravatar
|
||||||
// ['gravatar.neworld.org/', 'https://secure.gravatar.com/'],
|
// ['gravatar.neworld.org/', 'https://secure.gravatar.com/'],
|
||||||
['cdn.v2ex.com/gravatar/', 'https://secure.gravatar.com/avatar/', true],
|
['cdn.v2ex.com/gravatar/', 'https://secure.gravatar.com/avatar/', true],
|
||||||
@@ -74,15 +74,15 @@ const REDIRECT_MIRROR_HEADER = [
|
|||||||
['fastly-polyfill.net/', 'https://cdnjs.cloudflare.com/polyfill/', true],
|
['fastly-polyfill.net/', 'https://cdnjs.cloudflare.com/polyfill/', true],
|
||||||
['polyfill-fastly.net/', 'https://cdnjs.cloudflare.com/polyfill/', true],
|
['polyfill-fastly.net/', 'https://cdnjs.cloudflare.com/polyfill/', true],
|
||||||
// BootCDN has been controlled by a malicious actor and being used to spread malware
|
// BootCDN has been controlled by a malicious actor and being used to spread malware
|
||||||
['cdn.bootcss.com/', 'https://cdnjs.cloudflare.com/ajax/libs/'],
|
['cdn.bootcss.com/', 'https://cdnjs.cloudflare.com/ajax/libs/', true],
|
||||||
['cdn.bootcdn.net/', 'https://cdnjs.cloudflare.com/ajax/libs/'],
|
['cdn.bootcdn.net/', 'https://cdnjs.cloudflare.com/ajax/libs/', true],
|
||||||
['cdn.staticfile.net/', 'https://cdnjs.cloudflare.com/ajax/libs/'],
|
['cdn.staticfile.net/', 'https://cdnjs.cloudflare.com/ajax/libs/', true],
|
||||||
['cdn.staticfile.org/', 'https://cdnjs.cloudflare.com/ajax/libs/'],
|
['cdn.staticfile.org/', 'https://cdnjs.cloudflare.com/ajax/libs/', true],
|
||||||
// The UNPKG has not been actively maintained and is finally down (https://github.com/unpkg/unpkg/issues/412)
|
// The UNPKG has not been actively maintained and is finally down (https://github.com/unpkg/unpkg/issues/412)
|
||||||
['unpkg.com/', 'https://cdn.jsdelivr.net/npm/', true]
|
['unpkg.com/', 'https://cdn.jsdelivr.net/npm/', true]
|
||||||
] as const;
|
];
|
||||||
|
|
||||||
const REDIRECT_MIRROR_307 = [
|
const REDIRECT_MIRROR_307: Array<[from: string, to: string, canUboUriTransform?: boolean]> = [
|
||||||
// Redirect Google
|
// Redirect Google
|
||||||
['google.cn/', 'https://google.com/'],
|
['google.cn/', 'https://google.com/'],
|
||||||
['www.google.cn/', 'https://www.google.com/'],
|
['www.google.cn/', 'https://www.google.com/'],
|
||||||
@@ -94,14 +94,14 @@ const REDIRECT_MIRROR_307 = [
|
|||||||
['acg.tv/sm', 'https://www.nicovideo.jp/watch/sm'],
|
['acg.tv/sm', 'https://www.nicovideo.jp/watch/sm'],
|
||||||
['acg.tv/', 'https://b23.tv/'],
|
['acg.tv/', 'https://b23.tv/'],
|
||||||
// Minecraft Wiki
|
// Minecraft Wiki
|
||||||
['minecraft.fandom.com/wiki/', 'https://minecraft.wiki/w/'],
|
['minecraft.fandom.com/wiki/', 'https://minecraft.wiki/w/', true],
|
||||||
['minecraft.fandom.com/', 'https://minecraft.wiki/'],
|
['minecraft.fandom.com/', 'https://minecraft.wiki/', true],
|
||||||
// Hello, FANZA!
|
// Hello, FANZA!
|
||||||
['missav.com/', 'https://missav.ai/'],
|
['missav.com/', 'https://missav.ai/', true],
|
||||||
['thisav.com/', 'https://thisav.me/']
|
['thisav.com/', 'https://thisav.me/', true]
|
||||||
];
|
];
|
||||||
|
|
||||||
const REDIRECT_FAKEWEBSITES = [
|
const REDIRECT_FAKEWEBSITES: Array<[from: string, to: string]> = [ // all REDIRECT_FAKEWEBSITES can be transformed by uBO uritransform
|
||||||
// IGN China to IGN Global
|
// IGN China to IGN Global
|
||||||
['ign.xn--fiqs8s', 'https://cn.ign.com/ccpref/us'],
|
['ign.xn--fiqs8s', 'https://cn.ign.com/ccpref/us'],
|
||||||
// Fuck Makeding
|
// Fuck Makeding
|
||||||
@@ -140,7 +140,7 @@ const REDIRECT_FAKEWEBSITES = [
|
|||||||
['xshellcn.com', 'https://www.netsarang.com/products/xsh_overview.html'],
|
['xshellcn.com', 'https://www.netsarang.com/products/xsh_overview.html'],
|
||||||
['yuanchengxiezuo.com', 'https://www.teamviewer.com/zhcn'],
|
['yuanchengxiezuo.com', 'https://www.teamviewer.com/zhcn'],
|
||||||
['zbrushcn.com', 'https://www.maxon.net/en/zbrush']
|
['zbrushcn.com', 'https://www.maxon.net/en/zbrush']
|
||||||
] as const;
|
];
|
||||||
|
|
||||||
export const buildRedirectModule = task(require.main === module, __filename)(async (span) => {
|
export const buildRedirectModule = task(require.main === module, __filename)(async (span) => {
|
||||||
const fullDomains: string[] = [];
|
const fullDomains: string[] = [];
|
||||||
@@ -157,11 +157,13 @@ export const buildRedirectModule = task(require.main === module, __filename)(asy
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (let i = 0, len = REDIRECT_MIRROR_307.length; i < len; i++) {
|
for (let i = 0, len = REDIRECT_MIRROR_307.length; i < len; i++) {
|
||||||
const [from] = REDIRECT_MIRROR_307[i];
|
const [from, , canUboUriTransform] = REDIRECT_MIRROR_307[i];
|
||||||
const hostname = getHostname(from, { detectIp: false });
|
const hostname = getHostname(from, { detectIp: false });
|
||||||
if (hostname) {
|
if (hostname) {
|
||||||
fullDomains.push(hostname);
|
fullDomains.push(hostname);
|
||||||
minimumDomains.push(hostname);
|
if (!canUboUriTransform) {
|
||||||
|
minimumDomains.push(hostname);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (let i = 0, len = REDIRECT_FAKEWEBSITES.length; i < len; i++) {
|
for (let i = 0, len = REDIRECT_FAKEWEBSITES.length; i < len; i++) {
|
||||||
@@ -169,7 +171,10 @@ export const buildRedirectModule = task(require.main === module, __filename)(asy
|
|||||||
const hostname = getHostname(from, { detectIp: false });
|
const hostname = getHostname(from, { detectIp: false });
|
||||||
if (hostname) {
|
if (hostname) {
|
||||||
fullDomains.push(hostname);
|
fullDomains.push(hostname);
|
||||||
minimumDomains.push(hostname);
|
// REDIRECT_FAKEWEBSITES all can be transformed by uBO uritransform
|
||||||
|
// if (!canUboUriTransform) {
|
||||||
|
// minimumDomains.push(hostname);
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -197,6 +202,7 @@ export const buildRedirectModule = task(require.main === module, __filename)(asy
|
|||||||
`#!desc=Last Updated: ${new Date().toISOString()} Size: ${minimumDomains.length}`,
|
`#!desc=Last Updated: ${new Date().toISOString()} Size: ${minimumDomains.length}`,
|
||||||
'# This module only contains rules that doesn\'t work with/hasn\'t migrated to uBlock Origin\'s "uritransform" filter syntax',
|
'# This module only contains rules that doesn\'t work with/hasn\'t migrated to uBlock Origin\'s "uritransform" filter syntax',
|
||||||
'# uBO/AdGuard filter can be found at https://ruleset.skk.moe/Internal/sukka_ubo_url_redirect_filters.txt',
|
'# uBO/AdGuard filter can be found at https://ruleset.skk.moe/Internal/sukka_ubo_url_redirect_filters.txt',
|
||||||
|
'# This reduces mitm-hostnames and improves performance, with the tradeoff of uBO/AdGuard filter only cover mostly in browser.',
|
||||||
'',
|
'',
|
||||||
'[MITM]',
|
'[MITM]',
|
||||||
`hostname = %APPEND% ${minimumDomains.join(', ')}`,
|
`hostname = %APPEND% ${minimumDomains.join(', ')}`,
|
||||||
@@ -208,8 +214,12 @@ export const buildRedirectModule = task(require.main === module, __filename)(asy
|
|||||||
}
|
}
|
||||||
return acc;
|
return acc;
|
||||||
}, []),
|
}, []),
|
||||||
...REDIRECT_FAKEWEBSITES.map(([from, to]) => `^https?://(www.)?${(from)} ${to} 307`),
|
...REDIRECT_MIRROR_307.reduce<string[]>((acc, [from, to, canUboUriTransform]) => {
|
||||||
...REDIRECT_MIRROR_307.map(([from, to]) => `^https?://${escapeRegexp(from)}(.*) ${to}$1 307`)
|
if (!canUboUriTransform) {
|
||||||
|
acc.push(`^https?://${escapeRegexp(from)}(.*) ${to}$1 307`);
|
||||||
|
}
|
||||||
|
return acc;
|
||||||
|
}, [])
|
||||||
],
|
],
|
||||||
path.join(OUTPUT_MODULES_DIR, 'sukka_url_redirect_minimum.sgmodule')
|
path.join(OUTPUT_MODULES_DIR, 'sukka_url_redirect_minimum.sgmodule')
|
||||||
),
|
),
|
||||||
@@ -224,25 +234,47 @@ export const buildRedirectModule = task(require.main === module, __filename)(asy
|
|||||||
'! Homepage: https://ruleset.skk.moe',
|
'! Homepage: https://ruleset.skk.moe',
|
||||||
'! GitHub: https://github.com/SukkaW/Surge',
|
'! GitHub: https://github.com/SukkaW/Surge',
|
||||||
'',
|
'',
|
||||||
...REDIRECT_MIRROR_HEADER.reduce<string[]>((acc, [from, to, canUboUriTransform]) => {
|
...REDIRECT_MIRROR_HEADER.reduce<string[]>(uBOUriTransformGenerator, []),
|
||||||
if (!canUboUriTransform) {
|
...REDIRECT_MIRROR_307.reduce<string[]>(uBOUriTransformGenerator, []),
|
||||||
return acc;
|
...REDIRECT_FAKEWEBSITES.reduce<string[]>(uBOUriTransformGeneratorForFakeWebsites, [])
|
||||||
}
|
|
||||||
|
|
||||||
acc.push(
|
|
||||||
'||'
|
|
||||||
+ from
|
|
||||||
+ '$all,uritransform=/'
|
|
||||||
+ escapeRegexp(from).replaceAll('/', String.raw`\/`)
|
|
||||||
+ '/'
|
|
||||||
+ to.replace('https://', '').replaceAll('/', String.raw`\/`)
|
|
||||||
+ '/'
|
|
||||||
);
|
|
||||||
|
|
||||||
return acc;
|
|
||||||
}, [])
|
|
||||||
],
|
],
|
||||||
path.join(OUTPUT_INTERNAL_DIR, 'sukka_ubo_url_redirect_filters.txt')
|
path.join(OUTPUT_INTERNAL_DIR, 'sukka_ubo_url_redirect_filters.txt')
|
||||||
)
|
)
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function uBOUriTransformGenerator(acc: string[], [from, to, canUboUriTransform]: [from: string, to: string, canUboUriTransform?: boolean]): string[] {
|
||||||
|
if (!canUboUriTransform) {
|
||||||
|
return acc;
|
||||||
|
}
|
||||||
|
|
||||||
|
// unlike Surge, which processes rules form top to bottom, uBO treats later rules with higher priority (overriden-like behavior),
|
||||||
|
// so when doing uBO we need to prepend. Given the the rules count is small, the performance impact is negligible.
|
||||||
|
acc.unshift(
|
||||||
|
'||'
|
||||||
|
+ from
|
||||||
|
+ '$all,uritransform=/'
|
||||||
|
+ escapeRegexp(from).replaceAll('/', String.raw`\/`)
|
||||||
|
+ '/'
|
||||||
|
+ to.replace('https://', '').replaceAll('/', String.raw`\/`)
|
||||||
|
+ '/'
|
||||||
|
);
|
||||||
|
|
||||||
|
return acc;
|
||||||
|
}
|
||||||
|
|
||||||
|
function uBOUriTransformGeneratorForFakeWebsites(acc: string[], [from, to]: [from: string, to: string]): string[] {
|
||||||
|
// unlike Surge, which processes rules form top to bottom, uBO treats later rules with higher priority (overriden-like behavior),
|
||||||
|
// so when doing uBO we need to prepend. Given the the rules count is small, the performance impact is negligible.
|
||||||
|
acc.unshift(
|
||||||
|
'||'
|
||||||
|
+ from
|
||||||
|
+ '$all,uritransform=/'
|
||||||
|
+ String.raw`.*` + escapeRegexp(from).replaceAll('/', String.raw`\/`) + String.raw`\/(.*)`
|
||||||
|
+ '/'
|
||||||
|
+ to.replace('https://', '').replaceAll('/', String.raw`\/`)
|
||||||
|
+ '/'
|
||||||
|
);
|
||||||
|
|
||||||
|
return acc;
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user