2021-02-08 05:18:52 -05:00
|
|
|
package conf
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/golang/protobuf/proto"
|
2021-02-16 15:31:50 -05:00
|
|
|
|
|
|
|
"github.com/v2fly/v2ray-core/v4/app/dns/fakedns"
|
2021-02-08 05:18:52 -05:00
|
|
|
)
|
|
|
|
|
2021-04-09 19:08:50 -04:00
|
|
|
type FakeDNSPoolElementConfig struct {
|
2021-02-08 05:18:52 -05:00
|
|
|
IPPool string `json:"ipPool"`
|
|
|
|
LruSize int64 `json:"poolSize"`
|
|
|
|
}
|
|
|
|
|
2021-04-09 19:08:50 -04:00
|
|
|
type FakeDNSConfig struct {
|
|
|
|
IPPool string `json:"ipPool"`
|
|
|
|
LruSize int64 `json:"poolSize"`
|
|
|
|
Pools *[]FakeDNSPoolElementConfig `json:"pools,omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-02-08 05:18:52 -05:00
|
|
|
func (f FakeDNSConfig) Build() (proto.Message, error) {
|
2021-04-09 19:08:50 -04:00
|
|
|
if f.Pools != nil {
|
|
|
|
fakeDNSPool := &fakedns.FakeDnsPoolMulti{}
|
|
|
|
for _, v := range *f.Pools {
|
|
|
|
fakeDNSPool.Pools = append(fakeDNSPool.Pools, &fakedns.FakeDnsPool{IpPool: v.IPPool, LruSize: v.LruSize})
|
|
|
|
}
|
|
|
|
return fakeDNSPool, nil
|
|
|
|
}
|
|
|
|
|
2021-02-08 05:18:52 -05:00
|
|
|
return &fakedns.FakeDnsPool{
|
|
|
|
IpPool: f.IPPool,
|
|
|
|
LruSize: f.LruSize,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type FakeDNSPostProcessingStage struct{}
|
|
|
|
|
|
|
|
func (FakeDNSPostProcessingStage) Process(conf *Config) error {
|
|
|
|
var fakeDNSInUse bool
|
|
|
|
|
|
|
|
if conf.DNSConfig != nil {
|
|
|
|
for _, v := range conf.DNSConfig.Servers {
|
|
|
|
if v.Address.Family().IsDomain() {
|
|
|
|
if v.Address.Domain() == "fakedns" {
|
|
|
|
fakeDNSInUse = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if fakeDNSInUse {
|
|
|
|
if conf.FakeDNS == nil {
|
|
|
|
// Add a Fake DNS Config if there is none
|
|
|
|
conf.FakeDNS = &FakeDNSConfig{
|
2021-03-15 04:47:10 -04:00
|
|
|
IPPool: "198.18.0.0/15",
|
2021-02-08 05:18:52 -05:00
|
|
|
LruSize: 65535,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
found := false
|
|
|
|
// Check if there is a Outbound with necessary sniffer on
|
|
|
|
var inbounds []InboundDetourConfig
|
|
|
|
|
|
|
|
if len(conf.InboundConfigs) > 0 {
|
|
|
|
inbounds = append(inbounds, conf.InboundConfigs...)
|
|
|
|
}
|
|
|
|
for _, v := range inbounds {
|
|
|
|
if v.SniffingConfig != nil && v.SniffingConfig.Enabled && v.SniffingConfig.DestOverride != nil {
|
|
|
|
for _, dov := range *v.SniffingConfig.DestOverride {
|
|
|
|
if dov == "fakedns" {
|
|
|
|
found = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if !found {
|
|
|
|
newError("Defined Fake DNS but haven't enabled fake dns sniffing at any inbound.").AtWarning().WriteToLog()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|