mirror of
https://github.com/SukkaW/Surge.git
synced 2026-01-29 01:51:52 +08:00
Refactor Stream Hosts
This commit is contained in:
79
Build/build-stream-service.js
Normal file
79
Build/build-stream-service.js
Normal file
@@ -0,0 +1,79 @@
|
||||
// @ts-check
|
||||
const { task } = require('./lib/trace-runner');
|
||||
|
||||
const path = require('path');
|
||||
const { createRuleset } = require('./lib/create-file');
|
||||
|
||||
const {
|
||||
ALL, NORTH_AMERICA, EU, HK, TW, JP, KR
|
||||
// SOUTH_EAST_ASIA, AU
|
||||
} = require('../Source/stream');
|
||||
|
||||
/**
|
||||
* @param {string} fileId
|
||||
* @param {string} title
|
||||
* @param {import('../Source/stream').StreamService[]} streamServices
|
||||
*/
|
||||
const createRulesetForStreamService = (fileId, title, streamServices) => {
|
||||
return [
|
||||
// Domains
|
||||
...createRuleset(
|
||||
`Sukka's Ruleset - Stream Services: ${title}`,
|
||||
[
|
||||
'License: AGPL 3.0',
|
||||
'Homepage: https://ruleset.skk.moe',
|
||||
'GitHub: https://github.com/SukkaW/Surge',
|
||||
'',
|
||||
...streamServices.map(i => `- ${i.name}`)
|
||||
],
|
||||
new Date(),
|
||||
streamServices.flatMap(i => i.rules),
|
||||
'ruleset',
|
||||
path.resolve(__dirname, `../List/non_ip/${fileId}.conf`),
|
||||
path.resolve(__dirname, `../Clash/non_ip/${fileId}.txt`)
|
||||
),
|
||||
// IP
|
||||
...createRuleset(
|
||||
`Sukka's Ruleset - Stream Services' IPs: ${title}`,
|
||||
[
|
||||
'License: AGPL 3.0',
|
||||
'Homepage: https://ruleset.skk.moe',
|
||||
'GitHub: https://github.com/SukkaW/Surge',
|
||||
'',
|
||||
...streamServices.map(i => `- ${i.name}`)
|
||||
],
|
||||
new Date(),
|
||||
streamServices.flatMap(i => (
|
||||
i.ip
|
||||
? [
|
||||
...i.ip.v4.map(ip => `IP-CIDR,${ip},no-resolve`),
|
||||
...i.ip.v6.map(ip => `IP-CIDR6,${ip},no-resolve`)
|
||||
]
|
||||
: []
|
||||
)),
|
||||
'ruleset',
|
||||
path.resolve(__dirname, `../List/ip/${fileId}.conf`),
|
||||
path.resolve(__dirname, `../Clash/ip/${fileId}.txt`)
|
||||
)
|
||||
];
|
||||
};
|
||||
|
||||
const buildStreamService = task(__filename, async () => {
|
||||
return Promise.all([
|
||||
...createRulesetForStreamService('stream', 'All', ALL),
|
||||
...createRulesetForStreamService('stream_us', 'North America', NORTH_AMERICA),
|
||||
...createRulesetForStreamService('stream_eu', 'Europe', EU),
|
||||
...createRulesetForStreamService('stream_hk', 'Hong Kong', HK),
|
||||
...createRulesetForStreamService('stream_tw', 'Taiwan', TW),
|
||||
...createRulesetForStreamService('stream_jp', 'Japan', JP),
|
||||
// ...createRulesetForStreamService('stream_au', 'Oceania', AU),
|
||||
...createRulesetForStreamService('stream_kr', 'Korean', KR)
|
||||
// ...createRulesetForStreamService('stream_south_east_asia', 'South East Asia', SOUTH_EAST_ASIA)
|
||||
]);
|
||||
});
|
||||
|
||||
module.exports.buildStreamService = buildStreamService;
|
||||
|
||||
if (require.main === module) {
|
||||
buildStreamService();
|
||||
}
|
||||
Reference in New Issue
Block a user