2017-07-13 21:55:41 +08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2018-06-26 17:09:41 +08:00
|
|
|
stdlog "log"
|
2017-07-13 21:55:41 +08:00
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"syscall"
|
2018-06-26 16:15:48 +08:00
|
|
|
|
|
|
|
"github.com/nadoo/glider/common/log"
|
2018-06-26 21:22:24 +08:00
|
|
|
"github.com/nadoo/glider/dns"
|
2018-08-13 00:42:59 +08:00
|
|
|
"github.com/nadoo/glider/ipset"
|
2018-06-26 16:15:48 +08:00
|
|
|
"github.com/nadoo/glider/proxy"
|
2018-08-12 22:24:49 +08:00
|
|
|
"github.com/nadoo/glider/rule"
|
2018-08-11 11:46:10 +08:00
|
|
|
"github.com/nadoo/glider/strategy"
|
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"
|
2018-06-26 20:43:47 +08:00
|
|
|
_ "github.com/nadoo/glider/proxy/socks5"
|
|
|
|
_ "github.com/nadoo/glider/proxy/ss"
|
|
|
|
_ "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"
|
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
|
|
|
)
|
|
|
|
|
2019-09-15 20:50:52 +08:00
|
|
|
var version = "dev"
|
2017-07-30 01:54:19 +08:00
|
|
|
|
2017-08-23 16:35:39 +08:00
|
|
|
func main() {
|
2018-08-14 19:33:18 +08:00
|
|
|
// read configs
|
2017-08-23 16:35:39 +08:00
|
|
|
confInit()
|
2018-08-14 19:33:18 +08:00
|
|
|
|
|
|
|
// setup a log func
|
2018-06-26 17:09:41 +08:00
|
|
|
log.F = func(f string, v ...interface{}) {
|
|
|
|
if conf.Verbose {
|
|
|
|
stdlog.Printf(f, v...)
|
|
|
|
}
|
|
|
|
}
|
2018-06-26 16:15:48 +08:00
|
|
|
|
2018-08-14 19:33:18 +08:00
|
|
|
// global rule dialer
|
2018-08-12 22:24:49 +08:00
|
|
|
dialer := rule.NewDialer(conf.rules, strategy.NewDialer(conf.Forward, &conf.StrategyConfig))
|
2018-08-07 19:43:52 +08:00
|
|
|
|
2018-08-14 19:33:18 +08:00
|
|
|
// ipset manager
|
2018-11-27 23:25:20 +08:00
|
|
|
ipsetM, _ := ipset.NewManager(conf.rules)
|
2018-08-14 19:33:18 +08:00
|
|
|
|
|
|
|
// check and setup dns server
|
2018-08-10 19:03:30 +08:00
|
|
|
if conf.DNS != "" {
|
2018-08-12 22:07:19 +08:00
|
|
|
d, err := dns.NewServer(conf.DNS, dialer, &conf.DNSConfig)
|
2017-08-16 13:20:12 +08:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// rule
|
2018-01-08 23:37:58 +08:00
|
|
|
for _, r := range conf.rules {
|
|
|
|
for _, domain := range r.Domain {
|
2018-08-12 12:37:25 +08:00
|
|
|
if len(r.DNSServers) > 0 {
|
2018-08-12 22:07:19 +08:00
|
|
|
d.SetServers(domain, r.DNSServers...)
|
2017-08-16 13:20:12 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-23 18:58:24 +08:00
|
|
|
// add a handler to update proxy rules when a domain resolved
|
2018-07-29 23:44:23 +08:00
|
|
|
d.AddHandler(dialer.AddDomainIP)
|
2017-08-28 19:23:32 +08:00
|
|
|
if ipsetM != nil {
|
2018-07-29 23:44:23 +08:00
|
|
|
d.AddHandler(ipsetM.AddDomainIP)
|
2017-08-28 19:23:32 +08:00
|
|
|
}
|
2017-08-23 16:35:39 +08:00
|
|
|
|
2018-08-14 19:33:18 +08:00
|
|
|
d.Start()
|
2017-08-16 13:20:12 +08:00
|
|
|
}
|
|
|
|
|
2018-08-14 19:33:18 +08:00
|
|
|
// enable checkers
|
|
|
|
dialer.Check()
|
|
|
|
|
2018-08-11 11:46:10 +08:00
|
|
|
// Proxy Servers
|
2018-07-09 23:42:33 +08:00
|
|
|
for _, listen := range conf.Listen {
|
2018-08-12 18:50:44 +08:00
|
|
|
local, err := proxy.ServerFromURL(listen, dialer)
|
2018-07-09 23:42:33 +08:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2018-11-25 13:18:15 +08:00
|
|
|
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
|
|
|
|
}
|