diff --git a/src/EventsAndOrders.cpp b/src/EventsAndOrders.cpp index 6ca7e08e..4fde9600 100644 --- a/src/EventsAndOrders.cpp +++ b/src/EventsAndOrders.cpp @@ -7,6 +7,8 @@ //его главное отличие от orderBuf в том что события в нем не для выполнения, а для проверки в условиях сценариев //события в нем лишь вызывают другие команды, помещенные в блоке сценария, если условие совпало. + + //эта функция будет вызываться: // 1.на приеме сообщений в mqtt (см mqttCallback строку 142 в mqttClient.cpp) // 2.на приеме сообщений в ws @@ -21,7 +23,17 @@ void handleOrder() { if (orderBuf.length()) { String order = selectToMarker(orderBuf, ","); Serial.println("order: " + order); + //здесь нужно перебрать все методы execute всех векторов и выполнить те id которых совпали с id события + IoTItem* item = findIoTItem(selectToMarker(order, " ")); + if (item) { + String valStr = selectToMarkerLast(order, " "); + IoTValue value; + if (value.isDecimal = isDigitStr(valStr)) value.valD = valStr.toFloat(); + else value.valS = valStr; + item->setValue(value); + } + orderBuf = deleteBeforeDelimiter(orderBuf, ","); } }