58 lines
2.1 KiB
Markdown
58 lines
2.1 KiB
Markdown
# ATC_MiThermometer_Gateway
|
|
|
|
Python gateway for the [custom firmware](https://github.com/atc1441/ATC_MiThermometer) for the Xiaomi Thermometer LYWSD03MMC.
|
|
|
|

|
|
|
|
**Features:**
|
|
- [WIP] Can run on Raspberry Pi (3, 4, zero w) or any other Linux driven hardware which has BLE and WiFi support
|
|
- [WIP] Storing temperature, humidity and battery state as json in a text file
|
|
- [WIP] Implement a loop for fetching the data every x minute
|
|
- [DONE] Make in runnable in a docker container (because only cool people are using docker)
|
|
- [TODO] Make docker image smaller. I mean shiiit 1GB D: should be possible to be under 500MB
|
|
- [TODO] Make a microPython version for using the raspberry pico w or any other microcontroller with BLE and WiFi support
|
|
- [TODO] Collect data from multiple devices/gateways
|
|
- [TODO] Command line tool for managing the devices
|
|
- [TODO] Analyzing tool for making statistics
|
|
- [TODO] HomeAssistant integration
|
|
- [TODO] MQTT publishing
|
|
- [TODO] Maybe... a webinterface. But I suck at web stuff, so I don't know.
|
|
- [TODO] Implement other BLE Sensors
|
|
|
|
**Current State**
|
|
|
|

|
|
|
|
## Getting started
|
|
|
|
First of all, you need to flash the [custom firmware](https://github.com/atc1441/ATC_MiThermometer) on your LYWSD03MMC device. A step-by-step guid is in his youtube channel, the video is linked on his GitHub repo. It's straight forward and does not require any special hardware.
|
|
|
|
## Run Gateway
|
|
|
|
The libraries are needed to be installed as root, because the gateway itself needs to be executed as root, else it is not able to use the bluetooth adapter. In the future, I try to do it better. Also in the future it will be much easier to start and install.
|
|
|
|
Install `bluez`. It's needed for bluepy to communicate with the bluetooth adapter.
|
|
```bash
|
|
sudo apt-get install -y bluez
|
|
```
|
|
Install PIP Libraries
|
|
```bash
|
|
sudo pip3 install -r python/requirements.txt
|
|
```
|
|
Run Gateway
|
|
```bash
|
|
cd python/src
|
|
sudo python3 main.py
|
|
```
|
|
|
|
### Docker
|
|
|
|
Build docker container
|
|
```bash
|
|
docker-compose build
|
|
```
|
|
Run docker container. Killing the hosts bluetooth service is needed to access it from the docker container.
|
|
```bash
|
|
sudo sh run_docker.sh
|
|
```
|