mirror of
https://github.com/1technophile/OpenMQTTGateway.git
synced 2026-03-02 13:34:22 +01:00
By building only the log level required into LOG_LEVEL Co-authored-by: Florian <1technophile@users.noreply.github.com>
96 lines
3.5 KiB
C++
96 lines
3.5 KiB
C++
/*
|
|
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 <https://shop.gwl.eu/GridFree-Inverters/GridFree-AC-Inverter-with-limiter-2kW-SUN-2000G-45-90V.html>.
|
|
|
|
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 <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#include "User_config.h"
|
|
|
|
#ifdef ZgatewayGFSunInverter
|
|
|
|
# include <GfSun2000.h>
|
|
|
|
# include "TheengsCommon.h"
|
|
# include "config_GFSunInverter.h"
|
|
|
|
GfSun2000 GF = GfSun2000();
|
|
|
|
void GFSunInverterDataHandler(GfSun2000Data data) {
|
|
StaticJsonDocument<JSON_MSG_BUFFER> jdataBuffer;
|
|
JsonObject jdata = jdataBuffer.to<JsonObject>();
|
|
|
|
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<JSON_MSG_BUFFER> jregisterBuffer;
|
|
JsonObject jregister = jregisterBuffer.to<JsonObject>();
|
|
char buffer[4];
|
|
std::map<int16_t, int16_t>::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<JSON_MSG_BUFFER> jdataBuffer;
|
|
JsonObject jdata = jdataBuffer.to<JsonObject>();
|
|
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
|