2017-01-28 13:41:01 +00:00
|
|
|
/*
|
2019-10-27 10:13:24 +00:00
|
|
|
xdrv_07_domoticz.ino - domoticz support for Tasmota
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2019-12-31 13:23:34 +00:00
|
|
|
Copyright (C) 2020 Theo Arends
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2017-05-13 12:02:10 +01:00
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2017-05-13 12:02:10 +01:00
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2017-01-28 13:41:01 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef USE_DOMOTICZ
|
|
|
|
|
2018-11-07 09:30:03 +00:00
|
|
|
#define XDRV_07 7
|
|
|
|
|
2019-08-11 17:12:18 +01:00
|
|
|
#define D_PRFX_DOMOTICZ "Domoticz"
|
|
|
|
#define D_CMND_IDX "Idx"
|
|
|
|
#define D_CMND_KEYIDX "KeyIdx"
|
|
|
|
#define D_CMND_SWITCHIDX "SwitchIdx"
|
|
|
|
#define D_CMND_SENSORIDX "SensorIdx"
|
|
|
|
#define D_CMND_UPDATETIMER "UpdateTimer"
|
|
|
|
|
|
|
|
const char kDomoticzCommands[] PROGMEM = D_PRFX_DOMOTICZ "|" // Prefix
|
2019-08-01 16:18:49 +01:00
|
|
|
D_CMND_IDX "|" D_CMND_KEYIDX "|" D_CMND_SWITCHIDX "|" D_CMND_SENSORIDX "|" D_CMND_UPDATETIMER ;
|
|
|
|
|
|
|
|
void (* const DomoticzCommand[])(void) PROGMEM = {
|
|
|
|
&CmndDomoticzIdx, &CmndDomoticzKeyIdx, &CmndDomoticzSwitchIdx, &CmndDomoticzSensorIdx, &CmndDomoticzUpdateTimer };
|
2017-10-29 17:18:46 +00:00
|
|
|
|
2019-08-11 17:12:18 +01:00
|
|
|
const char DOMOTICZ_MESSAGE[] PROGMEM = "{\"idx\":%d,\"nvalue\":%d,\"svalue\":\"%s\",\"Battery\":%d,\"RSSI\":%d}";
|
|
|
|
|
2017-12-22 13:55:24 +00:00
|
|
|
#if MAX_DOMOTICZ_SNS_IDX < DZ_MAX_SENSORS
|
|
|
|
#error "Domoticz: Too many sensors or change settings.h layout"
|
|
|
|
#endif
|
2017-10-25 13:27:30 +01:00
|
|
|
|
|
|
|
const char kDomoticzSensors[] PROGMEM =
|
2019-08-25 15:25:38 +01:00
|
|
|
D_DOMOTICZ_TEMP "|" D_DOMOTICZ_TEMP_HUM "|" D_DOMOTICZ_TEMP_HUM_BARO "|" D_DOMOTICZ_POWER_ENERGY "|" D_DOMOTICZ_ILLUMINANCE "|"
|
2019-09-29 17:00:01 +01:00
|
|
|
D_DOMOTICZ_COUNT "|" D_DOMOTICZ_VOLTAGE "|" D_DOMOTICZ_CURRENT "|" D_DOMOTICZ_AIRQUALITY "|" D_DOMOTICZ_P1_SMART_METER "|" D_DOMOTICZ_SHUTTER ;
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2017-06-06 22:23:23 +01:00
|
|
|
char domoticz_in_topic[] = DOMOTICZ_IN_TOPIC;
|
|
|
|
|
2018-12-06 14:03:42 +00:00
|
|
|
int domoticz_update_timer = 0;
|
2019-07-24 12:09:42 +01:00
|
|
|
uint32_t domoticz_fan_debounce = 0; // iFan02 state debounce timer
|
|
|
|
bool domoticz_subscribe = false;
|
|
|
|
bool domoticz_update_flag = true;
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2019-11-26 15:51:53 +00:00
|
|
|
#ifdef USE_SHUTTER
|
|
|
|
bool domoticz_is_shutter = false;
|
|
|
|
#endif // USE_SHUTTER
|
|
|
|
|
2018-11-14 13:32:09 +00:00
|
|
|
int DomoticzBatteryQuality(void)
|
2018-04-01 20:37:00 +01:00
|
|
|
{
|
|
|
|
// Battery 0%: ESP 2.6V (minimum operating voltage is 2.5)
|
|
|
|
// Battery 100%: ESP 3.6V (maximum operating voltage is 3.6)
|
|
|
|
// Battery 101% to 200%: ESP over 3.6V (means over maximum operating voltage)
|
|
|
|
|
2019-07-08 11:52:26 +01:00
|
|
|
int quality = 100; // Voltage range from 2,6V > 0% to 3,6V > 100%
|
2018-04-01 20:37:00 +01:00
|
|
|
|
2019-07-08 11:52:26 +01:00
|
|
|
#ifdef USE_ADC_VCC
|
2018-04-01 20:37:00 +01:00
|
|
|
uint16_t voltage = ESP.getVcc();
|
|
|
|
if (voltage <= 2600) {
|
|
|
|
quality = 0;
|
|
|
|
} else if (voltage >= 4600) {
|
|
|
|
quality = 200;
|
|
|
|
} else {
|
|
|
|
quality = (voltage - 2600) / 10;
|
|
|
|
}
|
2019-07-08 11:52:26 +01:00
|
|
|
#endif
|
2018-04-01 20:37:00 +01:00
|
|
|
return quality;
|
|
|
|
}
|
|
|
|
|
2018-11-14 13:32:09 +00:00
|
|
|
int DomoticzRssiQuality(void)
|
2018-04-01 20:37:00 +01:00
|
|
|
{
|
|
|
|
// RSSI range: 0% to 10% (12 means disable RSSI in Domoticz)
|
|
|
|
|
|
|
|
return WifiGetRssiAsQuality(WiFi.RSSI()) / 10;
|
|
|
|
}
|
|
|
|
|
2019-07-14 21:08:19 +01:00
|
|
|
#ifdef USE_SONOFF_IFAN
|
2019-11-20 19:53:12 +00:00
|
|
|
void MqttPublishDomoticzFanState(void)
|
2018-12-06 14:03:42 +00:00
|
|
|
{
|
2019-11-03 11:33:36 +00:00
|
|
|
if (Settings.flag.mqtt_enabled && Settings.domoticz_relay_idx[1]) { // SetOption3 - Enable MQTT
|
2018-12-06 14:03:42 +00:00
|
|
|
char svalue[8]; // Fanspeed value
|
|
|
|
|
|
|
|
int fan_speed = GetFanspeed();
|
|
|
|
snprintf_P(svalue, sizeof(svalue), PSTR("%d"), fan_speed * 10);
|
2019-03-23 16:00:59 +00:00
|
|
|
Response_P(DOMOTICZ_MESSAGE, (int)Settings.domoticz_relay_idx[1], (0 == fan_speed) ? 0 : 2, svalue, DomoticzBatteryQuality(), DomoticzRssiQuality());
|
2018-12-06 14:03:42 +00:00
|
|
|
MqttPublish(domoticz_in_topic);
|
|
|
|
|
2019-07-24 12:09:42 +01:00
|
|
|
domoticz_fan_debounce = millis();
|
2018-12-06 14:03:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-20 19:53:12 +00:00
|
|
|
void DomoticzUpdateFanState(void)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2018-12-06 14:03:42 +00:00
|
|
|
if (domoticz_update_flag) {
|
|
|
|
MqttPublishDomoticzFanState();
|
|
|
|
}
|
2019-07-24 12:09:42 +01:00
|
|
|
domoticz_update_flag = true;
|
2018-12-06 14:03:42 +00:00
|
|
|
}
|
2019-07-14 21:08:19 +01:00
|
|
|
#endif // USE_SONOFF_IFAN
|
2018-12-06 09:49:49 +00:00
|
|
|
|
2019-01-28 13:08:33 +00:00
|
|
|
void MqttPublishDomoticzPowerState(uint8_t device)
|
2018-12-06 14:03:42 +00:00
|
|
|
{
|
2019-11-03 11:33:36 +00:00
|
|
|
if (Settings.flag.mqtt_enabled) { // SetOption3 - Enable MQTT
|
2018-12-06 09:49:49 +00:00
|
|
|
if ((device < 1) || (device > devices_present)) { device = 1; }
|
2018-12-06 14:03:42 +00:00
|
|
|
if (Settings.domoticz_relay_idx[device -1]) {
|
2019-11-26 15:51:53 +00:00
|
|
|
#ifdef USE_SHUTTER
|
|
|
|
if (domoticz_is_shutter) {
|
|
|
|
// Shutter is updated by sensor update - power state should not be sent
|
|
|
|
} else {
|
|
|
|
#endif // USE_SHUTTER
|
2019-07-14 21:08:19 +01:00
|
|
|
#ifdef USE_SONOFF_IFAN
|
2019-07-14 14:23:02 +01:00
|
|
|
if (IsModuleIfan() && (device > 1)) {
|
2018-12-06 14:03:42 +00:00
|
|
|
// Fan handled by MqttPublishDomoticzFanState
|
|
|
|
} else {
|
2019-07-14 21:08:19 +01:00
|
|
|
#endif // USE_SONOFF_IFAN
|
2018-12-06 14:03:42 +00:00
|
|
|
char svalue[8]; // Dimmer value
|
|
|
|
|
|
|
|
snprintf_P(svalue, sizeof(svalue), PSTR("%d"), Settings.light_dimmer);
|
2019-03-23 16:00:59 +00:00
|
|
|
Response_P(DOMOTICZ_MESSAGE, (int)Settings.domoticz_relay_idx[device -1], (power & (1 << (device -1))) ? 1 : 0, (light_type) ? svalue : "", DomoticzBatteryQuality(), DomoticzRssiQuality());
|
2018-12-06 09:49:49 +00:00
|
|
|
MqttPublish(domoticz_in_topic);
|
2019-07-14 21:08:19 +01:00
|
|
|
#ifdef USE_SONOFF_IFAN
|
2018-12-06 09:49:49 +00:00
|
|
|
}
|
2019-07-14 21:08:19 +01:00
|
|
|
#endif // USE_SONOFF_IFAN
|
2019-11-26 15:51:53 +00:00
|
|
|
#ifdef USE_SHUTTER
|
|
|
|
}
|
|
|
|
#endif //USE_SHUTTER
|
2018-12-06 09:49:49 +00:00
|
|
|
}
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-28 13:08:33 +00:00
|
|
|
void DomoticzUpdatePowerState(uint8_t device)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2017-07-15 14:07:30 +01:00
|
|
|
if (domoticz_update_flag) {
|
2017-10-18 17:22:34 +01:00
|
|
|
MqttPublishDomoticzPowerState(device);
|
2017-07-15 14:07:30 +01:00
|
|
|
}
|
2019-07-24 12:09:42 +01:00
|
|
|
domoticz_update_flag = true;
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
|
2018-11-14 13:32:09 +00:00
|
|
|
void DomoticzMqttUpdate(void)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2017-10-18 17:22:34 +01:00
|
|
|
if (domoticz_subscribe && (Settings.domoticz_update_timer || domoticz_update_timer)) {
|
2017-01-28 13:41:01 +00:00
|
|
|
domoticz_update_timer--;
|
|
|
|
if (domoticz_update_timer <= 0) {
|
2017-10-18 17:22:34 +01:00
|
|
|
domoticz_update_timer = Settings.domoticz_update_timer;
|
2019-06-30 15:44:36 +01:00
|
|
|
for (uint32_t i = 1; i <= devices_present; i++) {
|
2019-11-26 15:51:53 +00:00
|
|
|
#ifdef USE_SHUTTER
|
|
|
|
if (domoticz_is_shutter)
|
|
|
|
{
|
|
|
|
// no power state updates for shutters
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
#endif // USE_SHUTTER
|
2019-07-14 21:08:19 +01:00
|
|
|
#ifdef USE_SONOFF_IFAN
|
2019-07-14 14:23:02 +01:00
|
|
|
if (IsModuleIfan() && (i > 1)) {
|
2018-12-06 14:03:42 +00:00
|
|
|
MqttPublishDomoticzFanState();
|
|
|
|
break;
|
|
|
|
} else {
|
2019-07-14 21:08:19 +01:00
|
|
|
#endif // USE_SONOFF_IFAN
|
2018-12-06 14:03:42 +00:00
|
|
|
MqttPublishDomoticzPowerState(i);
|
2019-07-14 21:08:19 +01:00
|
|
|
#ifdef USE_SONOFF_IFAN
|
2018-12-06 14:03:42 +00:00
|
|
|
}
|
2019-07-14 21:08:19 +01:00
|
|
|
#endif // USE_SONOFF_IFAN
|
2017-04-25 17:24:42 +01:00
|
|
|
}
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-14 13:32:09 +00:00
|
|
|
void DomoticzMqttSubscribe(void)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2017-10-18 17:22:34 +01:00
|
|
|
uint8_t maxdev = (devices_present > MAX_DOMOTICZ_IDX) ? MAX_DOMOTICZ_IDX : devices_present;
|
2019-06-30 15:44:36 +01:00
|
|
|
for (uint32_t i = 0; i < maxdev; i++) {
|
2017-10-18 17:22:34 +01:00
|
|
|
if (Settings.domoticz_relay_idx[i]) {
|
2017-05-19 15:09:25 +01:00
|
|
|
domoticz_subscribe = true;
|
|
|
|
}
|
|
|
|
}
|
2019-11-26 15:51:53 +00:00
|
|
|
|
2017-06-06 22:23:23 +01:00
|
|
|
if (domoticz_subscribe) {
|
2017-01-28 13:41:01 +00:00
|
|
|
char stopic[TOPSZ];
|
2019-10-02 16:39:27 +01:00
|
|
|
snprintf_P(stopic, sizeof(stopic), PSTR(DOMOTICZ_OUT_TOPIC "/#")); // domoticz topic
|
2017-10-18 17:22:34 +01:00
|
|
|
MqttSubscribe(stopic);
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-17 16:18:41 +00:00
|
|
|
/*
|
|
|
|
* ArduinoJSON Domoticz Switch entry used to calculate jsonBuf: JSON_OBJECT_SIZE(11) + 129 = 313
|
|
|
|
{
|
|
|
|
"Battery" : 255,
|
|
|
|
"RSSI" : 12,
|
|
|
|
"dtype" : "Light/Switch",
|
|
|
|
"id" : "000140E7",
|
|
|
|
"idx" : 159,
|
|
|
|
"name" : "Sonoff1",
|
|
|
|
"nvalue" : 1,
|
|
|
|
"stype" : "Switch",
|
|
|
|
"svalue1" : "0",
|
|
|
|
"switchType" : "Dimmer",
|
|
|
|
"unit" : 1
|
2018-10-04 10:01:50 +01:00
|
|
|
}
|
|
|
|
* Fail on this one
|
|
|
|
{
|
|
|
|
"LastUpdate" : "2018-10-02 20:39:45",
|
|
|
|
"Name" : "Sfeerverlichting",
|
|
|
|
"Status" : "Off",
|
|
|
|
"Timers" : "true",
|
|
|
|
"Type" : "Group",
|
|
|
|
"idx" : "2"
|
2017-02-17 16:18:41 +00:00
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
2019-01-28 13:08:33 +00:00
|
|
|
bool DomoticzMqttData(void)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2019-07-24 12:09:42 +01:00
|
|
|
domoticz_update_flag = true;
|
2019-10-02 11:51:37 +01:00
|
|
|
|
2019-10-02 16:39:27 +01:00
|
|
|
if (strncasecmp_P(XdrvMailbox.topic, PSTR(DOMOTICZ_OUT_TOPIC), strlen(DOMOTICZ_OUT_TOPIC)) != 0) {
|
2019-10-02 11:51:37 +01:00
|
|
|
return false; // Process unchanged data
|
|
|
|
}
|
|
|
|
|
|
|
|
// topic is domoticz/out so try to analyse
|
|
|
|
if (XdrvMailbox.data_len < 20) {
|
|
|
|
return true; // No valid data
|
|
|
|
}
|
|
|
|
StaticJsonBuffer<400> jsonBuf;
|
|
|
|
JsonObject& domoticz = jsonBuf.parseObject(XdrvMailbox.data);
|
|
|
|
if (!domoticz.success()) {
|
|
|
|
return true; // To much or invalid data
|
|
|
|
}
|
2017-04-29 13:40:53 +01:00
|
|
|
// if (strcmp_P(domoticz["dtype"],PSTR("Light/Switch"))) {
|
2019-07-24 12:09:42 +01:00
|
|
|
// return true;
|
2017-04-25 17:24:42 +01:00
|
|
|
// }
|
2019-10-02 11:51:37 +01:00
|
|
|
uint32_t idx = domoticz["idx"];
|
|
|
|
int16_t nvalue = -1;
|
|
|
|
if (domoticz.containsKey("nvalue")) {
|
|
|
|
nvalue = domoticz["nvalue"];
|
|
|
|
}
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2019-10-02 11:51:37 +01:00
|
|
|
AddLog_P2(LOG_LEVEL_DEBUG_MORE, PSTR(D_LOG_DOMOTICZ "idx %d, nvalue %d"), idx, nvalue);
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2019-10-02 11:51:37 +01:00
|
|
|
bool found = false;
|
|
|
|
if ((idx > 0) && (nvalue >= 0) && (nvalue <= 15)) {
|
|
|
|
uint8_t maxdev = (devices_present > MAX_DOMOTICZ_IDX) ? MAX_DOMOTICZ_IDX : devices_present;
|
|
|
|
for (uint32_t i = 0; i < maxdev; i++) {
|
|
|
|
if (idx == Settings.domoticz_relay_idx[i]) {
|
|
|
|
bool iscolordimmer = strcmp_P(domoticz["dtype"],PSTR("Color Switch")) == 0;
|
2019-11-26 15:51:53 +00:00
|
|
|
bool isShutter = strcmp_P(domoticz["dtype"],PSTR("Light/Switch")) == 0 & strncmp_P(domoticz["switchType"],PSTR("Blinds"), 6) == 0;
|
|
|
|
|
2019-10-02 11:51:37 +01:00
|
|
|
char stemp1[10];
|
|
|
|
snprintf_P(stemp1, sizeof(stemp1), PSTR("%d"), i +1);
|
2019-07-14 21:08:19 +01:00
|
|
|
#ifdef USE_SONOFF_IFAN
|
2019-10-02 11:51:37 +01:00
|
|
|
if (IsModuleIfan() && (1 == i)) { // Idx 2 is fanspeed
|
|
|
|
uint8_t svalue = 0;
|
|
|
|
if (domoticz.containsKey("svalue1")) {
|
|
|
|
svalue = domoticz["svalue1"];
|
|
|
|
} else {
|
|
|
|
return true; // Invalid data
|
|
|
|
}
|
|
|
|
svalue = (nvalue == 2) ? svalue / 10 : 0;
|
|
|
|
if (GetFanspeed() == svalue) {
|
|
|
|
return true; // Stop loop as already set
|
|
|
|
}
|
|
|
|
if (TimePassedSince(domoticz_fan_debounce) < 1000) {
|
|
|
|
return true; // Stop loop if device in limbo
|
|
|
|
}
|
|
|
|
snprintf_P(XdrvMailbox.topic, XdrvMailbox.index, PSTR("/" D_CMND_FANSPEED));
|
|
|
|
snprintf_P(XdrvMailbox.data, XdrvMailbox.data_len, PSTR("%d"), svalue);
|
|
|
|
found = true;
|
|
|
|
} else
|
2019-07-14 21:08:19 +01:00
|
|
|
#endif // USE_SONOFF_IFAN
|
2019-11-26 15:51:53 +00:00
|
|
|
#ifdef USE_SHUTTER
|
|
|
|
if (isShutter)
|
|
|
|
{
|
|
|
|
if (domoticz.containsKey("nvalue")) {
|
|
|
|
nvalue = domoticz["nvalue"];
|
|
|
|
}
|
|
|
|
|
|
|
|
uint8_t position = 0;
|
|
|
|
if (domoticz.containsKey("svalue1")) {
|
|
|
|
position = domoticz["svalue1"];
|
|
|
|
}
|
|
|
|
if (nvalue != 2) {
|
|
|
|
position = nvalue == 0 ? 0 : 100;
|
|
|
|
}
|
|
|
|
|
|
|
|
snprintf_P(XdrvMailbox.topic, TOPSZ, PSTR("/" D_PRFX_SHUTTER D_CMND_SHUTTER_POSITION));
|
|
|
|
snprintf_P(XdrvMailbox.data, XdrvMailbox.data_len, PSTR("%d"), position);
|
|
|
|
XdrvMailbox.data_len = position > 99 ? 3 : (position > 9 ? 2 : 1);
|
|
|
|
|
|
|
|
found = true;
|
|
|
|
} else
|
|
|
|
#endif // USE_SHUTTER
|
2020-02-23 19:49:54 +00:00
|
|
|
#ifdef USE_LIGHT
|
2019-10-02 11:51:37 +01:00
|
|
|
if (iscolordimmer && 10 == nvalue) { // Color_SetColor
|
2020-01-04 17:24:33 +00:00
|
|
|
// https://www.domoticz.com/wiki/Domoticz_API/JSON_URL%27s#Set_a_light_to_a_certain_color_or_color_temperature
|
2019-10-02 11:51:37 +01:00
|
|
|
JsonObject& color = domoticz["Color"];
|
|
|
|
uint16_t level = nvalue = domoticz["svalue1"];
|
|
|
|
uint16_t r = color["r"]; r = r * level / 100;
|
|
|
|
uint16_t g = color["g"]; g = g * level / 100;
|
|
|
|
uint16_t b = color["b"]; b = b * level / 100;
|
|
|
|
uint16_t cw = color["cw"]; cw = cw * level / 100;
|
|
|
|
uint16_t ww = color["ww"]; ww = ww * level / 100;
|
2020-01-04 16:29:04 +00:00
|
|
|
uint16_t m = 0;
|
|
|
|
uint16_t t = 0;
|
|
|
|
if (color.containsKey("m")) {
|
|
|
|
m = color["m"];
|
|
|
|
t = color["t"];
|
|
|
|
}
|
|
|
|
if (2 == m) { // White with color temperature. Valid fields: t
|
2020-01-04 17:24:33 +00:00
|
|
|
snprintf_P(XdrvMailbox.topic, XdrvMailbox.index, PSTR("/" D_CMND_BACKLOG));
|
|
|
|
snprintf_P(XdrvMailbox.data, XdrvMailbox.data_len, PSTR(D_CMND_COLORTEMPERATURE " %d;" D_CMND_DIMMER " %d"), changeUIntScale(t, 0, 255, CT_MIN, CT_MAX), level);
|
2020-01-04 16:29:04 +00:00
|
|
|
} else {
|
|
|
|
snprintf_P(XdrvMailbox.topic, XdrvMailbox.index, PSTR("/" D_CMND_COLOR));
|
|
|
|
snprintf_P(XdrvMailbox.data, XdrvMailbox.data_len, PSTR("%02x%02x%02x%02x%02x"), r, g, b, cw, ww);
|
|
|
|
}
|
2019-10-02 11:51:37 +01:00
|
|
|
found = true;
|
|
|
|
}
|
|
|
|
else if ((!iscolordimmer && 2 == nvalue) || // gswitch_sSetLevel
|
|
|
|
(iscolordimmer && 15 == nvalue)) { // Color_SetBrightnessLevel
|
|
|
|
if (domoticz.containsKey("svalue1")) {
|
|
|
|
nvalue = domoticz["svalue1"];
|
|
|
|
} else {
|
|
|
|
return true; // Invalid data
|
2018-12-06 09:49:49 +00:00
|
|
|
}
|
2019-10-02 11:51:37 +01:00
|
|
|
if (light_type && (Settings.light_dimmer == nvalue) && ((power >> i) &1)) {
|
|
|
|
return true; // State already set
|
2018-12-06 09:49:49 +00:00
|
|
|
}
|
2019-10-02 11:51:37 +01:00
|
|
|
snprintf_P(XdrvMailbox.topic, XdrvMailbox.index, PSTR("/" D_CMND_DIMMER));
|
|
|
|
snprintf_P(XdrvMailbox.data, XdrvMailbox.data_len, PSTR("%d"), nvalue);
|
|
|
|
found = true;
|
2020-02-23 19:49:54 +00:00
|
|
|
} else
|
|
|
|
#endif // USE_LIGHT
|
|
|
|
if (1 == nvalue || 0 == nvalue) {
|
2019-10-02 11:51:37 +01:00
|
|
|
if (((power >> i) &1) == (power_t)nvalue) {
|
|
|
|
return true; // Stop loop
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
2019-10-02 11:51:37 +01:00
|
|
|
snprintf_P(XdrvMailbox.topic, XdrvMailbox.index, PSTR("/" D_CMND_POWER "%s"), (devices_present > 1) ? stemp1 : "");
|
|
|
|
snprintf_P(XdrvMailbox.data, XdrvMailbox.data_len, PSTR("%d"), nvalue);
|
|
|
|
found = true;
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
2019-10-02 11:51:37 +01:00
|
|
|
break;
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
}
|
2019-10-02 11:51:37 +01:00
|
|
|
}
|
|
|
|
if (!found) { return true; } // No command received
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2019-10-02 11:51:37 +01:00
|
|
|
AddLog_P2(LOG_LEVEL_DEBUG_MORE, PSTR(D_LOG_DOMOTICZ D_RECEIVED_TOPIC " %s, " D_DATA " %s"), XdrvMailbox.topic, XdrvMailbox.data);
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2019-10-02 11:51:37 +01:00
|
|
|
domoticz_update_flag = false;
|
|
|
|
return false; // Process new data
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
|
2019-08-01 16:18:49 +01:00
|
|
|
/*********************************************************************************************/
|
2017-01-28 15:31:11 +00:00
|
|
|
|
2019-01-28 13:08:33 +00:00
|
|
|
bool DomoticzSendKey(uint8_t key, uint8_t device, uint8_t state, uint8_t svalflg)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2019-07-24 12:09:42 +01:00
|
|
|
bool result = false;
|
2018-07-12 13:24:17 +01:00
|
|
|
|
|
|
|
if (device <= MAX_DOMOTICZ_IDX) {
|
|
|
|
if ((Settings.domoticz_key_idx[device -1] || Settings.domoticz_switch_idx[device -1]) && (svalflg)) {
|
2019-03-23 16:00:59 +00:00
|
|
|
Response_P(PSTR("{\"command\":\"switchlight\",\"idx\":%d,\"switchcmd\":\"%s\"}"),
|
2019-09-04 11:20:04 +01:00
|
|
|
(key) ? Settings.domoticz_switch_idx[device -1] : Settings.domoticz_key_idx[device -1], (state) ? (POWER_TOGGLE == state) ? "Toggle" : "On" : "Off");
|
2018-07-12 13:24:17 +01:00
|
|
|
MqttPublish(domoticz_in_topic);
|
2019-07-24 12:09:42 +01:00
|
|
|
result = true;
|
2018-07-12 13:24:17 +01:00
|
|
|
}
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
2018-07-12 13:24:17 +01:00
|
|
|
return result;
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*********************************************************************************************\
|
|
|
|
* Sensors
|
2017-12-22 13:55:24 +00:00
|
|
|
*
|
|
|
|
* Source : https://www.domoticz.com/wiki/Domoticz_API/JSON_URL%27s
|
|
|
|
* https://www.domoticz.com/wiki/MQTT
|
|
|
|
*
|
|
|
|
* Percentage, Barometric, Air Quality:
|
|
|
|
* {\"idx\":%d,\"nvalue\":%s}, Idx, Value
|
|
|
|
*
|
|
|
|
* Humidity:
|
|
|
|
* {\"idx\":%d,\"nvalue\":%s,\"svalue\":\"%s\"}, Idx, Humidity, HumidityStatus
|
|
|
|
*
|
|
|
|
* All other:
|
|
|
|
* {\"idx\":%d,\"nvalue\":0,\"svalue\":\"%s\"}, Idx, Value(s)
|
|
|
|
*
|
2017-01-28 13:41:01 +00:00
|
|
|
\*********************************************************************************************/
|
|
|
|
|
2017-10-18 17:22:34 +01:00
|
|
|
uint8_t DomoticzHumidityState(char *hum)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
|
|
|
uint8_t h = atoi(hum);
|
|
|
|
return (!h) ? 0 : (h < 40) ? 2 : (h > 70) ? 3 : 1;
|
|
|
|
}
|
|
|
|
|
2019-01-28 13:08:33 +00:00
|
|
|
void DomoticzSensor(uint8_t idx, char *data)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2017-10-18 17:22:34 +01:00
|
|
|
if (Settings.domoticz_sensor_idx[idx]) {
|
2019-08-25 15:25:38 +01:00
|
|
|
char dmess[128]; // {"idx":26700,"nvalue":0,"svalue":"22330.1;10234.4;22000.5;10243.4;1006;3000","Battery":100,"RSSI":10}
|
2017-09-13 13:19:34 +01:00
|
|
|
|
|
|
|
memcpy(dmess, mqtt_data, sizeof(dmess));
|
2017-12-22 13:55:24 +00:00
|
|
|
if (DZ_AIRQUALITY == idx) {
|
2019-03-23 16:00:59 +00:00
|
|
|
Response_P(PSTR("{\"idx\":%d,\"nvalue\":%s,\"Battery\":%d,\"RSSI\":%d}"),
|
2018-04-01 20:37:00 +01:00
|
|
|
Settings.domoticz_sensor_idx[idx], data, DomoticzBatteryQuality(), DomoticzRssiQuality());
|
2017-12-22 13:55:24 +00:00
|
|
|
} else {
|
2019-09-29 17:00:01 +01:00
|
|
|
uint8_t nvalue = 0;
|
|
|
|
#ifdef USE_SHUTTER
|
|
|
|
if (DZ_SHUTTER == idx) {
|
|
|
|
uint8_t position = atoi(data);
|
|
|
|
nvalue = position < 2 ? 0 : (position == 100 ? 1 : 2);
|
|
|
|
}
|
|
|
|
#endif // USE_SHUTTER
|
2019-03-23 16:00:59 +00:00
|
|
|
Response_P(DOMOTICZ_MESSAGE,
|
2019-09-29 17:00:01 +01:00
|
|
|
Settings.domoticz_sensor_idx[idx], nvalue, data, DomoticzBatteryQuality(), DomoticzRssiQuality());
|
2017-12-22 13:55:24 +00:00
|
|
|
}
|
2017-10-18 17:22:34 +01:00
|
|
|
MqttPublish(domoticz_in_topic);
|
2017-09-13 13:19:34 +01:00
|
|
|
memcpy(mqtt_data, dmess, sizeof(dmess));
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-28 13:08:33 +00:00
|
|
|
void DomoticzSensor(uint8_t idx, uint32_t value)
|
2017-10-02 15:45:03 +01:00
|
|
|
{
|
|
|
|
char data[16];
|
|
|
|
snprintf_P(data, sizeof(data), PSTR("%d"), value);
|
2017-10-18 17:22:34 +01:00
|
|
|
DomoticzSensor(idx, data);
|
2017-10-02 15:45:03 +01:00
|
|
|
}
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2017-10-18 17:22:34 +01:00
|
|
|
void DomoticzTempHumSensor(char *temp, char *hum)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
|
|
|
char data[16];
|
2017-10-18 17:22:34 +01:00
|
|
|
snprintf_P(data, sizeof(data), PSTR("%s;%s;%d"), temp, hum, DomoticzHumidityState(hum));
|
|
|
|
DomoticzSensor(DZ_TEMP_HUM, data);
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
|
2017-10-18 17:22:34 +01:00
|
|
|
void DomoticzTempHumPressureSensor(char *temp, char *hum, char *baro)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
|
|
|
char data[32];
|
2017-10-18 17:22:34 +01:00
|
|
|
snprintf_P(data, sizeof(data), PSTR("%s;%s;%d;%s;5"), temp, hum, DomoticzHumidityState(hum), baro);
|
|
|
|
DomoticzSensor(DZ_TEMP_HUM_BARO, data);
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
|
2018-08-19 12:00:27 +01:00
|
|
|
void DomoticzSensorPowerEnergy(int power, char *energy)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
|
|
|
char data[16];
|
|
|
|
snprintf_P(data, sizeof(data), PSTR("%d;%s"), power, energy);
|
2017-10-18 17:22:34 +01:00
|
|
|
DomoticzSensor(DZ_POWER_ENERGY, data);
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
|
2019-09-05 17:02:36 +01:00
|
|
|
void DomoticzSensorP1SmartMeter(char *usage1, char *usage2, char *return1, char *return2, int power)
|
2019-08-25 15:25:38 +01:00
|
|
|
{
|
|
|
|
//usage1 = energy usage meter tariff 1, This is an incrementing counter
|
|
|
|
//usage2 = energy usage meter tariff 2, This is an incrementing counter
|
|
|
|
//return1 = energy return meter tariff 1, This is an incrementing counter
|
|
|
|
//return2 = energy return meter tariff 2, This is an incrementing counter
|
2019-09-05 17:02:36 +01:00
|
|
|
//power = if >= 0 actual usage power. if < 0 actual return power (Watt)
|
|
|
|
int consumed = power;
|
|
|
|
int produced = 0;
|
|
|
|
if (power < 0) {
|
|
|
|
consumed = 0;
|
|
|
|
produced = -power;
|
|
|
|
}
|
2019-08-25 15:25:38 +01:00
|
|
|
char data[64];
|
|
|
|
snprintf_P(data, sizeof(data), PSTR("%s;%s;%s;%s;%d;%d"), usage1, usage2, return1, return2, consumed, produced);
|
|
|
|
DomoticzSensor(DZ_P1_SMART_METER, data);
|
|
|
|
}
|
|
|
|
|
2019-08-01 16:18:49 +01:00
|
|
|
/*********************************************************************************************\
|
|
|
|
* Commands
|
|
|
|
\*********************************************************************************************/
|
|
|
|
|
|
|
|
void CmndDomoticzIdx(void)
|
|
|
|
{
|
|
|
|
if ((XdrvMailbox.index > 0) && (XdrvMailbox.index <= MAX_DOMOTICZ_IDX)) {
|
|
|
|
if (XdrvMailbox.payload >= 0) {
|
|
|
|
Settings.domoticz_relay_idx[XdrvMailbox.index -1] = XdrvMailbox.payload;
|
|
|
|
restart_flag = 2;
|
|
|
|
}
|
2019-08-11 17:12:18 +01:00
|
|
|
ResponseCmndIdxNumber(Settings.domoticz_relay_idx[XdrvMailbox.index -1]);
|
2019-08-01 16:18:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CmndDomoticzKeyIdx(void)
|
|
|
|
{
|
|
|
|
if ((XdrvMailbox.index > 0) && (XdrvMailbox.index <= MAX_DOMOTICZ_IDX)) {
|
|
|
|
if (XdrvMailbox.payload >= 0) {
|
|
|
|
Settings.domoticz_key_idx[XdrvMailbox.index -1] = XdrvMailbox.payload;
|
|
|
|
}
|
2019-08-11 17:12:18 +01:00
|
|
|
ResponseCmndIdxNumber(Settings.domoticz_key_idx[XdrvMailbox.index -1]);
|
2019-08-01 16:18:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CmndDomoticzSwitchIdx(void)
|
|
|
|
{
|
|
|
|
if ((XdrvMailbox.index > 0) && (XdrvMailbox.index <= MAX_DOMOTICZ_IDX)) {
|
|
|
|
if (XdrvMailbox.payload >= 0) {
|
|
|
|
Settings.domoticz_switch_idx[XdrvMailbox.index -1] = XdrvMailbox.payload;
|
|
|
|
}
|
2019-08-11 17:12:18 +01:00
|
|
|
ResponseCmndIdxNumber(Settings.domoticz_switch_idx[XdrvMailbox.index -1]);
|
2019-08-01 16:18:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CmndDomoticzSensorIdx(void)
|
|
|
|
{
|
|
|
|
if ((XdrvMailbox.index > 0) && (XdrvMailbox.index <= DZ_MAX_SENSORS)) {
|
|
|
|
if (XdrvMailbox.payload >= 0) {
|
|
|
|
Settings.domoticz_sensor_idx[XdrvMailbox.index -1] = XdrvMailbox.payload;
|
|
|
|
}
|
2019-08-11 17:12:18 +01:00
|
|
|
ResponseCmndIdxNumber(Settings.domoticz_sensor_idx[XdrvMailbox.index -1]);
|
2019-08-01 16:18:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CmndDomoticzUpdateTimer(void)
|
|
|
|
{
|
|
|
|
if ((XdrvMailbox.payload >= 0) && (XdrvMailbox.payload < 3601)) {
|
|
|
|
Settings.domoticz_update_timer = XdrvMailbox.payload;
|
|
|
|
}
|
2019-08-11 17:12:18 +01:00
|
|
|
ResponseCmndNumber(Settings.domoticz_update_timer);
|
2019-08-01 16:18:49 +01:00
|
|
|
}
|
|
|
|
|
2017-01-28 13:41:01 +00:00
|
|
|
/*********************************************************************************************\
|
|
|
|
* Presentation
|
|
|
|
\*********************************************************************************************/
|
|
|
|
|
2017-02-06 09:08:40 +00:00
|
|
|
#ifdef USE_WEBSERVER
|
2018-10-10 21:21:44 +01:00
|
|
|
|
|
|
|
#define WEB_HANDLE_DOMOTICZ "dm"
|
|
|
|
|
2017-09-02 13:37:02 +01:00
|
|
|
const char S_CONFIGURE_DOMOTICZ[] PROGMEM = D_CONFIGURE_DOMOTICZ;
|
|
|
|
|
2018-10-10 21:21:44 +01:00
|
|
|
const char HTTP_BTN_MENU_DOMOTICZ[] PROGMEM =
|
2019-02-13 15:05:25 +00:00
|
|
|
"<p><form action='" WEB_HANDLE_DOMOTICZ "' method='get'><button>" D_CONFIGURE_DOMOTICZ "</button></form></p>";
|
2018-10-10 21:21:44 +01:00
|
|
|
|
|
|
|
const char HTTP_FORM_DOMOTICZ[] PROGMEM =
|
2019-02-13 15:05:25 +00:00
|
|
|
"<fieldset><legend><b> " D_DOMOTICZ_PARAMETERS " </b></legend>"
|
|
|
|
"<form method='post' action='" WEB_HANDLE_DOMOTICZ "'>"
|
|
|
|
"<table>";
|
2018-10-10 21:21:44 +01:00
|
|
|
const char HTTP_FORM_DOMOTICZ_RELAY[] PROGMEM =
|
2019-05-31 18:51:24 +01:00
|
|
|
"<tr><td style='width:260px'><b>" D_DOMOTICZ_IDX " %d</b></td><td style='width:70px'><input id='r%d' placeholder='0' value='%d'></td></tr>"
|
|
|
|
"<tr><td style='width:260px'><b>" D_DOMOTICZ_KEY_IDX " %d</b></td><td style='width:70px'><input id='k%d' placeholder='0' value='%d'></td></tr>";
|
|
|
|
const char HTTP_FORM_DOMOTICZ_SWITCH[] PROGMEM =
|
|
|
|
"<tr><td style='width:260px'><b>" D_DOMOTICZ_SWITCH_IDX " %d</b></td><td style='width:70px'><input id='s%d' placeholder='0' value='%d'></td></tr>";
|
2018-10-10 21:21:44 +01:00
|
|
|
const char HTTP_FORM_DOMOTICZ_SENSOR[] PROGMEM =
|
2019-05-31 18:51:24 +01:00
|
|
|
"<tr><td style='width:260px'><b>" D_DOMOTICZ_SENSOR_IDX " %d</b> %s</td><td style='width:70px'><input id='l%d' placeholder='0' value='%d'></td></tr>";
|
2018-10-10 21:21:44 +01:00
|
|
|
const char HTTP_FORM_DOMOTICZ_TIMER[] PROGMEM =
|
2019-05-31 18:51:24 +01:00
|
|
|
"<tr><td style='width:260px'><b>" D_DOMOTICZ_UPDATE_TIMER "</b> (" STR(DOMOTICZ_UPDATE_TIMER) ")</td><td style='width:70px'><input id='ut' placeholder='" STR(DOMOTICZ_UPDATE_TIMER) "' value='%d'></td></tr>";
|
2018-10-10 21:21:44 +01:00
|
|
|
|
2018-11-14 13:32:09 +00:00
|
|
|
void HandleDomoticzConfiguration(void)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2019-01-10 11:57:42 +00:00
|
|
|
if (!HttpCheckPriviledgedAccess()) { return; }
|
|
|
|
|
2017-10-18 17:22:34 +01:00
|
|
|
AddLog_P(LOG_LEVEL_DEBUG, S_LOG_HTTP, S_CONFIGURE_DOMOTICZ);
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2018-10-10 21:21:44 +01:00
|
|
|
if (WebServer->hasArg("save")) {
|
|
|
|
DomoticzSaveSettings();
|
2018-10-12 10:42:52 +01:00
|
|
|
WebRestart(1);
|
2018-10-10 21:21:44 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-06-03 09:51:21 +01:00
|
|
|
char stemp[40];
|
2017-09-02 13:37:02 +01:00
|
|
|
|
2019-03-10 14:36:34 +00:00
|
|
|
WSContentStart_P(S_CONFIGURE_DOMOTICZ);
|
2019-03-04 17:16:07 +00:00
|
|
|
WSContentSendStyle();
|
2019-03-10 14:36:34 +00:00
|
|
|
WSContentSend_P(HTTP_FORM_DOMOTICZ);
|
2019-06-30 15:44:36 +01:00
|
|
|
for (uint32_t i = 0; i < MAX_DOMOTICZ_IDX; i++) {
|
2017-10-18 17:22:34 +01:00
|
|
|
if (i < devices_present) {
|
2019-03-04 17:16:07 +00:00
|
|
|
WSContentSend_P(HTTP_FORM_DOMOTICZ_RELAY,
|
2019-06-03 15:36:24 +01:00
|
|
|
i +1, i, Settings.domoticz_relay_idx[i],
|
|
|
|
i +1, i, Settings.domoticz_key_idx[i]);
|
2017-04-03 15:38:15 +01:00
|
|
|
}
|
2018-08-25 12:08:06 +01:00
|
|
|
if (pin[GPIO_SWT1 +i] < 99) {
|
2019-03-04 17:16:07 +00:00
|
|
|
WSContentSend_P(HTTP_FORM_DOMOTICZ_SWITCH,
|
2019-06-03 15:36:24 +01:00
|
|
|
i +1, i, Settings.domoticz_switch_idx[i]);
|
2017-04-03 15:38:15 +01:00
|
|
|
}
|
2019-07-14 21:08:19 +01:00
|
|
|
#ifdef USE_SONOFF_IFAN
|
2019-07-14 14:23:02 +01:00
|
|
|
if (IsModuleIfan() && (1 == i)) { break; }
|
2019-07-14 21:08:19 +01:00
|
|
|
#endif // USE_SONOFF_IFAN
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
2019-06-30 15:44:36 +01:00
|
|
|
for (uint32_t i = 0; i < DZ_MAX_SENSORS; i++) {
|
2019-03-04 17:16:07 +00:00
|
|
|
WSContentSend_P(HTTP_FORM_DOMOTICZ_SENSOR,
|
2019-06-03 15:36:24 +01:00
|
|
|
i +1, GetTextIndexed(stemp, sizeof(stemp), i, kDomoticzSensors), i, Settings.domoticz_sensor_idx[i]);
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
2019-03-04 17:16:07 +00:00
|
|
|
WSContentSend_P(HTTP_FORM_DOMOTICZ_TIMER, Settings.domoticz_update_timer);
|
2019-03-10 14:36:34 +00:00
|
|
|
WSContentSend_P(PSTR("</table>"));
|
|
|
|
WSContentSend_P(HTTP_FORM_END);
|
2019-03-11 09:38:41 +00:00
|
|
|
WSContentSpaceButton(BUTTON_CONFIGURATION);
|
2019-03-16 15:23:41 +00:00
|
|
|
WSContentStop();
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
|
|
|
|
2018-11-14 13:32:09 +00:00
|
|
|
void DomoticzSaveSettings(void)
|
2017-01-28 13:41:01 +00:00
|
|
|
{
|
2017-09-13 13:19:34 +01:00
|
|
|
char stemp[20];
|
2017-12-22 13:55:24 +00:00
|
|
|
char ssensor_indices[6 * MAX_DOMOTICZ_SNS_IDX];
|
2018-01-30 13:14:55 +00:00
|
|
|
char tmp[100];
|
2017-01-28 13:41:01 +00:00
|
|
|
|
2019-06-30 15:44:36 +01:00
|
|
|
for (uint32_t i = 0; i < MAX_DOMOTICZ_IDX; i++) {
|
2019-03-04 17:16:07 +00:00
|
|
|
snprintf_P(stemp, sizeof(stemp), PSTR("r%d"), i);
|
2018-01-30 13:14:55 +00:00
|
|
|
WebGetArg(stemp, tmp, sizeof(tmp));
|
|
|
|
Settings.domoticz_relay_idx[i] = (!strlen(tmp)) ? 0 : atoi(tmp);
|
2019-03-04 17:16:07 +00:00
|
|
|
snprintf_P(stemp, sizeof(stemp), PSTR("k%d"), i);
|
2018-01-30 13:14:55 +00:00
|
|
|
WebGetArg(stemp, tmp, sizeof(tmp));
|
|
|
|
Settings.domoticz_key_idx[i] = (!strlen(tmp)) ? 0 : atoi(tmp);
|
2019-03-04 17:16:07 +00:00
|
|
|
snprintf_P(stemp, sizeof(stemp), PSTR("s%d"), i);
|
2018-01-30 13:14:55 +00:00
|
|
|
WebGetArg(stemp, tmp, sizeof(tmp));
|
|
|
|
Settings.domoticz_switch_idx[i] = (!strlen(tmp)) ? 0 : atoi(tmp);
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
2017-12-22 13:55:24 +00:00
|
|
|
ssensor_indices[0] = '\0';
|
2019-06-30 15:44:36 +01:00
|
|
|
for (uint32_t i = 0; i < DZ_MAX_SENSORS; i++) {
|
2019-03-04 17:16:07 +00:00
|
|
|
snprintf_P(stemp, sizeof(stemp), PSTR("l%d"), i);
|
2018-01-30 13:14:55 +00:00
|
|
|
WebGetArg(stemp, tmp, sizeof(tmp));
|
|
|
|
Settings.domoticz_sensor_idx[i] = (!strlen(tmp)) ? 0 : atoi(tmp);
|
2017-12-22 13:55:24 +00:00
|
|
|
snprintf_P(ssensor_indices, sizeof(ssensor_indices), PSTR("%s%s%d"), ssensor_indices, (strlen(ssensor_indices)) ? "," : "", Settings.domoticz_sensor_idx[i]);
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
2018-01-30 13:14:55 +00:00
|
|
|
WebGetArg("ut", tmp, sizeof(tmp));
|
|
|
|
Settings.domoticz_update_timer = (!strlen(tmp)) ? DOMOTICZ_UPDATE_TIMER : atoi(tmp);
|
2017-12-22 13:55:24 +00:00
|
|
|
|
2019-03-08 14:15:42 +00:00
|
|
|
AddLog_P2(LOG_LEVEL_INFO, PSTR(D_LOG_DOMOTICZ D_CMND_IDX " %d,%d,%d,%d, " D_CMND_KEYIDX " %d,%d,%d,%d, " D_CMND_SWITCHIDX " %d,%d,%d,%d, " D_CMND_SENSORIDX " %s, " D_CMND_UPDATETIMER " %d"),
|
2017-10-18 17:22:34 +01:00
|
|
|
Settings.domoticz_relay_idx[0], Settings.domoticz_relay_idx[1], Settings.domoticz_relay_idx[2], Settings.domoticz_relay_idx[3],
|
|
|
|
Settings.domoticz_key_idx[0], Settings.domoticz_key_idx[1], Settings.domoticz_key_idx[2], Settings.domoticz_key_idx[3],
|
|
|
|
Settings.domoticz_switch_idx[0], Settings.domoticz_switch_idx[1], Settings.domoticz_switch_idx[2], Settings.domoticz_switch_idx[3],
|
2017-12-22 13:55:24 +00:00
|
|
|
ssensor_indices, Settings.domoticz_update_timer);
|
2017-01-28 13:41:01 +00:00
|
|
|
}
|
2018-01-13 14:53:02 +00:00
|
|
|
#endif // USE_WEBSERVER
|
2018-01-05 11:26:19 +00:00
|
|
|
|
|
|
|
/*********************************************************************************************\
|
|
|
|
* Interface
|
|
|
|
\*********************************************************************************************/
|
|
|
|
|
2019-01-28 13:08:33 +00:00
|
|
|
bool Xdrv07(uint8_t function)
|
2018-01-05 11:26:19 +00:00
|
|
|
{
|
2019-01-28 13:08:33 +00:00
|
|
|
bool result = false;
|
2019-11-26 15:58:05 +00:00
|
|
|
|
2019-11-03 11:33:36 +00:00
|
|
|
if (Settings.flag.mqtt_enabled) { // SetOption3 - Enable MQTT
|
2018-01-05 11:26:19 +00:00
|
|
|
switch (function) {
|
2019-07-24 12:09:42 +01:00
|
|
|
case FUNC_EVERY_SECOND:
|
|
|
|
DomoticzMqttUpdate();
|
|
|
|
break;
|
|
|
|
case FUNC_MQTT_DATA:
|
|
|
|
result = DomoticzMqttData();
|
|
|
|
break;
|
2018-10-10 21:21:44 +01:00
|
|
|
#ifdef USE_WEBSERVER
|
|
|
|
case FUNC_WEB_ADD_BUTTON:
|
2019-03-10 14:36:34 +00:00
|
|
|
WSContentSend_P(HTTP_BTN_MENU_DOMOTICZ);
|
2018-10-10 21:21:44 +01:00
|
|
|
break;
|
|
|
|
case FUNC_WEB_ADD_HANDLER:
|
|
|
|
WebServer->on("/" WEB_HANDLE_DOMOTICZ, HandleDomoticzConfiguration);
|
|
|
|
break;
|
|
|
|
#endif // USE_WEBSERVER
|
2018-01-05 11:26:19 +00:00
|
|
|
case FUNC_MQTT_SUBSCRIBE:
|
|
|
|
DomoticzMqttSubscribe();
|
2019-11-26 15:51:53 +00:00
|
|
|
#ifdef USE_SHUTTER
|
|
|
|
if (Settings.domoticz_sensor_idx[DZ_SHUTTER]) { domoticz_is_shutter = true; }
|
|
|
|
#endif // USE_SHUTTER
|
2018-01-05 11:26:19 +00:00
|
|
|
break;
|
2018-01-18 15:19:28 +00:00
|
|
|
case FUNC_MQTT_INIT:
|
|
|
|
domoticz_update_timer = 2;
|
|
|
|
break;
|
2018-01-05 11:26:19 +00:00
|
|
|
case FUNC_SHOW_SENSOR:
|
|
|
|
// DomoticzSendSensor();
|
|
|
|
break;
|
2019-08-01 16:18:49 +01:00
|
|
|
case FUNC_COMMAND:
|
2019-08-11 17:12:18 +01:00
|
|
|
result = DecodeCommand(kDomoticzCommands, DomoticzCommand);
|
2019-08-01 16:18:49 +01:00
|
|
|
break;
|
2018-01-05 11:26:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2017-01-28 13:41:01 +00:00
|
|
|
#endif // USE_DOMOTICZ
|