overflow_probes/main.go

142 lines
3.9 KiB
Go
Raw Normal View History

2017-09-18 09:21:58 +00:00
package main
import (
"context"
"flag"
"fmt"
"os"
"os/signal"
2017-09-28 10:09:33 +00:00
"path"
2017-09-18 09:21:58 +00:00
"syscall"
"time"
2017-09-21 08:38:05 +00:00
lfcc "git.loafle.net/commons_go/config"
2017-09-18 09:21:58 +00:00
"git.loafle.net/commons_go/logging"
2017-09-21 08:38:05 +00:00
"git.loafle.net/overflow/overflow_probes/auth"
"git.loafle.net/overflow/overflow_probes/commons"
"git.loafle.net/overflow/overflow_probes/config"
2017-09-21 11:04:30 +00:00
"git.loafle.net/overflow/overflow_probes/probe"
2017-09-18 09:21:58 +00:00
)
2017-09-28 10:09:33 +00:00
/*
/bin/
probe.exe
/config/
/sensor/
noauthprobe.json
central.json
probe.json
logging.json
2017-09-18 09:21:58 +00:00
2017-09-28 10:09:33 +00:00
*/
2017-09-18 09:21:58 +00:00
2017-09-29 12:30:27 +00:00
// const (
// // name of the service
// serviceName = "Probe"
// serviceDescription = "Probe Service of overFlow"
// )
2017-09-18 09:21:58 +00:00
2017-09-21 08:38:05 +00:00
var (
daemonCommand *string
configDir *string
)
2017-09-18 09:21:58 +00:00
func init() {
2017-09-29 12:30:27 +00:00
// flag.Usage = func() {
// fmt.Printf("Usage of %s\n", os.Args[0])
// fmt.Printf(" [install | remove | start | stop | status]\n")
// flag.PrintDefaults()
// }
2017-09-18 09:21:58 +00:00
2017-09-21 08:38:05 +00:00
configDir = flag.String("config-dir", ".", "The directory of config")
2017-09-18 09:21:58 +00:00
flag.Parse()
}
func main() {
var err error
2017-09-21 08:38:05 +00:00
var handler commons.Handler
2017-09-18 09:21:58 +00:00
defer logging.Logger.Sync()
2017-09-28 10:09:33 +00:00
printBanner()
2017-09-18 09:21:58 +00:00
2017-09-21 08:38:05 +00:00
if dir, err := lfcc.ABSPathify(*configDir); nil != err {
logging.Logger.Panic(fmt.Sprintf("Probe: config path[%s] is not valid", *configDir))
} else {
logging.Logger.Debug(fmt.Sprintf("Probe: config path[%s]", dir))
2017-09-28 10:09:33 +00:00
config.ConfigDir = &dir
2017-09-21 08:38:05 +00:00
}
2017-09-28 10:09:33 +00:00
cfp := path.Join(*config.ConfigDir, config.ConfigFileName)
config.ConfigFilePath = &cfp
2017-09-21 08:38:05 +00:00
conf := lfcc.New()
2017-09-28 10:09:33 +00:00
config.CFG = &config.Config{}
if err := conf.Load(config.CFG, *config.ConfigFilePath); nil != err {
2017-09-21 08:38:05 +00:00
logging.Logger.Panic(fmt.Sprintf("Probe: config is not valid error[%v]", err))
}
2017-09-18 09:21:58 +00:00
go func() {
2017-09-28 10:09:33 +00:00
if handler, err = auth.New(); nil != err {
logging.Logger.Error(fmt.Sprintf("Auth: error: %v", err))
2017-09-29 12:30:27 +00:00
return
2017-09-28 10:09:33 +00:00
}
2017-09-22 09:20:07 +00:00
if err := handler.Serve(); err != nil {
2017-09-28 10:09:33 +00:00
logging.Logger.Error(fmt.Sprintf("Auth: Stopped[%v]", err))
2017-09-21 11:04:30 +00:00
return
}
2017-09-28 10:09:33 +00:00
if handler, err = probe.New(); nil != err {
2017-09-27 13:55:29 +00:00
logging.Logger.Error(fmt.Sprintf("Probe: error: %v", err))
return
}
2017-09-22 09:20:07 +00:00
if err := handler.Serve(); err != nil {
2017-09-21 11:04:30 +00:00
logging.Logger.Error(fmt.Sprintf("Probe: error: %v", err))
return
2017-09-18 09:21:58 +00:00
}
}()
// // Set up channel on which to send signal notifications.
// // We must use a buffered channel or risk missing the signal
// // if we're not ready to receive when the signal is sent.
interrupt := make(chan os.Signal, 1)
signal.Notify(interrupt,
syscall.SIGKILL,
syscall.SIGSTOP,
syscall.SIGHUP,
syscall.SIGINT,
syscall.SIGTERM,
syscall.SIGQUIT)
<-interrupt
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
2017-09-21 08:38:05 +00:00
if err := handler.Shutdown(ctx); err != nil {
2017-09-29 12:30:27 +00:00
logging.Logger.Error(fmt.Sprintf("Probe error: %v", err))
2017-09-18 09:21:58 +00:00
}
}
2017-09-28 10:09:33 +00:00
const (
version = "1.0.0"
website = "https://www.overflow.cloud"
banner = `
`
)
func printBanner() {
fmt.Println(banner)
fmt.Printf("Version: %s\n", version)
fmt.Printf("URL: %s\n", website)
fmt.Println()
}