fix: setting BLE device name once services are enumerated

This commit is contained in:
evilsocket 2019-03-17 13:36:59 +01:00
commit d6e6746809
No known key found for this signature in database
GPG key ID: 1564D7F30393A456
2 changed files with 14 additions and 3 deletions

View file

@ -367,6 +367,10 @@ func (mod *BLERecon) showServices(p gatt.Peripheral, services []*gatt.Service) {
data = parseRawData(raw) data = parseRawData(raw)
} }
if ch.Name() == "Device Name" && data != "" && mod.currDevice.DeviceName == "" {
mod.currDevice.DeviceName = data
}
if multi == nil { if multi == nil {
char.Data = data char.Data = data
rows = append(rows, []string{ rows = append(rows, []string{

View file

@ -28,6 +28,7 @@ type BLEService struct {
type BLEDevice struct { type BLEDevice struct {
LastSeen time.Time LastSeen time.Time
DeviceName string
Vendor string Vendor string
RSSI int RSSI int
Device gatt.Peripheral Device gatt.Peripheral
@ -62,9 +63,15 @@ func NewBLEDevice(p gatt.Peripheral, a *gatt.Advertisement, rssi int) *BLEDevice
} }
func (d *BLEDevice) Name() string { func (d *BLEDevice) Name() string {
name := d.Device.Name() // get the name if it's being set during services enumeration via 'Device Name'
if name == "" && d.Advertisement != nil { name := d.DeviceName
name = d.Advertisement.LocalName if name == "" {
// get the name from the device
name := d.Device.Name()
if name == "" && d.Advertisement != nil {
// get the name from the advertisement data
name = d.Advertisement.LocalName
}
} }
return name return name
} }