mirror of
https://github.com/v2fly/v2ray-core.git
synced 2024-11-06 18:28:00 -05:00
43 lines
1.1 KiB
Go
43 lines
1.1 KiB
Go
|
package sniffer
|
||
|
|
||
|
import (
|
||
|
"github.com/v2fly/v2ray-core/v4/app/proxyman"
|
||
|
"github.com/v2fly/v2ray-core/v4/infra/conf/cfgcommon"
|
||
|
"strings"
|
||
|
)
|
||
|
|
||
|
//go:generate go run github.com/v2fly/v2ray-core/v4/common/errors/errorgen
|
||
|
|
||
|
type SniffingConfig struct {
|
||
|
Enabled bool `json:"enabled"`
|
||
|
DestOverride *cfgcommon.StringList `json:"destOverride"`
|
||
|
MetadataOnly bool `json:"metadataOnly"`
|
||
|
}
|
||
|
|
||
|
// Build implements Buildable.
|
||
|
func (c *SniffingConfig) Build() (*proxyman.SniffingConfig, error) {
|
||
|
var p []string
|
||
|
if c.DestOverride != nil {
|
||
|
for _, domainOverride := range *c.DestOverride {
|
||
|
switch strings.ToLower(domainOverride) {
|
||
|
case "http":
|
||
|
p = append(p, "http")
|
||
|
case "tls", "https", "ssl":
|
||
|
p = append(p, "tls")
|
||
|
case "fakedns":
|
||
|
p = append(p, "fakedns")
|
||
|
case "fakedns+others":
|
||
|
p = append(p, "fakedns+others")
|
||
|
default:
|
||
|
return nil, newError("unknown protocol: ", domainOverride)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return &proxyman.SniffingConfig{
|
||
|
Enabled: c.Enabled,
|
||
|
DestinationOverride: p,
|
||
|
MetadataOnly: c.MetadataOnly,
|
||
|
}, nil
|
||
|
}
|