esphome/esphome/components/xiaomi_jqjcy01ym/xiaomi_jqjcy01ym.cpp

66 lines
2 KiB
C++

#include "xiaomi_jqjcy01ym.h"
#include "esphome/core/log.h"
#ifdef ARDUINO_ARCH_ESP32
namespace esphome {
namespace xiaomi_jqjcy01ym {
static const char *const TAG = "xiaomi_jqjcy01ym";
void XiaomiJQJCY01YM::dump_config() {
ESP_LOGCONFIG(TAG, "Xiaomi JQJCY01YM");
LOG_SENSOR(" ", "Temperature", this->temperature_);
LOG_SENSOR(" ", "Humidity", this->humidity_);
LOG_SENSOR(" ", "Formaldehyde", this->formaldehyde_);
LOG_SENSOR(" ", "Battery Level", this->battery_level_);
}
bool XiaomiJQJCY01YM::parse_device(const esp32_ble_tracker::ESPBTDevice &device) {
if (device.address_uint64() != this->address_) {
ESP_LOGVV(TAG, "parse_device(): unknown MAC address.");
return false;
}
ESP_LOGVV(TAG, "parse_device(): MAC address %s found.", device.address_str().c_str());
bool success = false;
for (auto &service_data : device.get_service_datas()) {
auto res = xiaomi_ble::parse_xiaomi_header(service_data);
if (!res.has_value()) {
continue;
}
if (res->is_duplicate) {
continue;
}
if (res->has_encryption) {
ESP_LOGVV(TAG, "parse_device(): payload decryption is currently not supported on this device.");
continue;
}
if (!(xiaomi_ble::parse_xiaomi_message(service_data.data, *res))) {
continue;
}
if (!(xiaomi_ble::report_xiaomi_results(res, device.address_str()))) {
continue;
}
if (res->temperature.has_value() && this->temperature_ != nullptr)
this->temperature_->publish_state(*res->temperature);
if (res->humidity.has_value() && this->humidity_ != nullptr)
this->humidity_->publish_state(*res->humidity);
if (res->formaldehyde.has_value() && this->formaldehyde_ != nullptr)
this->formaldehyde_->publish_state(*res->formaldehyde);
if (res->battery_level.has_value() && this->battery_level_ != nullptr)
this->battery_level_->publish_state(*res->battery_level);
success = true;
}
if (!success) {
return false;
}
return true;
}
} // namespace xiaomi_jqjcy01ym
} // namespace esphome
#endif