This tool retrieves tokens for all devices connected to Xiaomi cloud and encryption keys for BLE devices.
It supports two ways of authentication:
- username (e-mail/Xiaomi Cloud account ID) & password
- QR code
After logging in you have to select a Xiaomi's server region (cn - China, de - Germany etc.). Leave it empty to check all available
In return all of your devices connected to account will be listed, together with their name and IP address.
Download and run token_extractor.exe.
Linux & Home Assistant (in SSH & Web Terminal)
Execute following command:
bash <(curl -L https://github.com/PiotrMachowski/Xiaomi-cloud-tokens-extractor/raw/master/run.sh)If installation fails try Docker version
Docker & Home Assistant (in SSH & Web Terminal)
Execute following command:
bash <(curl -L https://github.com/PiotrMachowski/Xiaomi-cloud-tokens-extractor/raw/master/run_docker.sh)To run this command in HA you have to disable
protected modein addon's settings and restart it
Download and unpack archive:
wget https://github.com/PiotrMachowski/Xiaomi-cloud-tokens-extractor/releases/latest/download/token_extractor.zip
unzip token_extractor.zip
cd token_extractorInstall dependencies and run script:
pip3 install -r requirements.txt
python3 token_extractor.pyIf you have problems with using this tool try following solutions:
- Make yourself sure that you provide correct credentials (e.g. not ones from Roborock app!)
- Remove Cloudflare DNS
- Disable network ad blockers (AdGuard, PiHole, etc.) and restrictions (UniFi Country Restriction etc.)
- Check SPAM folders for 2FA e-mail
- Use QR code authentication instead of username & password
- Just wait - there is a limit of 3/5 (depending on region) 2FA requests per day
- Map extractor - live map for Xiaomi Vacuums
- Map card - manual vacuum control from a Lovelace card
If you want to support my work with a donation you can use one of the following platforms:
| Platform | Payment methods | Link | Comment |
|---|---|---|---|
| Ko-fi |
|
|
|
| buycoffee.to |
|
|
|
| PayPal |
|
|
|
| Revolut |
|
|
|
