blatted/blatted/tools/ble/scanner.py

56 lines
1.9 KiB
Python
Raw Normal View History

2023-05-13 14:32:15 +02:00
import asyncio
from typing import Dict, Any
2023-05-13 14:32:15 +02:00
import bleak.exc
2023-05-13 13:31:49 +02:00
from bleak import BleakScanner
2023-05-13 14:32:15 +02:00
from bleak.backends.device import BLEDevice
from bleak.backends.scanner import AdvertisementData
from pydispatch import Dispatcher
2023-05-13 13:31:49 +02:00
from ...events.event import DeviceDiscovered
from ...tools import context
2023-05-13 14:32:15 +02:00
class Scanner(Dispatcher):
_events_ = ["device_discovered"]
2023-05-13 14:32:15 +02:00
def __init__(self) -> None:
self.environment = context.get_environment()
self.devices: Dict[str, Any] = {}
self.bind(device_discovered=self.on_device_discovered)
2023-05-13 14:32:15 +02:00
def discover_callback(
self, device: BLEDevice, advertising_data: AdvertisementData
) -> None:
if len(advertising_data.service_uuids) > 0:
#discovered = DiscoveredDevice(device, advertising_data)
discovered = DeviceDiscovered(device, advertising_data)
if context.get_environment() == context.BlattedEnvironment.CLI:
self.emit("device_discovered", data=discovered)
elif context.get_environment() == context.BlattedEnvironment.TUI:
pass # TODO Implement
2023-05-13 14:32:15 +02:00
def on_device_discovered(self, data: DeviceDiscovered) -> None:
if data.device.address not in self.devices:
print(f"new device discovered: {data.device}")
self.devices[data.device.address] = {"data": data, "seen": 1}
else:
self.devices[data.device.address]["seen"] += 1
print(
f"device seen {self.devices[data.device.address]['seen']} times: {data.device}"
)
async def run(self) -> None:
stop_event = asyncio.Event()
async with BleakScanner(self.discover_callback):
await stop_event.wait()
2023-05-13 14:32:15 +02:00
def run():
2023-05-13 13:31:49 +02:00
print("scanner called")
2023-05-13 14:32:15 +02:00
try:
asyncio.run(Scanner().run())
2023-05-13 14:32:15 +02:00
except bleak.exc.BleakDBusError as exc:
print(f"ERROR: {exc}")