Merge pull request #16187 from s-hadinger/zigbee_so144

Zigbee ``SetOption144 1`` includes a timestamp in `ZbReceived` messages
This commit is contained in:
s-hadinger 2022-08-09 18:46:07 +02:00 committed by GitHub
commit 9cd7320637
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 14 additions and 5 deletions

View File

@ -13,6 +13,7 @@ All notable changes to this project will be documented in this file.
- Zigbee include "BatteryPercentage" in all messages - Zigbee include "BatteryPercentage" in all messages
- Commands ``WifiScan`` and ``WifiTest`` (#16141) - Commands ``WifiScan`` and ``WifiTest`` (#16141)
- Support for Catalan language translations by Albert Gonzalez (#16145) - Support for Catalan language translations by Albert Gonzalez (#16145)
- Zigbee ``SetOption144 1`` includes a timestamp in `ZbReceived` messages
### Changed ### Changed
- ESP32 LVGL library from v8.2.0 to v8.3.0 (#16019) - ESP32 LVGL library from v8.2.0 to v8.3.0 (#16019)

View File

@ -171,7 +171,7 @@ typedef union { // Restricted by MISRA-C Rule 18.4 bu
uint32_t gui_module_name : 1; // bit 27 (v11.1.0.3) - SetOption141 - (GUI) Disable display of GUI module name (1) uint32_t gui_module_name : 1; // bit 27 (v11.1.0.3) - SetOption141 - (GUI) Disable display of GUI module name (1)
uint32_t wait_for_wifi_result : 1; // bit 28 (v11.1.0.4) - SetOption142 - (Wifi) Wait 1 second for wifi connection solving some FRITZ!Box modem issues (1) uint32_t wait_for_wifi_result : 1; // bit 28 (v11.1.0.4) - SetOption142 - (Wifi) Wait 1 second for wifi connection solving some FRITZ!Box modem issues (1)
uint32_t zigbee_no_batt_autoprobe : 1; // bit 29 (v12.0.2.4) - SetOption143 - (Zigbee) Disable Battery auto-probe and using auto-binding uint32_t zigbee_no_batt_autoprobe : 1; // bit 29 (v12.0.2.4) - SetOption143 - (Zigbee) Disable Battery auto-probe and using auto-binding
uint32_t spare30 : 1; // bit 30 uint32_t zigbee_include_time : 1; // bit 30 (v12.0.2.4) - SetOption144 - (Zigbee) include time in `ZbReceived` messages like other sensors
uint32_t spare31 : 1; // bit 31 uint32_t spare31 : 1; // bit 31
}; };
} SOBitfield5; } SOBitfield5;

View File

@ -828,7 +828,7 @@ public:
void jsonAddDataAttributes(Z_attribute_list & attr_list) const; void jsonAddDataAttributes(Z_attribute_list & attr_list) const;
void jsonAddDeviceAttributes(Z_attribute_list & attr_list) const; void jsonAddDeviceAttributes(Z_attribute_list & attr_list) const;
void jsonDumpSingleDevice(Z_attribute_list & attr_list, uint32_t dump_mode, bool add_name) const; void jsonDumpSingleDevice(Z_attribute_list & attr_list, uint32_t dump_mode, bool add_name) const;
void jsonPublishAttrList(const char * json_prefix, const Z_attribute_list &attr_list) const; void jsonPublishAttrList(const char * json_prefix, const Z_attribute_list &attr_list, bool include_time = false) const;
void jsonLightState(Z_attribute_list & attr_list) const; void jsonLightState(Z_attribute_list & attr_list) const;
// dump device attributes to ZbData // dump device attributes to ZbData

View File

@ -522,14 +522,22 @@ void Z_Devices::jsonAppend(uint16_t shortaddr, const Z_attribute_list &attr_list
// //
// internal function to publish device information with respect to all `SetOption`s // internal function to publish device information with respect to all `SetOption`s
// //
void Z_Device::jsonPublishAttrList(const char * json_prefix, const Z_attribute_list &attr_list) const { void Z_Device::jsonPublishAttrList(const char * json_prefix, const Z_attribute_list &attr_list, bool include_time) const {
bool use_fname = (Settings->flag4.zigbee_use_names) && (friendlyName); // should we replace shortaddr with friendlyname? bool use_fname = (Settings->flag4.zigbee_use_names) && (friendlyName); // should we replace shortaddr with friendlyname?
ResponseClear(); // clear string ResponseClear(); // clear string
// Do we prefix with `ZbReceived`? // Do we prefix with `ZbReceived`?
if (!Settings->flag4.remove_zbreceived && !Settings->flag5.zb_received_as_subtopic) { if (!Settings->flag4.remove_zbreceived && !Settings->flag5.zb_received_as_subtopic) {
Response_P(PSTR("{\"%s\":"), json_prefix); if (include_time && Rtc.utc_time >= START_VALID_TIME) {
// Add time if needed (and if time is valide)
ResponseAppendTimeFormat(Settings->flag2.time_format);
ResponseAppend_P(PSTR(",\"%s\":"), json_prefix);
} else {
ResponseAppend_P(PSTR("{\"%s\":"), json_prefix);
}
} }
// What key do we use, shortaddr or name? // What key do we use, shortaddr or name?
if (!Settings->flag5.zb_omit_json_addr) { if (!Settings->flag5.zb_omit_json_addr) {
if (use_fname) { if (use_fname) {
@ -609,7 +617,7 @@ void Z_Devices::jsonPublishFlush(uint16_t shortaddr) {
attr_list.setBattPercent(device.batt_percent); attr_list.setBattPercent(device.batt_percent);
} }
device.jsonPublishAttrList(PSTR(D_JSON_ZIGBEE_RECEIVED), attr_list); device.jsonPublishAttrList(PSTR(D_JSON_ZIGBEE_RECEIVED), attr_list, Settings->flag5.zigbee_include_time);
attr_list.reset(); // clear the attributes attr_list.reset(); // clear the attributes
} }
} }