package main import ( "context" "fmt" stdlog "log" "net" "os" "os/signal" "syscall" "time" "github.com/nadoo/glider/common/log" "github.com/nadoo/glider/dns" "github.com/nadoo/glider/ipset" "github.com/nadoo/glider/proxy" "github.com/nadoo/glider/rule" // comment out the protocol you don't need to make the compiled binary smaller. _ "github.com/nadoo/glider/proxy/http" _ "github.com/nadoo/glider/proxy/kcp" _ "github.com/nadoo/glider/proxy/mixed" _ "github.com/nadoo/glider/proxy/obfs" _ "github.com/nadoo/glider/proxy/reject" _ "github.com/nadoo/glider/proxy/socks4" _ "github.com/nadoo/glider/proxy/socks5" _ "github.com/nadoo/glider/proxy/ss" _ "github.com/nadoo/glider/proxy/ssh" _ "github.com/nadoo/glider/proxy/ssr" _ "github.com/nadoo/glider/proxy/tcptun" _ "github.com/nadoo/glider/proxy/tls" _ "github.com/nadoo/glider/proxy/trojan" _ "github.com/nadoo/glider/proxy/udptun" _ "github.com/nadoo/glider/proxy/uottun" _ "github.com/nadoo/glider/proxy/vmess" _ "github.com/nadoo/glider/proxy/ws" ) var version = "0.11.0" func main() { // read configs confInit() // setup a log func if conf.Verbose { log.F = func(f string, v ...interface{}) { stdlog.Output(2, fmt.Sprintf(f, v...)) } } // global rule proxy p := rule.NewProxy(conf.Forward, &conf.StrategyConfig, conf.rules) // ipset manager ipsetM, _ := ipset.NewManager(conf.rules) // check and setup dns server if conf.DNS != "" { d, err := dns.NewServer(conf.DNS, p, &conf.DNSConfig) if err != nil { log.Fatal(err) } // rule for _, r := range conf.rules { for _, domain := range r.Domain { if len(r.DNSServers) > 0 { d.SetServers(domain, r.DNSServers) } } } // custom resolver net.DefaultResolver = &net.Resolver{ PreferGo: true, Dial: func(ctx context.Context, network, address string) (net.Conn, error) { d := net.Dialer{Timeout: time.Second * 3} return d.DialContext(ctx, "udp", conf.DNS) }, } // add a handler to update proxy rules when a domain resolved d.AddHandler(p.AddDomainIP) if ipsetM != nil { d.AddHandler(ipsetM.AddDomainIP) } d.Start() } // enable checkers p.Check() // Proxy Servers for _, listen := range conf.Listen { local, err := proxy.ServerFromURL(listen, p) if err != nil { log.Fatal(err) } go local.ListenAndServe() } sigCh := make(chan os.Signal, 1) signal.Notify(sigCh, syscall.SIGINT, syscall.SIGTERM) <-sigCh }