Forked Casambi Bluetooth client library with switch event support, use original if no special need. https://github.com/lkempf/casambi-bt
Project description
Casambi Bluetooth Revamped - Python library for Casambi networks
This is a customized fork of the original casambi-bt library with additional features and should only be used for special needs:
- Switch event support - Receive button press/release/hold events from Casambi switches (wired + wireless)
- Improved relay status handling - Better support for relay units
- Classic protocol (experimental) - Basic unit control for Classic (legacy) firmware networks
- Bug fixes and improvements - Various fixes based on real-world usage
This library provides a bluetooth interface to Casambi-based lights. It is not associated with Casambi.
For Home Assistant integration using this library, see casambi-bt-hass.
Getting started
This library is available on PyPi:
pip install casambi-bt-revamped
Have a look at demo.py for a small example.
Switch Event Support
This library supports receiving physical switch events as a decoded stream of INVOCATION frames (ground truth from the official Android app).
Event types you can expect:
button_pressbutton_releasebutton_holdbutton_release_after_holdinput_event(raw NotifyInput frame that may accompany presses/holds; useful for diagnostics and some wired devices)
from CasambiBt import Casambi
def handle_switch_event(event_data):
print(
"Switch event:",
{
"unit_id": event_data.get("unit_id"),
"button": event_data.get("button"),
"event": event_data.get("event"),
# INVOCATION metadata (useful for debugging/correlation)
"event_id": event_data.get("event_id"),
"opcode": event_data.get("opcode"),
"target_type": event_data.get("target_type"),
"origin": event_data.get("origin"),
"age": event_data.get("age"),
# NotifyInput fields (target_type=0x12)
"input_code": event_data.get("input_code"),
"input_channel": event_data.get("input_channel"),
"input_value16": event_data.get("input_value16"),
"input_mapped_event": event_data.get("input_mapped_event"),
},
)
casa = Casambi()
# ... connect to network ...
# Register switch event handler
casa.registerSwitchEventHandler(handle_switch_event)
# Events will be received when buttons are pressed/released
Notes:
- Wireless (battery) switches typically send a "button stream" (target_type
0x06) for press/release, and a NotifyInput stream (target_type0x12) for hold/release-after-hold. - Wired switches often only send NotifyInput (target_type
0x12), soinput_codeis mapped intobutton_press/button_release/...when appropriate. - The library suppresses same-state retransmits at the protocol layer (edge detection), so Home Assistant-style time-window deduplication should generally not be necessary.
For the parsing details and field layout, see doc/PROTOCOL_PARSING.md.
Classic (Legacy Firmware) Support (Experimental)
This library can also connect to Classic Casambi networks and send unit control commands.
How it works (ground truth: the bundled Android app sources):
- Classic devices expose a CMAC-signed data channel (
ca51/ca52) or a "Classic conformant" signed channel on the EVO UUID. - The cloud network JSON exposes
visitorKey/managerKey(hex strings) instead of an EVOkeyStore. - Commands are signed with AES-CMAC and sent as Classic "command records" (see
doc/PROTOCOL_PARSING.md).
Environment flags:
CASAMBI_BT_DISABLE_CLASSIC=1to refuse Classic connections (fail fast)CASAMBI_BT_CLASSIC_USE_MANAGER=1to sign with the 16-byte manager signature (default is visitor/4-byte prefix)CASAMBI_BT_LOG_RAW_NOTIFIES=1to enable very verbose per-notify hexdumps (mainly for Classic debugging)
MacOS
MacOS does not expose the Bluetooth MAC address via their official API, if you're running this library on MacOS, it will use an undocumented IOBluetooth API to get the MAC Address. Without the real MAC address the integration with Casambi will not work. If you're running into problems fetching the MAC address on MacOS, try it on a Raspberry Pi.
Casambi network setup
If you have problems connecting to the network please check that your network is configured appropriately before creating an issue. The network I test this with uses the Evoultion firmware and is configured as follows (screenshots are for the iOS app but the Android app should look very similar):
Development / Offline Testing
This repo includes log-driven unit tests for switch parsing:
cd casambi-bt
python -m unittest -v
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file casambi_bt_revamped-0.3.12.dev9.tar.gz.
File metadata
- Download URL: casambi_bt_revamped-0.3.12.dev9.tar.gz
- Upload date:
- Size: 59.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
61b625cb90ed8a28e15a7ceeae95865f9650f82399edcd0f0b65ca1db7563ffd
|
|
| MD5 |
dbfbab4caded31455f716ae2f13cdb10
|
|
| BLAKE2b-256 |
3e949d7f27d75bdbd8467d267d58e662818b920b8abf67da96a44807f0406f25
|
File details
Details for the file casambi_bt_revamped-0.3.12.dev9-py3-none-any.whl.
File metadata
- Download URL: casambi_bt_revamped-0.3.12.dev9-py3-none-any.whl
- Upload date:
- Size: 57.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
937822954ddcd49d72f52f48c964f45aace16ac20b403a1415a112147aa00c23
|
|
| MD5 |
1fb155b3604dda08576526213d5f14b0
|
|
| BLAKE2b-256 |
9add5ae7926d84a5eaef3926c34bec8313873722b983d84b3a16bbcc3590c719
|