|
@@ -5,7 +5,6 @@ package main
|
|
|
import (
|
|
import (
|
|
|
"flag"
|
|
"flag"
|
|
|
"fmt"
|
|
"fmt"
|
|
|
- "io"
|
|
|
|
|
"os"
|
|
"os"
|
|
|
"os/signal"
|
|
"os/signal"
|
|
|
"path/filepath"
|
|
"path/filepath"
|
|
@@ -14,7 +13,7 @@ import (
|
|
|
|
|
|
|
|
"v2ray.com/core"
|
|
"v2ray.com/core"
|
|
|
"v2ray.com/core/common/platform"
|
|
"v2ray.com/core/common/platform"
|
|
|
- "v2ray.com/core/common/platform/ctlcmd"
|
|
|
|
|
|
|
+ "v2ray.com/core/main/confloader"
|
|
|
_ "v2ray.com/core/main/distro/all"
|
|
_ "v2ray.com/core/main/distro/all"
|
|
|
)
|
|
)
|
|
|
|
|
|
|
@@ -61,24 +60,12 @@ func GetConfigFormat() string {
|
|
|
|
|
|
|
|
func startV2Ray() (core.Server, error) {
|
|
func startV2Ray() (core.Server, error) {
|
|
|
configFile := getConfigFilePath()
|
|
configFile := getConfigFilePath()
|
|
|
- var configInput io.Reader
|
|
|
|
|
- if configFile == "stdin:" {
|
|
|
|
|
- configInput = os.Stdin
|
|
|
|
|
- } else if strings.HasPrefix(configFile, "http://") || strings.HasPrefix(configFile, "https://") {
|
|
|
|
|
- content, err := ctlcmd.Run([]string{"fetch", configFile}, nil)
|
|
|
|
|
- if err != nil {
|
|
|
|
|
- return nil, err
|
|
|
|
|
- }
|
|
|
|
|
- configInput = &content
|
|
|
|
|
- } else {
|
|
|
|
|
- fixedFile := os.ExpandEnv(configFile)
|
|
|
|
|
- file, err := os.Open(fixedFile)
|
|
|
|
|
- if err != nil {
|
|
|
|
|
- return nil, newError("config file not readable").Base(err)
|
|
|
|
|
- }
|
|
|
|
|
- defer file.Close()
|
|
|
|
|
- configInput = file
|
|
|
|
|
|
|
+ configInput, err := confloader.LoadConfig(configFile)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ return nil, newError("failed to load config: ", configFile).Base(err)
|
|
|
}
|
|
}
|
|
|
|
|
+ defer configInput.Close()
|
|
|
|
|
+
|
|
|
config, err := core.LoadConfig(GetConfigFormat(), configFile, configInput)
|
|
config, err := core.LoadConfig(GetConfigFormat(), configFile, configInput)
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
return nil, newError("failed to read config file: ", configFile).Base(err)
|
|
return nil, newError("failed to read config file: ", configFile).Base(err)
|