mirror of
https://github.com/nitezs/sub2clash.git
synced 2024-12-23 14:44:42 -05:00
将节点和订阅转换为 clash(meta) 配置
.github/workflows | ||
api | ||
config | ||
logger | ||
middleware | ||
model | ||
parser | ||
templates | ||
utils | ||
validator | ||
.env.example | ||
.gitignore | ||
.goreleaser.yaml | ||
docker-compose.yml | ||
Dockerfile | ||
go.mod | ||
go.sum | ||
LICENSE.txt | ||
main.go | ||
README.md |
sub2clash
将订阅链接转换为 Clash、Clash.Meta 配置
特性
- 开箱即用的规则、策略组配置
- 自动根据节点名称按国家划分策略组
- 支持多订阅合并
- 支持多种协议
- Shadowsocks
- ShadowsocksR
- Vmess
- Vless
- Trojan
使用
运行
配置
可以通过编辑 .env 文件来修改默认配置,docker 直接添加环境变量
变量名 | 说明 | 默认值 |
---|---|---|
BASE_PATH | 程序运行子路径,例如将服务反代在 https://example.com/sub 则此变量值应为 /sub |
/ |
PORT | 端口 | 8011 |
META_TEMPLATE | meta 模板文件名 | template_meta.yaml |
CLASH_TEMPLATE | clash 模板文件名 | template_clash.yaml |
REQUEST_RETRY_TIMES | Get 请求重试次数 | 3 |
REQUEST_MAX_FILE_SIZE | Get 请求订阅文件最大大小(byte) | 1048576 |
CACHE_EXPIRE | 订阅缓存时间(秒) | 300 |
LOG_LEVEL | 日志等级,可选值 debug ,info ,warn ,error |
info |
API
/clash
, /meta
获取 Clash/Clash.Meta 配置链接
Query 参数 | 类型 | 是否必须 | 默认值 | 说明 |
---|---|---|---|---|
sub | string | sub/proxy 至少有一项存在 | - | 订阅链接(可以输入多个,用 , 分隔) |
proxy | string | sub/proxy 至少有一项存在 | - | 节点分享链接(可以输入多个,用 , 分隔) |
refresh | bool | 否 | false |
强制刷新配置(默认缓存 5 分钟) |
template | string | 否 | - | 外部模板链接或内部模板名称 |
ruleProvider | string | 否 | - | 格式 [Behavior,Url,Group,Prepend,Name],[Behavior,Url,Group,Prepend,Name]... ,其中 Group 是该规则集所走的策略组名,Prepend 为 bool 类型,如果为 true 规则将被添加到规则列表顶部,否则添加到规则列表底部(会调整到MATCH规则之前) |
rule | string | 否 | - | 格式 [Rule,Prepend],[Rule,Prepend]... ,其中 Prepend 为 bool 类型,如果为 true 规则将被添加到规则列表顶部,否则添加到规则列表底部(会调整到MATCH规则之前) |
autoTest | bool | 否 | false |
国家策略组是否自动测速 |
lazy | bool | 否 | false |
自动测速是否启用 lazy |
sort | string | 否 | nameasc |
国家策略组排序策略,可选值 nameasc 、namedesc 、sizeasc 、sizedesc |
默认模板
已知问题
代理链接解析还没有经过严格测试,可能会出现解析错误的情况,如果出现问题请提交 issue