1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2026-04-18 11:39:11 -04:00

support fetching config from http

This commit is contained in:
Darien Raymond
2018-04-08 23:22:55 +02:00
parent 6f2d4c72cc
commit b7f2f30244
8 changed files with 103 additions and 63 deletions

View File

@@ -3,79 +3,23 @@ package json
//go:generate go run $GOPATH/src/v2ray.com/core/common/errors/errorgen/main.go -pkg json -path Main,Json
import (
"context"
"io"
"os"
"os/exec"
"v2ray.com/core"
"v2ray.com/core/common"
"v2ray.com/core/common/platform"
"v2ray.com/core/common/signal"
"v2ray.com/core/common/platform/ctlcmd"
)
type logWriter struct{}
func (*logWriter) Write(b []byte) (int, error) {
n, err := os.Stderr.Write(b)
if err == nil {
os.Stderr.WriteString(platform.LineSeparator())
}
return n, err
}
func jsonToProto(input io.Reader) (*core.Config, error) {
v2ctl := platform.GetToolLocation("v2ctl")
if _, err := os.Stat(v2ctl); err != nil {
return nil, err
}
cmd := exec.Command(v2ctl, "config")
cmd.Stdin = input
cmd.Stderr = &logWriter{}
cmd.SysProcAttr = getSysProcAttr()
stdoutReader, err := cmd.StdoutPipe()
if err != nil {
return nil, err
}
defer stdoutReader.Close()
if err := cmd.Start(); err != nil {
return nil, err
}
var config *core.Config
loadTask := signal.ExecuteAsync(func() error {
c, err := core.LoadConfig("protobuf", "", stdoutReader)
if err != nil {
return err
}
config = c
return nil
})
waitTask := signal.ExecuteAsync(func() error {
return cmd.Wait()
})
if err := signal.ErrorOrFinish2(context.Background(), loadTask, waitTask); err != nil {
return nil, err
}
return config, nil
}
func init() {
common.Must(core.RegisterConfigLoader(&core.ConfigFormat{
Name: "JSON",
Extension: []string{"json"},
Loader: func(input io.Reader) (*core.Config, error) {
config, err := jsonToProto(input)
jsonContent, err := ctlcmd.Run([]string{"config"}, input)
if err != nil {
return nil, newError("failed to execute v2ctl to convert config file.").Base(err).AtWarning()
}
return config, nil
return core.LoadConfig("protobuf", "", &jsonContent)
},
}))
}

View File

@@ -1,9 +0,0 @@
// +build !windows
package json
import "syscall"
func getSysProcAttr() *syscall.SysProcAttr {
return nil
}

View File

@@ -1,11 +0,0 @@
// +build windows
package json
import "syscall"
func getSysProcAttr() *syscall.SysProcAttr {
return &syscall.SysProcAttr{
HideWindow: true,
}
}