glider/main.go

109 lines
2.4 KiB
Go
Raw Normal View History

2017-07-13 21:55:41 +08:00
package main
import (
"context"
"fmt"
2018-06-26 17:09:41 +08:00
stdlog "log"
"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"
2017-07-30 01:54:19 +08:00
func main() {
// read configs
confInit()
// setup a log func
if conf.Verbose {
log.F = func(f string, v ...interface{}) {
stdlog.Output(2, fmt.Sprintf(f, v...))
2018-06-26 17:09:41 +08:00
}
}
// global rule proxy
2020-09-24 18:50:04 +08:00
pxy := rule.NewProxy(conf.Forward, &conf.StrategyConfig, conf.rules)
// ipset manager
ipsetM, _ := ipset.NewManager(conf.rules)
// check and setup dns server
if conf.DNS != "" {
2020-09-24 18:50:04 +08:00
d, err := dns.NewServer(conf.DNS, pxy, &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)
}
}
}
// 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", conf.DNS)
},
}
// 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()
}
// enable checkers
2020-09-24 18:50:04 +08:00
pxy.Check()
2018-08-11 11:46:10 +08:00
// Proxy Servers
2018-07-09 23:42:33 +08:00
for _, listen := range conf.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
}