1
0
mirror of https://github.com/nitezs/sub2sing-box.git synced 2024-12-10 09:38:49 -05:00
将节点和订阅转换为 sing-box 配置
Go to file
2024-11-16 01:18:49 +08:00
.github/workflows try to fix ss parser 2024-11-06 18:38:59 +08:00
.vscode try to fix ss parser 2024-11-06 18:38:59 +08:00
api try to fix ss parser 2024-11-06 18:38:59 +08:00
cmd fix 2024-11-16 01:16:22 +08:00
common try to fix ss parser 2024-11-06 18:38:59 +08:00
constant feat: add socks parser 2024-11-13 10:49:01 +08:00
model mod: country code map 2024-11-16 01:18:49 +08:00
parser fix: hy2 parser 2024-11-16 00:26:54 +08:00
templates try to fix ss parser 2024-11-06 18:38:59 +08:00
util try to fix ss parser 2024-11-06 18:38:59 +08:00
.gitattributes try to fix ss parser 2024-11-06 18:38:59 +08:00
.gitignore try to fix ss parser 2024-11-06 18:38:59 +08:00
.goreleaser.yaml try to fix ss parser 2024-11-06 18:38:59 +08:00
docker-compose.yaml try to fix ss parser 2024-11-06 18:38:59 +08:00
Dockerfile try to fix ss parser 2024-11-06 18:38:59 +08:00
go.mod try to fix ss parser 2024-11-06 18:38:59 +08:00
go.sum try to fix ss parser 2024-11-06 18:38:59 +08:00
LICENSE try to fix ss parser 2024-11-06 18:38:59 +08:00
main.go try to fix ss parser 2024-11-06 18:38:59 +08:00
merge-templates.sh 🐛 Fix vless reality missing utls 2024-10-22 20:29:45 +08:00
README.md try to fix ss parser 2024-11-06 18:38:59 +08:00

sub2sing-box

将订阅/节点连接转换为 sing-box 配置的工具。

控制台命令

使用 sub2sing-box <command> -h 查看各命令的帮助信息。

配置

示例:

{
  "subscriptions": ["订阅地址1", "订阅地址2"],
  "proxies": ["代理1", "代理2"],
  "template": "模板路径或网络地址",
  "delete": "剩余流量",
  "rename": { "原文本": "新文本" },
  "group-type": "selector",
  "sort": "name",
  "sort-type": "asc",
  "output": "./config.json"
}

将上述 JSON 内容保存为 sub2sing-box.json,执行:

sub2sing-box convert -c ./sub2sing-box.json

即可生成 sing-box 配置,无需每次重复设置参数。

模板

默认模板

默认模板位于 templates 目录,使用 tun 配置,可以根据需求自行修改模板内容。

占位符

模板中可使用以下占位符:

  • <all-proxy-tags>: 插入所有节点标签
  • <all-country-tags>: 插入所有国家标签
  • <国家(地区)二字码>: 插入指定国家(地区)所有节点标签,如 <tw>

占位符使用示例:

假设有节点:

  • US
  • SG
  • TW
{
  "type": "selector",
  "tag": "节点选择",
  "outbounds": ["<all-proxy-tags>", "direct"],
  "interrupt_exist_connections": true
}

// 转换后

{
  "type": "selector",
  "tag": "节点选择",
  "outbounds": ["US", "SG", "TW", "direct"],
  "interrupt_exist_connections": true
}
{
  "type": "selector",
  "tag": "节点选择",
  "outbounds": ["<all-country-tags>", "direct"],
  "interrupt_exist_connections": true
}

// 转换后

{
  "type": "selector",
  "tag": "节点选择",
  "outbounds": ["美国(US)", "新加坡(SG)", "台湾(TW)", "direct"],
  "interrupt_exist_connections": true
}

// 其中 "美国(US)", "新加坡(SG)", "台湾(TW)" 为策略组,分别包含 US, SG, TW 节点
{
  "type": "selector",
  "tag": "巴哈姆特",
  "outbounds": ["<tw>", "direct"],
  "interrupt_exist_connections": true
}

// 转换后

{
  "type": "selector",
  "tag": "巴哈姆特",
  "outbounds": ["台湾(TW)", "direct"],
  "interrupt_exist_connections": true
}

Docker 使用

docker run -p 8080:8080 nite07/sub2sing-box:latest

可以挂载目录添加自定义模板

Server 模式 API

GET /convert

query 描述
data 同上方配置,但需要使用 base64 URL safe 编码