mirror of
https://github.com/SagerNet/sing-box.git
synced 2025-04-03 20:07:36 +03:00
Add duplicate tag check
This commit is contained in:
parent
9774a659b0
commit
47fc3ebda4
1 changed files with 51 additions and 1 deletions
|
@ -4,6 +4,7 @@ import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
|
E "github.com/sagernet/sing/common/exceptions"
|
||||||
"github.com/sagernet/sing/common/json"
|
"github.com/sagernet/sing/common/json"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -30,7 +31,7 @@ func (o *Options) UnmarshalJSONContext(ctx context.Context, content []byte) erro
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
o.RawMessage = content
|
o.RawMessage = content
|
||||||
return nil
|
return checkOptions(o)
|
||||||
}
|
}
|
||||||
|
|
||||||
type LogOptions struct {
|
type LogOptions struct {
|
||||||
|
@ -42,3 +43,52 @@ type LogOptions struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type StubOptions struct{}
|
type StubOptions struct{}
|
||||||
|
|
||||||
|
func checkOptions(options *Options) error {
|
||||||
|
err := checkInbounds(options.Inbounds)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = checkOutbounds(options.Outbounds, options.Endpoints)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func checkInbounds(inbounds []Inbound) error {
|
||||||
|
seen := make(map[string]bool)
|
||||||
|
for _, inbound := range inbounds {
|
||||||
|
if inbound.Tag == "" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if seen[inbound.Tag] {
|
||||||
|
return E.New("duplicate inbound tag: ", inbound.Tag)
|
||||||
|
}
|
||||||
|
seen[inbound.Tag] = true
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func checkOutbounds(outbounds []Outbound, endpoints []Endpoint) error {
|
||||||
|
seen := make(map[string]bool)
|
||||||
|
for _, outbound := range outbounds {
|
||||||
|
if outbound.Tag == "" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if seen[outbound.Tag] {
|
||||||
|
return E.New("duplicate outbound/endpoint tag: ", outbound.Tag)
|
||||||
|
}
|
||||||
|
seen[outbound.Tag] = true
|
||||||
|
}
|
||||||
|
for _, endpoint := range endpoints {
|
||||||
|
if endpoint.Tag == "" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if seen[endpoint.Tag] {
|
||||||
|
return E.New("duplicate outbound/endpoint tag: ", endpoint.Tag)
|
||||||
|
}
|
||||||
|
seen[endpoint.Tag] = true
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue