new: new ticker module with netmon.cap example caplet

This commit is contained in:
evilsocket 2018-01-27 19:54:38 +01:00
commit 73c13beb8a
3 changed files with 114 additions and 0 deletions

4
caplets/netmon.cap Normal file
View file

@ -0,0 +1,4 @@
net.recon on
net.probe on
clear
ticker on

View file

@ -22,6 +22,7 @@ func main() {
fmt.Printf(core.Bold("%s v%s\n\n"), core.Name, core.Version)
sess.Register(modules.NewEventsStream(sess))
sess.Register(modules.NewTicker(sess))
sess.Register(modules.NewMacChanger(sess))
sess.Register(modules.NewProber(sess))
sess.Register(modules.NewDiscovery(sess))

109
modules/ticker.go Normal file
View file

@ -0,0 +1,109 @@
package modules
import (
"time"
"github.com/evilsocket/bettercap-ng/log"
"github.com/evilsocket/bettercap-ng/session"
)
type Ticker struct {
session.SessionModule
Period time.Duration
Commands []string
}
func NewTicker(s *session.Session) *Ticker {
t := &Ticker{
SessionModule: session.NewSessionModule("ticker", s),
}
t.AddParam(session.NewStringParameter("ticker.commands",
"clear; net.show",
"",
"List of commands separated by a ;"))
t.AddParam(session.NewIntParameter("ticker.period",
"1",
"Ticker period in seconds"))
t.AddHandler(session.NewModuleHandler("ticker on", "",
"Start the ticker.",
func(args []string) error {
return t.Start()
}))
t.AddHandler(session.NewModuleHandler("ticker off", "",
"Stop the ticker.",
func(args []string) error {
return t.Stop()
}))
return t
}
func (t *Ticker) Name() string {
return "ticker"
}
func (t *Ticker) Description() string {
return "A module to execute one or more commands every given amount of seconds."
}
func (t *Ticker) Author() string {
return "Simone Margaritelli <evilsocket@protonmail.com>"
}
func (t *Ticker) Configure() error {
var err error
var commands string
var period int
if err, commands = t.StringParam("ticker.commands"); err != nil {
return err
}
t.Commands = session.ParseCommands(commands)
if err, period = t.IntParam("ticker.period"); err != nil {
return err
}
t.Period = time.Duration(period) * time.Second
return nil
}
func (t *Ticker) Start() error {
if t.Running() == true {
return session.ErrAlreadyStarted
} else if err := t.Configure(); err != nil {
return err
}
t.SetRunning(true)
go func() {
log.Info("Ticker running with period %ds.", t.Period)
tick := time.Tick(t.Period)
for _ = range tick {
if t.Running() == false {
break
}
for _, cmd := range t.Commands {
if err := t.Session.Run(cmd); err != nil {
log.Error("%s", err)
}
}
}
}()
return nil
}
func (t *Ticker) Stop() error {
if t.Running() == false {
return session.ErrAlreadyStopped
}
t.SetRunning(false)
return nil
}