Skip to main content

Parser for passive BLE advertisements

Project description

BLE parser for passive BLE advertisements

This pypi package is parsing BLE advertisements to readable data for several sensors and can be used for device tracking (by (fixed) MAC address or by UUID). The parser was originally developed as part of the BLE monitor custom component for Home Assistant, but can now be used for other implementations. The package does NOT take care of the data collecting of the BLE advertisements, you can use other packages like aioblescan or bleson to do that part. An example is given in the examples folder.

Installation

pip install bleparser

Supported sensors

Supported sensor brands

  • Acconeer
  • Air Mentor
  • Amazfit
  • ATC (custom firmware for Xiaomi/Qingping sensors)
  • BlueMaestro
  • Brifit
  • BTHome
  • b-parasite
  • Govee
  • HHCC
  • Inkbird
  • iNode
  • Jaalee
  • Jinou
  • Kegtron
  • KKM
  • Mikrotik
  • Moat
  • Oral-B
  • Qingping
  • Relsib
  • Ruuvitag
  • Sensirion
  • SensorPush
  • SmartDry
  • Switchbot
  • Teltonika
  • Thermoplus
  • Thermopro
  • Tilt
  • Xiaogui (Scale)
  • Xiaomi (MiBeacon)
  • Xiaomi (MiScale)

A full list of all supported sensors can be found on the BLE monitor documentation

Usage

When using default input parameters, you can use bleparser with raw BLE data as follows (more working examples below).

ble_parser = BleParser()
sensor_msg, tracker_msg = ble_parser.parse_raw_data(data)

You can set optional parameters, the example below shows all possible input parameters with default values.

ble_parser = BleParser(
    report_unknown=False,
    discovery=True,
    filter_duplicates=False,
    sensor_whitelist=[],
    tracker_whitelist=[],
    aeskeys={}
    )
sensor_msg, tracker_msg = ble_parser.parse_raw_data(data)

It is also possible to use advertisement data directly.

ble_parser = BleParser()
sensor_data, tracker_data = self.parse_advertisement(
    mac,
    rssi,
    service_class_uuid16,
    service_class_uuid128,
    local_name,
    service_data_list,
    man_spec_data_list
)

service_data_list and man_spec_data_list have to be in a list, as a BLE advertisement can contain multiple service data/manufacturer specific data packets.

report_unknown

Report unknown sensors. Can be set to Acconeer, Air Mentor, Amazfit, ATC, b-parasite, BlueMaestro, Brifit, BTHome, Govee, HHCC, Inkbird, iNode, Jaalee, Jinou, Kegtron, KKM, Mikrotik, Moat, Mi Scale, Oral-B, Qingping, Relsib, Ruuvitag, SensorPush, Sensirion, SmartDry, Switchbot, Teltonika, Thermoplus, Thermopro, Tilt, Xiaogui or Xiaomi to report unknown sensors of a specific brand to the logger. You can set it to Other to report all unknown advertisements to the logger. Default: False

discovery

Boolean. When set to False, only sensors in sensor_whitelist will be parsed. Default: True

filter_duplicates

Boolean. Most sensors send multipe advertisements with the exact same data, to increase reception quality. When set to True, it will filter duplicate advertisements based on a packet_id that is send by the sensor. Only one advertisement will be parsed if it has the same packet_id. Note that not all sensors have packet_ids. Default: False

sensor_whitelist

List with MAC addresses or UUIDs of devices that are being parsed, if discovery is set to False. If discovery is set to True, all supported sensors will be parsed. Default: []

The MAC addresses should be in bytes.

    sensor_whitelist=[bytes.fromhex("A4:C1:38:56:53:84".replace(":", ""))],

tracker_whitelist

List with devices (MAC addresses or UUIDs) to track. Default: []

aeskeys

Dictionary with mac + encryption key pairs, for sensors that require an encryption key to decrypt the payload. Default: {}

The mac and encryption key pairs should be in bytes.

    aeskeys={bytes.fromhex("A4:C1:38:56:53:84".replace(":", "")): bytes.fromhex("a115210eed7a88e50ad52662e732a9fb") for mac, aeskey in AESKEYS.items()},

Result

The parser result are two two dictionaries, one with sensor data (e.g. temperature readings) and one with tracking data.

Parsing sensor data

The following minimal example shows how to extract the sensor measurements out of a (supported) BLE advertisement:

from bleparser import BleParser

data_string = "043e2502010000219335342d5819020106151695fe5020aa01da219335342d580d1004fe004802c4"
data = bytes(bytearray.fromhex(data_string))

ble_parser = BleParser()
sensor_msg, tracker_msg = ble_parser.parse_raw_data(data)
print(sensor_msg)

The output of sensor_msg is:

{'rssi': -60, 'mac': '582D34359321', 'type': 'LYWSDCGQ', 'packet': 218, 'firmware': 'Xiaomi (MiBeacon V2)', 'data': True, 'temperature': 25.4, 'humidity': 58.4}

If the advertisements can be parsed, it will always show the rssi, mac, type, packet, firmware and data fields. Additional fields with the measurements, like temperature and humidity will be available depending on the sensor type.

Parsing tracker data

A minimal example for tracking BLE devices is shown below. To prevent tracking of all devices that pass by, you will have to specify a whitelist with devices that you want to track. This needs to be a list with MAC addresses in lower case, without :.

from bleparser import BleParser

data_string = "043e2502010000219335342d5819020106151695fe5020aa01da219335342d580d1004fe004802c4"
data = bytes(bytearray.fromhex(data_string))

tracker_whitelist = []
track_mac = "58:2D:34:35:93:21"
track_mac = bytes.fromhex(track_mac.replace(":", ""))
tracker_whitelist.append(track_mac.lower())

ble_parser = BleParser(tracker_whitelist=tracker_whitelist)
sensor_msg, tracker_msg = ble_parser.parse_raw_data(data)
print(tracker_msg)

The result is:

{'is connected': True, 'mac': '582D34359321', 'rssi': -60}

The output is always showing the mac, rssi and if it is connected.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bleparser-3.7.3.tar.gz (50.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bleparser-3.7.3-py3-none-any.whl (71.5 kB view details)

Uploaded Python 3

File details

Details for the file bleparser-3.7.3.tar.gz.

File metadata

  • Download URL: bleparser-3.7.3.tar.gz
  • Upload date:
  • Size: 50.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for bleparser-3.7.3.tar.gz
Algorithm Hash digest
SHA256 2db06504f772e944ef98eb5bf75a7e07085f71e243a850d7ed1872f92b202757
MD5 72ba2c8bcd2796a7eed7008548ccb557
BLAKE2b-256 6e6b121b79b522d17cd6cc2a3fde8df481ff0505816be738a0e9a22e717dc6e6

See more details on using hashes here.

File details

Details for the file bleparser-3.7.3-py3-none-any.whl.

File metadata

  • Download URL: bleparser-3.7.3-py3-none-any.whl
  • Upload date:
  • Size: 71.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for bleparser-3.7.3-py3-none-any.whl
Algorithm Hash digest
SHA256 472f626c0e15b1e3891ca373dd2c0751a43354df95beb39d39a42784b47b3858
MD5 b0aba2d06019a872dde5c24a2c429681
BLAKE2b-256 a75ff4089f5ab165e657e7f70f2142363802071a07123f2a1480acfe5b85f984

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page