diff options
-rw-r--r-- | cmd/rr/cmd/root.go | 33 | ||||
-rw-r--r-- | service/http/service.go | 11 |
2 files changed, 34 insertions, 10 deletions
diff --git a/cmd/rr/cmd/root.go b/cmd/rr/cmd/root.go index 5e936580..4ab37967 100644 --- a/cmd/rr/cmd/root.go +++ b/cmd/rr/cmd/root.go @@ -27,6 +27,7 @@ import ( "github.com/spiral/roadrunner/cmd/rr/utils" "github.com/spiral/roadrunner/service" "os" + "path/filepath" ) // Service bus for all the commands. @@ -81,13 +82,6 @@ func (w *ViperWrapper) Unmarshal(out interface{}) error { // Execute adds all child commands to the CLI command and sets flags appropriately. // This is called by main.main(). It only needs to happen once to the CLI. func Execute() { - if cfg := initConfig(cfgFile, []string{"."}, ".rr"); cfg != nil { - if err := Container.Init(cfg); err != nil { - utils.Printf("<red+hb>Error:</reset> <red>%s</reset>\n", err) - os.Exit(1) - } - } - if err := CLI.Execute(); err != nil { utils.Printf("<red+hb>Error:</reset> <red>%s</reset>\n", err) os.Exit(1) @@ -97,12 +91,19 @@ func Execute() { func init() { CLI.PersistentFlags().BoolVarP(&Verbose, "Verbose", "v", false, "Verbose output") CLI.PersistentFlags().BoolVarP(&Debug, "debug", "d", false, "debug mode") - CLI.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is .rr.yaml)") + CLI.PersistentFlags().StringVarP(&cfgFile, "config", "c", "", "config file (default is .rr.yaml)") cobra.OnInitialize(func() { if Verbose { Logger.SetLevel(logrus.DebugLevel) } + + if cfg := initConfig(cfgFile, []string{"."}, ".rr"); cfg != nil { + if err := Container.Init(cfg); err != nil { + utils.Printf("<red+hb>Error:</reset> <red>%s</reset>\n", err) + os.Exit(1) + } + } }) } @@ -110,8 +111,24 @@ func initConfig(cfgFile string, path []string, name string) service.Config { cfg := viper.New() if cfgFile != "" { + if absPath, err := filepath.Abs(cfgFile); err == nil { + cfgFile = absPath + + // force working absPath related to config file + if err := os.Chdir(filepath.Dir(absPath)); err != nil { + Logger.Error(err) + } + } + // Use cfg file from the flag. cfg.SetConfigFile(cfgFile) + + if dir, err := filepath.Abs(cfgFile); err == nil { + // force working absPath related to config file + if err := os.Chdir(filepath.Dir(dir)); err != nil { + Logger.Error(err) + } + } } else { // automatic location for _, p := range path { diff --git a/service/http/service.go b/service/http/service.go index f988a843..ecce1c15 100644 --- a/service/http/service.go +++ b/service/http/service.go @@ -11,8 +11,13 @@ import ( "sync/atomic" ) -// ID contains default svc name. -const ID = "http" +const ( + // ID contains default svc name. + ID = "http" + + // httpKey indicates to php process that it's running under http service + httpKey = "rr_http" +) // http middleware type. type middleware func(f http.HandlerFunc) http.HandlerFunc @@ -69,6 +74,8 @@ func (s *Service) Serve() error { for k, v := range values { s.cfg.Workers.SetEnv(k, v) } + + s.cfg.Workers.SetEnv(httpKey, "true") } rr := roadrunner.NewServer(s.cfg.Workers) |