7namespace mopeka_pro_check {
9static const char *
const TAG =
"mopeka_pro_check";
10static const uint8_t MANUFACTURER_DATA_LENGTH = 10;
11static const uint16_t MANUFACTURER_ID = 0x0059;
12static const double MOPEKA_LPG_COEF[] = {0.573045, -0.002822, -0.00000535};
15 ESP_LOGCONFIG(TAG,
"Mopeka Pro Check");
16 LOG_SENSOR(
" ",
"Level", this->
level_);
19 LOG_SENSOR(
" ",
"Reading Distance", this->
distance_);
34 char addr_buf[MAC_ADDRESS_PRETTY_BUFFER_SIZE];
35 ESP_LOGVV(TAG,
"parse_device(): MAC address %s found.", device.
address_str_to(addr_buf));
39 if (manu_datas.size() != 1) {
40 ESP_LOGE(TAG,
"Unexpected manu_datas size (%d)", manu_datas.size());
44 const auto &manu_data = manu_datas[0];
46 ESP_LOGVV(TAG,
"Manufacturer data:");
47 for (
const uint8_t
byte : manu_data.data) {
48 ESP_LOGVV(TAG,
"0x%02x",
byte);
51 if (manu_data.data.size() != MANUFACTURER_DATA_LENGTH) {
52 ESP_LOGE(TAG,
"Unexpected manu_data size (%d)", manu_data.data.size());
62 ESP_LOGE(TAG,
"Unsupported Sensor Type (0x%X)", manu_data.data[0]);
81 ESP_LOGW(TAG,
"Read Quality too low to report distance or level");
95 ESP_LOGD(TAG,
"Distance Sensor: Quality (0x%X) Distance (%" PRId32
"mm)", quality_value, distance_value);
106 if (this->
level_ !=
nullptr) {
107 uint8_t tank_level = 0;
108 if (distance_value >= this->
full_mm_) {
110 }
else if (distance_value > this->
empty_mm_) {
128 float v = (float) ((
message[1] & 0x7F) / 32.0f);
130 float percent = (v - 2.2f) / 0.65f * 100.0f;
131 if (percent < 0.0f) {
134 if (percent > 100.0f) {
137 return (uint8_t) percent;
142 double raw_level =
raw & 0x3FFF;
143 double raw_t = (
message[2] & 0x7F);
145 return (uint32_t) (raw_level *
146 (MOPEKA_LPG_COEF[0] + MOPEKA_LPG_COEF[1] * raw_t + MOPEKA_LPG_COEF[2] * raw_t * raw_t));
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_manufacturer_datas() const
SensorReadQuality min_signal_quality_
SensorReadQuality parse_read_quality_(const std::vector< uint8_t > &message)
void dump_config() override
sensor::Sensor * read_quality_
sensor::Sensor * ignored_reads_
int8_t parse_temperature_(const std::vector< uint8_t > &message)
uint32_t ignored_read_count_
sensor::Sensor * battery_level_
uint8_t parse_battery_level_(const std::vector< uint8_t > &message)
sensor::Sensor * distance_
bool parse_device(const esp32_ble_tracker::ESPBTDevice &device) override
Main parse function that gets called for all ble advertisements.
sensor::Sensor * temperature_
uint32_t parse_distance_(const std::vector< uint8_t > &message)
void publish_state(float state)
Publish a new state to the front-end.
Providing packet encoding functions for exchanging data with a remote host.