commit
1a88ca09f5
@ -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
6
ws.go
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user