mirror of
https://github.com/bettercap/bettercap.git
synced 2025-03-12 04:36:03 -07:00
fix: setting BLE device name once services are enumerated
This commit is contained in:
parent
64a5ce2b58
commit
d6e6746809
@ -367,6 +367,10 @@ func (mod *BLERecon) showServices(p gatt.Peripheral, services []*gatt.Service) {
|
||||
data = parseRawData(raw)
|
||||
}
|
||||
|
||||
if ch.Name() == "Device Name" && data != "" && mod.currDevice.DeviceName == "" {
|
||||
mod.currDevice.DeviceName = data
|
||||
}
|
||||
|
||||
if multi == nil {
|
||||
char.Data = data
|
||||
rows = append(rows, []string{
|
||||
|
@ -28,6 +28,7 @@ type BLEService struct {
|
||||
|
||||
type BLEDevice struct {
|
||||
LastSeen time.Time
|
||||
DeviceName string
|
||||
Vendor string
|
||||
RSSI int
|
||||
Device gatt.Peripheral
|
||||
@ -62,9 +63,15 @@ func NewBLEDevice(p gatt.Peripheral, a *gatt.Advertisement, rssi int) *BLEDevice
|
||||
}
|
||||
|
||||
func (d *BLEDevice) Name() string {
|
||||
name := d.Device.Name()
|
||||
if name == "" && d.Advertisement != nil {
|
||||
name = d.Advertisement.LocalName
|
||||
// get the name if it's being set during services enumeration via 'Device Name'
|
||||
name := d.DeviceName
|
||||
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
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user