2017-07-13 21:55:41 +08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2020-09-23 22:14:18 +08:00
|
|
|
"context"
|
2019-10-20 17:52:25 +08:00
|
|
|
"fmt"
|
2018-06-26 17:09:41 +08:00
|
|
|
stdlog "log"
|
2020-09-23 22:14:18 +08:00
|
|
|
"net"
|
2017-07-13 21:55:41 +08:00
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"syscall"
|
2020-09-23 22:14:18 +08:00
|
|
|
"time"
|
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-06-26 20:43:47 +08:00
|
|
|
|
2020-08-14 12:56:59 +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"
|
2020-04-13 12:22:03 +08:00
|
|
|
_ "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
|
|
|
)
|
|
|
|
|
2020-09-23 22:14:18 +08:00
|
|
|
var version = "0.11.0"
|
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
|
2020-09-14 20:56:37 +08:00
|
|
|
if conf.Verbose {
|
|
|
|
log.F = func(f string, v ...interface{}) {
|
2019-10-20 17:52:25 +08:00
|
|
|
stdlog.Output(2, fmt.Sprintf(f, v...))
|
2018-06-26 17:09:41 +08:00
|
|
|
}
|
|
|
|
}
|
2018-06-26 16:15:48 +08:00
|
|
|
|
2019-09-18 19:40:14 +08:00
|
|
|
// global rule proxy
|
2020-09-24 18:50:04 +08:00
|
|
|
pxy := rule.NewProxy(conf.Forward, &conf.StrategyConfig, conf.rules)
|
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 != "" {
|
2020-09-24 18:50:04 +08:00
|
|
|
d, err := dns.NewServer(conf.DNS, pxy, &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 {
|
2020-05-02 20:02:19 +08:00
|
|
|
d.SetServers(domain, r.DNSServers)
|
2017-08-16 13:20:12 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-23 22:14:18 +08:00
|
|
|
// 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)
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2017-08-23 18:58:24 +08:00
|
|
|
// add a handler to update proxy rules when a domain resolved
|
2020-09-24 18:50:04 +08:00
|
|
|
d.AddHandler(pxy.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
|
2020-09-24 18:50:04 +08:00
|
|
|
pxy.Check()
|
2018-08-14 19:33:18 +08:00
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
|
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
|
|
|
|
}
|