mirror of https://github.com/arendst/Tasmota.git
changes for HASS
This commit is contained in:
parent
9a21dc864f
commit
388937c97e
|
@ -20,6 +20,8 @@
|
||||||
--------------------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------------------
|
||||||
Version yyyymmdd Action Description
|
Version yyyymmdd Action Description
|
||||||
--------------------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------------------
|
||||||
|
0.9.1.5 20201021 changed - HASS related ('null', hold back discovery), number of found sensors for RULES
|
||||||
|
-------
|
||||||
0.9.1.4 20201020 changed - use BearSSL for decryption, revert to old TELEPERIOD-cycle as default
|
0.9.1.4 20201020 changed - use BearSSL for decryption, revert to old TELEPERIOD-cycle as default
|
||||||
-------
|
-------
|
||||||
0.9.1.3 20200926 changed - Improve HA discovery, make key+MAC case insensitive
|
0.9.1.3 20200926 changed - Improve HA discovery, make key+MAC case insensitive
|
||||||
|
@ -59,6 +61,7 @@ void MI32notifyCB(NimBLERemoteCharacteristic* pRemoteCharacteristic, uint8_t* pD
|
||||||
struct {
|
struct {
|
||||||
uint16_t perPage = 4;
|
uint16_t perPage = 4;
|
||||||
uint32_t period; // set manually in addition to TELE-period, is set to TELE-period after start
|
uint32_t period; // set manually in addition to TELE-period, is set to TELE-period after start
|
||||||
|
union {
|
||||||
struct {
|
struct {
|
||||||
uint32_t init:1;
|
uint32_t init:1;
|
||||||
uint32_t connected:1;
|
uint32_t connected:1;
|
||||||
|
@ -77,7 +80,10 @@ struct {
|
||||||
uint32_t shallTriggerTele:1;
|
uint32_t shallTriggerTele:1;
|
||||||
uint32_t triggeredTele:1;
|
uint32_t triggeredTele:1;
|
||||||
uint32_t shallClearResults:1; // BLE scan results
|
uint32_t shallClearResults:1; // BLE scan results
|
||||||
|
uint32_t shallShowStatusInfo:1; // react to amount of found sensors via RULES
|
||||||
|
uint32_t firstAutodiscoveryDone:1;
|
||||||
|
};
|
||||||
|
uint32_t all = 0;
|
||||||
} mode;
|
} mode;
|
||||||
struct {
|
struct {
|
||||||
uint8_t sensor; // points to to the number 0...255
|
uint8_t sensor; // points to to the number 0...255
|
||||||
|
@ -85,10 +91,11 @@ struct {
|
||||||
struct {
|
struct {
|
||||||
uint32_t allwaysAggregate:1; // always show all known values of one sensor in brdigemode
|
uint32_t allwaysAggregate:1; // always show all known values of one sensor in brdigemode
|
||||||
uint32_t noSummary:1; // no sensor values at TELE-period
|
uint32_t noSummary:1; // no sensor values at TELE-period
|
||||||
uint32_t minimalSummary:1; // DEPRECATED!!
|
|
||||||
uint32_t directBridgeMode:1; // send every received BLE-packet as a MQTT-message in real-time
|
uint32_t directBridgeMode:1; // send every received BLE-packet as a MQTT-message in real-time
|
||||||
|
uint32_t holdBackFirstAutodiscovery:1; // allows to trigger it later
|
||||||
uint32_t showRSSI:1;
|
uint32_t showRSSI:1;
|
||||||
uint32_t ignoreBogusBattery:1;
|
uint32_t ignoreBogusBattery:1;
|
||||||
|
uint32_t minimalSummary:1; // DEPRECATED!!
|
||||||
} option;
|
} option;
|
||||||
} MI32;
|
} MI32;
|
||||||
|
|
||||||
|
@ -536,6 +543,24 @@ int MI32_decryptPacket(char *_buf, uint16_t _bufSize, uint32_t _type){
|
||||||
}
|
}
|
||||||
#endif // USE_MI_DECRYPTION
|
#endif // USE_MI_DECRYPTION
|
||||||
|
|
||||||
|
#ifdef USE_HOME_ASSISTANT
|
||||||
|
/**
|
||||||
|
* @brief For HASS only, changes last entry of JSON in mqtt_data to 'null'
|
||||||
|
*/
|
||||||
|
|
||||||
|
void MI32nullifyEndOfMQTT_DATA(){
|
||||||
|
char *p = mqtt_data + strlen(mqtt_data);
|
||||||
|
while(true){
|
||||||
|
*p--;
|
||||||
|
if(p[0]==':'){
|
||||||
|
p[1] = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ResponseAppend_P(PSTR("null"));
|
||||||
|
}
|
||||||
|
#endif // USE_HOME_ASSISTANT
|
||||||
|
|
||||||
/*********************************************************************************************\
|
/*********************************************************************************************\
|
||||||
* common functions
|
* common functions
|
||||||
\*********************************************************************************************/
|
\*********************************************************************************************/
|
||||||
|
@ -626,6 +651,7 @@ uint32_t MIBLEgetSensorSlot(uint8_t (&_MAC)[6], uint16_t _type, uint8_t counter)
|
||||||
}
|
}
|
||||||
MIBLEsensors.push_back(_newSensor);
|
MIBLEsensors.push_back(_newSensor);
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG,PSTR("%s: new %s at slot: %u"),D_CMND_MI32, kMI32DeviceType[_type-1],MIBLEsensors.size()-1);
|
AddLog_P2(LOG_LEVEL_DEBUG,PSTR("%s: new %s at slot: %u"),D_CMND_MI32, kMI32DeviceType[_type-1],MIBLEsensors.size()-1);
|
||||||
|
MI32.mode.shallShowStatusInfo = 1;
|
||||||
return MIBLEsensors.size()-1;
|
return MIBLEsensors.size()-1;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -643,6 +669,13 @@ void MI32triggerTele(void){
|
||||||
#endif // USE_RULES
|
#endif // USE_RULES
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MI32StatusInfo() {
|
||||||
|
MI32.mode.shallShowStatusInfo = 0;
|
||||||
|
Response_P(PSTR("{\"%s\":{\"found\":%u}}"), D_CMND_MI32, MIBLEsensors.size());
|
||||||
|
XdrvRulesProcess();
|
||||||
|
}
|
||||||
|
|
||||||
/*********************************************************************************************\
|
/*********************************************************************************************\
|
||||||
* init NimBLE
|
* init NimBLE
|
||||||
\*********************************************************************************************/
|
\*********************************************************************************************/
|
||||||
|
@ -666,6 +699,7 @@ MIBLEbindKeys.reserve(10);
|
||||||
MI32.option.directBridgeMode = 0;
|
MI32.option.directBridgeMode = 0;
|
||||||
MI32.option.showRSSI = 1;
|
MI32.option.showRSSI = 1;
|
||||||
MI32.option.ignoreBogusBattery = 1; // from advertisements
|
MI32.option.ignoreBogusBattery = 1; // from advertisements
|
||||||
|
MI32.option.holdBackFirstAutodiscovery = 1;
|
||||||
|
|
||||||
MI32StartScanTask(); // Let's get started !!
|
MI32StartScanTask(); // Let's get started !!
|
||||||
}
|
}
|
||||||
|
@ -1439,6 +1473,10 @@ void MI32EverySecond(bool restart){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(MI32.mode.shallShowStatusInfo == 1){
|
||||||
|
MI32StatusInfo();
|
||||||
|
}
|
||||||
|
|
||||||
if(restart){
|
if(restart){
|
||||||
_counter = 0;
|
_counter = 0;
|
||||||
MI32.mode.canScan = 0;
|
MI32.mode.canScan = 0;
|
||||||
|
@ -1616,7 +1654,7 @@ bool MI32Cmd(void) {
|
||||||
* Presentation
|
* Presentation
|
||||||
\*********************************************************************************************/
|
\*********************************************************************************************/
|
||||||
|
|
||||||
const char HTTP_MI32[] PROGMEM = "{s}MI ESP32 {m}%u%s / %u{e}";
|
const char HTTP_MI32[] PROGMEM = "{s}MI ESP32 v0.9.1.5{m}%u%s / %u{e}";
|
||||||
const char HTTP_MI32_MAC[] PROGMEM = "{s}%s %s{m}%s{e}";
|
const char HTTP_MI32_MAC[] PROGMEM = "{s}%s %s{m}%s{e}";
|
||||||
const char HTTP_RSSI[] PROGMEM = "{s}%s " D_RSSI "{m}%d dBm{e}";
|
const char HTTP_RSSI[] PROGMEM = "{s}%s " D_RSSI "{m}%d dBm{e}";
|
||||||
const char HTTP_BATTERY[] PROGMEM = "{s}%s" " Battery" "{m}%u %%{e}";
|
const char HTTP_BATTERY[] PROGMEM = "{s}%s" " Battery" "{m}%u %%{e}";
|
||||||
|
@ -1633,6 +1671,12 @@ void MI32Show(bool json)
|
||||||
bool _noSummarySave = MI32.option.noSummary;
|
bool _noSummarySave = MI32.option.noSummary;
|
||||||
bool _minimalSummarySave = MI32.option.minimalSummary;
|
bool _minimalSummarySave = MI32.option.minimalSummary;
|
||||||
if(hass_mode==2){
|
if(hass_mode==2){
|
||||||
|
if(MI32.option.holdBackFirstAutodiscovery){
|
||||||
|
if(!MI32.mode.firstAutodiscoveryDone){
|
||||||
|
MI32.mode.firstAutodiscoveryDone = 1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
MI32.option.noSummary = false;
|
MI32.option.noSummary = false;
|
||||||
MI32.option.minimalSummary = false;
|
MI32.option.minimalSummary = false;
|
||||||
}
|
}
|
||||||
|
@ -1659,7 +1703,7 @@ void MI32Show(bool json)
|
||||||
if(MIBLEsensors[i].eventType.tempHum || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
if(MIBLEsensors[i].eventType.tempHum || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
||||||
if (!isnan(MIBLEsensors[i].hum) && !isnan(MIBLEsensors[i].temp)
|
if (!isnan(MIBLEsensors[i].hum) && !isnan(MIBLEsensors[i].temp)
|
||||||
#ifdef USE_HOME_ASSISTANT
|
#ifdef USE_HOME_ASSISTANT
|
||||||
||(hass_mode==2)
|
||(hass_mode!=-1)
|
||||||
#endif //USE_HOME_ASSISTANT
|
#endif //USE_HOME_ASSISTANT
|
||||||
) {
|
) {
|
||||||
ResponseAppend_P(PSTR(","));
|
ResponseAppend_P(PSTR(","));
|
||||||
|
@ -1672,7 +1716,7 @@ void MI32Show(bool json)
|
||||||
if(MIBLEsensors[i].eventType.temp || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate) {
|
if(MIBLEsensors[i].eventType.temp || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate) {
|
||||||
if (!isnan(MIBLEsensors[i].temp)
|
if (!isnan(MIBLEsensors[i].temp)
|
||||||
#ifdef USE_HOME_ASSISTANT
|
#ifdef USE_HOME_ASSISTANT
|
||||||
||(hass_mode==2)
|
||(hass_mode!=-1)
|
||||||
#endif //USE_HOME_ASSISTANT
|
#endif //USE_HOME_ASSISTANT
|
||||||
) {
|
) {
|
||||||
char temperature[FLOATSZ];
|
char temperature[FLOATSZ];
|
||||||
|
@ -1685,7 +1729,7 @@ void MI32Show(bool json)
|
||||||
if(MIBLEsensors[i].eventType.hum || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate) {
|
if(MIBLEsensors[i].eventType.hum || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate) {
|
||||||
if (!isnan(MIBLEsensors[i].hum)
|
if (!isnan(MIBLEsensors[i].hum)
|
||||||
#ifdef USE_HOME_ASSISTANT
|
#ifdef USE_HOME_ASSISTANT
|
||||||
||(hass_mode==2)
|
||(hass_mode!=-1)
|
||||||
#endif //USE_HOME_ASSISTANT
|
#endif //USE_HOME_ASSISTANT
|
||||||
) {
|
) {
|
||||||
char hum[FLOATSZ];
|
char hum[FLOATSZ];
|
||||||
|
@ -1698,10 +1742,13 @@ void MI32Show(bool json)
|
||||||
if(MIBLEsensors[i].eventType.lux || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
if(MIBLEsensors[i].eventType.lux || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
||||||
if (MIBLEsensors[i].lux!=0x0ffffff
|
if (MIBLEsensors[i].lux!=0x0ffffff
|
||||||
#ifdef USE_HOME_ASSISTANT
|
#ifdef USE_HOME_ASSISTANT
|
||||||
||(hass_mode==2)
|
||(hass_mode!=-1)
|
||||||
#endif //USE_HOME_ASSISTANT
|
#endif //USE_HOME_ASSISTANT
|
||||||
) { // this is the error code -> no lux
|
) { // this is the error code -> no lux
|
||||||
ResponseAppend_P(PSTR(",\"" D_JSON_ILLUMINANCE "\":%u"), MIBLEsensors[i].lux);
|
ResponseAppend_P(PSTR(",\"" D_JSON_ILLUMINANCE "\":%u"), MIBLEsensors[i].lux);
|
||||||
|
#ifdef USE_HOME_ASSISTANT
|
||||||
|
if (MIBLEsensors[i].lux==0x0ffffff) MI32nullifyEndOfMQTT_DATA();
|
||||||
|
#endif //USE_HOME_ASSISTANT
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1709,10 +1756,13 @@ void MI32Show(bool json)
|
||||||
if(MIBLEsensors[i].eventType.moist || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
if(MIBLEsensors[i].eventType.moist || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
||||||
if (MIBLEsensors[i].moisture!=0xff
|
if (MIBLEsensors[i].moisture!=0xff
|
||||||
#ifdef USE_HOME_ASSISTANT
|
#ifdef USE_HOME_ASSISTANT
|
||||||
||(hass_mode==2)
|
||(hass_mode!=-1)
|
||||||
#endif //USE_HOME_ASSISTANT
|
#endif //USE_HOME_ASSISTANT
|
||||||
) {
|
) {
|
||||||
ResponseAppend_P(PSTR(",\"" D_JSON_MOISTURE "\":%u"), MIBLEsensors[i].moisture);
|
ResponseAppend_P(PSTR(",\"" D_JSON_MOISTURE "\":%u"), MIBLEsensors[i].moisture);
|
||||||
|
#ifdef USE_HOME_ASSISTANT
|
||||||
|
if (MIBLEsensors[i].moisture==0xff) MI32nullifyEndOfMQTT_DATA();
|
||||||
|
#endif //USE_HOME_ASSISTANT
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1720,10 +1770,13 @@ void MI32Show(bool json)
|
||||||
if(MIBLEsensors[i].eventType.fert || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
if(MIBLEsensors[i].eventType.fert || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
||||||
if (MIBLEsensors[i].fertility!=0xffff
|
if (MIBLEsensors[i].fertility!=0xffff
|
||||||
#ifdef USE_HOME_ASSISTANT
|
#ifdef USE_HOME_ASSISTANT
|
||||||
||(hass_mode==2)
|
||(hass_mode!=-1)
|
||||||
#endif //USE_HOME_ASSISTANT
|
#endif //USE_HOME_ASSISTANT
|
||||||
) {
|
) {
|
||||||
ResponseAppend_P(PSTR(",\"Fertility\":%u"), MIBLEsensors[i].fertility);
|
ResponseAppend_P(PSTR(",\"Fertility\":%u"), MIBLEsensors[i].fertility);
|
||||||
|
#ifdef USE_HOME_ASSISTANT
|
||||||
|
if (MIBLEsensors[i].fertility==0xffff) MI32nullifyEndOfMQTT_DATA();
|
||||||
|
#endif //USE_HOME_ASSISTANT
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1762,10 +1815,13 @@ void MI32Show(bool json)
|
||||||
if(MIBLEsensors[i].eventType.bat || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
if(MIBLEsensors[i].eventType.bat || !MI32.mode.triggeredTele || MI32.option.allwaysAggregate){
|
||||||
if (MIBLEsensors[i].bat != 0x00
|
if (MIBLEsensors[i].bat != 0x00
|
||||||
#ifdef USE_HOME_ASSISTANT
|
#ifdef USE_HOME_ASSISTANT
|
||||||
||(hass_mode==2)
|
||(hass_mode!=-1)
|
||||||
#endif //USE_HOME_ASSISTANT
|
#endif //USE_HOME_ASSISTANT
|
||||||
) { // this is the error code -> no battery
|
) { // this is the error code -> no battery
|
||||||
ResponseAppend_P(PSTR(",\"Battery\":%u"), MIBLEsensors[i].bat);
|
ResponseAppend_P(PSTR(",\"Battery\":%u"), MIBLEsensors[i].bat);
|
||||||
|
#ifdef USE_HOME_ASSISTANT
|
||||||
|
if (MIBLEsensors[i].bat == 0x00) MI32nullifyEndOfMQTT_DATA();
|
||||||
|
#endif //USE_HOME_ASSISTANT
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue