|
@ -11,9 +11,6 @@ Copyright (C) 2016-2018 by Xose Pérez <xose dot perez at gmail dot com> |
|
|
#include <ArduinoJson.h>
|
|
|
#include <ArduinoJson.h>
|
|
|
|
|
|
|
|
|
bool _dcz_enabled = false; |
|
|
bool _dcz_enabled = false; |
|
|
unsigned long _dcz_skip_time = 0; |
|
|
|
|
|
unsigned long _dcz_last_idx = 0; |
|
|
|
|
|
unsigned long _dcz_last_time = 0; |
|
|
|
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
//------------------------------------------------------------------------------
|
|
|
// Private methods
|
|
|
// Private methods
|
|
@ -28,13 +25,6 @@ int _domoticzRelay(unsigned int idx) { |
|
|
return -1; |
|
|
return -1; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
bool _domoticzSkip(unsigned long idx) { |
|
|
|
|
|
if (idx == _dcz_last_idx && (millis() - _dcz_last_time < _dcz_skip_time)) return true; |
|
|
|
|
|
_dcz_last_idx = idx; |
|
|
|
|
|
_dcz_last_time = millis(); |
|
|
|
|
|
return false; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void _domoticzMqttSubscribe(bool value) { |
|
|
void _domoticzMqttSubscribe(bool value) { |
|
|
|
|
|
|
|
|
String dczTopicOut = getSetting("dczTopicOut", DOMOTICZ_OUT_TOPIC); |
|
|
String dczTopicOut = getSetting("dczTopicOut", DOMOTICZ_OUT_TOPIC); |
|
@ -73,14 +63,9 @@ void _domoticzMqtt(unsigned int type, const char * topic, const char * payload) |
|
|
unsigned long idx = root["idx"]; |
|
|
unsigned long idx = root["idx"]; |
|
|
int relayID = _domoticzRelay(idx); |
|
|
int relayID = _domoticzRelay(idx); |
|
|
if (relayID >= 0) { |
|
|
if (relayID >= 0) { |
|
|
|
|
|
|
|
|
// Skip message if recursive
|
|
|
|
|
|
if (_domoticzSkip(idx)) return; |
|
|
|
|
|
|
|
|
|
|
|
unsigned long value = root["nvalue"]; |
|
|
unsigned long value = root["nvalue"]; |
|
|
DEBUG_MSG_P(PSTR("[DOMOTICZ] Received value %d for IDX %d\n"), value, idx); |
|
|
DEBUG_MSG_P(PSTR("[DOMOTICZ] Received value %d for IDX %d\n"), value, idx); |
|
|
relayStatus(relayID, value == 1); |
|
|
relayStatus(relayID, value == 1); |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
@ -93,7 +78,6 @@ void _domoticzWebSocketOnSend(JsonObject& root) { |
|
|
|
|
|
|
|
|
root["dczVisible"] = 1; |
|
|
root["dczVisible"] = 1; |
|
|
root["dczEnabled"] = getSetting("dczEnabled", DOMOTICZ_ENABLED).toInt() == 1; |
|
|
root["dczEnabled"] = getSetting("dczEnabled", DOMOTICZ_ENABLED).toInt() == 1; |
|
|
root["dczSkip"] = getSetting("dczSkip", DOMOTICZ_SKIP_TIME); |
|
|
|
|
|
root["dczTopicIn"] = getSetting("dczTopicIn", DOMOTICZ_IN_TOPIC); |
|
|
root["dczTopicIn"] = getSetting("dczTopicIn", DOMOTICZ_IN_TOPIC); |
|
|
root["dczTopicOut"] = getSetting("dczTopicOut", DOMOTICZ_OUT_TOPIC); |
|
|
root["dczTopicOut"] = getSetting("dczTopicOut", DOMOTICZ_OUT_TOPIC); |
|
|
|
|
|
|
|
@ -117,7 +101,6 @@ void _domoticzWebSocketOnSend(JsonObject& root) { |
|
|
|
|
|
|
|
|
void _domoticzConfigure() { |
|
|
void _domoticzConfigure() { |
|
|
_dcz_enabled = getSetting("dczEnabled", DOMOTICZ_ENABLED).toInt() == 1; |
|
|
_dcz_enabled = getSetting("dczEnabled", DOMOTICZ_ENABLED).toInt() == 1; |
|
|
_dcz_skip_time = 1000 * getSetting("dczSkip", DOMOTICZ_SKIP_TIME).toInt(); |
|
|
|
|
|
_domoticzMqttSubscribe(_dcz_enabled); |
|
|
_domoticzMqttSubscribe(_dcz_enabled); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -129,14 +112,9 @@ template<typename T> void domoticzSend(const char * key, T nvalue, const char * |
|
|
if (!_dcz_enabled) return; |
|
|
if (!_dcz_enabled) return; |
|
|
unsigned int idx = getSetting(key).toInt(); |
|
|
unsigned int idx = getSetting(key).toInt(); |
|
|
if (idx > 0) { |
|
|
if (idx > 0) { |
|
|
|
|
|
|
|
|
// Skip message if recursive
|
|
|
|
|
|
if (_domoticzSkip(idx)) return; |
|
|
|
|
|
|
|
|
|
|
|
char payload[128]; |
|
|
char payload[128]; |
|
|
snprintf(payload, sizeof(payload), "{\"idx\": %d, \"nvalue\": %s, \"svalue\": \"%s\"}", idx, String(nvalue).c_str(), svalue); |
|
|
snprintf(payload, sizeof(payload), "{\"idx\": %d, \"nvalue\": %s, \"svalue\": \"%s\"}", idx, String(nvalue).c_str(), svalue); |
|
|
mqttSendRaw(getSetting("dczTopicIn", DOMOTICZ_IN_TOPIC).c_str(), payload); |
|
|
mqttSendRaw(getSetting("dczTopicIn", DOMOTICZ_IN_TOPIC).c_str(), payload); |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|