Merge pull request #55 from septs/master

add configure file support
This commit is contained in:
ginuerzh 2016-11-09 17:51:23 +08:00 committed by GitHub
commit 1a88ca09f5
2 changed files with 49 additions and 22 deletions

View File

@ -2,51 +2,64 @@ package main
import ( import (
"crypto/tls" "crypto/tls"
"encoding/json"
"flag" "flag"
"fmt" "fmt"
"github.com/ginuerzh/gost" "github.com/ginuerzh/gost"
"github.com/golang/glog" "github.com/golang/glog"
"golang.org/x/net/http2" "golang.org/x/net/http2"
"io/ioutil"
"os" "os"
"runtime" "runtime"
"sync" "sync"
) )
var ( var (
chainNodes stringlist options struct {
serverNodes stringlist ChainNodes, ServeNodes flagStringList
pv bool }
) )
func init() { func init() {
flag.Var(&serverNodes, "L", "listen address, can listen on multiple ports") var (
flag.Var(&chainNodes, "F", "forward address, can make a forward chain") configureFile string
flag.BoolVar(&pv, "V", false, "print version") printVersion bool
)
flag.StringVar(&configureFile, "C", "", "configure file")
flag.Var(&options.ChainNodes, "F", "forward address, can make a forward chain")
flag.Var(&options.ServeNodes, "L", "listen address, can listen on multiple ports")
flag.BoolVar(&printVersion, "V", false, "print version")
flag.Parse() flag.Parse()
if err := loadConfigureFile(configureFile); err != nil {
glog.Fatal(err)
}
if glog.V(5) { if glog.V(5) {
http2.VerboseLogs = true http2.VerboseLogs = true
} }
}
func main() {
if flag.NFlag() == 0 { if flag.NFlag() == 0 {
flag.PrintDefaults() flag.PrintDefaults()
return return
} }
if pv {
fmt.Fprintf(os.Stderr, "gost %s (%s)\n", gost.Version, runtime.Version()) if printVersion {
fmt.Fprintf(os.Stderr, "GOST %s (%s)\n", gost.Version, runtime.Version())
return return
} }
}
func main() {
chain := gost.NewProxyChain() chain := gost.NewProxyChain()
if err := chain.AddProxyNodeString(chainNodes...); err != nil { if err := chain.AddProxyNodeString(options.ChainNodes...); err != nil {
glog.Fatal(err) glog.Fatal(err)
} }
chain.Init() chain.Init()
var wg sync.WaitGroup var wg sync.WaitGroup
for _, ns := range serverNodes { for _, ns := range options.ServeNodes {
serverNode, err := gost.ParseProxyNode(ns) serverNode, err := gost.ParseProxyNode(ns)
if err != nil { if err != nil {
glog.Fatal(err) glog.Fatal(err)
@ -73,12 +86,26 @@ func main() {
wg.Wait() wg.Wait()
} }
type stringlist []string func loadConfigureFile(configureFile string) error {
if configureFile == "" {
func (list *stringlist) String() string { return nil
return fmt.Sprintf("%s", *list) }
} content, err := ioutil.ReadFile(configureFile)
func (list *stringlist) Set(value string) error { if err != nil {
*list = append(*list, value) return err
}
if err := json.Unmarshal(content, &options); err != nil {
return err
}
return nil
}
type flagStringList []string
func (this *flagStringList) String() string {
return fmt.Sprintf("%s", *this)
}
func (this *flagStringList) Set(value string) error {
*this = append(*this, value)
return nil return nil
} }

6
ws.go
View File

@ -1,14 +1,12 @@
package gost package gost
import ( import (
//"github.com/ginuerzh/gosocks5"
"crypto/tls" "crypto/tls"
"github.com/golang/glog" "github.com/golang/glog"
"github.com/gorilla/websocket" "github.com/gorilla/websocket"
"net" "net"
"net/http" "net/http"
"net/http/httputil" "net/http/httputil"
//"net/url"
"time" "time"
) )
@ -28,6 +26,7 @@ func NewWebsocketServer(base *ProxyServer) *WebsocketServer {
WriteBufferSize: 1024, WriteBufferSize: 1024,
CheckOrigin: func(r *http.Request) bool { return true }, CheckOrigin: func(r *http.Request) bool { return true },
}, },
CompressionSupported: true,
} }
} }
@ -83,6 +82,7 @@ func WebsocketClientConn(url string, conn net.Conn, config *tls.Config) (*Websoc
NetDial: func(net, addr string) (net.Conn, error) { NetDial: func(net, addr string) (net.Conn, error) {
return conn, nil return conn, nil
}, },
CompressionSupported: true,
} }
c, resp, err := dialer.Dial(url, nil) c, resp, err := dialer.Dial(url, nil)
@ -90,7 +90,7 @@ func WebsocketClientConn(url string, conn net.Conn, config *tls.Config) (*Websoc
return nil, err return nil, err
} }
resp.Body.Close() resp.Body.Close()
c.EnableWriteCompression(true)
return &WebsocketConn{conn: c}, nil return &WebsocketConn{conn: c}, nil
} }