BLEZ - Asynchronous Bluetooth Low Energy on Linux for Rust

This library provides an asynchronous, fully featured interface to the Bluetooth Low Energy (BLE) APIs of the official Linux Bluetooth protocol stack (BlueZ) for Rust. Both publishing local and consuming remote GATT services using idiotmatic Rust code is supported. Asynchronous support is depended by Tokio.

This project started as a fork of blurz but has since then become a full rewrite. Documentation has been mostly copied from the BlueZ API specification, but also extended.

The following features are provided:

Classic Bluetooth is unsupported except for device discovery.

Requirements

This libray has been tested with BlueZ version 5.56. Older versions might work, but be aware that many bugs related to GATT handling exist. Refer to the official changelog for details.

bluetoothd must be running and configured for access over D-Bus. On most distributions this should work out of the box.

For building, D-Bus library headers must be installed. On Debian-based distributions install the package libdbus-1-dev.

Troubleshooting

The library returns detailed errors received from BlueZ.

Set the Rust log level to trace to see all D-Bus communications with BlueZ.

In some cases checking the Bluetooth system log might provide further insights. On Debian-based systems it can be displayed by executing journalctl -u bluetooth. Check the bluetoothd man page for increasing the log level.

Examples

Refer to the API documentation and examples folder for examples.

The follwing example applications are provided.

Use cargo run --example <name> to run a particular example application.