package main import ( "context" "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" config = parseConfig() ) func main() { // global rule proxy pxy := rule.NewProxy(config.Forward, &config.StrategyConfig, config.rules) // ipset manager ipsetM, _ := ipset.NewManager(config.rules) // check and setup dns server if config.DNS != "" { d, err := dns.NewServer(config.DNS, pxy, &config.DNSConfig) if err != nil { log.Fatal(err) } // rules for _, r := range config.rules { for _, domain := range r.Domain { if len(r.DNSServers) > 0 { d.SetServers(domain, r.DNSServers) } } } // add a handler to update proxy rules when a domain resolved d.AddHandler(pxy.AddDomainIP) if ipsetM != nil { d.AddHandler(ipsetM.AddDomainIP) } d.Start() // 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", config.DNS) }, } } // enable checkers pxy.Check() // Proxy Servers for _, listen := range config.Listen { local, err := proxy.ServerFromURL(listen, pxy) if err != nil { log.Fatal(err) } go local.ListenAndServe() } sigCh := make(chan os.Signal, 1) signal.Notify(sigCh, syscall.SIGINT, syscall.SIGTERM) <-sigCh }