wifictld-analyzer/cmd/controller.go

74 lines
1.7 KiB
Go
Raw Normal View History

2018-06-03 20:37:52 +02:00
package cmd
import (
2019-03-01 10:54:19 +01:00
"net"
2018-06-03 20:37:52 +02:00
"os"
"os/signal"
"syscall"
2019-02-28 17:26:55 +01:00
"dev.sum7.eu/genofire/golang-lib/file"
2019-02-28 16:24:29 +01:00
"github.com/bdlm/log"
2018-06-03 20:37:52 +02:00
"github.com/spf13/cobra"
2019-02-28 16:22:55 +01:00
"dev.sum7.eu/genofire/wifictld-analyzer/capture"
2019-02-28 17:26:55 +01:00
"dev.sum7.eu/genofire/wifictld-analyzer/config"
2019-02-28 16:22:55 +01:00
"dev.sum7.eu/genofire/wifictld-analyzer/controller"
2019-03-01 10:54:19 +01:00
"dev.sum7.eu/genofire/wifictld-analyzer/data"
2019-02-28 16:22:55 +01:00
"dev.sum7.eu/genofire/wifictld-analyzer/database"
2019-03-01 10:54:19 +01:00
"dev.sum7.eu/genofire/wifictld-analyzer/web"
2018-06-03 20:37:52 +02:00
)
// queryCmd represents the query command
var controllerCmd = &cobra.Command{
Use: "controller <interfaces>",
Short: "simulate a wifictld controller",
2018-07-10 21:40:38 +02:00
Example: `analyzer controller "/etc/wifictld.conf"`,
2018-06-03 20:37:52 +02:00
Args: cobra.ExactArgs(1),
Run: func(cmd *cobra.Command, args []string) {
2018-07-10 21:40:38 +02:00
configObj := &config.Config{}
2018-06-03 20:37:52 +02:00
2018-07-10 21:40:38 +02:00
file.ReadTOML(args[0], configObj)
2018-06-03 20:37:52 +02:00
2018-07-10 21:40:38 +02:00
db := database.NewDB(configObj.StatePath)
2018-06-03 20:37:52 +02:00
2018-07-10 21:40:38 +02:00
ctr := controller.NewController(db)
2018-06-03 20:37:52 +02:00
defer ctr.Close()
2019-03-01 10:54:19 +01:00
var handlers []data.Handler
if configObj.Webserver.Enable {
log.Infof("starting webserver on %s", configObj.Webserver.Bind)
srv := web.New(configObj.Webserver)
go srv.Start()
handlers = append(handlers, srv.Handler)
defer srv.Close()
}
coll := capture.NewCollector(func(addr *net.UDPAddr, msg *data.SocketMSG) (*data.SocketMSG, error) {
for _, a := range handlers {
a(addr, msg)
}
if !configObj.Answer {
ctr.Handler(addr, msg)
return nil, nil
}
return ctr.Handler(addr, msg)
}, configObj.Interfaces)
2018-06-03 20:37:52 +02:00
defer coll.Close()
ctr.Send = coll.Send
ctr.SendTo = coll.SendTo
// Wait for INT/TERM
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)
sig := <-sigs
log.Println("received", sig)
},
}
func init() {
2019-03-01 10:54:19 +01:00
RootCMD.AddCommand(controllerCmd)
2018-06-03 20:37:52 +02:00
}