glider/main.go

96 lines
2.1 KiB
Go
Raw Normal View History

2017-07-13 21:55:41 +08:00
package main
import (
"fmt"
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"
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"
_ "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
)
2020-04-04 22:57:29 +08:00
var version = "0.10.0"
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.Output(2, fmt.Sprintf(f, v...))
2018-06-26 17:09:41 +08:00
}
}
// global rule proxy
p := rule.NewProxy(conf.rules, strategy.NewProxy(conf.Forward, &conf.StrategyConfig))
// 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...)
}
}
}
// add a handler to update proxy rules when a domain resolved
d.AddHandler(p.AddDomainIP)
if ipsetM != nil {
2018-07-29 23:44:23 +08:00
d.AddHandler(ipsetM.AddDomainIP)
}
d.Start()
}
// enable checkers
p.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, p)
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
}