mirror of
https://github.com/netbirdio/netbird.git
synced 2024-11-22 08:03:30 +01:00
d040cfed7e
* fix: retry logic
149 lines
2.9 KiB
Go
149 lines
2.9 KiB
Go
package cmd
|
|
|
|
import (
|
|
"github.com/kardianos/service"
|
|
log "github.com/sirupsen/logrus"
|
|
"github.com/spf13/cobra"
|
|
"github.com/wiretrustee/wiretrustee/util"
|
|
"time"
|
|
)
|
|
|
|
func (p *program) Start(s service.Service) error {
|
|
|
|
// Start should not block. Do the actual work async.
|
|
log.Info("starting service") //nolint
|
|
go func() {
|
|
err := runClient()
|
|
if err != nil {
|
|
log.Errorf("stopped Wiretrustee client app due to error: %v", err)
|
|
return
|
|
}
|
|
}()
|
|
return nil
|
|
}
|
|
|
|
func (p *program) Stop(s service.Service) error {
|
|
go func() {
|
|
stopCh <- 1
|
|
}()
|
|
|
|
select {
|
|
case <-cleanupCh:
|
|
case <-time.After(time.Second * 10):
|
|
log.Warnf("failed waiting for service cleanup, terminating")
|
|
}
|
|
log.Info("stopped Wiretrustee service") //nolint
|
|
return nil
|
|
}
|
|
|
|
var (
|
|
runCmd = &cobra.Command{
|
|
Use: "run",
|
|
Short: "runs wiretrustee as service",
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
|
|
err := util.InitLog(logLevel, logFile)
|
|
if err != nil {
|
|
log.Errorf("failed initializing log %v", err)
|
|
return
|
|
}
|
|
|
|
SetupCloseHandler()
|
|
|
|
prg := &program{
|
|
cmd: cmd,
|
|
args: args,
|
|
}
|
|
|
|
s, err := newSVC(prg, newSVCConfig())
|
|
if err != nil {
|
|
cmd.PrintErrln(err)
|
|
return
|
|
}
|
|
err = s.Run()
|
|
if err != nil {
|
|
cmd.PrintErrln(err)
|
|
return
|
|
}
|
|
cmd.Printf("Wiretrustee service is running")
|
|
},
|
|
}
|
|
)
|
|
|
|
var (
|
|
startCmd = &cobra.Command{
|
|
Use: "start",
|
|
Short: "starts wiretrustee service",
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
err := util.InitLog(logLevel, logFile)
|
|
if err != nil {
|
|
log.Errorf("failed initializing log %v", err)
|
|
return err
|
|
}
|
|
s, err := newSVC(&program{}, newSVCConfig())
|
|
if err != nil {
|
|
cmd.PrintErrln(err)
|
|
return err
|
|
}
|
|
err = s.Start()
|
|
if err != nil {
|
|
cmd.PrintErrln(err)
|
|
return err
|
|
}
|
|
cmd.Println("Wiretrustee service has been started")
|
|
return nil
|
|
},
|
|
}
|
|
)
|
|
|
|
var (
|
|
stopCmd = &cobra.Command{
|
|
Use: "stop",
|
|
Short: "stops wiretrustee service",
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
err := util.InitLog(logLevel, logFile)
|
|
if err != nil {
|
|
log.Errorf("failed initializing log %v", err)
|
|
}
|
|
s, err := newSVC(&program{}, newSVCConfig())
|
|
if err != nil {
|
|
cmd.PrintErrln(err)
|
|
return
|
|
}
|
|
err = s.Stop()
|
|
if err != nil {
|
|
cmd.PrintErrln(err)
|
|
return
|
|
}
|
|
cmd.Println("Wiretrustee service has been stopped")
|
|
},
|
|
}
|
|
)
|
|
|
|
var (
|
|
restartCmd = &cobra.Command{
|
|
Use: "restart",
|
|
Short: "restarts wiretrustee service",
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
err := util.InitLog(logLevel, logFile)
|
|
if err != nil {
|
|
log.Errorf("failed initializing log %v", err)
|
|
}
|
|
s, err := newSVC(&program{}, newSVCConfig())
|
|
if err != nil {
|
|
cmd.PrintErrln(err)
|
|
return
|
|
}
|
|
err = s.Restart()
|
|
if err != nil {
|
|
cmd.PrintErrln(err)
|
|
return
|
|
}
|
|
cmd.Println("Wiretrustee service has been restarted")
|
|
},
|
|
}
|
|
)
|
|
|
|
func init() {
|
|
}
|