- Why is this component called “passive” and what does this mean
- INSTALLATION ISSUES
- RECEPTION ISSUES
- OTHER ISSUES
- TIPS AND TRICKS
- DEBUG
- FORUM
Unlike the original mitemp_bt
component (and most other solutions), this custom component does not use connections (polling) to collect data. The fact is that many sensors from the Xiaomi ecosystem transmit information themselves about their condition to the air with some frequency. We need only to "passively" receive these messages and update the status of the corresponding entities in the Home Assistant. What does this give us?
- firstly, it reduces the power consumption of the sensors (the battery lasts longer), since the sensor does not transmit anything other than that provided by its developers.
- secondly, since the range of bluetooth is rather limited, passive reception can solve some problems that arise when using "polling" components. In the case of connecting to a sensor, a two-way exchange takes place, which means we not only should “hear” the sensor well, but the sensor, in its turn, must also “hear” us well, and this could be problematic. To increase the radius of reception, you can, for example, install an external bt-dongle with a large antenna on your host, to make it "hear" better, but you can’t do anything with the sensor itself. A passive data collection method solves this problem, because in this case the sensor does not know about our existence, and should not "hear" us at all. The main thing is that we "hear" it well.
- another important point is the fact that the frequency of sending data for many sensors is quite high. For example, the LYWSDCGQ sensor sends about 20-25 measurements per minute. If your sensor is far away, or you have poor reception conditions, you only need to receive one out of twenty messages to update your Home Assistant entity... Not a bad chance, is it? And if you increase the
period
option, then the chances increase even more. In addition, receiving a stream of 20-25 measurements per minute gives you the opportunity to increase the resolution of measurements by averaging (which is implemented in our component) and this gives more smooth (beautiful, if you want) graphs and a faster reaction of corresponding automations. - passive method allows without problems collecting data from several interfaces simultaneously, which expands your ability to increase the reception area. For example, you can use several external BT-dongles connected by cheap USB-RJ45 extenders and high-quality cat5/6 ethernet cables.
I’m not sure that I have listed all the advantages resulting from the passivity of this component. But I hope that I was able to explain the essence.
Python needs root access to access the HCI interface. If Python doesn't have root access, you will get an error message in Home Assistant which ends with:
PermissionError: [Errno 1] Operation not permitted
First, try to set root access with
sudo setcap 'cap_net_raw,cap_net_admin+eip' `readlink -f \`which python3\``
Next, check that it is set correctly with the following command
sudo getcap `readlink -f \`which python3\``
The command will return the path to python and looks like (can vary based on your python version):
/usr/bin/python3.7 = cap_net_admin,cap_net_raw+eip
Make sure you first stop Home Assistant and then start Home Assistant again. Restarting Home Assistant is not enough, as the python process does not exit upon restart.
If you have multiple python versions, make sure it refers to the same version which is used by Home Assistant. If Home Assistant is using a different version, e.g. python3.6, run the following command to set the correct version (adjust it to your own version if needed).
sudo setcap 'cap_net_raw,cap_net_admin+eip' /usr/bin/python3.6
To find the correct number, run the following command:
hcitool dev
The command will return the HCI interface number and mac address.
Devices:
hci0 B8:27:EB:77:75:50
You can set option batt_entities
to True
- the battery sensor entity will be created automatically for each device reporting battery status.
Or you can create a battery sensor by using a template sensor. Add the following to your configuration.yaml
. Make sure you adjust the name of the sensor with your own sensor.
sensor:
- platform: template
sensors:
ble_battery_582d34339449:
friendly_name: "Battery"
unit_of_measurement: "%"
value_template: "{{ state_attr('sensor.ble_temperature_582d34339449', 'battery_level') }}"
device_class: "battery"
The custom component uses Bluetooth (BLE) to receive messages from your sensor(s). The number of messages per minute that are being send by your sensor depends on the type, but is around 20 messages per minute for LYWSDCGQ, LYWSD02 and CGG1 sensors, around 2 per minute for HHCCPOT002 and around 1 per minute for HHCCJCY01T.
The number of messages that are received by Home Assistant can be less or even zero. Parameters that affect the reception of messages are:
- The distance between the sensor and the Bluetooth device on your Home Assistant device.
Try to keep the distance as limited as possible.
- Interference with other electrical devices.
Especially SSD devices are known to affect the Bluetooth reception, try to place your SSD drive as far as possible from your Bluetooth tranceiver.
-
Metal cases are a big problem for built-in bluetooth and wifi without an external antenna!
-
The quality of your Bluetooth transceiver.
The range of the built-in Bluetooth tranceiver of a Raspberry Pi is known to be limited. Try using an external Bluetooth transceiver to increase the range, e.g. with an external antenna.
It is also worth noting that starting from v0.5.5, a component can receive data from multiple interfaces simultaneously (see the hci_interface
option).
- You should also pay attention to this issue, since your problem may not be directly related to reception.
There are several ways to increase coverage:
- use an external BT-dongle (preferably with a full-size antenna).
- use multiple spaced BT-dongles. You can experiment with various extension cords (for example, inexpensive USB-RJ45 extenders in combination with a regular ethernet cable).
- use additional devices with their own BT-interface, and connect them to Home Assistant. For example, it could be another raspberrypi with Home Assistant and our component, connected to the main host using the remote_homeassistant component, which links multiple Home Assistant instances together.
There are several ways:
-
LYWSD03MMC only: using TelinkFlasher, see also the instructions here
- Keep the sensor close to the mobile phone (android only) or Windows computer.
- Make sure that the bluetooth is enabled.
- Using your browser, navigate to this page.
- Now, click the [Connect] button and wait until it shows "Connected." See the Log section at the bottom.
- Once connected, click the [Do Activation] button and wait until the "Mi Bind Key" shows the information.
-
Android only. Get the key with the customized MiHome mod.
-
Get the key from the MiHome application traffic (in violation of the Xiaomi user agreement terms) while adding a sensor to the application ("pairing"). If the sensor has already been added before, then you can first delete it and add it again: Unfortunately, the steps described below do not work anymore, since Xiaomi has enabled additional encryption of API requests, and therefore the procedure for intercepting traffic has become much more complicated. There are no instructions yet, so try to get by with the first two methods. If you have no choice, then create a separate issue, in which I will tell you what to do step by step, and we will use this issue as a guide for others.- iOS: Two known working options
- using Charles proxy, paid $7-10,
- using Stream - Network Debug Tool, free. For more detailed instructions, check these instructions or these instructions.
- Android:
- using Packet Capture.
- using Burp Suite, device must be rooted.
- iOS: Two known working options
Since our component uses a special operating mode of the HCI interface and works with a continuous data stream, conflicts with other software using the same HCI interface are possible. The conflict is caused by the fact that another component can switch the HCI interface to a different operating mode, thereby stopping the reception of data. Or our component may lead to malfunctioning of another component. A reliable, but not the only way out of this situation (apart from the refusal to use one component in favor of another) can be the use of two BT-interfaces (one for our component, the second, for example, for the tracker). Work is underway to find other solutions to such situations...
Often, the cause of this is the presence of bugs in the system components responsible for the BT operation (kernel modules, firmwares, etc). As a rule, in such cases, the corresponding entries appear in the system log. Please carefully review the contents of your syslog
, and try searching the Internet for a solution - with high probability you are not alone in this. For example, here is an issue with a typical Raspberry PI problem - BT problem, Raspberry PI3 and Hass.io
In addition, in the case of Raspberry Pi, a common problem is a lack of power. If you do not observe any negative effects associated with a lack of power, then this does not mean that they actually are not present. We have feedback from users who have solved their bluetooth problems installing a more powerful power supply and high-quality cable. Good powering is very important for raspberry. In addition to a sufficiently powerful power supply, attention should be paid to the power cable - it should be able to deliver this power. Often, to compensate for losses, power supplies are made with a slightly higher output voltage (up to 5.1V or even 5.25V).
My sensor from the Xiaomi ecosystem is not in the list of supported ones. How to request implementation?
- Install the component if you have not already done so.
- Make sure you have logger enabled, and logging enabled for
info
level (globally or just forcustom_components.ble_monitor
). For example:
logger:
default: warn
logs:
custom_components.ble_monitor: info
- Place your sensor extremely close to the HA host (BT interface).
- Enable the option
report_unknown
. - Wait until a number of "BLE ADV from UNKNOWN" messages accumulate in the log.
- Create a new issue, write everything you know about your sensor and attach the obtained log.
- Do not forget to disable the
report_unknown
option (delete it or set it toFalse
and restart HA)! Since the potentially large output of this option will spam the log and can mask really important messages. - Wait for a response from the developers.
Battery level is not broadcasted by all sensors. Check the list of supported sensors to see if your sensor supports battery level. LYWSD02 sensors need to be updated to firmware 1.1.2_00085 or above to the show battery level.
When the reception of data from sensors is stopped for some reason (hardware failure, errors at the system level, and so on), it may take an unacceptably long time before we notice this fact. Here is a discussion of a solution to solve this problem using a template binary sensor, which can be used in automation to send notifications, for example.
To enable debug logging, add the following lines to configuration.yaml
:
logger:
default: warn
logs:
custom_components.ble_monitor: debug
In addition, the btmon
utility can provide a lot of useful information.
For example, using the command
btmon --write hcitrace.snoop | tee hcitrace.txt
You can write to the hcitrace.snoop and hcitrace.txt files the moment the problem occurs and attach this files to your issue.
You can more freely discuss the operation of the component, ask for support, leave feedback and share your experience in our topic on the Home Assistant forum.