8static const char *
const TAG =
"atc_mithermometer";
11 ESP_LOGCONFIG(TAG,
"ATC MiThermometer");
13 LOG_SENSOR(
" ",
"Humidity", this->
humidity_);
20 ESP_LOGVV(TAG,
"parse_device(): unknown MAC address.");
23 char addr_buf[MAC_ADDRESS_PRETTY_BUFFER_SIZE];
25 ESP_LOGVV(TAG,
"parse_device(): MAC address %s found.", addr_str);
30 if (!res.has_value()) {
39 if (res->temperature.has_value() && this->temperature_ !=
nullptr)
41 if (res->humidity.has_value() && this->humidity_ !=
nullptr)
43 if (res->battery_level.has_value() && this->battery_level_ !=
nullptr)
45 if (res->battery_voltage.has_value() && this->battery_voltage_ !=
nullptr)
58 ESP_LOGVV(TAG,
"parse_header(): no service data UUID magic bytes.");
63 if (
raw.size() < 13) {
64 ESP_LOGVV(TAG,
"parse_header_(): service data too short (%zu).",
raw.size());
68 static uint8_t last_frame_count = 0;
69 if (last_frame_count ==
raw[12]) {
70 ESP_LOGVV(TAG,
"parse_header(): duplicate data packet received (%hhu).", last_frame_count);
73 last_frame_count =
raw[12];
86 const uint8_t *data =
message.data();
87 const int data_length = 13;
89 if (
message.size() != data_length) {
90 ESP_LOGVV(TAG,
"parse_message(): payload has wrong size (%d)!",
message.size());
95 const int16_t
temperature = uint16_t(data[7]) | (uint16_t(data[6]) << 8);
105 const int16_t battery_voltage = uint16_t(data[11]) | (uint16_t(data[10]) << 8);
112 if (!result.has_value()) {
113 ESP_LOGVV(TAG,
"report_results(): no results available.");
117 ESP_LOGD(TAG,
"Got ATC MiThermometer (%s):",
address);
119 if (result->temperature.has_value()) {
120 ESP_LOGD(TAG,
" Temperature: %.1f °C", *result->temperature);
122 if (result->humidity.has_value()) {
123 ESP_LOGD(TAG,
" Humidity: %.0f %%", *result->humidity);
125 if (result->battery_level.has_value()) {
126 ESP_LOGD(TAG,
" Battery Level: %.0f %%", *result->battery_level);
128 if (result->battery_voltage.has_value()) {
129 ESP_LOGD(TAG,
" Battery Voltage: %.3f V", *result->battery_voltage);
sensor::Sensor * temperature_
sensor::Sensor * signal_strength_
bool report_results_(const optional< ParseResult > &result, const char *address)
bool parse_device(const esp32_ble_tracker::ESPBTDevice &device) override
sensor::Sensor * humidity_
bool parse_message_(const std::vector< uint8_t > &message, ParseResult &result)
sensor::Sensor * battery_level_
void dump_config() override
sensor::Sensor * battery_voltage_
optional< ParseResult > parse_header_(const esp32_ble_tracker::ServiceData &service_data)
bool contains(uint8_t data1, uint8_t data2) const
uint64_t address_uint64() const
const char * address_str_to(std::span< char, MAC_ADDRESS_PRETTY_BUFFER_SIZE > buf) const
Format MAC address into provided buffer, returns pointer to buffer for convenience.
const std::vector< ServiceData > & get_service_datas() const
void publish_state(float state)
Publish a new state to the front-end.
const LogString * message
optional< float > battery_voltage
optional< float > humidity
optional< float > temperature
optional< float > battery_level