fix(subscribe): enhance server tag handling in subscription logic

This commit is contained in:
Chang lue Tsen 2025-04-30 15:38:01 +09:00
parent 9a1942f8cf
commit c5b0507187
3 changed files with 37 additions and 13 deletions

View File

@ -177,27 +177,28 @@ func (l *SubscribeLogic) getRules() ([]*server.RuleGroup, error) {
func (l *SubscribeLogic) buildClientConfig(req *types.SubscribeRequest, userSub *user.Subscribe, servers []*server.Server, rules []*server.RuleGroup) ([]byte, string, error) {
tags := make(map[string][]*server.Server)
groups, err := l.svc.ServerModel.QueryAllGroup(l.ctx)
serverTags, err := l.svc.ServerModel.FindServerTags(l.ctx)
if err != nil {
l.Errorw("[Generate Subscribe]find group error: %v", logger.Field("error", err.Error()))
return nil, "", errors.Wrapf(xerr.NewErrCode(xerr.DatabaseQueryError), "find group error: %v", err.Error())
l.Errorw("[Generate Subscribe]find server tags error: %v", logger.Field("error", err.Error()))
return nil, "", errors.Wrapf(xerr.NewErrCode(xerr.DatabaseQueryError), "find server tags error: %v", err.Error())
}
for _, group := range groups {
total, servers, err := l.svc.ServerModel.FindServerListByFilter(l.ctx, &server.ServerFilter{
Tags: []string{group.Name},
})
// Deduplicate tags
serverTags = tool.RemoveDuplicateElements(serverTags...)
for _, tag := range serverTags {
s, err := l.svc.ServerModel.FindServersByTag(l.ctx.Request.Context(), tag)
if err != nil {
l.Errorw("[Generate Subscribe]find servers by tag error: %v", logger.Field("error", err.Error()))
continue
}
if total > 0 {
tags[group.Name] = servers
if len(s) > 0 {
tags[tag] = s
}
}
proxyManager := adapter.NewAdapter(&adapter.Config{
Nodes: servers,
Rules: rules,
Tags: make(map[string][]*server.Server),
Tags: tags,
})
clientType := l.getClientType(req)
var resp []byte

View File

@ -12,25 +12,36 @@ import (
"github.com/perfect-panel/server/pkg/adapter/surfboard"
)
type Config struct {
Nodes []*server.Server
Rules []*server.RuleGroup
Tags map[string][]*server.Server
}
type Adapter struct {
proxy.Adapter
}
func NewAdapter(nodes []*server.Server, rules []*server.RuleGroup) *Adapter {
func NewAdapter(cfg *Config) *Adapter {
// 转换服务器列表
proxies := adapterProxies(nodes)
proxies := adapterProxies(cfg.Nodes)
// 生成代理组
proxyGroup, region := generateProxyGroup(proxies)
// 转换规则组
g, r := adapterRules(rules)
g, r := adapterRules(cfg.Rules)
// 加入兜底节点
for i, group := range g {
if len(group.Proxies) == 0 {
g[i].Proxies = append([]string{"DIRECT"}, region...)
}
}
// 合并代理组
proxyGroup = RemoveEmptyGroup(append(proxyGroup, g...))
// 处理标签
proxyGroup = adapterTags(cfg.Tags, proxyGroup)
return &Adapter{
Adapter: proxy.Adapter{
Proxies: proxies,

View File

@ -109,6 +109,18 @@ func adapterRules(groups []*server.RuleGroup) (proxyGroup []proxy.Group, rules [
return
}
func adapterTags(tags map[string][]*server.Server, group []proxy.Group) (proxyGroup []proxy.Group) {
for tag, servers := range tags {
proxies := adapterProxies(servers)
if len(proxies) != 0 {
for _, p := range proxies {
group = addProxyToGroup(p.Name, tag, group)
}
}
}
return group
}
func generateProxyGroup(servers []proxy.Proxy) (proxyGroup []proxy.Group, region []string) {
// 设置手动选择分组
proxyGroup = append(proxyGroup, []proxy.Group{