diff options
author | Valery Piashchynski <[email protected]> | 2020-12-22 23:02:25 +0300 |
---|---|---|
committer | Valery Piashchynski <[email protected]> | 2020-12-22 23:02:25 +0300 |
commit | fd1e98bc6339abfa66523bf9d2208d00df8ee4bc (patch) | |
tree | b679441276717e687a5b460ebeba7ad0eee69be9 /cmd/cli/serve.go | |
parent | 40b6c3169931a3fef62b649db19ff01dc685b7d4 (diff) |
events listeners refactor, CLI initial commit
Diffstat (limited to 'cmd/cli/serve.go')
-rw-r--r-- | cmd/cli/serve.go | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/cmd/cli/serve.go b/cmd/cli/serve.go new file mode 100644 index 00000000..ace239fc --- /dev/null +++ b/cmd/cli/serve.go @@ -0,0 +1,62 @@ +package cli + +import ( + "os" + "os/signal" + "syscall" + + "github.com/spiral/errors" + "go.uber.org/zap" + + "github.com/spf13/cobra" +) + +func init() { + root.AddCommand(&cobra.Command{ + Use: "serve", + Short: "Start RoadRunner Temporal service(s)", + RunE: handler, + }) +} + +func handler(cmd *cobra.Command, args []string) error { + const op = errors.Op("handle serve command") + /* + We need to have path to the config at the RegisterTarget stage + But after cobra.Execute, because cobra fills up cli variables on this stage + */ + err := Container.Init() + if err != nil { + return errors.E(op, err) + } + + errCh, err := Container.Serve() + if err != nil { + return errors.E(op, err) + } + + // https://golang.org/pkg/os/signal/#Notify + // should be of buffer size at least 1 + c := make(chan os.Signal, 1) + signal.Notify(c, os.Interrupt, syscall.SIGTERM, syscall.SIGINT) + + for { + select { + case e := <-errCh: + Logger.Error(e.Error.Error(), zap.String("service", e.VertexID)) + er := Container.Stop() + if er != nil { + Logger.Error(e.Error.Error(), zap.String("service", e.VertexID)) + if er != nil { + return errors.E(op, er) + } + } + case <-c: + err = Container.Stop() + if err != nil { + return errors.E(op, err) + } + return nil + } + } +} |