add configure file support
This commit is contained in:
parent
e159216280
commit
b758b3d9ac
@ -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
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user