glider/main.go

100 lines
2.3 KiB
Go
Raw Normal View History

2017-07-13 21:55:41 +08:00
package main
import (
"context"
"net"
2017-07-13 21:55:41 +08:00
"os"
"os/signal"
"syscall"
"time"
"github.com/nadoo/glider/common/log"
"github.com/nadoo/glider/dns"
2018-08-13 00:42:59 +08:00
"github.com/nadoo/glider/ipset"
"github.com/nadoo/glider/proxy"
2018-08-12 22:24:49 +08:00
"github.com/nadoo/glider/rule"
2018-06-26 20:43:47 +08:00
// comment out the protocol you don't need to make the compiled binary smaller.
2018-06-26 20:43:47 +08:00
_ "github.com/nadoo/glider/proxy/http"
2018-11-30 19:01:25 +08:00
_ "github.com/nadoo/glider/proxy/kcp"
2018-06-26 20:43:47 +08:00
_ "github.com/nadoo/glider/proxy/mixed"
2018-12-12 21:40:31 +08:00
_ "github.com/nadoo/glider/proxy/obfs"
2019-03-07 23:34:29 +08:00
_ "github.com/nadoo/glider/proxy/reject"
_ "github.com/nadoo/glider/proxy/socks4"
2018-06-26 20:43:47 +08:00
_ "github.com/nadoo/glider/proxy/socks5"
_ "github.com/nadoo/glider/proxy/ss"
2020-05-04 13:53:59 +08:00
_ "github.com/nadoo/glider/proxy/ssh"
2018-06-26 20:43:47 +08:00
_ "github.com/nadoo/glider/proxy/ssr"
_ "github.com/nadoo/glider/proxy/tcptun"
2018-06-28 23:20:04 +08:00
_ "github.com/nadoo/glider/proxy/tls"
2020-04-08 01:09:51 +08:00
_ "github.com/nadoo/glider/proxy/trojan"
2018-06-26 20:43:47 +08:00
_ "github.com/nadoo/glider/proxy/udptun"
_ "github.com/nadoo/glider/proxy/uottun"
2018-07-03 00:31:43 +08:00
_ "github.com/nadoo/glider/proxy/vmess"
2018-07-24 00:54:38 +08:00
_ "github.com/nadoo/glider/proxy/ws"
2017-07-13 21:55:41 +08:00
)
var (
version = "0.11.0"
config = parseConfig()
)
2017-07-30 01:54:19 +08:00
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
2020-09-24 18:50:04 +08:00
d.AddHandler(pxy.AddDomainIP)
if ipsetM != nil {
2018-07-29 23:44:23 +08:00
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
2020-09-24 18:50:04 +08:00
pxy.Check()
2018-08-11 11:46:10 +08:00
// Proxy Servers
for _, listen := range config.Listen {
2020-09-24 18:50:04 +08:00
local, err := proxy.ServerFromURL(listen, pxy)
2018-07-09 23:42:33 +08:00
if err != nil {
log.Fatal(err)
}
go local.ListenAndServe()
2018-07-09 23:42:33 +08:00
}
2017-07-13 21:55:41 +08:00
sigCh := make(chan os.Signal, 1)
signal.Notify(sigCh, syscall.SIGINT, syscall.SIGTERM)
<-sigCh
}