/* * This file is part of the "bluetoothheater" distribution * (https://gitlab.com/mrjones.id.au/bluetoothheater) * * Copyright (C) 2018 Ray Jones * * 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. * * 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 . * */ #include "BTC_JSON.h" #include "DebugPort.h" #include "../Protocol/helpers.h" #include "NVstorage.h" #include "../RTC/BTCDateTime.h" #include "../RTC/Timers.h" #include "../Bluetooth/BluetoothAbstract.h" #include "../WiFi/BTCWebServer.h" #include "../cfg/BTCConfig.h" char defaultJSONstr[64]; CModerator JSONmoderator; void interpretJsonCommand(char* pLine) { if(strlen(pLine) == 0) return; DebugPort.print("JSON parse... "); DebugPort.print(pLine); StaticJsonBuffer<512> jsonBuffer; // create a JSON buffer on the heap JsonObject& obj = jsonBuffer.parseObject(pLine); if(!obj.success()) { DebugPort.println(" FAILED"); return; } DebugPort.println(" OK"); JsonObject::iterator it; for(it = obj.begin(); it != obj.end(); ++it) { if(strcmp("TempDesired", it->key) == 0) { if(!reqTemp(it->value.as())) { // this request is blocked if OEM controller active JSONmoderator.reset("TempDesired"); } } else if(strcmp("RunState", it->key) == 0) { if(it->value.as()) { requestOn(); } else { requestOff(); } } else if(strcmp("PumpMin", it->key) == 0) { setPumpMin(it->value.as()); } else if(strcmp("PumpMax", it->key) == 0) { setPumpMax(it->value.as()); } else if(strcmp("FanMin", it->key) == 0) { setFanMin(it->value.as()); } else if(strcmp("FanMax", it->key) == 0) { setFanMax(it->value.as()); } else if(strcmp("Thermostat", it->key) == 0) { if(!setThermostatMode(it->value.as())) { // this request is blocked if OEM controller active JSONmoderator.reset("ThermoStat"); } } else if(strcmp("NVsave", it->key) == 0) { if(it->value.as() == 8861) saveNV(); } else if(strcmp("DateTime", it->key) == 0) { setDateTime(it->value.as()); } else if(strcmp("Date", it->key) == 0) { setDate(it->value.as()); } else if(strcmp("Time", it->key) == 0) { setTime(it->value.as()); } else if(strcmp("PumpPrime", it->key) == 0) { reqPumpPrime(it->value.as()); } else if(strcmp("Refresh", it->key) == 0) { resetJSONmoderator(); } else if(strcmp("Timer1Days", it->key) == 0) { decodeTimerDays(0, it->value.as()); } else if(strcmp("Timer1Start", it->key) == 0) { decodeTimerTime(0, 0, it->value.as()); } else if(strcmp("Timer1Stop", it->key) == 0) { decodeTimerTime(0, 1, it->value.as()); } else if(strcmp("Timer1Repeat", it->key) == 0) { decodeTimerRepeat(0, it->value.as()); } else if(strcmp("Timer2Days", it->key) == 0) { decodeTimerDays(1, it->value.as()); } else if(strcmp("Timer2Start", it->key) == 0) { decodeTimerTime(1, 0, it->value.as()); } else if(strcmp("Timer2Stop", it->key) == 0) { decodeTimerTime(1, 1, it->value.as()); } else if(strcmp("Timer2Repeat", it->key) == 0) { decodeTimerRepeat(1, it->value.as()); } } } bool makeJsonString(CModerator& moderator, char* opStr, int len) { StaticJsonBuffer<600> jsonBuffer; // create a JSON buffer on the stack JsonObject& root = jsonBuffer.createObject(); // create object to add JSON commands to bool bSend = false; // reset should send flag float tidyTemp = int(getActualTemperature() * 10) * 0.1f; // round to 0.1 resolution bSend |= moderator.addJson("TempCurrent", tidyTemp, root); bSend |= moderator.addJson("TempDesired", getHeaterInfo().getTemperature_Desired(), root); bSend |= moderator.addJson("TempMin", getHeaterInfo().getTemperature_Min(), root); bSend |= moderator.addJson("TempMax", getHeaterInfo().getTemperature_Max(), root); bSend |= moderator.addJson("TempBody", getHeaterInfo().getTemperature_HeatExchg(), root); bSend |= moderator.addJson("RunState", getHeaterInfo().getRunState(), root); bSend |= moderator.addJson("RunString", getHeaterInfo().getRunStateStr(), root); // verbose it up! bSend |= moderator.addJson("ErrorState", getHeaterInfo().getErrState(), root ); bSend |= moderator.addJson("ErrorString", getHeaterInfo().getErrStateStrEx(), root); // verbose it up! bSend |= moderator.addJson("Thermostat", getHeaterInfo().isThermostat(), root ); bSend |= moderator.addJson("PumpFixed", getHeaterInfo().getPump_Fixed(), root ); bSend |= moderator.addJson("PumpMin", getHeaterInfo().getPump_Min(), root ); bSend |= moderator.addJson("PumpMax", getHeaterInfo().getPump_Max(), root ); bSend |= moderator.addJson("PumpActual", getHeaterInfo().getPump_Actual(), root ); bSend |= moderator.addJson("FanMin", getHeaterInfo().getFan_Min(), root ); bSend |= moderator.addJson("FanMax", getHeaterInfo().getFan_Max(), root ); bSend |= moderator.addJson("FanRPM", getHeaterInfo().getFan_Actual(), root ); bSend |= moderator.addJson("FanVoltage", getHeaterInfo().getFan_Voltage(), root ); bSend |= moderator.addJson("SystemVoltage", getHeaterInfo().getBattVoltage(), root ); bSend |= moderator.addJson("GlowVoltage", getHeaterInfo().getGlow_Voltage(), root ); bSend |= moderator.addJson("GlowCurrent", getHeaterInfo().getGlow_Current(), root ); bSend |= moderator.addJson("Timer1Start", getTimerStr(0, 0), root ); bSend |= moderator.addJson("Timer1Stop", getTimerStr(0, 1), root ); bSend |= moderator.addJson("Timer1Days", getTimerStr(0, 2), root ); bSend |= moderator.addJson("Timer1Repeat", getTimerStr(0, 3), root ); bSend |= moderator.addJson("Timer2Start", getTimerStr(1, 0), root ); bSend |= moderator.addJson("Timer2Stop", getTimerStr(1, 1), root ); bSend |= moderator.addJson("Timer2Days", getTimerStr(1, 2), root ); bSend |= moderator.addJson("Timer2Repeat", getTimerStr(1, 3), root ); bSend |= moderator.addJson("BluewireStat", getControllerStat(), root ); if(bSend) { root.printTo(opStr, len); } return bSend; } void updateJSONclients(bool report) { char jsonStr[600]; if(makeJsonString(JSONmoderator, jsonStr, sizeof(jsonStr))) { if (report) { DebugPort.print("JSON send: "); DebugPort.println(jsonStr); } getBluetoothClient().send( jsonStr ); sendWebServerString( jsonStr ); } } void resetJSONmoderator() { JSONmoderator.reset(); }