mirror of
https://github.com/bettercap/bettercap
synced 2025-07-14 09:03:39 -07:00
new: gps module
This commit is contained in:
parent
1857a62645
commit
caa801c764
3 changed files with 159 additions and 0 deletions
1
main.go
1
main.go
|
@ -53,6 +53,7 @@ func main() {
|
||||||
sess.Register(modules.NewWiFiRecon(sess))
|
sess.Register(modules.NewWiFiRecon(sess))
|
||||||
sess.Register(modules.NewBLERecon(sess))
|
sess.Register(modules.NewBLERecon(sess))
|
||||||
sess.Register(modules.NewSynScanner(sess))
|
sess.Register(modules.NewSynScanner(sess))
|
||||||
|
sess.Register(modules.NewGPS(sess))
|
||||||
|
|
||||||
if err = sess.Start(); err != nil {
|
if err = sess.Start(); err != nil {
|
||||||
log.Fatal("%s", err)
|
log.Fatal("%s", err)
|
||||||
|
|
155
modules/gps.go
Normal file
155
modules/gps.go
Normal file
|
@ -0,0 +1,155 @@
|
||||||
|
package modules
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/bettercap/bettercap/core"
|
||||||
|
"github.com/bettercap/bettercap/log"
|
||||||
|
"github.com/bettercap/bettercap/session"
|
||||||
|
|
||||||
|
"github.com/adrianmo/go-nmea"
|
||||||
|
"github.com/tarm/serial"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GPS struct {
|
||||||
|
session.SessionModule
|
||||||
|
|
||||||
|
serialPort string
|
||||||
|
baudRate int
|
||||||
|
serial *serial.Port
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewGPS(s *session.Session) *GPS {
|
||||||
|
gps := &GPS{
|
||||||
|
SessionModule: session.NewSessionModule("http.server", s),
|
||||||
|
serialPort: "/dev/ttyUSB0",
|
||||||
|
baudRate: 19200,
|
||||||
|
}
|
||||||
|
|
||||||
|
gps.AddParam(session.NewStringParameter("gps.device",
|
||||||
|
gps.serialPort,
|
||||||
|
"",
|
||||||
|
"Serial device of the GPS hardware."))
|
||||||
|
|
||||||
|
gps.AddParam(session.NewIntParameter("gps.baudrate",
|
||||||
|
fmt.Sprintf("%d", gps.baudRate),
|
||||||
|
"Baud rate of the GPS serial device."))
|
||||||
|
|
||||||
|
gps.AddHandler(session.NewModuleHandler("gps on", "",
|
||||||
|
"Start acquiring from the GPS hardware.",
|
||||||
|
func(args []string) error {
|
||||||
|
return gps.Start()
|
||||||
|
}))
|
||||||
|
|
||||||
|
gps.AddHandler(session.NewModuleHandler("gps off", "",
|
||||||
|
"Stop acquiring from the GPS hardware.",
|
||||||
|
func(args []string) error {
|
||||||
|
return gps.Stop()
|
||||||
|
}))
|
||||||
|
|
||||||
|
gps.AddHandler(session.NewModuleHandler("gps.show", "",
|
||||||
|
"Show the last coordinates returned by the GPS hardware.",
|
||||||
|
func(args []string) error {
|
||||||
|
return gps.Show()
|
||||||
|
}))
|
||||||
|
|
||||||
|
return gps
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gps *GPS) Name() string {
|
||||||
|
return "gps"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gps *GPS) Description() string {
|
||||||
|
return "A module talking with GPS hardware on a serial interface."
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gps *GPS) Author() string {
|
||||||
|
return "Simone Margaritelli <evilsocket@protonmail.com>"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gps *GPS) Configure() (err error) {
|
||||||
|
if err, gps.serialPort = gps.StringParam("gps.device"); err != nil {
|
||||||
|
return err
|
||||||
|
} else if err, gps.baudRate = gps.IntParam("gps.baudrate"); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
gps.serial, err = serial.OpenPort(&serial.Config{
|
||||||
|
Name: gps.serialPort,
|
||||||
|
Baud: gps.baudRate,
|
||||||
|
ReadTimeout: time.Second * 1,
|
||||||
|
})
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gps *GPS) readLine() (line string, err error) {
|
||||||
|
var n int
|
||||||
|
|
||||||
|
b := make([]byte, 1)
|
||||||
|
for {
|
||||||
|
if n, err = gps.serial.Read(b); err != nil {
|
||||||
|
return
|
||||||
|
} else if n == 1 {
|
||||||
|
if b[0] == '\n' {
|
||||||
|
return core.Trim(line), nil
|
||||||
|
} else {
|
||||||
|
line += string(b[0])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gps *GPS) Show() error {
|
||||||
|
fmt.Printf("latitude:%f longitude:%f quality:%s satellites:%s altitude:%s\n",
|
||||||
|
gps.Session.GPS.Latitude,
|
||||||
|
gps.Session.GPS.Longitude,
|
||||||
|
gps.Session.GPS.FixQuality,
|
||||||
|
gps.Session.GPS.NumSatellites,
|
||||||
|
gps.Session.GPS.Altitude)
|
||||||
|
|
||||||
|
gps.Session.Refresh()
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gps *GPS) Start() error {
|
||||||
|
if gps.Running() == true {
|
||||||
|
return session.ErrAlreadyStarted
|
||||||
|
} else if err := gps.Configure(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return gps.SetRunning(true, func() {
|
||||||
|
|
||||||
|
defer gps.serial.Close()
|
||||||
|
|
||||||
|
for gps.Running() {
|
||||||
|
if line, err := gps.readLine(); err == nil {
|
||||||
|
if info, err := nmea.Parse(line); err == nil {
|
||||||
|
s := info.GetSentence()
|
||||||
|
// http://aprs.gids.nl/nmea/#gga
|
||||||
|
if s.Type == "GNGGA" {
|
||||||
|
gps.Session.GPS = info.(nmea.GNGGA)
|
||||||
|
} else {
|
||||||
|
log.Debug("Skipping message %v", s)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
log.Debug("Error parsing line '%s': %s", line, err)
|
||||||
|
}
|
||||||
|
} else if err != io.EOF {
|
||||||
|
log.Warning("Error while reading serial port: %s", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (gps *GPS) Stop() error {
|
||||||
|
return gps.SetRunning(false, func() {
|
||||||
|
// let the read fail and exit
|
||||||
|
gps.serial.Close()
|
||||||
|
})
|
||||||
|
}
|
|
@ -21,6 +21,8 @@ import (
|
||||||
"github.com/bettercap/bettercap/firewall"
|
"github.com/bettercap/bettercap/firewall"
|
||||||
"github.com/bettercap/bettercap/network"
|
"github.com/bettercap/bettercap/network"
|
||||||
"github.com/bettercap/bettercap/packets"
|
"github.com/bettercap/bettercap/packets"
|
||||||
|
|
||||||
|
"github.com/adrianmo/go-nmea"
|
||||||
)
|
)
|
||||||
|
|
||||||
const HistoryFile = "~/bettercap.history"
|
const HistoryFile = "~/bettercap.history"
|
||||||
|
@ -45,6 +47,7 @@ type Session struct {
|
||||||
Input *readline.Instance `json:"-"`
|
Input *readline.Instance `json:"-"`
|
||||||
StartedAt time.Time `json:"started_at"`
|
StartedAt time.Time `json:"started_at"`
|
||||||
Active bool `json:"active"`
|
Active bool `json:"active"`
|
||||||
|
GPS nmea.GNGGA `json:"gps"`
|
||||||
Prompt Prompt `json:"-"`
|
Prompt Prompt `json:"-"`
|
||||||
|
|
||||||
CoreHandlers []CommandHandler `json:"-"`
|
CoreHandlers []CommandHandler `json:"-"`
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue