/* Theengs OpenMQTTGateway - We Unite Sensors in One Open-Source Interface Act as a wifi or ethernet gateway between your GridFree SUN-2000G inverter and a MQTT broker. Send inverter metrics by MQTT. This gateway enables to: - publish MQTT data, which are received by RS232 ModBus. Library for read metrics from GWL Power, GridFree SUN-2000G inverter . This file is part of OpenMQTTGateway. OpenMQTTGateway 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. OpenMQTTGateway 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 "User_config.h" #ifdef ZgatewayGFSunInverter # include # include "TheengsCommon.h" # include "config_GFSunInverter.h" GfSun2000 GF = GfSun2000(); void GFSunInverterDataHandler(GfSun2000Data data) { StaticJsonDocument jdataBuffer; JsonObject jdata = jdataBuffer.to(); jdata["device_id"] = (char*)data.deviceID; THEENGS_LOG_TRACE(F("Device ID : %s\n" CR), data.deviceID); jdata["ac_voltage"] = data.ACVoltage; THEENGS_LOG_TRACE(F("AC Voltage : %.1f\tV\n" CR), data.ACVoltage); jdata["dc_voltage"] = data.DCVoltage; THEENGS_LOG_TRACE(F("DC Voltage : %.1f\tV\n" CR), data.DCVoltage); jdata["power"] = data.averagePower; THEENGS_LOG_TRACE(F("Output Power : %.1f\tW (5min avg)\n" CR), data.averagePower); jdata["c_energy"] = data.customEnergyCounter; THEENGS_LOG_TRACE(F("Custom Energy : %.1f\tkW/h (can be reseted)\n" CR), data.customEnergyCounter); jdata["t_energy"] = data.totalEnergyCounter; THEENGS_LOG_TRACE(F("Total Energy : %.1f\tkW/h\n" CR), data.totalEnergyCounter); # ifdef GFSUNINVERTER_DEVEL StaticJsonDocument jregisterBuffer; JsonObject jregister = jregisterBuffer.to(); char buffer[4]; std::map::iterator itr; for (itr = data.modbusRegistry.begin(); itr != data.modbusRegistry.end(); ++itr) { THEENGS_LOG_NOTICE("%d: %d\n", itr->first, itr->second); sprintf(buffer, "%d", itr->first); jregister[buffer] = itr->second; } jdata["register"] = jregister; # endif jdata["origin"] = subjectRFtoMQTT; enqueueJsonObject(jdata); } void GFSunInverterErrorHandler(int errorId, char* errorMessage) { char buffer[50]; sprintf(buffer, "Error response: %02X - %s\n", errorId, errorMessage); THEENGS_LOG_ERROR(buffer); StaticJsonDocument jdataBuffer; JsonObject jdata = jdataBuffer.to(); jdata["status"] = "error"; jdata["msg"] = errorMessage; jdata["id"] = errorId; jdata["origin"] = subjectRFtoMQTT; enqueueJsonObject(jdata); } void setupGFSunInverter() { GF.setup(Serial2); GF.setDataHandler(GFSunInverterDataHandler); GF.setErrorHandler(GFSunInverterErrorHandler); THEENGS_LOG_TRACE(F("gatewayGFSunInverter setup done " CR)); } void ZgatewayGFSunInverterMQTT() { GF.readData(); delay(GFSUNINVERTER_DELAY); } #endif