An unofficial reverse engineered Husqvarna Automower Connect BLE library
Project description
AutoMower-BLE
This is an unofficial reverse engineered Husqvarna Automower Connect BLE library. This allows connecting and controlling an Automower without any accounts, cloud or network connection.
<a href="https://liberapay.com/alistair23/donate"><img alt="Donate using Liberapay" src="https://liberapay.com/assets/widgets/donate.svg"></a>
This library is written with the intent of integrating into Home Assistant, but it can be used independently as well.
Details on how this was developed are available at: https://www.alistair23.me/2024/01/06/reverse-engineering-automower-ble
This was developed and tested against a Automower 305, but it should work on all Automowers. If you are able to test on different models please do and report any results back.
Testing Requests
You can run the request unit tests with
python3 ./request.py
Testing Responses
You can run the response unit tests with
python3 ./response.py
Testing Connections
You can test querying data and sending commands with the following
python3 ./mower.py --address D8:B6:73:40:07:37
You can uncomment parts of async def main(mower)
to send commands
Debugging on an android phone
You can get Bluetooth debug logs from an android phone which will help for unknown codes or implementation of extra devices. To debug you need to enable developer mode on your android handset/tablet (and have the manufacturer app installed to communicate with your mower)
To enable debug mode on android:
- Go into settings and System (Sometimes this is in About phone). Look for the "Build number" entry.
- Tap this several times, onscreen you should then see a note confirming by tapping 7 times developer mode will be enabled.
- Once enabled, click BACK and you'll see a "Developer Options" menu. In there scroll to find "Enable Bluetooth HCI snoop log".
- Set "Enable Bluetooth HCI snoop log" to "Enabled"
- Turn bluetooth OFF then back ON to enable the logging.
Go into your mower app and carry out the commands, making a note of precise time you send the command to the mower. Once you've captured the commands, to retrieve the log you can either grab it using your phones file browser. The file location is /data/misc/bluetooth/logs The filename is btsnoop_hci.log (This varies, for example Samsung phones store them elsewhere)
An alternative is to use the adb via usb to retrieve the log. Plug your phone in via usb and use adb to download your bug report: adb bugreport MyFilename (This will generate a bugreport and save it as MyFilename.zip) Extract that zip file and the bluetooth HCI snoop file is in FS/data/log/bt/btsnoop_hci.log
These bluetooth hci snoop files (btsnoop_hci.log) are in wireshark file format so use wireshark to view them. You can then see the commands sent and received from your mower and can then decode/investigate the commands.
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
Hashes for automower_ble-0.1.35-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a089a3d948bbd7e91be5bf11d2955c487edb9cf1aeb211b63d51067e6601b399 |
|
MD5 | 7528589dd4cb38583b4d7c7c9bc535f7 |
|
BLAKE2b-256 | a6a2acc50536a3ef1338929699b06036a140e6f80e4e276d8c2fbbfebc39b923 |