|
@@ -36,17 +36,17 @@ import (
|
|
)
|
|
)
|
|
|
|
|
|
var (
|
|
var (
|
|
- cfgFile string
|
|
|
|
- cfgDir string
|
|
|
|
- showVersion bool
|
|
|
|
- strictConfig bool
|
|
|
|
|
|
+ cfgFile string
|
|
|
|
+ cfgDir string
|
|
|
|
+ showVersion bool
|
|
|
|
+ strictConfigMode bool
|
|
)
|
|
)
|
|
|
|
|
|
func init() {
|
|
func init() {
|
|
rootCmd.PersistentFlags().StringVarP(&cfgFile, "config", "c", "./frpc.ini", "config file of frpc")
|
|
rootCmd.PersistentFlags().StringVarP(&cfgFile, "config", "c", "./frpc.ini", "config file of frpc")
|
|
rootCmd.PersistentFlags().StringVarP(&cfgDir, "config_dir", "", "", "config directory, run one frpc service for each file in config directory")
|
|
rootCmd.PersistentFlags().StringVarP(&cfgDir, "config_dir", "", "", "config directory, run one frpc service for each file in config directory")
|
|
rootCmd.PersistentFlags().BoolVarP(&showVersion, "version", "v", false, "version of frpc")
|
|
rootCmd.PersistentFlags().BoolVarP(&showVersion, "version", "v", false, "version of frpc")
|
|
- rootCmd.PersistentFlags().BoolVarP(&strictConfig, "strict_config", "", false, "strict config parsing mode")
|
|
|
|
|
|
+ rootCmd.PersistentFlags().BoolVarP(&strictConfigMode, "strict_config", "", false, "strict config parsing mode, unknown fields will cause an error")
|
|
}
|
|
}
|
|
|
|
|
|
var rootCmd = &cobra.Command{
|
|
var rootCmd = &cobra.Command{
|
|
@@ -110,7 +110,7 @@ func handleTermSignal(svr *client.Service) {
|
|
}
|
|
}
|
|
|
|
|
|
func runClient(cfgFilePath string) error {
|
|
func runClient(cfgFilePath string) error {
|
|
- cfg, pxyCfgs, visitorCfgs, isLegacyFormat, err := config.LoadClientConfig(cfgFilePath, strictConfig)
|
|
|
|
|
|
+ cfg, pxyCfgs, visitorCfgs, isLegacyFormat, err := config.LoadClientConfig(cfgFilePath, strictConfigMode)
|
|
if err != nil {
|
|
if err != nil {
|
|
return err
|
|
return err
|
|
}
|
|
}
|
|
@@ -122,14 +122,11 @@ func runClient(cfgFilePath string) error {
|
|
warning, err := validation.ValidateAllClientConfig(cfg, pxyCfgs, visitorCfgs)
|
|
warning, err := validation.ValidateAllClientConfig(cfg, pxyCfgs, visitorCfgs)
|
|
if warning != nil {
|
|
if warning != nil {
|
|
fmt.Printf("WARNING: %v\n", warning)
|
|
fmt.Printf("WARNING: %v\n", warning)
|
|
- if strictConfig {
|
|
|
|
- return fmt.Errorf("warning: %v", warning)
|
|
|
|
- }
|
|
|
|
}
|
|
}
|
|
if err != nil {
|
|
if err != nil {
|
|
return err
|
|
return err
|
|
}
|
|
}
|
|
- return startService(cfg, pxyCfgs, visitorCfgs, cfgFilePath, strictConfig)
|
|
|
|
|
|
+ return startService(cfg, pxyCfgs, visitorCfgs, cfgFilePath)
|
|
}
|
|
}
|
|
|
|
|
|
func startService(
|
|
func startService(
|
|
@@ -137,7 +134,6 @@ func startService(
|
|
pxyCfgs []v1.ProxyConfigurer,
|
|
pxyCfgs []v1.ProxyConfigurer,
|
|
visitorCfgs []v1.VisitorConfigurer,
|
|
visitorCfgs []v1.VisitorConfigurer,
|
|
cfgFile string,
|
|
cfgFile string,
|
|
- strictConfig bool,
|
|
|
|
) error {
|
|
) error {
|
|
log.InitLog(cfg.Log.To, cfg.Log.Level, cfg.Log.MaxDays, cfg.Log.DisablePrintColor)
|
|
log.InitLog(cfg.Log.To, cfg.Log.Level, cfg.Log.MaxDays, cfg.Log.DisablePrintColor)
|
|
|
|
|
|
@@ -145,13 +141,12 @@ func startService(
|
|
log.Info("start frpc service for config file [%s]", cfgFile)
|
|
log.Info("start frpc service for config file [%s]", cfgFile)
|
|
defer log.Info("frpc service for config file [%s] stopped", cfgFile)
|
|
defer log.Info("frpc service for config file [%s] stopped", cfgFile)
|
|
}
|
|
}
|
|
- svr := client.NewService(cfg, pxyCfgs, visitorCfgs, cfgFile, strictConfig)
|
|
|
|
|
|
+ svr := client.NewService(cfg, pxyCfgs, visitorCfgs, cfgFile)
|
|
|
|
|
|
shouldGracefulClose := cfg.Transport.Protocol == "kcp" || cfg.Transport.Protocol == "quic"
|
|
shouldGracefulClose := cfg.Transport.Protocol == "kcp" || cfg.Transport.Protocol == "quic"
|
|
// Capture the exit signal if we use kcp or quic.
|
|
// Capture the exit signal if we use kcp or quic.
|
|
if shouldGracefulClose {
|
|
if shouldGracefulClose {
|
|
go handleTermSignal(svr)
|
|
go handleTermSignal(svr)
|
|
}
|
|
}
|
|
-
|
|
|
|
return svr.Run(context.Background())
|
|
return svr.Run(context.Background())
|
|
}
|
|
}
|