glider/main.go

91 lines
1.9 KiB
Go
Raw Normal View History

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"
"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-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"
_ "github.com/nadoo/glider/proxy/mixed"
_ "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
)
2017-07-18 19:25:54 +08:00
// VERSION .
2018-09-04 20:26:40 +08:00
const VERSION = "0.6.9"
2017-07-30 01:54:19 +08:00
func main() {
// read configs
confInit()
// 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...)
}
}
// global rule dialer
2018-08-12 22:24:49 +08:00
dialer := rule.NewDialer(conf.rules, strategy.NewDialer(conf.Forward, &conf.StrategyConfig))
// ipset manager
ipsetM, _ := ipset.NewManager(conf.IPSet, conf.rules)
// check and setup dns server
if conf.DNS != "" {
d, err := dns.NewServer(conf.DNS, dialer, &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...)
}
}
}
// add a handler to update proxy rules when a domain resolved
2018-07-29 23:44:23 +08:00
d.AddHandler(dialer.AddDomainIP)
if ipsetM != nil {
2018-07-29 23:44:23 +08:00
d.AddHandler(ipsetM.AddDomainIP)
}
d.Start()
}
// 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 {
local, err := proxy.ServerFromURL(listen, dialer)
2018-07-09 23:42:33 +08:00
if err != nil {
log.Fatal(err)
}
2018-10-29 16:18:51 +08:00
go local.ListenAndServe(nil)
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
}