Merge PR #544: Fronius: Rework plugin entirely, queue request and simplify structure for new API versions
This commit is contained in:
commit
c0d0e973e7
@ -5,9 +5,8 @@ nymea plug-in for Fronius solar devices.
|
||||
## Supported Things
|
||||
|
||||
* PV-Inverter
|
||||
* Storage
|
||||
* Data Logger
|
||||
* Smart Meter
|
||||
* Storage
|
||||
|
||||
## Requirements
|
||||
|
||||
|
||||
@ -1,20 +1,13 @@
|
||||
include(../plugins.pri)
|
||||
|
||||
QT += \
|
||||
network \
|
||||
QT += network
|
||||
|
||||
SOURCES += \
|
||||
froniusnetworkreply.cpp \
|
||||
froniussolarconnection.cpp \
|
||||
integrationpluginfronius.cpp \
|
||||
froniusthing.cpp \
|
||||
froniuslogger.cpp \
|
||||
froniusinverter.cpp \
|
||||
froniusstorage.cpp \
|
||||
froniusmeter.cpp \
|
||||
|
||||
HEADERS += \
|
||||
froniusnetworkreply.h \
|
||||
froniussolarconnection.h \
|
||||
integrationpluginfronius.h \
|
||||
froniusthing.h \
|
||||
froniuslogger.h \
|
||||
froniusinverter.h \
|
||||
froniusstorage.h \
|
||||
froniusmeter.h \
|
||||
|
||||
@ -1,137 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
* This project including source code and documentation is protected by
|
||||
* copyright law, and remains the property of nymea GmbH. All rights, including
|
||||
* reproduction, publication, editing and translation, are reserved. The use of
|
||||
* this project is subject to the terms of a license agreement to be concluded
|
||||
* with nymea GmbH in accordance with the terms of use of nymea GmbH, available
|
||||
* under https://nymea.io/license
|
||||
*
|
||||
* GNU Lesser General Public License Usage
|
||||
* Alternatively, this project may be redistributed and/or modified under the
|
||||
* terms of the GNU Lesser General Public License as published by the Free
|
||||
* Software Foundation; version 3. This project 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
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with this project. If not, see <https://www.gnu.org/licenses/>.
|
||||
*
|
||||
* For any further details and any questions please contact us under
|
||||
* contact@nymea.io or see our FAQ/Licensing Information on
|
||||
* https://nymea.io/license/faq
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#include "froniusinverter.h"
|
||||
#include <QJsonDocument>
|
||||
#include "extern-plugininfo.h"
|
||||
#include <QDateTime>
|
||||
|
||||
FroniusInverter::FroniusInverter(Thing *thing, QObject *parent) : FroniusThing(thing, parent)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
QString FroniusInverter::activity() const
|
||||
{
|
||||
return m_activity;
|
||||
}
|
||||
|
||||
void FroniusInverter::setActivity(const QString &activity)
|
||||
{
|
||||
m_activity = activity;
|
||||
}
|
||||
|
||||
QUrl FroniusInverter::updateUrl()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
QUrlQuery query;
|
||||
requestUrl.setHost(hostAddress());
|
||||
requestUrl.setPath(baseUrl() + "GetInverterRealtimeData.cgi");
|
||||
query.addQueryItem("Scope", "Device");
|
||||
query.addQueryItem("DeviceId", deviceId());
|
||||
query.addQueryItem("DataCollection", "CommonInverterData");
|
||||
requestUrl.setQuery(query);
|
||||
|
||||
return requestUrl;
|
||||
}
|
||||
|
||||
void FroniusInverter::updateThingInfo(const QByteArray &data)
|
||||
{
|
||||
// Convert the rawdata to a JSON document
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "FroniusInverter: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
pluginThing()->setStateValue(inverterConnectedStateTypeId,false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
QVariantMap headMap = jsonDoc.toVariant().toMap().value("Head").toMap();
|
||||
|
||||
qCDebug(dcFronius()) << "Inverter data" << qUtf8Printable(QJsonDocument::fromVariant(dataMap).toJson(QJsonDocument::Indented));
|
||||
|
||||
// Set the inverter device state
|
||||
if (dataMap.contains("PAC")) {
|
||||
if(dataMap.value("PAC").toMap().values().at(0) == "W")
|
||||
pluginThing()->setStateValue(inverterCurrentPowerStateTypeId, -dataMap.value("PAC").toMap().values().at(1).toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("DAY_ENERGY")) {
|
||||
if (dataMap.value("DAY_ENERGY").toMap().values().at(0) == "Wh")
|
||||
pluginThing()->setStateValue(inverterEdayStateTypeId, dataMap.value("DAY_ENERGY").toMap().values().at(1).toDouble()/1000);
|
||||
}
|
||||
|
||||
if (dataMap.contains("YEAR_ENERGY")) {
|
||||
if(dataMap.value("YEAR_ENERGY").toMap().values().at(0) == "Wh")
|
||||
pluginThing()->setStateValue(inverterEyearStateTypeId, dataMap.value("YEAR_ENERGY").toMap().values().at(1).toInt()/1000);
|
||||
}
|
||||
|
||||
if (dataMap.contains("TOTAL_ENERGY")) {
|
||||
if(dataMap.value("TOTAL_ENERGY").toMap().values().at(0) == "Wh")
|
||||
pluginThing()->setStateValue(inverterTotalEnergyProducedStateTypeId, dataMap.value("TOTAL_ENERGY").toMap().values().at(1).toInt()/1000);
|
||||
}
|
||||
|
||||
//update successful
|
||||
pluginThing()->setStateValue(inverterConnectedStateTypeId,true);
|
||||
|
||||
}
|
||||
|
||||
QUrl FroniusInverter::activityUrl()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(hostAddress());
|
||||
requestUrl.setPath(baseUrl()+"GetPowerFlowRealtimeData.fcgi");
|
||||
|
||||
return requestUrl;
|
||||
}
|
||||
|
||||
void FroniusInverter::updateActivityInfo(const QByteArray &data)
|
||||
{
|
||||
// Convert the rawdata to a json document
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if(error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "FroniusInverter: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
return;
|
||||
}
|
||||
|
||||
// create StorageInfo list map
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
|
||||
if (dataMap.value("Site").toMap().value("P_PV").toFloat() > 0) {
|
||||
pluginThing()->setStateValue(inverterActiveStateTypeId, "production");
|
||||
} else {
|
||||
pluginThing()->setStateValue(inverterActiveStateTypeId, "inactive");
|
||||
}
|
||||
}
|
||||
@ -1,144 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
* This project including source code and documentation is protected by
|
||||
* copyright law, and remains the property of nymea GmbH. All rights, including
|
||||
* reproduction, publication, editing and translation, are reserved. The use of
|
||||
* this project is subject to the terms of a license agreement to be concluded
|
||||
* with nymea GmbH in accordance with the terms of use of nymea GmbH, available
|
||||
* under https://nymea.io/license
|
||||
*
|
||||
* GNU Lesser General Public License Usage
|
||||
* Alternatively, this project may be redistributed and/or modified under the
|
||||
* terms of the GNU Lesser General Public License as published by the Free
|
||||
* Software Foundation; version 3. This project 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
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with this project. If not, see <https://www.gnu.org/licenses/>.
|
||||
*
|
||||
* For any further details and any questions please contact us under
|
||||
* contact@nymea.io or see our FAQ/Licensing Information on
|
||||
* https://nymea.io/license/faq
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#include "froniuslogger.h"
|
||||
#include "extern-plugininfo.h"
|
||||
|
||||
#include <QJsonDocument>
|
||||
#include <QDateTime>
|
||||
|
||||
FroniusLogger::FroniusLogger(Thing *thing, QObject *parent) : FroniusThing(thing, parent)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
QUrl FroniusLogger::updateUrl()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(hostAddress());
|
||||
requestUrl.setPath(baseUrl() + "GetLoggerInfo.cgi");
|
||||
|
||||
return requestUrl;
|
||||
}
|
||||
|
||||
void FroniusLogger::updateThingInfo(const QByteArray &data)
|
||||
{
|
||||
// Convert the rawdata to a json document
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
// qCWarning(dcFroniusSolar()) << "Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
pluginThing()->setStateValue(dataloggerConnectedStateTypeId,false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
QVariantMap headMap = jsonDoc.toVariant().toMap().value("Head").toMap();
|
||||
QVariantMap bodyMap = jsonDoc.toVariant().toMap().value("Body").toMap();
|
||||
|
||||
//qCDebug(dcFronius()) << qUtf8Printable(jsonDoc.toJson(QJsonDocument::Indented));
|
||||
|
||||
// create LoggerInfo list Map
|
||||
QVariantMap LoggerInfoMap = bodyMap.value("LoggerInfo").toMap();
|
||||
|
||||
// copy retrieved information to device states
|
||||
if (LoggerInfoMap.contains("ProductID"))
|
||||
pluginThing()->setStateValue(dataloggerProductidStateTypeId, LoggerInfoMap.value("ProductID").toString());
|
||||
|
||||
if (LoggerInfoMap.contains("PlatformID"))
|
||||
pluginThing()->setStateValue(dataloggerPlatformidStateTypeId, LoggerInfoMap.value("PlatformID").toString());
|
||||
|
||||
if (LoggerInfoMap.contains("HWVersion"))
|
||||
pluginThing()->setStateValue(dataloggerHwversionStateTypeId, LoggerInfoMap.value("HWVersion").toString());
|
||||
|
||||
if (LoggerInfoMap.contains("SWVersion"))
|
||||
pluginThing()->setStateValue(dataloggerSwversionStateTypeId, LoggerInfoMap.value("SWVersion").toString());
|
||||
|
||||
if (LoggerInfoMap.contains("TimezoneLocation"))
|
||||
pluginThing()->setStateValue(dataloggerTzonelocStateTypeId, LoggerInfoMap.value("TimezoneLocation").toString());
|
||||
|
||||
if (LoggerInfoMap.contains("TimezoneName"))
|
||||
pluginThing()->setStateValue(dataloggerTzoneStateTypeId, LoggerInfoMap.value("TimezoneName").toString());
|
||||
|
||||
if (LoggerInfoMap.contains("DefaultLanguage"))
|
||||
pluginThing()->setStateValue(dataloggerDefaultlangStateTypeId, LoggerInfoMap.value("DefaultLanguage").toString());
|
||||
|
||||
if (LoggerInfoMap.contains("CashFactor"))
|
||||
pluginThing()->setStateValue(dataloggerCashfactorStateTypeId, LoggerInfoMap.value("CashFactor").toDouble());
|
||||
|
||||
if (LoggerInfoMap.contains("CashCurrency"))
|
||||
pluginThing()->setStateValue(dataloggerCashcurrencyStateTypeId, LoggerInfoMap.value("CashCurrency").toString());
|
||||
|
||||
if (LoggerInfoMap.contains("CO2Factor"))
|
||||
pluginThing()->setStateValue(dataloggerCo2factorStateTypeId, LoggerInfoMap.value("CO2Factor").toDouble());
|
||||
|
||||
if (LoggerInfoMap.contains("CO2Unit"))
|
||||
pluginThing()->setStateValue(dataloggerCo2unitStateTypeId, LoggerInfoMap.value("CO2Unit").toString());
|
||||
|
||||
//update successful
|
||||
pluginThing()->setStateValue(dataloggerConnectedStateTypeId,true);
|
||||
}
|
||||
|
||||
void FroniusLogger::updatePowerRelayState(const QByteArray &data)
|
||||
{
|
||||
// Convert the rawdata to a json document
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
// qCWarning(dcFroniusSolar()) << "Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
pluginThing()->setStateValue(dataloggerConnectedStateTypeId,false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap bodyMap = jsonDoc.toVariant().toMap().value("Body").toMap();
|
||||
QVariantMap dataMap = bodyMap.value("Data").toMap();
|
||||
QVariantMap emrsMap = dataMap.value("emrs").toMap();
|
||||
|
||||
// create LoggerInfo list Map
|
||||
QVariantMap GpiosMap = emrsMap.value("gpios").toMap();
|
||||
//qCDebug(dcFroniusSolar()) << "Body: " << GpiosMap;
|
||||
|
||||
// copy retrieved information to device states
|
||||
if (GpiosMap.contains("Reason")) {
|
||||
qCDebug(dcFronius()) << "Power Relay State Reason: " << GpiosMap.value("Reason").toString();
|
||||
pluginThing()->setStateValue(dataloggerPowerManagmentRelayReasonStateTypeId, GpiosMap.value("Reason").toString());
|
||||
}
|
||||
|
||||
if (GpiosMap.contains("State")) {
|
||||
qCDebug(dcFronius()) << "Power Relay State: " << GpiosMap.value("State").toString();
|
||||
pluginThing()->setStateValue(dataloggerPowerManagmentRelayStateTypeId, GpiosMap.value("State").toBool());
|
||||
}
|
||||
|
||||
//update successful
|
||||
pluginThing()->setStateValue(dataloggerConnectedStateTypeId,true);
|
||||
}
|
||||
@ -1,53 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
* This project including source code and documentation is protected by
|
||||
* copyright law, and remains the property of nymea GmbH. All rights, including
|
||||
* reproduction, publication, editing and translation, are reserved. The use of
|
||||
* this project is subject to the terms of a license agreement to be concluded
|
||||
* with nymea GmbH in accordance with the terms of use of nymea GmbH, available
|
||||
* under https://nymea.io/license
|
||||
*
|
||||
* GNU Lesser General Public License Usage
|
||||
* Alternatively, this project may be redistributed and/or modified under the
|
||||
* terms of the GNU Lesser General Public License as published by the Free
|
||||
* Software Foundation; version 3. This project 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
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with this project. If not, see <https://www.gnu.org/licenses/>.
|
||||
*
|
||||
* For any further details and any questions please contact us under
|
||||
* contact@nymea.io or see our FAQ/Licensing Information on
|
||||
* https://nymea.io/license/faq
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#ifndef FRONIUSLOGGER_H
|
||||
#define FRONIUSLOGGER_H
|
||||
|
||||
#include <QObject>
|
||||
#include <QUrl>
|
||||
#include "froniusinverter.h"
|
||||
#include "froniusmeter.h"
|
||||
#include "froniusstorage.h"
|
||||
|
||||
class FroniusLogger : public FroniusThing
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit FroniusLogger(Thing *thing, QObject *parent = 0);
|
||||
|
||||
QUrl updateUrl();
|
||||
|
||||
void updateThingInfo(const QByteArray &data);
|
||||
void updatePowerRelayState(const QByteArray &data);
|
||||
};
|
||||
|
||||
#endif // FRONIUSLOGGER_H
|
||||
@ -1,153 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
* This project including source code and documentation is protected by
|
||||
* copyright law, and remains the property of nymea GmbH. All rights, including
|
||||
* reproduction, publication, editing and translation, are reserved. The use of
|
||||
* this project is subject to the terms of a license agreement to be concluded
|
||||
* with nymea GmbH in accordance with the terms of use of nymea GmbH, available
|
||||
* under https://nymea.io/license
|
||||
*
|
||||
* GNU Lesser General Public License Usage
|
||||
* Alternatively, this project may be redistributed and/or modified under the
|
||||
* terms of the GNU Lesser General Public License as published by the Free
|
||||
* Software Foundation; version 3. This project 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
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with this project. If not, see <https://www.gnu.org/licenses/>.
|
||||
*
|
||||
* For any further details and any questions please contact us under
|
||||
* contact@nymea.io or see our FAQ/Licensing Information on
|
||||
* https://nymea.io/license/faq
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#include "froniusmeter.h"
|
||||
#include "extern-plugininfo.h"
|
||||
|
||||
#include <QJsonDocument>
|
||||
#include <QDateTime>
|
||||
|
||||
FroniusMeter::FroniusMeter(Thing* thing, QObject *parent) : FroniusThing(thing, parent)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
QString FroniusMeter::activity() const
|
||||
{
|
||||
return m_activity;
|
||||
}
|
||||
|
||||
void FroniusMeter::setActivity(const QString &activity)
|
||||
{
|
||||
m_activity = activity;
|
||||
}
|
||||
|
||||
QUrl FroniusMeter::updateUrl()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
QUrlQuery query;
|
||||
requestUrl.setHost(hostAddress());
|
||||
requestUrl.setPath(baseUrl() + "GetMeterRealtimeData.cgi");
|
||||
query.addQueryItem("Scope", "Device");
|
||||
query.addQueryItem("DeviceId", deviceId());
|
||||
requestUrl.setQuery(query);
|
||||
return requestUrl;
|
||||
}
|
||||
|
||||
void FroniusMeter::updateThingInfo(const QByteArray &data)
|
||||
{
|
||||
// Convert the rawdata to a JSON document
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "FroniusMeter: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
pluginThing()->setStateValue(meterConnectedStateTypeId, false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our thing
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
//QVariantMap headMap = jsonDoc.toVariant().toMap().value("Head").toMap();
|
||||
|
||||
//Add Smart meter with following states: „PowerReal_P_Sum“, „EnergyReal_WAC_Sum_Produced“, „EnergyReal_WAC_Sum_Consumed“
|
||||
|
||||
qCDebug(dcFronius()) << "Meter data" << qUtf8Printable(QJsonDocument::fromVariant(dataMap).toJson(QJsonDocument::Indented));
|
||||
|
||||
// Power
|
||||
if (dataMap.contains("PowerReal_P_Sum")) {
|
||||
pluginThing()->setStateValue(meterCurrentPowerStateTypeId, dataMap.value("PowerReal_P_Sum").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("PowerReal_P_Phase_1")) {
|
||||
pluginThing()->setStateValue(meterCurrentPowerPhaseAStateTypeId, dataMap.value("PowerReal_P_Phase_1").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("PowerReal_P_Phase_2")) {
|
||||
pluginThing()->setStateValue(meterCurrentPowerPhaseBStateTypeId, dataMap.value("PowerReal_P_Phase_2").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("PowerReal_P_Phase_3")) {
|
||||
pluginThing()->setStateValue(meterCurrentPowerPhaseCStateTypeId, dataMap.value("PowerReal_P_Phase_3").toDouble());
|
||||
}
|
||||
|
||||
// Current
|
||||
if (dataMap.contains("Current_AC_Phase_1")) {
|
||||
pluginThing()->setStateValue(meterCurrentPhaseAStateTypeId, dataMap.value("Current_AC_Phase_1").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("Current_AC_Phase_2")) {
|
||||
pluginThing()->setStateValue(meterCurrentPhaseBStateTypeId, dataMap.value("Current_AC_Phase_2").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("Current_AC_Phase_3")) {
|
||||
pluginThing()->setStateValue(meterCurrentPhaseCStateTypeId, dataMap.value("Current_AC_Phase_3").toDouble());
|
||||
}
|
||||
|
||||
// Voltage
|
||||
if (dataMap.contains("Voltage_AC_Phase_1")) {
|
||||
pluginThing()->setStateValue(meterVoltagePhaseAStateTypeId, dataMap.value("Voltage_AC_Phase_1").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("Voltage_AC_Phase_2")) {
|
||||
pluginThing()->setStateValue(meterVoltagePhaseBStateTypeId, dataMap.value("Voltage_AC_Phase_2").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("Voltage_AC_Phase_3")) {
|
||||
pluginThing()->setStateValue(meterVoltagePhaseCStateTypeId, dataMap.value("Voltage_AC_Phase_3").toDouble());
|
||||
}
|
||||
|
||||
// Total energy
|
||||
if (dataMap.contains("EnergyReal_WAC_Sum_Produced")) {
|
||||
pluginThing()->setStateValue(meterTotalEnergyProducedStateTypeId, dataMap.value("EnergyReal_WAC_Sum_Produced").toInt()/1000.00);
|
||||
}
|
||||
|
||||
if (dataMap.contains("EnergyReal_WAC_Sum_Consumed")) {
|
||||
pluginThing()->setStateValue(meterTotalEnergyConsumedStateTypeId, dataMap.value("EnergyReal_WAC_Sum_Consumed").toInt()/1000.00);
|
||||
}
|
||||
|
||||
// Frequency
|
||||
if (dataMap.contains("Frequency_Phase_Average")) {
|
||||
pluginThing()->setStateValue(meterFrequencyStateTypeId, dataMap.value("Frequency_Phase_Average").toDouble());
|
||||
}
|
||||
|
||||
//update successful
|
||||
pluginThing()->setStateValue(meterConnectedStateTypeId,true);
|
||||
}
|
||||
|
||||
QUrl FroniusMeter::activityUrl()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(hostAddress());
|
||||
requestUrl.setPath(baseUrl()+"GetPowerFlowRealtimeData.fcgi");
|
||||
|
||||
return requestUrl;
|
||||
}
|
||||
@ -1,6 +1,6 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Copyright 2013 - 2022, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
@ -28,27 +28,50 @@
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#ifndef FRONIUSMETER_H
|
||||
#define FRONIUSMETER_H
|
||||
#include "froniusnetworkreply.h"
|
||||
|
||||
#include <QObject>
|
||||
#include "froniusthing.h"
|
||||
|
||||
class FroniusMeter : public FroniusThing
|
||||
FroniusNetworkReply::~FroniusNetworkReply()
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
explicit FroniusMeter(Thing* thing, QObject *parent = 0);
|
||||
if (m_networkReply) {
|
||||
// We don't need the finished signal any more, object gets deleted
|
||||
disconnect(m_networkReply, &QNetworkReply::finished, this, &FroniusNetworkReply::finished);
|
||||
|
||||
QString activity() const;
|
||||
void setActivity(const QString &activity);
|
||||
if (m_networkReply->isRunning()) {
|
||||
// Abort the reply, we are not interested in it any more
|
||||
m_networkReply->abort();
|
||||
}
|
||||
|
||||
QUrl updateUrl();
|
||||
void updateThingInfo(const QByteArray &data);
|
||||
QUrl activityUrl();
|
||||
m_networkReply->deleteLater();
|
||||
}
|
||||
}
|
||||
|
||||
private:
|
||||
QString m_activity;
|
||||
};
|
||||
QUrl FroniusNetworkReply::requestUrl() const
|
||||
{
|
||||
return m_request.url();
|
||||
}
|
||||
|
||||
QNetworkRequest FroniusNetworkReply::request() const
|
||||
{
|
||||
return m_request;
|
||||
}
|
||||
|
||||
QNetworkReply *FroniusNetworkReply::networkReply() const
|
||||
{
|
||||
return m_networkReply;
|
||||
}
|
||||
|
||||
FroniusNetworkReply::FroniusNetworkReply(const QNetworkRequest &request, QObject *parent) :
|
||||
QObject(parent),
|
||||
m_request(request)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
void FroniusNetworkReply::setNetworkReply(QNetworkReply *networkReply)
|
||||
{
|
||||
m_networkReply = networkReply;
|
||||
|
||||
// The QNetworkReply will be deleted in the destructor if set
|
||||
connect(m_networkReply, &QNetworkReply::finished, this, &FroniusNetworkReply::finished);
|
||||
}
|
||||
|
||||
#endif // FRONIUSMETER_H
|
||||
@ -1,6 +1,6 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Copyright 2013 - 2022, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
@ -28,29 +28,36 @@
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#ifndef FRONIUSINVERTER_H
|
||||
#define FRONIUSINVERTER_H
|
||||
#ifndef FRONIUSNETWORKREPLY_H
|
||||
#define FRONIUSNETWORKREPLY_H
|
||||
|
||||
#include <QObject>
|
||||
#include "froniusthing.h"
|
||||
#include <QNetworkReply>
|
||||
|
||||
class FroniusInverter : public FroniusThing
|
||||
class FroniusNetworkReply : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit FroniusInverter(Thing *thing, QObject *parent = 0);
|
||||
friend class FroniusSolarConnection;
|
||||
|
||||
QString activity() const;
|
||||
void setActivity(const QString &activity);
|
||||
Thing* inverterThing() const;
|
||||
QUrl updateUrl();
|
||||
void updateThingInfo(const QByteArray &data);
|
||||
QUrl activityUrl();
|
||||
void updateActivityInfo(const QByteArray &data);
|
||||
public:
|
||||
~FroniusNetworkReply();
|
||||
|
||||
QUrl requestUrl() const;
|
||||
|
||||
QNetworkRequest request() const;
|
||||
QNetworkReply *networkReply() const;
|
||||
|
||||
signals:
|
||||
void finished();
|
||||
|
||||
private:
|
||||
QString m_activity;
|
||||
explicit FroniusNetworkReply(const QNetworkRequest &request, QObject *parent = nullptr);
|
||||
|
||||
QNetworkRequest m_request;
|
||||
QNetworkReply *m_networkReply = nullptr;
|
||||
|
||||
void setNetworkReply(QNetworkReply *networkReply);
|
||||
};
|
||||
|
||||
#endif // FRONIUSINVERTER_H
|
||||
#endif // FRONIUSNETWORKREPLY_H
|
||||
203
fronius/froniussolarconnection.cpp
Normal file
203
fronius/froniussolarconnection.cpp
Normal file
@ -0,0 +1,203 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2022, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
* This project including source code and documentation is protected by
|
||||
* copyright law, and remains the property of nymea GmbH. All rights, including
|
||||
* reproduction, publication, editing and translation, are reserved. The use of
|
||||
* this project is subject to the terms of a license agreement to be concluded
|
||||
* with nymea GmbH in accordance with the terms of use of nymea GmbH, available
|
||||
* under https://nymea.io/license
|
||||
*
|
||||
* GNU Lesser General Public License Usage
|
||||
* Alternatively, this project may be redistributed and/or modified under the
|
||||
* terms of the GNU Lesser General Public License as published by the Free
|
||||
* Software Foundation; version 3. This project 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
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with this project. If not, see <https://www.gnu.org/licenses/>.
|
||||
*
|
||||
* For any further details and any questions please contact us under
|
||||
* contact@nymea.io or see our FAQ/Licensing Information on
|
||||
* https://nymea.io/license/faq
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#include "froniussolarconnection.h"
|
||||
#include "extern-plugininfo.h"
|
||||
|
||||
#include <QUrlQuery>
|
||||
|
||||
FroniusSolarConnection::FroniusSolarConnection(NetworkAccessManager *networkManager, const QHostAddress &address, QObject *parent) :
|
||||
QObject(parent),
|
||||
m_networkManager(networkManager),
|
||||
m_address(address)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
QHostAddress FroniusSolarConnection::address() const
|
||||
{
|
||||
return m_address;
|
||||
}
|
||||
|
||||
bool FroniusSolarConnection::available() const
|
||||
{
|
||||
return m_available;
|
||||
}
|
||||
|
||||
bool FroniusSolarConnection::busy() const
|
||||
{
|
||||
return m_requestQueue.count() > 1;
|
||||
}
|
||||
|
||||
FroniusNetworkReply *FroniusSolarConnection::getVersion()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(m_address.toString());
|
||||
requestUrl.setPath("/solar_api/GetAPIVersion.cgi");
|
||||
|
||||
FroniusNetworkReply *reply = new FroniusNetworkReply(QNetworkRequest(requestUrl), this);
|
||||
m_requestQueue.enqueue(reply);
|
||||
sendNextRequest();
|
||||
return reply;
|
||||
}
|
||||
|
||||
FroniusNetworkReply *FroniusSolarConnection::getActiveDevices()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(m_address.toString());
|
||||
requestUrl.setPath("/solar_api/v1/GetActiveDeviceInfo.cgi");
|
||||
|
||||
QUrlQuery query;
|
||||
query.addQueryItem("DeviceClass", "System");
|
||||
requestUrl.setQuery(query);
|
||||
|
||||
FroniusNetworkReply *reply = new FroniusNetworkReply(QNetworkRequest(requestUrl), this);
|
||||
m_requestQueue.enqueue(reply);
|
||||
|
||||
// Note: we use this request for detecting if the logger is available or not.
|
||||
connect(reply, &FroniusNetworkReply::finished, this, [=](){
|
||||
if (reply->networkReply()->error() == QNetworkReply::NoError) {
|
||||
// Reply was successfully, we can communicate
|
||||
if (!m_available) {
|
||||
qCDebug(dcFronius()) << "Connection: the connection is now available";
|
||||
m_available = true;
|
||||
emit availableChanged(m_available);
|
||||
|
||||
// Destroy any pending requests
|
||||
qDeleteAll(m_requestQueue);
|
||||
m_requestQueue.clear();
|
||||
}
|
||||
} else {
|
||||
// Ther have been errors, seems like we not available any more
|
||||
if (m_available) {
|
||||
qCDebug(dcFronius()) << "Connection: the connection is not available any more:" << reply->networkReply()->errorString();
|
||||
m_available = false;
|
||||
emit availableChanged(m_available);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
sendNextRequest();
|
||||
return reply;
|
||||
}
|
||||
|
||||
FroniusNetworkReply *FroniusSolarConnection::getPowerFlowRealtimeData()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(m_address.toString());
|
||||
requestUrl.setPath("/solar_api/v1/GetPowerFlowRealtimeData.fcgi");
|
||||
|
||||
FroniusNetworkReply *reply = new FroniusNetworkReply(QNetworkRequest(requestUrl), this);
|
||||
m_requestQueue.enqueue(reply);
|
||||
sendNextRequest();
|
||||
return reply;
|
||||
}
|
||||
|
||||
FroniusNetworkReply *FroniusSolarConnection::getInverterRealtimeData(int inverterId)
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(m_address.toString());
|
||||
requestUrl.setPath("/solar_api/v1/GetInverterRealtimeData.cgi");
|
||||
|
||||
QUrlQuery query;
|
||||
query.addQueryItem("Scope", "Device");
|
||||
query.addQueryItem("DeviceId", QString::number(inverterId));
|
||||
query.addQueryItem("DataCollection", "CommonInverterData");
|
||||
requestUrl.setQuery(query);
|
||||
|
||||
FroniusNetworkReply *reply = new FroniusNetworkReply(QNetworkRequest(requestUrl), this);
|
||||
m_requestQueue.enqueue(reply);
|
||||
sendNextRequest();
|
||||
return reply;
|
||||
}
|
||||
|
||||
FroniusNetworkReply *FroniusSolarConnection::getMeterRealtimeData(int meterId)
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(m_address.toString());
|
||||
requestUrl.setPath("/solar_api/v1/GetMeterRealtimeData.cgi");
|
||||
|
||||
QUrlQuery query;
|
||||
query.addQueryItem("Scope", "Device");
|
||||
query.addQueryItem("DeviceId", QString::number(meterId));
|
||||
requestUrl.setQuery(query);
|
||||
|
||||
FroniusNetworkReply *reply = new FroniusNetworkReply(QNetworkRequest(requestUrl), this);
|
||||
m_requestQueue.enqueue(reply);
|
||||
sendNextRequest();
|
||||
return reply;
|
||||
}
|
||||
|
||||
FroniusNetworkReply *FroniusSolarConnection::getStorageRealtimeData(int meterId)
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(m_address.toString());
|
||||
requestUrl.setPath("/solar_api/v1/GetStorageRealtimeData.cgi");
|
||||
|
||||
QUrlQuery query;
|
||||
query.addQueryItem("Scope", "Device");
|
||||
query.addQueryItem("DeviceId", QString::number(meterId));
|
||||
requestUrl.setQuery(query);
|
||||
|
||||
FroniusNetworkReply *reply = new FroniusNetworkReply(QNetworkRequest(requestUrl), this);
|
||||
m_requestQueue.enqueue(reply);
|
||||
sendNextRequest();
|
||||
return reply;
|
||||
}
|
||||
|
||||
void FroniusSolarConnection::sendNextRequest()
|
||||
{
|
||||
if (m_currentReply)
|
||||
return;
|
||||
|
||||
if (m_requestQueue.isEmpty())
|
||||
return;
|
||||
|
||||
m_currentReply = m_requestQueue.dequeue();
|
||||
|
||||
qCDebug(dcFronius()) << "Connection: Sending request" << m_currentReply->request().url().toString();
|
||||
m_currentReply->setNetworkReply(m_networkManager->get(m_currentReply->request()));
|
||||
|
||||
connect(m_currentReply, &FroniusNetworkReply::finished, this, [=](){
|
||||
qCDebug(dcFronius()) << "Connection: Request finished" << m_currentReply->networkReply()->error();
|
||||
|
||||
// Note: the network reply will be deleted in the destructor
|
||||
m_currentReply->deleteLater();
|
||||
|
||||
m_currentReply = nullptr;
|
||||
sendNextRequest();
|
||||
});
|
||||
}
|
||||
@ -1,6 +1,6 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Copyright 2013 - 2022, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
@ -28,29 +28,53 @@
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#ifndef FRONIUSSTORAGE_H
|
||||
#define FRONIUSSTORAGE_H
|
||||
#ifndef FRONIUSSOLARCONNECTION_H
|
||||
#define FRONIUSSOLARCONNECTION_H
|
||||
|
||||
#include <QObject>
|
||||
#include "froniusthing.h"
|
||||
|
||||
class FroniusStorage : public FroniusThing
|
||||
#include <QQueue>
|
||||
#include <QHostAddress>
|
||||
|
||||
#include <network/networkaccessmanager.h>
|
||||
|
||||
#include "froniusnetworkreply.h"
|
||||
|
||||
class FroniusSolarConnection : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit FroniusStorage(Thing *thing, QObject *parent = 0);
|
||||
explicit FroniusSolarConnection(NetworkAccessManager *networkManager, const QHostAddress &address, QObject *parent = nullptr);
|
||||
|
||||
QString charging_state() const;
|
||||
void setChargingState(const QString &charging_state);
|
||||
QHostAddress address() const;
|
||||
|
||||
QUrl updateUrl();
|
||||
void updateThingInfo(const QByteArray &data);
|
||||
QUrl activityUrl();
|
||||
void updateActivityInfo(const QByteArray &data);
|
||||
bool available() const;
|
||||
|
||||
bool busy() const;
|
||||
|
||||
FroniusNetworkReply *getVersion();
|
||||
FroniusNetworkReply *getActiveDevices();
|
||||
FroniusNetworkReply *getPowerFlowRealtimeData();
|
||||
|
||||
FroniusNetworkReply *getInverterRealtimeData(int inverterId);
|
||||
FroniusNetworkReply *getMeterRealtimeData(int meterId);
|
||||
FroniusNetworkReply *getStorageRealtimeData(int meterId);
|
||||
|
||||
signals:
|
||||
void availableChanged(bool available);
|
||||
|
||||
private:
|
||||
QString m_charging_state;
|
||||
int m_charge;
|
||||
NetworkAccessManager *m_networkManager = nullptr;
|
||||
QHostAddress m_address;
|
||||
|
||||
bool m_available = false;
|
||||
|
||||
// Request queue to prevent overloading the device with requests
|
||||
FroniusNetworkReply *m_currentReply = nullptr;
|
||||
QQueue<FroniusNetworkReply *> m_requestQueue;
|
||||
|
||||
void sendNextRequest();
|
||||
|
||||
};
|
||||
#endif // FRONIUSSTORAGE_H
|
||||
|
||||
#endif // FRONIUSSOLARCONNECTION_H
|
||||
@ -1,136 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
* This project including source code and documentation is protected by
|
||||
* copyright law, and remains the property of nymea GmbH. All rights, including
|
||||
* reproduction, publication, editing and translation, are reserved. The use of
|
||||
* this project is subject to the terms of a license agreement to be concluded
|
||||
* with nymea GmbH in accordance with the terms of use of nymea GmbH, available
|
||||
* under https://nymea.io/license
|
||||
*
|
||||
* GNU Lesser General Public License Usage
|
||||
* Alternatively, this project may be redistributed and/or modified under the
|
||||
* terms of the GNU Lesser General Public License as published by the Free
|
||||
* Software Foundation; version 3. This project 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
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with this project. If not, see <https://www.gnu.org/licenses/>.
|
||||
*
|
||||
* For any further details and any questions please contact us under
|
||||
* contact@nymea.io or see our FAQ/Licensing Information on
|
||||
* https://nymea.io/license/faq
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#include "froniusstorage.h"
|
||||
#include <QJsonDocument>
|
||||
#include "extern-plugininfo.h"
|
||||
#include <QDateTime>
|
||||
|
||||
FroniusStorage::FroniusStorage(Thing* thing, QObject *parent) : FroniusThing(thing, parent)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
QString FroniusStorage::charging_state() const
|
||||
{
|
||||
return m_charging_state;
|
||||
}
|
||||
|
||||
void FroniusStorage::setChargingState(const QString &charging_state)
|
||||
{
|
||||
m_charging_state = charging_state;
|
||||
}
|
||||
|
||||
QUrl FroniusStorage::updateUrl()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
QUrlQuery query;
|
||||
requestUrl.setHost(hostAddress());
|
||||
requestUrl.setPath(baseUrl() + "GetStorageRealtimeData.cgi");
|
||||
query.addQueryItem("Scope", "Device");
|
||||
query.addQueryItem("DeviceId", deviceId());
|
||||
requestUrl.setQuery(query);
|
||||
|
||||
return requestUrl;
|
||||
}
|
||||
|
||||
void FroniusStorage::updateThingInfo(const QByteArray &data)
|
||||
{
|
||||
// Convert the rawdata to a JSON document
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "FroniusStorage: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
pluginThing()->setStateValue(storageConnectedStateTypeId,false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our thing
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
// QVariantMap headMap = jsonDoc.toVariant().toMap().value("Head").toMap();
|
||||
|
||||
qCDebug(dcFronius()) << "Storage data" << qUtf8Printable(QJsonDocument::fromVariant(dataMap).toJson(QJsonDocument::Indented));
|
||||
|
||||
// create StorageInfo list map
|
||||
QVariantMap storageInfoMap = dataMap.value("Controller").toMap();
|
||||
|
||||
// copy retrieved information to thing states
|
||||
if (storageInfoMap.contains("StateOfCharge_Relative")) {
|
||||
pluginThing()->setStateValue(storageBatteryLevelStateTypeId, storageInfoMap.value("StateOfCharge_Relative").toInt());
|
||||
if (pluginThing()->stateValue(storageChargingStateStateTypeId).toString() == "charging" && (storageInfoMap.value("StateOfCharge_Relative").toInt() < 5)) {
|
||||
pluginThing()->setStateValue(storageBatteryCriticalStateTypeId, true);
|
||||
} else {
|
||||
pluginThing()->setStateValue(storageBatteryCriticalStateTypeId, false);
|
||||
}
|
||||
}
|
||||
|
||||
if (storageInfoMap.contains("Temperature_Cell"))
|
||||
pluginThing()->setStateValue(storageCellTemperatureStateTypeId, storageInfoMap.value("Temperature_Cell").toDouble());
|
||||
|
||||
if (storageInfoMap.contains("Capacity_Maximum"))
|
||||
pluginThing()->setStateValue(storageCapacityStateTypeId, storageInfoMap.value("Capacity_Maximum").toDouble());
|
||||
|
||||
pluginThing()->setStateValue(storageConnectedStateTypeId,true);
|
||||
}
|
||||
|
||||
QUrl FroniusStorage::activityUrl()
|
||||
{
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(hostAddress());
|
||||
requestUrl.setPath(baseUrl()+"GetPowerFlowRealtimeData.fcgi");
|
||||
|
||||
return requestUrl;
|
||||
}
|
||||
|
||||
void FroniusStorage::updateActivityInfo(const QByteArray &data)
|
||||
{
|
||||
// Convert the rawdata to a json document
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if(error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "FroniusStorage: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
return;
|
||||
}
|
||||
|
||||
// create StorageInfo list map
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
float charge_akku = dataMap.value("Site").toMap().value("P_Akku").toFloat();
|
||||
pluginThing()->setStateValue(storageCurrentPowerStateTypeId, charge_akku);
|
||||
if (charge_akku < 0) {
|
||||
pluginThing()->setStateValue(storageChargingStateStateTypeId, "discharging");
|
||||
} else if (charge_akku > 0) {
|
||||
pluginThing()->setStateValue(storageChargingStateStateTypeId, "charging");
|
||||
} else {
|
||||
pluginThing()->setStateValue(storageChargingStateStateTypeId, "idle");
|
||||
}
|
||||
}
|
||||
@ -1,6 +1,6 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Copyright 2013 - 2022, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
@ -29,16 +29,16 @@
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
#include "plugininfo.h"
|
||||
#include "integrationpluginfronius.h"
|
||||
#include "plugintimer.h"
|
||||
#include "integrationpluginfronius.h"
|
||||
#include "network/networkaccessmanager.h"
|
||||
#include "network/networkdevicediscovery.h"
|
||||
|
||||
#include <QUrl>
|
||||
#include <QDebug>
|
||||
#include <QPointer>
|
||||
#include <QUrlQuery>
|
||||
#include <QJsonDocument>
|
||||
#include <QPointer>
|
||||
#include <QDebug>
|
||||
|
||||
// Notes: Test IPs: 93.82.221.82 | 88.117.152.99
|
||||
|
||||
@ -83,18 +83,18 @@ void IntegrationPluginFronius::discoverThings(ThingDiscoveryInfo *info)
|
||||
description = networkDeviceInfo.macAddress() + " (" + networkDeviceInfo.macAddressManufacturer() + ")";
|
||||
}
|
||||
|
||||
ThingDescriptor descriptor(dataloggerThingClassId, title, description);
|
||||
ThingDescriptor descriptor(connectionThingClassId, title, description);
|
||||
|
||||
// Check if we already have set up this device
|
||||
Things existingThings = myThings().filterByParam(dataloggerThingLoggerMacParamTypeId, networkDeviceInfo.macAddress());
|
||||
Things existingThings = myThings().filterByParam(connectionThingMacParamTypeId, networkDeviceInfo.macAddress());
|
||||
if (existingThings.count() == 1) {
|
||||
qCDebug(dcFronius()) << "This thing already exists in the system." << existingThings.first() << networkDeviceInfo;
|
||||
descriptor.setThingId(existingThings.first()->id());
|
||||
}
|
||||
|
||||
ParamList params;
|
||||
params << Param(dataloggerThingLoggerHostParamTypeId, networkDeviceInfo.address().toString());
|
||||
params << Param(dataloggerThingLoggerMacParamTypeId, networkDeviceInfo.macAddress());
|
||||
params << Param(connectionThingAddressParamTypeId, networkDeviceInfo.address().toString());
|
||||
params << Param(connectionThingMacParamTypeId, networkDeviceInfo.macAddress());
|
||||
descriptor.setParams(params);
|
||||
info->addThingDescriptor(descriptor);
|
||||
}
|
||||
@ -104,36 +104,30 @@ void IntegrationPluginFronius::discoverThings(ThingDiscoveryInfo *info)
|
||||
|
||||
void IntegrationPluginFronius::setupThing(ThingSetupInfo *info)
|
||||
{
|
||||
qCDebug(dcFronius()) << "Setting up a new thing:" << info->thing()->name();
|
||||
|
||||
Thing *thing = info->thing();
|
||||
qCDebug(dcFronius()) << "Setting up" << thing;
|
||||
|
||||
if (thing->thingClassId() == dataloggerThingClassId) {
|
||||
//check if a data logger is already added with this IPv4Address
|
||||
foreach(FroniusLogger *logger, m_froniusLoggers.keys()){
|
||||
if(logger->hostAddress() == thing->paramValue(dataloggerThingLoggerHostParamTypeId).toString()){
|
||||
//this logger at this IPv4 address is already added
|
||||
qCWarning(dcFronius()) << "thing at " << thing->paramValue(dataloggerThingLoggerHostParamTypeId).toString() << " already added!";
|
||||
info->finish(Thing::ThingErrorThingInUse);
|
||||
return;
|
||||
}
|
||||
if (thing->thingClassId() == connectionThingClassId) {
|
||||
|
||||
QHostAddress address(thing->paramValue(connectionThingAddressParamTypeId).toString());
|
||||
|
||||
// Handle reconfigure
|
||||
if (m_froniusConnections.values().contains(thing)) {
|
||||
FroniusSolarConnection *connection = m_froniusConnections.key(thing);
|
||||
m_froniusConnections.remove(connection);
|
||||
connection->deleteLater();
|
||||
}
|
||||
|
||||
// Perform a HTTP request on the given IPv4Address to find things
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(thing->paramValue(dataloggerThingLoggerHostParamTypeId).toString());
|
||||
requestUrl.setPath("/solar_api/GetAPIVersion.cgi");
|
||||
// Create the connection
|
||||
FroniusSolarConnection *connection = new FroniusSolarConnection(hardwareManager()->networkManager(), address, thing);
|
||||
|
||||
qCDebug(dcFronius()) << "Search at address" << requestUrl.toString();
|
||||
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(QNetworkRequest(requestUrl));
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, info, [this, info, thing, reply] {
|
||||
QByteArray data = reply->readAll();
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString() << reply->url();
|
||||
info->finish(Thing::ThingErrorHardwareNotAvailable, tr("Device not reachable"));
|
||||
// Verify the version
|
||||
FroniusNetworkReply *reply = connection->getVersion();
|
||||
connect(reply, &FroniusNetworkReply::finished, info, [=] {
|
||||
QByteArray data = reply->networkReply()->readAll();
|
||||
if (reply->networkReply()->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->networkReply()->error() << reply->networkReply()->errorString() << reply->networkReply()->url();
|
||||
info->finish(Thing::ThingErrorHardwareNotAvailable, QT_TR_NOOP("The device is not reachable"));
|
||||
return;
|
||||
}
|
||||
|
||||
@ -142,11 +136,12 @@ void IntegrationPluginFronius::setupThing(ThingSetupInfo *info)
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "Failed to parse JSON data" << data << ":" << error.errorString() << data;
|
||||
info->finish(Thing::ThingErrorHardwareFailure, tr("Please try again"));
|
||||
info->finish(Thing::ThingErrorHardwareFailure, QT_TR_NOOP("Unable to read the data. Please try again."));
|
||||
return;
|
||||
}
|
||||
|
||||
QVariantMap versionResponseMap = jsonDoc.toVariant().toMap();
|
||||
qCDebug(dcFronius()) << "Compatibility version" << versionResponseMap.value("CompatibilityRange").toString();
|
||||
|
||||
// Knwon version with broken JSON API
|
||||
if (versionResponseMap.value("CompatibilityRange").toString() == "1.6-2") {
|
||||
@ -155,34 +150,47 @@ void IntegrationPluginFronius::setupThing(ThingSetupInfo *info)
|
||||
return;
|
||||
}
|
||||
|
||||
FroniusLogger *newLogger = new FroniusLogger(thing, this);
|
||||
newLogger->setBaseUrl(versionResponseMap.value("BaseURL").toString());
|
||||
newLogger->setHostAddress(thing->paramValue(dataloggerThingLoggerHostParamTypeId).toString());
|
||||
m_froniusLoggers.insert(newLogger, thing);
|
||||
|
||||
m_froniusConnections.insert(connection, thing);
|
||||
info->finish(Thing::ThingErrorNoError);
|
||||
|
||||
// Update the already known states
|
||||
thing->setStateValue("connected", true);
|
||||
thing->setStateValue(connectionVersionStateTypeId, versionResponseMap.value("CompatibilityRange").toString());
|
||||
});
|
||||
|
||||
} else if ((thing->thingClassId() == inverterThingClassId) ||
|
||||
(thing->thingClassId() == meterThingClassId) ||
|
||||
(thing->thingClassId() == storageThingClassId)) {
|
||||
connect(connection, &FroniusSolarConnection::availableChanged, this, [=](bool available){
|
||||
qCDebug(dcFronius()) << thing << "Available changed" << available;
|
||||
thing->setStateValue("connected", available);
|
||||
|
||||
Thing *loggerThing = myThings().findById(thing->parentId());
|
||||
if (!loggerThing) {
|
||||
qCWarning(dcFronius()) << "Could not find Logger Thing for thing " << thing->name();
|
||||
return info->finish(Thing::ThingErrorHardwareNotAvailable, "Please try again");
|
||||
}
|
||||
|
||||
if (!loggerThing->setupComplete()) {
|
||||
//wait for the parent to finish the setup process
|
||||
connect(loggerThing, &Thing::setupStatusChanged, info, [this, info, loggerThing] {
|
||||
if (loggerThing->setupComplete()) {
|
||||
setupChild(info, loggerThing);
|
||||
if (!available) {
|
||||
// Update all child things, they will be set to available once the connection starts working again
|
||||
foreach (Thing *childThing, myThings().filterByParentId(thing->id())) {
|
||||
childThing->setStateValue("connected", false);
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
} else if ((thing->thingClassId() == inverterThingClassId ||
|
||||
thing->thingClassId() == meterThingClassId ||
|
||||
thing->thingClassId() == storageThingClassId)) {
|
||||
|
||||
// Verify the parent connection
|
||||
Thing *parentThing = myThings().findById(thing->parentId());
|
||||
if (!parentThing) {
|
||||
qCWarning(dcFronius()) << "Could not find the parent for" << thing;
|
||||
info->finish(Thing::ThingErrorHardwareNotAvailable);
|
||||
return;
|
||||
}
|
||||
setupChild(info, loggerThing);
|
||||
|
||||
FroniusSolarConnection *connection = m_froniusConnections.key(parentThing);
|
||||
if (!connection) {
|
||||
qCWarning(dcFronius()) << "Could not find the parent connection for" << thing;
|
||||
info->finish(Thing::ThingErrorHardwareNotAvailable);
|
||||
return;
|
||||
}
|
||||
|
||||
info->finish(Thing::ThingErrorNoError);
|
||||
|
||||
} else {
|
||||
Q_ASSERT_X(false, "setupThing", QString("Unhandled thingClassId: %1").arg(thing->thingClassId().toString()).toUtf8());
|
||||
}
|
||||
@ -192,206 +200,69 @@ void IntegrationPluginFronius::postSetupThing(Thing *thing)
|
||||
{
|
||||
qCDebug(dcFronius()) << "Post setup" << thing->name();
|
||||
|
||||
if (!m_pluginTimer) {
|
||||
m_pluginTimer = hardwareManager()->pluginTimerManager()->registerTimer(2);
|
||||
connect(m_pluginTimer, &PluginTimer::timeout, this, [this]() {
|
||||
foreach (Thing *logger, m_froniusLoggers)
|
||||
updateThingStates(logger);
|
||||
if (thing->thingClassId() == connectionThingClassId) {
|
||||
|
||||
foreach (Thing *inverter, m_froniusInverters)
|
||||
updateThingStates(inverter);
|
||||
// Create a refresh timer for monitoring the active devices
|
||||
if (!m_connectionRefreshTimer) {
|
||||
m_connectionRefreshTimer = hardwareManager()->pluginTimerManager()->registerTimer(2);
|
||||
connect(m_connectionRefreshTimer, &PluginTimer::timeout, this, [this]() {
|
||||
foreach (FroniusSolarConnection *connection, m_froniusConnections.keys()) {
|
||||
refreshConnection(connection);
|
||||
}
|
||||
});
|
||||
|
||||
foreach (Thing *meter, m_froniusMeters)
|
||||
updateThingStates(meter);
|
||||
m_connectionRefreshTimer->start();
|
||||
}
|
||||
|
||||
foreach (Thing *storage, m_froniusStorages)
|
||||
updateThingStates(storage);
|
||||
});
|
||||
}
|
||||
|
||||
if (thing->thingClassId() == dataloggerThingClassId) {
|
||||
searchNewThings(m_froniusLoggers.key(thing));
|
||||
thing->setStateValue(dataloggerConnectedStateTypeId, true);
|
||||
updateThingStates(thing);
|
||||
} else if ((thing->thingClassId() == inverterThingClassId) ||
|
||||
(thing->thingClassId() == meterThingClassId) ||
|
||||
(thing->thingClassId() == storageThingClassId)) {
|
||||
updateThingStates(thing);
|
||||
} else {
|
||||
Q_ASSERT_X(false, "postSetupThing", QString("Unhandled thingClassId: %1").arg(thing->thingClassId().toString()).toUtf8());
|
||||
// Refresh now
|
||||
FroniusSolarConnection *connection = m_froniusConnections.key(thing);
|
||||
if (connection) {
|
||||
refreshConnection(connection);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void IntegrationPluginFronius::thingRemoved(Thing *thing)
|
||||
{
|
||||
if (thing->thingClassId() == dataloggerThingClassId) {
|
||||
FroniusLogger *logger = m_froniusLoggers.key(thing);
|
||||
m_froniusLoggers.remove(logger);
|
||||
logger->deleteLater();
|
||||
} else if (thing->thingClassId() == inverterThingClassId) {
|
||||
FroniusInverter *inverter = m_froniusInverters.key(thing);
|
||||
m_froniusInverters.remove(inverter);
|
||||
inverter->deleteLater();
|
||||
} else if (thing->thingClassId() == meterThingClassId) {
|
||||
FroniusMeter *meter = m_froniusMeters.key(thing);
|
||||
m_froniusMeters.remove(meter);
|
||||
meter->deleteLater();
|
||||
} else if (thing->thingClassId() == storageThingClassId) {
|
||||
FroniusStorage *storage = m_froniusStorages.key(thing);
|
||||
m_froniusStorages.remove(storage);
|
||||
storage->deleteLater();
|
||||
} else {
|
||||
Q_ASSERT_X(false, "thingRemoved", QString("Unhandled thingClassId: %1").arg(thing->thingClassId().toString()).toUtf8());
|
||||
if (thing->thingClassId() == connectionThingClassId) {
|
||||
FroniusSolarConnection *connection = m_froniusConnections.key(thing);
|
||||
m_froniusConnections.remove(connection);
|
||||
connection->deleteLater();
|
||||
}
|
||||
|
||||
if (myThings().isEmpty()) {
|
||||
hardwareManager()->pluginTimerManager()->unregisterTimer(m_pluginTimer);
|
||||
m_pluginTimer = nullptr;
|
||||
if (myThings().filterByThingClassId(connectionThingClassId).isEmpty()) {
|
||||
hardwareManager()->pluginTimerManager()->unregisterTimer(m_connectionRefreshTimer);
|
||||
m_connectionRefreshTimer = nullptr;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void IntegrationPluginFronius::executeAction(ThingActionInfo *info)
|
||||
{
|
||||
Action action = info->action();
|
||||
Thing *thing = info->thing();
|
||||
qCDebug(dcFronius()) << "Execute action" << thing->name() << action.actionTypeId().toString();
|
||||
|
||||
if (thing->thingClassId() == dataloggerThingClassId) {
|
||||
if (action.actionTypeId() == dataloggerSearchDevicesActionTypeId) {
|
||||
searchNewThings(m_froniusLoggers.key(thing));
|
||||
info->finish(Thing::ThingErrorNoError);
|
||||
} else {
|
||||
Q_ASSERT_X(false, "executeAction", QString("Unhandled action: %1").arg(action.actionTypeId().toString()).toUtf8());
|
||||
}
|
||||
} else {
|
||||
Q_ASSERT_X(false, "executeAction", QString("Unhandled thingClassId: %1").arg(thing->thingClassId().toString()).toUtf8());
|
||||
}
|
||||
Q_UNUSED(info)
|
||||
}
|
||||
|
||||
void IntegrationPluginFronius::updateThingStates(Thing *thing)
|
||||
void IntegrationPluginFronius::refreshConnection(FroniusSolarConnection *connection)
|
||||
{
|
||||
qCDebug(dcFronius()) << "Update thing values for" << thing->name();
|
||||
|
||||
if (thing->thingClassId() == inverterThingClassId) {
|
||||
qCDebug(dcFronius()) << "Update inverter" << m_froniusInverters.key(thing)->updateUrl();
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(QNetworkRequest(m_froniusInverters.key(thing)->updateUrl()));
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, thing, [this, thing, reply]() {
|
||||
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString() << reply->request().url();
|
||||
return;
|
||||
}
|
||||
QByteArray data = reply->readAll();
|
||||
if (m_froniusInverters.values().contains(thing)){ // check if thing was not removed before reply was received
|
||||
m_froniusInverters.key(thing)->updateThingInfo(data);
|
||||
}
|
||||
});
|
||||
QNetworkReply *next_reply = hardwareManager()->networkManager()->get(QNetworkRequest(m_froniusInverters.key(thing)->activityUrl()));
|
||||
connect(next_reply, &QNetworkReply::finished, next_reply, &QNetworkReply::deleteLater);
|
||||
connect(next_reply, &QNetworkReply::finished, thing, [this, thing, next_reply] {
|
||||
if (next_reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << next_reply->error() << next_reply->errorString() << next_reply->request().url();
|
||||
return;
|
||||
}
|
||||
QByteArray data = next_reply->readAll();
|
||||
if (m_froniusInverters.values().contains(thing)){ // check if thing was not removed before reply was received
|
||||
m_froniusInverters.key(thing)->updateActivityInfo(data);
|
||||
}
|
||||
});
|
||||
} else if (thing->thingClassId() == dataloggerThingClassId) {
|
||||
qCDebug(dcFronius()) << "Update logger" << m_froniusLoggers.key(thing)->updateUrl();
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(QNetworkRequest(m_froniusLoggers.key(thing)->updateUrl()));
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, thing, [this, thing, reply]() {
|
||||
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString() << reply->request().url();
|
||||
return;
|
||||
}
|
||||
QByteArray data = reply->readAll();
|
||||
if (m_froniusLoggers.values().contains(thing)){ // check if thing was not removed before reply was received
|
||||
m_froniusLoggers.key(thing)->updateThingInfo(data);
|
||||
}
|
||||
});
|
||||
|
||||
} else if (thing->thingClassId() == meterThingClassId) {
|
||||
qCDebug(dcFronius()) << "Update meter" << m_froniusMeters.key(thing)->updateUrl();
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(QNetworkRequest(m_froniusMeters.key(thing)->updateUrl()));
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, thing, [this, thing, reply]() {
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString() << reply->request().url();
|
||||
return;
|
||||
}
|
||||
QByteArray data = reply->readAll();
|
||||
if (m_froniusMeters.values().contains(thing)){ // check if thing was not removed before reply was received
|
||||
m_froniusMeters.key(thing)->updateThingInfo(data);
|
||||
}
|
||||
});
|
||||
|
||||
} else if (thing->thingClassId() == storageThingClassId) {
|
||||
qCDebug(dcFronius()) << "Update storage" << m_froniusStorages.key(thing)->updateUrl();
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(QNetworkRequest(m_froniusStorages.key(thing)->updateUrl()));
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, thing, [this, thing, reply]() {
|
||||
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString() << reply->request().url();
|
||||
return;
|
||||
}
|
||||
QByteArray data = reply->readAll();
|
||||
if (m_froniusStorages.values().contains(thing)){ // check if thing was not removed before reply was received
|
||||
m_froniusStorages.key(thing)->updateThingInfo(data);
|
||||
}
|
||||
});
|
||||
QNetworkReply *next_reply = hardwareManager()->networkManager()->get(QNetworkRequest(m_froniusStorages.key(thing)->activityUrl()));
|
||||
connect(next_reply, &QNetworkReply::finished, next_reply, &QNetworkReply::deleteLater);
|
||||
connect(next_reply, &QNetworkReply::finished, thing, [this, thing, next_reply]() {
|
||||
|
||||
if (next_reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << next_reply->error() << next_reply->errorString() << next_reply->request().url();
|
||||
return;
|
||||
}
|
||||
QByteArray data = next_reply->readAll();
|
||||
if(m_froniusStorages.values().contains(thing)){ // check if thing was not removed before reply was received
|
||||
m_froniusStorages.key(thing)->updateActivityInfo(data);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
Q_ASSERT_X(false, "updateThingState", QString("Unhandled thingClassId: %1").arg(thing->thingClassId().toString()).toUtf8());
|
||||
if (connection->busy()) {
|
||||
qCWarning(dcFronius()) << "Connection busy. Skipping refresh cycle for host" << connection->address().toString();
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
void IntegrationPluginFronius::searchNewThings(FroniusLogger *logger)
|
||||
{
|
||||
QUrl url; QUrlQuery query;
|
||||
query.addQueryItem("DeviceClass", "System");
|
||||
url.setScheme("http");
|
||||
url.setHost(logger->hostAddress());
|
||||
url.setPath(logger->baseUrl() + "GetActiveDeviceInfo.cgi");
|
||||
url.setQuery(query);
|
||||
|
||||
qCDebug(dcFronius()) << "Searching new things at address" << url.toString();
|
||||
QNetworkRequest request = QNetworkRequest(url);
|
||||
request.setHeader(QNetworkRequest::KnownHeaders::ContentTypeHeader, "application/json");
|
||||
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(request);
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, logger, [this, logger, reply]() {
|
||||
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString() << reply->request().url();
|
||||
// Note: this call will be used to monitor the available state of the connection internally
|
||||
FroniusNetworkReply *reply = connection->getActiveDevices();
|
||||
connect(reply, &FroniusNetworkReply::finished, this, [=]() {
|
||||
if (reply->networkReply()->error() != QNetworkReply::NoError) {
|
||||
// Note: the connection warns about any errors if available changed
|
||||
return;
|
||||
}
|
||||
|
||||
Thing *loggerThing = m_froniusLoggers.value(logger);
|
||||
if (!loggerThing)
|
||||
Thing *connectionThing = m_froniusConnections.value(connection);
|
||||
if (!connectionThing)
|
||||
return;
|
||||
|
||||
// Convert the rawdata to a json document
|
||||
QByteArray data = reply->readAll();
|
||||
QByteArray data = reply->networkReply()->readAll();
|
||||
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
@ -402,70 +273,62 @@ void IntegrationPluginFronius::searchNewThings(FroniusLogger *logger)
|
||||
// Parse the data for thing information
|
||||
QList<ThingDescriptor> thingDescriptors;
|
||||
|
||||
// Check reply information
|
||||
QVariantMap bodyMap = jsonDoc.toVariant().toMap().value("Body").toMap();
|
||||
qCDebug(dcFronius()) << "System:" << qUtf8Printable(QJsonDocument::fromVariant(bodyMap).toJson(QJsonDocument::Indented));
|
||||
//qCDebug(dcFronius()) << "System:" << qUtf8Printable(QJsonDocument::fromVariant(bodyMap).toJson());
|
||||
|
||||
// Parse reply for inverters at the host address
|
||||
// Check if there are new inverters
|
||||
QVariantMap inverterMap = bodyMap.value("Data").toMap().value("Inverter").toMap();
|
||||
foreach (const QString &inverterId, inverterMap.keys()) {
|
||||
//check if thing already connected to logger
|
||||
if (!thingExists(inverterThingIdParamTypeId, inverterId)) {
|
||||
QString thingDescription = loggerThing->name();
|
||||
ThingDescriptor descriptor(inverterThingClassId, "Fronius Solar Inverter", thingDescription, loggerThing->id());
|
||||
QVariantMap inverterInfo = inverterMap.value(inverterId).toMap();
|
||||
const QString serialNumber = inverterInfo.value("Serial").toString();
|
||||
|
||||
// Note: we use the id to identify for backwards compatibility
|
||||
if (myThings().filterByParam(inverterThingIdParamTypeId, inverterId).isEmpty()) {
|
||||
QString thingDescription = connectionThing->name();
|
||||
ThingDescriptor descriptor(inverterThingClassId, "Fronius Solar Inverter", thingDescription, connectionThing->id());
|
||||
ParamList params;
|
||||
params.append(Param(inverterThingIdParamTypeId, inverterId));
|
||||
params.append(Param(inverterThingSerialNumberParamTypeId, serialNumber));
|
||||
descriptor.setParams(params);
|
||||
thingDescriptors.append(descriptor);
|
||||
}
|
||||
}
|
||||
|
||||
// parse reply for meter things at the host address
|
||||
// Check if there are new meters
|
||||
QVariantMap meterMap = bodyMap.value("Data").toMap().value("Meter").toMap();
|
||||
foreach (const QString &meterId, meterMap.keys()) {
|
||||
//check if thing already connected to logger
|
||||
if (!thingExists(meterThingIdParamTypeId, meterId)) {
|
||||
// get meter infos
|
||||
///solar_api/v1/GetMeterRealtimeData.cgi?Scope=Device&DeviceId=0
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(logger->hostAddress());
|
||||
requestUrl.setPath(logger->baseUrl() + "GetMeterRealtimeData.cgi");
|
||||
QUrlQuery query;
|
||||
query.addQueryItem("Scope", "Device");
|
||||
query.addQueryItem("DeviceId", meterId);
|
||||
requestUrl.setQuery(query);
|
||||
|
||||
qCDebug(dcFronius()) << "Get meter information before setup";
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(QNetworkRequest(requestUrl));
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, this, [=]() {
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString();
|
||||
// Note: we use the id to identify for backwards compatibility
|
||||
if (myThings().filterByParam(meterThingIdParamTypeId, meterId).isEmpty()) {
|
||||
// Get the meter realtime data for details
|
||||
FroniusNetworkReply *realtimeDataReply = connection->getMeterRealtimeData(meterId.toInt());
|
||||
connect(realtimeDataReply, &FroniusNetworkReply::finished, this, [=]() {
|
||||
if (realtimeDataReply->networkReply()->error() != QNetworkReply::NoError) {
|
||||
return;
|
||||
}
|
||||
|
||||
QByteArray data = reply->readAll();
|
||||
QByteArray data = realtimeDataReply->networkReply()->readAll();
|
||||
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
qCWarning(dcFronius()) << "Meter: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
|
||||
QString thingName;
|
||||
QString serialNumber;
|
||||
|
||||
if (dataMap.contains("Details")) {
|
||||
QVariantMap details = dataMap.value("Details").toMap();
|
||||
thingName = details.value("Manufacturer", "Fronius").toString() + " " + details.value("Model", "Smart Meter").toString();
|
||||
serialNumber = details.value("Serial").toString();
|
||||
} else {
|
||||
thingName = loggerThing->name() + " Meter " + meterId;
|
||||
thingName = connectionThing->name() + " Meter " + meterId;
|
||||
}
|
||||
|
||||
ThingDescriptor descriptor(meterThingClassId, thingName, QString(), loggerThing->id());
|
||||
ThingDescriptor descriptor(meterThingClassId, thingName, QString(), connectionThing->id());
|
||||
ParamList params;
|
||||
params.append(Param(meterThingIdParamTypeId, meterId));
|
||||
params.append(Param(meterThingSerialNumberParamTypeId, serialNumber));
|
||||
@ -475,38 +338,29 @@ void IntegrationPluginFronius::searchNewThings(FroniusLogger *logger)
|
||||
}
|
||||
}
|
||||
|
||||
// parse reply for storage things at the host address
|
||||
// Check if there are new energy storages
|
||||
QVariantMap storageMap = bodyMap.value("Data").toMap().value("Storage").toMap();
|
||||
foreach (const QString &storageId, storageMap.keys()) {
|
||||
//check if thing already connected to logger
|
||||
if (!thingExists(storageThingIdParamTypeId, storageId)) {
|
||||
QUrlQuery query;
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(logger->hostAddress());
|
||||
requestUrl.setPath(logger->baseUrl() + "GetStorageRealtimeData.cgi");
|
||||
query.addQueryItem("Scope","Device");
|
||||
query.addQueryItem("DeviceId", storageId);
|
||||
requestUrl.setQuery(query);
|
||||
// Note: we use the id to identify for backwards compatibility
|
||||
if (myThings().filterByParam(storageThingIdParamTypeId, storageId).isEmpty()) {
|
||||
|
||||
qCDebug(dcFronius()) << "Get storage information before setup" << requestUrl.toString();
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(QNetworkRequest(requestUrl));
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, this, [=]() {
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString();
|
||||
// Get the meter realtime data for details
|
||||
FroniusNetworkReply *realtimeDataReply = connection->getStorageRealtimeData(storageId.toInt());
|
||||
connect(realtimeDataReply, &FroniusNetworkReply::finished, this, [=]() {
|
||||
if (realtimeDataReply->networkReply()->error() != QNetworkReply::NoError) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Convert the rawdata to a json document
|
||||
QByteArray data = reply->readAll();
|
||||
QByteArray data = realtimeDataReply->networkReply()->readAll();
|
||||
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
qCWarning(dcFronius()) << "Storage: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap().value("Controller").toMap();
|
||||
|
||||
QString thingName;
|
||||
@ -516,20 +370,20 @@ void IntegrationPluginFronius::searchNewThings(FroniusLogger *logger)
|
||||
thingName = details.value("Manufacturer", "Fronius").toString() + " " + details.value("Model", "Energy Storage").toString();
|
||||
serialNumber = details.value("Serial").toString();
|
||||
} else {
|
||||
thingName = loggerThing->name() + " Storage " + storageId;
|
||||
thingName = connectionThing->name() + " Storage " + storageId;
|
||||
}
|
||||
|
||||
ThingDescriptor descriptor(storageThingClassId, thingName, QString(), loggerThing->id());
|
||||
ThingDescriptor descriptor(storageThingClassId, thingName, QString(), connectionThing->id());
|
||||
ParamList params;
|
||||
params.append(Param(storageThingIdParamTypeId, storageId));
|
||||
params.append(Param(storageThingSerialNumberParamTypeId, serialNumber));
|
||||
descriptor.setParams(params);
|
||||
emit autoThingsAppeared(ThingDescriptors() << descriptor);
|
||||
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
// Inform about unhandled devices
|
||||
QVariantMap ohmpilotMap = bodyMap.value("Data").toMap().value("Ohmpilot").toMap();
|
||||
foreach (QString ohmpilotId, ohmpilotMap.keys()) {
|
||||
qCDebug(dcFronius()) << "Unhandled device Ohmpilot" << ohmpilotId;
|
||||
@ -549,84 +403,273 @@ void IntegrationPluginFronius::searchNewThings(FroniusLogger *logger)
|
||||
emit autoThingsAppeared(thingDescriptors);
|
||||
thingDescriptors.clear();
|
||||
}
|
||||
|
||||
// All devices
|
||||
updatePowerFlow(connection);
|
||||
updateInverters(connection);
|
||||
updateMeters(connection);
|
||||
updateStorages(connection);
|
||||
});
|
||||
}
|
||||
|
||||
bool IntegrationPluginFronius::thingExists(const ParamTypeId &thingParamId, QString thingId)
|
||||
void IntegrationPluginFronius::updatePowerFlow(FroniusSolarConnection *connection)
|
||||
{
|
||||
foreach (Thing *thing, myThings()) {
|
||||
if (thing->paramValue(thingParamId).toString() == thingId) {
|
||||
return true;
|
||||
Thing *parentThing = m_froniusConnections.value(connection);
|
||||
|
||||
// Get power flow realtime data and update storage and pv power values according to the total values
|
||||
// The inverter details inform about the PV production after feeding the storage, but we should use the total
|
||||
// to make sure the sum is correct. Battery seems to be feeded DC to DC before the AC power convertion
|
||||
FroniusNetworkReply *powerFlowReply = connection->getPowerFlowRealtimeData();
|
||||
connect(powerFlowReply, &FroniusNetworkReply::finished, this, [=]() {
|
||||
if (powerFlowReply->networkReply()->error() != QNetworkReply::NoError) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
|
||||
QByteArray data = powerFlowReply->networkReply()->readAll();
|
||||
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "Meter: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
//qCDebug(dcFronius()) << "Power flow data" << qUtf8Printable(QJsonDocument::fromVariant(dataMap).toJson(QJsonDocument::Indented));
|
||||
|
||||
// Find the inverter for this connection and set the total power
|
||||
Things availableInverters = myThings().filterByParentId(parentThing->id()).filterByThingClassId(inverterThingClassId);
|
||||
if (availableInverters.count() == 1) {
|
||||
Thing *inverterThing = availableInverters.first();
|
||||
double pvPower = dataMap.value("Site").toMap().value("P_PV").toDouble();
|
||||
inverterThing->setStateValue(inverterCurrentPowerStateTypeId, - pvPower);
|
||||
}
|
||||
|
||||
// Find the storage for this connection and update the current power
|
||||
Things availableStorages = myThings().filterByParentId(parentThing->id()).filterByThingClassId(storageThingClassId);
|
||||
if (availableStorages.count() == 1) {
|
||||
Thing *storageThing = availableStorages.first();
|
||||
// Note: negative (charge), positiv (discharge)
|
||||
double akkuPower = - dataMap.value("Site").toMap().value("P_Akku").toDouble();
|
||||
storageThing->setStateValue(storageCurrentPowerStateTypeId, akkuPower);
|
||||
if (akkuPower < 0) {
|
||||
storageThing->setStateValue(storageChargingStateStateTypeId, "discharging");
|
||||
} else if (akkuPower > 0) {
|
||||
storageThing->setStateValue(storageChargingStateStateTypeId, "charging");
|
||||
} else {
|
||||
storageThing->setStateValue(storageChargingStateStateTypeId, "idle");
|
||||
}
|
||||
}
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
void IntegrationPluginFronius::setupChild(ThingSetupInfo *info, Thing *loggerThing)
|
||||
|
||||
void IntegrationPluginFronius::updateInverters(FroniusSolarConnection *connection)
|
||||
{
|
||||
Thing *thing = info->thing();
|
||||
if (thing->thingClassId() == inverterThingClassId) {
|
||||
FroniusInverter *newInverter = new FroniusInverter(thing,this);
|
||||
newInverter->setDeviceId(thing->paramValue(inverterThingIdParamTypeId).toString());
|
||||
newInverter->setBaseUrl(m_froniusLoggers.key(loggerThing)->baseUrl());
|
||||
newInverter->setHostAddress(m_froniusLoggers.key(loggerThing)->hostAddress());
|
||||
Thing *parentThing = m_froniusConnections.value(connection);
|
||||
foreach (Thing *inverterThing, myThings().filterByParentId(parentThing->id()).filterByThingClassId(inverterThingClassId)) {
|
||||
int inverterId = inverterThing->paramValue(inverterThingIdParamTypeId).toInt();
|
||||
|
||||
// Get inverter unique ID
|
||||
QUrl requestUrl;
|
||||
requestUrl.setScheme("http");
|
||||
requestUrl.setHost(newInverter->hostAddress());
|
||||
requestUrl.setPath(newInverter->baseUrl() + "GetInverterInfo.cgi");
|
||||
|
||||
QNetworkReply *reply = hardwareManager()->networkManager()->get(QNetworkRequest(requestUrl));
|
||||
connect(reply, &QNetworkReply::finished, reply, &QNetworkReply::deleteLater);
|
||||
connect(reply, &QNetworkReply::finished, info, [this, info, newInverter, reply]() {
|
||||
|
||||
QByteArray data = reply->readAll();
|
||||
|
||||
if (reply->error() != QNetworkReply::NoError) {
|
||||
qCWarning(dcFronius()) << "Network request error:" << reply->error() << reply->errorString();
|
||||
info->finish(Thing::ThingErrorHardwareNotAvailable, "Device not reachable");
|
||||
// Get the inverter realtime data
|
||||
FroniusNetworkReply *realtimeDataReply = connection->getInverterRealtimeData(inverterId);
|
||||
connect(realtimeDataReply, &FroniusNetworkReply::finished, this, [=]() {
|
||||
if (realtimeDataReply->networkReply()->error() != QNetworkReply::NoError) {
|
||||
// Thing does not seem to be reachable
|
||||
inverterThing->setStateValue("connected", false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Convert the rawdata to a json document
|
||||
QByteArray data = realtimeDataReply->networkReply()->readAll();
|
||||
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
info->finish(Thing::ThingErrorHardwareNotAvailable, "Please try again");
|
||||
qCWarning(dcFronius()) << "Inverter: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
inverterThing->setStateValue("connected", false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Check reply information
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
// check for thing id in reply
|
||||
if (dataMap.contains(newInverter->deviceId())) {
|
||||
qCDebug(dcFronius()) << "Found Thing with unique:" << dataMap.value(newInverter->deviceId()).toMap().value("UniqueID").toString();
|
||||
newInverter->setUniqueId(dataMap.value(newInverter->deviceId()).toMap().value("UniqueID").toString());
|
||||
qCDebug(dcFronius()) << "Stored unique ID:" << newInverter->uniqueId();
|
||||
//qCDebug(dcFronius()) << "Inverter data" << qUtf8Printable(QJsonDocument::fromVariant(dataMap).toJson(QJsonDocument::Indented));
|
||||
|
||||
// Note: this is the PV power after feeding the battery, we have to use the total PV production from the power flow
|
||||
//if (dataMap.contains("PAC")) {
|
||||
// QVariantMap map = dataMap.value("PAC").toMap();
|
||||
// if (map.value("Unit") == "W") {
|
||||
// inverterThing->setStateValue(inverterCurrentPowerStateTypeId, - map.value("Value").toDouble());
|
||||
// }
|
||||
//}
|
||||
|
||||
// Set the inverter device state
|
||||
if (dataMap.contains("DAY_ENERGY")) {
|
||||
QVariantMap map = dataMap.value("DAY_ENERGY").toMap();
|
||||
if (map.value("Unit") == "Wh") {
|
||||
inverterThing->setStateValue(inverterEnergyDayStateTypeId, map.value("Value").toDouble() / 1000);
|
||||
}
|
||||
}
|
||||
|
||||
m_froniusInverters.insert(newInverter, info->thing());
|
||||
info->finish(Thing::ThingErrorNoError);
|
||||
if (dataMap.contains("YEAR_ENERGY")) {
|
||||
QVariantMap map = dataMap.value("YEAR_ENERGY").toMap();
|
||||
if (map.value("Unit") == "Wh") {
|
||||
inverterThing->setStateValue(inverterEnergyYearStateTypeId, map.value("Value").toDouble() / 1000);
|
||||
}
|
||||
}
|
||||
|
||||
if (dataMap.contains("TOTAL_ENERGY")) {
|
||||
QVariantMap map = dataMap.value("TOTAL_ENERGY").toMap();
|
||||
if (map.value("Unit") == "Wh") {
|
||||
inverterThing->setStateValue(inverterTotalEnergyProducedStateTypeId, map.value("Value").toDouble() / 1000);
|
||||
}
|
||||
}
|
||||
|
||||
inverterThing->setStateValue("connected", true);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
void IntegrationPluginFronius::updateMeters(FroniusSolarConnection *connection)
|
||||
{
|
||||
Thing *parentThing = m_froniusConnections.value(connection);
|
||||
foreach (Thing *meterThing, myThings().filterByParentId(parentThing->id()).filterByThingClassId(meterThingClassId)) {
|
||||
int meterId = meterThing->paramValue(inverterThingIdParamTypeId).toInt();
|
||||
|
||||
// Get the inverter realtime data
|
||||
FroniusNetworkReply *realtimeDataReply = connection->getMeterRealtimeData(meterId);
|
||||
connect(realtimeDataReply, &FroniusNetworkReply::finished, this, [=]() {
|
||||
if (realtimeDataReply->networkReply()->error() != QNetworkReply::NoError) {
|
||||
// Thing does not seem to be reachable
|
||||
meterThing->setStateValue("connected", false);
|
||||
return;
|
||||
}
|
||||
|
||||
QByteArray data = realtimeDataReply->networkReply()->readAll();
|
||||
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "Meter: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
meterThing->setStateValue("connected", false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
//qCDebug(dcFronius()) << "Meter data" << qUtf8Printable(QJsonDocument::fromVariant(dataMap).toJson(QJsonDocument::Indented));
|
||||
|
||||
// Power
|
||||
if (dataMap.contains("PowerReal_P_Sum")) {
|
||||
meterThing->setStateValue(meterCurrentPowerStateTypeId, dataMap.value("PowerReal_P_Sum").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("PowerReal_P_Phase_1")) {
|
||||
meterThing->setStateValue(meterCurrentPowerPhaseAStateTypeId, dataMap.value("PowerReal_P_Phase_1").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("PowerReal_P_Phase_2")) {
|
||||
meterThing->setStateValue(meterCurrentPowerPhaseBStateTypeId, dataMap.value("PowerReal_P_Phase_2").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("PowerReal_P_Phase_3")) {
|
||||
meterThing->setStateValue(meterCurrentPowerPhaseCStateTypeId, dataMap.value("PowerReal_P_Phase_3").toDouble());
|
||||
}
|
||||
|
||||
// Current
|
||||
if (dataMap.contains("Current_AC_Phase_1")) {
|
||||
meterThing->setStateValue(meterCurrentPhaseAStateTypeId, dataMap.value("Current_AC_Phase_1").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("Current_AC_Phase_2")) {
|
||||
meterThing->setStateValue(meterCurrentPhaseBStateTypeId, dataMap.value("Current_AC_Phase_2").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("Current_AC_Phase_3")) {
|
||||
meterThing->setStateValue(meterCurrentPhaseCStateTypeId, dataMap.value("Current_AC_Phase_3").toDouble());
|
||||
}
|
||||
|
||||
// Voltage
|
||||
if (dataMap.contains("Voltage_AC_Phase_1")) {
|
||||
meterThing->setStateValue(meterVoltagePhaseAStateTypeId, dataMap.value("Voltage_AC_Phase_1").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("Voltage_AC_Phase_2")) {
|
||||
meterThing->setStateValue(meterVoltagePhaseBStateTypeId, dataMap.value("Voltage_AC_Phase_2").toDouble());
|
||||
}
|
||||
|
||||
if (dataMap.contains("Voltage_AC_Phase_3")) {
|
||||
meterThing->setStateValue(meterVoltagePhaseCStateTypeId, dataMap.value("Voltage_AC_Phase_3").toDouble());
|
||||
}
|
||||
|
||||
// Total energy
|
||||
if (dataMap.contains("EnergyReal_WAC_Sum_Produced")) {
|
||||
meterThing->setStateValue(meterTotalEnergyProducedStateTypeId, dataMap.value("EnergyReal_WAC_Sum_Produced").toInt()/1000.00);
|
||||
}
|
||||
|
||||
if (dataMap.contains("EnergyReal_WAC_Sum_Consumed")) {
|
||||
meterThing->setStateValue(meterTotalEnergyConsumedStateTypeId, dataMap.value("EnergyReal_WAC_Sum_Consumed").toInt()/1000.00);
|
||||
}
|
||||
|
||||
// Frequency
|
||||
if (dataMap.contains("Frequency_Phase_Average")) {
|
||||
meterThing->setStateValue(meterFrequencyStateTypeId, dataMap.value("Frequency_Phase_Average").toDouble());
|
||||
}
|
||||
|
||||
meterThing->setStateValue("connected", true);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
void IntegrationPluginFronius::updateStorages(FroniusSolarConnection *connection)
|
||||
{
|
||||
Thing *parentThing = m_froniusConnections.value(connection);
|
||||
foreach (Thing *storageThing, myThings().filterByParentId(parentThing->id()).filterByThingClassId(storageThingClassId)) {
|
||||
int storageId = storageThing->paramValue(storageThingIdParamTypeId).toInt();
|
||||
|
||||
// Get the storage realtime data
|
||||
FroniusNetworkReply *realtimeDataReply = connection->getStorageRealtimeData(storageId);
|
||||
connect(realtimeDataReply, &FroniusNetworkReply::finished, this, [=]() {
|
||||
if (realtimeDataReply->networkReply()->error() != QNetworkReply::NoError) {
|
||||
// Thing does not seem to be reachable
|
||||
storageThing->setStateValue("connected", false);
|
||||
return;
|
||||
}
|
||||
|
||||
QByteArray data = realtimeDataReply->networkReply()->readAll();
|
||||
|
||||
QJsonParseError error;
|
||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &error);
|
||||
if (error.error != QJsonParseError::NoError) {
|
||||
qCWarning(dcFronius()) << "Meter: Failed to parse JSON data" << data << ":" << error.errorString();
|
||||
storageThing->setStateValue("connected", false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the data and update the states of our device
|
||||
QVariantMap dataMap = jsonDoc.toVariant().toMap().value("Body").toMap().value("Data").toMap();
|
||||
//qCDebug(dcFronius()) << "Storage data" << qUtf8Printable(QJsonDocument::fromVariant(dataMap).toJson(QJsonDocument::Indented));
|
||||
|
||||
QVariantMap storageInfoMap = dataMap.value("Controller").toMap();
|
||||
|
||||
// copy retrieved information to thing states
|
||||
if (storageInfoMap.contains("StateOfCharge_Relative")) {
|
||||
storageThing->setStateValue(storageBatteryLevelStateTypeId, storageInfoMap.value("StateOfCharge_Relative").toInt());
|
||||
if (storageThing->stateValue(storageChargingStateStateTypeId).toString() == "charging" && (storageInfoMap.value("StateOfCharge_Relative").toInt() < 5)) {
|
||||
storageThing->setStateValue(storageBatteryCriticalStateTypeId, true);
|
||||
} else {
|
||||
storageThing->setStateValue(storageBatteryCriticalStateTypeId, false);
|
||||
}
|
||||
}
|
||||
|
||||
if (storageInfoMap.contains("Temperature_Cell"))
|
||||
storageThing->setStateValue(storageCellTemperatureStateTypeId, storageInfoMap.value("Temperature_Cell").toDouble());
|
||||
|
||||
if (storageInfoMap.contains("Capacity_Maximum"))
|
||||
storageThing->setStateValue(storageCapacityStateTypeId, storageInfoMap.value("Capacity_Maximum").toDouble());
|
||||
|
||||
|
||||
storageThing->setStateValue("connected", true);
|
||||
});
|
||||
|
||||
} else if (thing->thingClassId() == meterThingClassId) {
|
||||
FroniusMeter *newMeter = new FroniusMeter(thing, this);;
|
||||
newMeter->setDeviceId(thing->paramValue(meterThingIdParamTypeId).toString());
|
||||
newMeter->setBaseUrl(m_froniusLoggers.key(loggerThing)->baseUrl());
|
||||
newMeter->setHostAddress(m_froniusLoggers.key(loggerThing)->hostAddress());
|
||||
|
||||
m_froniusMeters.insert(newMeter, thing);
|
||||
info->finish(Thing::ThingErrorNoError);
|
||||
|
||||
} else if (thing->thingClassId() == storageThingClassId) {
|
||||
FroniusStorage *newStorage = new FroniusStorage(thing, this);
|
||||
newStorage->setDeviceId(thing->paramValue(storageThingIdParamTypeId).toString());
|
||||
newStorage->setBaseUrl(m_froniusLoggers.key(loggerThing)->baseUrl());
|
||||
newStorage->setHostAddress(m_froniusLoggers.key(loggerThing)->hostAddress());
|
||||
|
||||
m_froniusStorages.insert(newStorage, info->thing());
|
||||
info->finish(Thing::ThingErrorNoError);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Copyright 2013 - 2020, nymea GmbH
|
||||
* Copyright 2013 - 2022, nymea GmbH
|
||||
* Contact: contact@nymea.io
|
||||
*
|
||||
* This file is part of nymea.
|
||||
@ -32,7 +32,7 @@
|
||||
#define INTEGRATIONPLUGINFRONIUS_H
|
||||
|
||||
#include "integrations/integrationplugin.h"
|
||||
#include "froniuslogger.h"
|
||||
#include "froniussolarconnection.h"
|
||||
|
||||
#include <QHash>
|
||||
#include <QNetworkReply>
|
||||
@ -57,21 +57,17 @@ public:
|
||||
void thingRemoved(Thing* thing) override;
|
||||
|
||||
private:
|
||||
PluginTimer *m_pluginTimer = nullptr;
|
||||
PluginTimer *m_connectionRefreshTimer = nullptr;
|
||||
|
||||
QHash<FroniusLogger *, Thing *> m_froniusLoggers;
|
||||
QHash<FroniusInverter *, Thing *> m_froniusInverters;
|
||||
QHash<FroniusMeter *, Thing *> m_froniusMeters;
|
||||
QHash<FroniusStorage *, Thing *> m_froniusStorages;
|
||||
QHash<FroniusSolarConnection *, Thing *> m_froniusConnections;
|
||||
|
||||
QHash<QUuid, ThingActionInfo *> m_asyncActions;
|
||||
void refreshConnection(FroniusSolarConnection *connection);
|
||||
|
||||
void updateThingStates(Thing *thing);
|
||||
void updatePowerFlow(FroniusSolarConnection *connection);
|
||||
void updateInverters(FroniusSolarConnection *connection);
|
||||
void updateMeters(FroniusSolarConnection *connection);
|
||||
void updateStorages(FroniusSolarConnection *connection);
|
||||
|
||||
void searchNewThings(FroniusLogger *logger);
|
||||
bool thingExists(const ParamTypeId &thingParamId, QString thingId);
|
||||
|
||||
void setupChild(ThingSetupInfo *info, Thing *parentThing);
|
||||
};
|
||||
|
||||
#endif // INTEGRATIONPLUGINFRONIUS_H
|
||||
|
||||
@ -10,7 +10,7 @@
|
||||
"thingClasses": [
|
||||
{
|
||||
"id": "4fd79fed-42f1-4df9-be64-3df7b2e0bda2",
|
||||
"name": "datalogger",
|
||||
"name": "connection",
|
||||
"displayName": "Fronius Solar",
|
||||
"createMethods": ["discovery", "user"],
|
||||
"interfaces": ["gateway"],
|
||||
@ -18,7 +18,7 @@
|
||||
"paramTypes": [
|
||||
{
|
||||
"id": "52da0197-4b78-4fec-aa72-70f949e26edc",
|
||||
"name": "loggerHost",
|
||||
"name": "address",
|
||||
"displayName": "Host address",
|
||||
"type": "QString",
|
||||
"inputType": "IPv4Address",
|
||||
@ -26,9 +26,10 @@
|
||||
},
|
||||
{
|
||||
"id": "2237972e-385b-4458-b5d3-1d1fb4ae8756",
|
||||
"name": "loggerMac",
|
||||
"displayName": "MAC address",
|
||||
"name": "mac",
|
||||
"displayName": "Mac address",
|
||||
"type": "QString",
|
||||
"readOnly": true,
|
||||
"defaultValue": "00:00:00:00:00:00"
|
||||
}
|
||||
],
|
||||
@ -37,127 +38,25 @@
|
||||
"id": "98e4476f-e745-4a7f-b795-19269cb70c40",
|
||||
"name": "connected",
|
||||
"displayName": "Reachable",
|
||||
"displayNameEvent": "logger reachable changed",
|
||||
"displayNameEvent": "Reachable changed",
|
||||
"type": "bool",
|
||||
"defaultValue": false
|
||||
},
|
||||
{
|
||||
"id": "b22052ef-14da-43d2-982b-f2c2d8c03206",
|
||||
"name": "productid",
|
||||
"displayName": "Product ID",
|
||||
"displayNameEvent": "Product ID changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "65c068e6-4a0b-4672-9724-ae95216c4c9c",
|
||||
"name": "platformid",
|
||||
"displayName": "Platform ID",
|
||||
"displayNameEvent": "Platform ID changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "3b4206e5-74c7-4708-96b8-2abfab0c41d6",
|
||||
"name": "hwversion",
|
||||
"displayName": "Hardware version",
|
||||
"displayNameEvent": "Hardware version changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "31743ca5-4353-4f26-b2ad-5da43e5b9d86",
|
||||
"name": "swversion",
|
||||
"displayName": "Software version",
|
||||
"displayNameEvent": "Software version changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "d034f59d-dc34-450a-a6f3-68264767a3e4",
|
||||
"name": "tzoneloc",
|
||||
"displayName": "Timezone location",
|
||||
"displayNameEvent": "Timezone location changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "6bdfeeda-7a47-4043-a011-5eb96308a7d6",
|
||||
"name": "tzone",
|
||||
"displayName": "Time zone",
|
||||
"displayNameEvent": "Time zone changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "18b250e2-080a-4991-b368-177c4da83eca",
|
||||
"name": "defaultlang",
|
||||
"displayName": "Default language",
|
||||
"displayNameEvent": "Default language changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "bc18595b-17c7-4a1f-8002-b908a3d9239d",
|
||||
"name": "cashfactor",
|
||||
"displayName": "Cash factor",
|
||||
"displayNameEvent": "Cash factor changed",
|
||||
"type": "double",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "84da30c8-a7fb-49c6-884c-9521f9f62bbc",
|
||||
"name": "cashcurrency",
|
||||
"displayName": "Cash currency",
|
||||
"displayNameEvent": "Cash Currency changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "8ab01225-7be5-4482-a99b-314108ae0e2b",
|
||||
"name": "co2factor",
|
||||
"displayName": "CO2 factor",
|
||||
"displayNameEvent": "CO2 factor changed",
|
||||
"type": "double",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "b0e655f8-27d0-4add-918b-461cadc8efcc",
|
||||
"name": "co2unit",
|
||||
"displayName": "CO2 unit",
|
||||
"displayNameEvent": "CO2 unit changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "b217acf6-0c5e-4a3e-a50c-4c0133c871c2",
|
||||
"name": "powerManagmentRelay",
|
||||
"displayName": "Power management relay",
|
||||
"displayNameEvent": "Power management relay status changed",
|
||||
"type": "bool",
|
||||
"defaultValue": false
|
||||
},
|
||||
{
|
||||
"id": "5650ce9b-0d7d-4c52-b410-ea618889b4bb",
|
||||
"name": "powerManagmentRelayReason",
|
||||
"displayName": "Power management relay reason",
|
||||
"displayNameEvent": "Power management relay reason changed",
|
||||
"id": "8fd0c0ed-af89-4887-bf0f-040b13c25268",
|
||||
"name": "version",
|
||||
"displayName": "Version",
|
||||
"displayNameEvent": "Version changed",
|
||||
"type": "QString",
|
||||
"defaultValue": ""
|
||||
}
|
||||
],
|
||||
"actionTypes": [
|
||||
{
|
||||
"id": "c217fdc1-de18-41dc-b5d8-8072f84e7b6c",
|
||||
"name": "searchDevices",
|
||||
"displayName": "Search new devices"
|
||||
}
|
||||
]
|
||||
"actionTypes": [ ]
|
||||
},
|
||||
{
|
||||
"id": "540aa956-8b8f-4982-9f58-343a76cea846",
|
||||
"name": "inverter",
|
||||
"displayName": "Fronius Solar Inverter",
|
||||
"displayName": "Fronius solar inverter",
|
||||
"createMethods": ["auto"],
|
||||
"interfaces" : ["solarinverter", "connectable"],
|
||||
"paramTypes": [
|
||||
@ -166,8 +65,14 @@
|
||||
"name": "id",
|
||||
"displayName": "Device ID",
|
||||
"type": "QString",
|
||||
"inputType": "TextLine",
|
||||
"readOnly": true
|
||||
"readOnly": true
|
||||
},
|
||||
{
|
||||
"id": "5e073a9d-f2de-4ff4-95f1-065a0ef4d51b",
|
||||
"name": "serialNumber",
|
||||
"displayName": "Serial number",
|
||||
"type": "QString",
|
||||
"readOnly": true
|
||||
}
|
||||
],
|
||||
"stateTypes": [
|
||||
@ -180,14 +85,6 @@
|
||||
"defaultValue": false,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "e763baa7-5eaf-438c-83f0-4fa6c0f7eeb0",
|
||||
"name": "active",
|
||||
"displayName": "Inverter active",
|
||||
"displayNameEvent": "Inverter active changed",
|
||||
"type": "QString",
|
||||
"defaultValue": "-"
|
||||
},
|
||||
{
|
||||
"id": "788accbc-b86e-471b-b37f-14c9c6411526",
|
||||
"name": "currentPower",
|
||||
@ -195,25 +92,26 @@
|
||||
"displayNameEvent": "Current power changed",
|
||||
"type": "double",
|
||||
"unit": "Watt",
|
||||
"defaultValue": "0"
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "b6af1bf5-753d-47b6-a151-e4d801fe6ff8",
|
||||
"name": "eday",
|
||||
"displayName": "Energy of current day",
|
||||
"displayNameEvent": "Energy of day changed",
|
||||
"name": "energyDay",
|
||||
"displayName": "Energy produced today",
|
||||
"displayNameEvent": "Energy produced today changed",
|
||||
"type": "double",
|
||||
"unit": "KiloWattHour",
|
||||
"defaultValue": "0"
|
||||
"defaultValue": 0
|
||||
},
|
||||
{
|
||||
"id": "7fd2fa28-9bcc-4f01-a823-459437d185f6",
|
||||
"name": "eyear",
|
||||
"displayName": "Energy of current year",
|
||||
"displayNameEvent": "Energy of year changed",
|
||||
"name": "energyYear",
|
||||
"displayName": "Energy produced year",
|
||||
"displayNameEvent": "Energy produced changed",
|
||||
"type": "int",
|
||||
"unit": "KiloWattHour",
|
||||
"defaultValue": "0"
|
||||
"defaultValue": 0
|
||||
},
|
||||
{
|
||||
"id": "d6dbb879-4cbc-4db3-830e-b92ba91a13e5",
|
||||
@ -222,7 +120,7 @@
|
||||
"displayNameEvent": "Total produced energy changed",
|
||||
"type": "double",
|
||||
"unit": "KiloWattHour",
|
||||
"defaultValue": "0"
|
||||
"defaultValue": 0
|
||||
}
|
||||
]
|
||||
},
|
||||
@ -260,6 +158,16 @@
|
||||
"defaultValue": false,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "e5056ea1-88a2-410b-9c5e-6322aca4cb17",
|
||||
"name": "currentPower",
|
||||
"displayName": "Current power usage",
|
||||
"displayNameEvent": "Current power usage changed",
|
||||
"type": "double",
|
||||
"unit": "Watt",
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "267bc59f-1113-4aff-a502-4618a591aa16",
|
||||
"name": "voltagePhaseA",
|
||||
@ -267,7 +175,8 @@
|
||||
"displayNameEvent": "Voltage phase A changed",
|
||||
"type": "double",
|
||||
"unit": "Volt",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "bbcedb80-30f1-493e-81f0-5f77f2847353",
|
||||
@ -276,7 +185,8 @@
|
||||
"displayNameEvent": "Voltage phase B changed",
|
||||
"type": "double",
|
||||
"unit": "Volt",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "8037557b-40dc-411b-8937-bcd1695f898a",
|
||||
@ -285,7 +195,8 @@
|
||||
"displayNameEvent": "Voltage phase C changed",
|
||||
"type": "double",
|
||||
"unit": "Volt",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "a9673688-d84a-4848-8583-a70739130252",
|
||||
@ -294,7 +205,8 @@
|
||||
"displayNameEvent": "Current phase A changed",
|
||||
"type": "double",
|
||||
"unit": "Ampere",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "15632e49-95f9-496d-830c-53a31ca6d98e",
|
||||
@ -303,7 +215,8 @@
|
||||
"displayNameEvent": "Current phase B changed",
|
||||
"type": "double",
|
||||
"unit": "Ampere",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "10a24ba9-a57a-48a9-98f3-52671c09e855",
|
||||
@ -312,16 +225,8 @@
|
||||
"displayNameEvent": "Current phase C changed",
|
||||
"type": "double",
|
||||
"unit": "Ampere",
|
||||
"defaultValue": 0
|
||||
},
|
||||
{
|
||||
"id": "e5056ea1-88a2-410b-9c5e-6322aca4cb17",
|
||||
"name": "currentPower",
|
||||
"displayName": "Current power usage",
|
||||
"displayNameEvent": "Current power usage changed",
|
||||
"type": "double",
|
||||
"unit": "Watt",
|
||||
"defaultValue": "0"
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "ca14cca5-d9f0-49c5-a8f7-907d4c0825f0",
|
||||
@ -330,7 +235,7 @@
|
||||
"displayNameEvent": "Energy production changed",
|
||||
"type": "double",
|
||||
"unit": "KiloWattHour",
|
||||
"defaultValue": "0"
|
||||
"defaultValue": 0
|
||||
},
|
||||
{
|
||||
"id": "f3451818-48d2-42a5-94fd-ad094c06967f",
|
||||
@ -339,7 +244,7 @@
|
||||
"displayNameEvent": "Energy consumption changed",
|
||||
"type": "double",
|
||||
"unit": "KiloWattHour",
|
||||
"defaultValue": "0"
|
||||
"defaultValue": 0
|
||||
},
|
||||
{
|
||||
"id": "6dbbb062-447b-47d6-b2e4-dceac9aff795",
|
||||
@ -348,7 +253,8 @@
|
||||
"displayNameEvent": "Current power phase A changed",
|
||||
"type": "double",
|
||||
"unit": "Watt",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "f230e78e-15b0-47a4-b494-bae65be00755",
|
||||
@ -357,7 +263,8 @@
|
||||
"displayNameEvent": "Current power phase B changed",
|
||||
"type": "double",
|
||||
"unit": "Watt",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "56b5d550-d902-4c33-9288-8ee972735a75",
|
||||
@ -366,7 +273,8 @@
|
||||
"displayNameEvent": "Current power phase C changed",
|
||||
"type": "double",
|
||||
"unit": "Watt",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "9ff64b29-e023-4395-abd4-b6c366acfd9e",
|
||||
@ -375,7 +283,8 @@
|
||||
"displayNameEvent": "Frequency changed",
|
||||
"type": "double",
|
||||
"unit": "Hertz",
|
||||
"defaultValue": 0.00
|
||||
"defaultValue": 0.00,
|
||||
"cached": false
|
||||
}
|
||||
]
|
||||
},
|
||||
@ -429,7 +338,8 @@
|
||||
"displayNameEvent": "Current power changed",
|
||||
"type": "double",
|
||||
"unit": "Watt",
|
||||
"defaultValue": 0
|
||||
"defaultValue": 0,
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "3b163deb-67a2-41d1-8441-b2d53ad846ef",
|
||||
@ -458,7 +368,8 @@
|
||||
"displayNameEvent": "Cell temperature changed",
|
||||
"type": "double",
|
||||
"unit": "DegreeCelsius",
|
||||
"defaultValue": "0"
|
||||
"defaultValue": "0",
|
||||
"cached": false
|
||||
},
|
||||
{
|
||||
"id": "e5396312-b50e-4d6f-b628-5b51448971d3",
|
||||
|
||||
@ -9,17 +9,17 @@
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../integrationpluginfronius.cpp" line="136"/>
|
||||
<source>Device not reachable</source>
|
||||
<translation>Gerät nicht erreichbar</translation>
|
||||
<location filename="../integrationpluginfronius.cpp" line="122"/>
|
||||
<source>The device is not reachable</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../integrationpluginfronius.cpp" line="145"/>
|
||||
<source>Please try again</source>
|
||||
<translation>Bitte versuchen Sie es erneut</translation>
|
||||
<location filename="../integrationpluginfronius.cpp" line="131"/>
|
||||
<source>Unable to read the data. Please try again.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../integrationpluginfronius.cpp" line="154"/>
|
||||
<location filename="../integrationpluginfronius.cpp" line="141"/>
|
||||
<source>The firmware version 1.6-2 of this Fronius data logger has a broken API. Please update your Fronius device.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
@ -27,276 +27,96 @@
|
||||
<context>
|
||||
<name>fronius</name>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="165"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="168"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="67"/>
|
||||
<source>Battery level</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: batteryLevel, ID: {5c6da672-9662-41bc-8c8c-aa0f32481251})
|
||||
----------
|
||||
The name of the StateType ({5c6da672-9662-41bc-8c8c-aa0f32481251}) of ThingClass storage</extracomment>
|
||||
<extracomment>The name of the StateType ({5c6da672-9662-41bc-8c8c-aa0f32481251}) of ThingClass storage</extracomment>
|
||||
<translation>Batteriestand</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="171"/>
|
||||
<source>Battery level changed</source>
|
||||
<extracomment>The name of the EventType ({5c6da672-9662-41bc-8c8c-aa0f32481251}) of ThingClass storage</extracomment>
|
||||
<translation>Batteriestand geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="174"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="177"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="70"/>
|
||||
<source>Battery level critical</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: batteryCritical, ID: {e5396312-b50e-4d6f-b628-5b51448971d3})
|
||||
----------
|
||||
The name of the StateType ({e5396312-b50e-4d6f-b628-5b51448971d3}) of ThingClass storage</extracomment>
|
||||
<extracomment>The name of the StateType ({e5396312-b50e-4d6f-b628-5b51448971d3}) of ThingClass storage</extracomment>
|
||||
<translation>Batteriestand kritisch</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="180"/>
|
||||
<source>Battery level critical changed</source>
|
||||
<extracomment>The name of the EventType ({e5396312-b50e-4d6f-b628-5b51448971d3}) of ThingClass storage</extracomment>
|
||||
<translation>Batteriestand kritisch geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="183"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="186"/>
|
||||
<source>CO2 factor</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: co2factor, ID: {8ab01225-7be5-4482-a99b-314108ae0e2b})
|
||||
----------
|
||||
The name of the StateType ({8ab01225-7be5-4482-a99b-314108ae0e2b}) of ThingClass datalogger</extracomment>
|
||||
<translation>CO2 Faktor</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="189"/>
|
||||
<source>CO2 factor changed</source>
|
||||
<extracomment>The name of the EventType ({8ab01225-7be5-4482-a99b-314108ae0e2b}) of ThingClass datalogger</extracomment>
|
||||
<translation>CO2 Faktor geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="192"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="195"/>
|
||||
<source>CO2 unit</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: co2unit, ID: {b0e655f8-27d0-4add-918b-461cadc8efcc})
|
||||
----------
|
||||
The name of the StateType ({b0e655f8-27d0-4add-918b-461cadc8efcc}) of ThingClass datalogger</extracomment>
|
||||
<translation>CO2-Einheit</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="198"/>
|
||||
<source>CO2 unit changed</source>
|
||||
<extracomment>The name of the EventType ({b0e655f8-27d0-4add-918b-461cadc8efcc}) of ThingClass datalogger</extracomment>
|
||||
<translation>CO2-Einheit geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="201"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="204"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="73"/>
|
||||
<source>Capacity</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: capacity, ID: {3b163deb-67a2-41d1-8441-b2d53ad846ef})
|
||||
----------
|
||||
The name of the StateType ({3b163deb-67a2-41d1-8441-b2d53ad846ef}) of ThingClass storage</extracomment>
|
||||
<extracomment>The name of the StateType ({3b163deb-67a2-41d1-8441-b2d53ad846ef}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="207"/>
|
||||
<source>Capacity changed</source>
|
||||
<extracomment>The name of the EventType ({3b163deb-67a2-41d1-8441-b2d53ad846ef}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="210"/>
|
||||
<source>Cash Currency changed</source>
|
||||
<extracomment>The name of the EventType ({84da30c8-a7fb-49c6-884c-9521f9f62bbc}) of ThingClass datalogger</extracomment>
|
||||
<translation>Bargeldwährung geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="213"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="216"/>
|
||||
<source>Cash currency</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: cashcurrency, ID: {84da30c8-a7fb-49c6-884c-9521f9f62bbc})
|
||||
----------
|
||||
The name of the StateType ({84da30c8-a7fb-49c6-884c-9521f9f62bbc}) of ThingClass datalogger</extracomment>
|
||||
<translation>Bargeldwährung</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="219"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="222"/>
|
||||
<source>Cash factor</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: cashfactor, ID: {bc18595b-17c7-4a1f-8002-b908a3d9239d})
|
||||
----------
|
||||
The name of the StateType ({bc18595b-17c7-4a1f-8002-b908a3d9239d}) of ThingClass datalogger</extracomment>
|
||||
<translation>Cash-Faktor</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="225"/>
|
||||
<source>Cash factor changed</source>
|
||||
<extracomment>The name of the EventType ({bc18595b-17c7-4a1f-8002-b908a3d9239d}) of ThingClass datalogger</extracomment>
|
||||
<translation>Cash-Faktor geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="228"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="231"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="76"/>
|
||||
<source>Cell temperature</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: cellTemperature, ID: {4417499c-1757-4309-868a-be5cf3455c4a})
|
||||
----------
|
||||
The name of the StateType ({4417499c-1757-4309-868a-be5cf3455c4a}) of ThingClass storage</extracomment>
|
||||
<extracomment>The name of the StateType ({4417499c-1757-4309-868a-be5cf3455c4a}) of ThingClass storage</extracomment>
|
||||
<translation>Zellentemperatur</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="234"/>
|
||||
<source>Cell temperature changed</source>
|
||||
<extracomment>The name of the EventType ({4417499c-1757-4309-868a-be5cf3455c4a}) of ThingClass storage</extracomment>
|
||||
<translation>Zellentemperatur geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="246"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="249"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="82"/>
|
||||
<source>Current phase A</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPhaseA, ID: {a9673688-d84a-4848-8583-a70739130252})
|
||||
----------
|
||||
The name of the StateType ({a9673688-d84a-4848-8583-a70739130252}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({a9673688-d84a-4848-8583-a70739130252}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="252"/>
|
||||
<source>Current phase A changed</source>
|
||||
<extracomment>The name of the EventType ({a9673688-d84a-4848-8583-a70739130252}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="255"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="258"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="85"/>
|
||||
<source>Current phase B</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPhaseB, ID: {15632e49-95f9-496d-830c-53a31ca6d98e})
|
||||
----------
|
||||
The name of the StateType ({15632e49-95f9-496d-830c-53a31ca6d98e}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({15632e49-95f9-496d-830c-53a31ca6d98e}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="261"/>
|
||||
<source>Current phase B changed</source>
|
||||
<extracomment>The name of the EventType ({15632e49-95f9-496d-830c-53a31ca6d98e}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="264"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="267"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="88"/>
|
||||
<source>Current phase C</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPhaseC, ID: {10a24ba9-a57a-48a9-98f3-52671c09e855})
|
||||
----------
|
||||
The name of the StateType ({10a24ba9-a57a-48a9-98f3-52671c09e855}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({10a24ba9-a57a-48a9-98f3-52671c09e855}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="270"/>
|
||||
<source>Current phase C changed</source>
|
||||
<extracomment>The name of the EventType ({10a24ba9-a57a-48a9-98f3-52671c09e855}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="291"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="294"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="97"/>
|
||||
<source>Current power phase A</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPowerPhaseA, ID: {6dbbb062-447b-47d6-b2e4-dceac9aff795})
|
||||
----------
|
||||
The name of the StateType ({6dbbb062-447b-47d6-b2e4-dceac9aff795}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({6dbbb062-447b-47d6-b2e4-dceac9aff795}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="297"/>
|
||||
<source>Current power phase A changed</source>
|
||||
<extracomment>The name of the EventType ({6dbbb062-447b-47d6-b2e4-dceac9aff795}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="300"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="303"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="100"/>
|
||||
<source>Current power phase B</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPowerPhaseB, ID: {f230e78e-15b0-47a4-b494-bae65be00755})
|
||||
----------
|
||||
The name of the StateType ({f230e78e-15b0-47a4-b494-bae65be00755}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({f230e78e-15b0-47a4-b494-bae65be00755}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="306"/>
|
||||
<source>Current power phase B changed</source>
|
||||
<extracomment>The name of the EventType ({f230e78e-15b0-47a4-b494-bae65be00755}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="309"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="312"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="103"/>
|
||||
<source>Current power phase C</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPowerPhaseC, ID: {56b5d550-d902-4c33-9288-8ee972735a75})
|
||||
----------
|
||||
The name of the StateType ({56b5d550-d902-4c33-9288-8ee972735a75}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({56b5d550-d902-4c33-9288-8ee972735a75}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="315"/>
|
||||
<source>Current power phase C changed</source>
|
||||
<extracomment>The name of the EventType ({56b5d550-d902-4c33-9288-8ee972735a75}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="390"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="393"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="130"/>
|
||||
<source>Frequency</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: frequency, ID: {9ff64b29-e023-4395-abd4-b6c366acfd9e})
|
||||
----------
|
||||
The name of the StateType ({9ff64b29-e023-4395-abd4-b6c366acfd9e}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({9ff64b29-e023-4395-abd4-b6c366acfd9e}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="396"/>
|
||||
<source>Frequency changed</source>
|
||||
<extracomment>The name of the EventType ({9ff64b29-e023-4395-abd4-b6c366acfd9e}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="411"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="145"/>
|
||||
<source>Fronius smart meter</source>
|
||||
<extracomment>The name of the ThingClass ({c3cb53a4-32dd-434d-9d9c-aada41f8129c})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="414"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="148"/>
|
||||
<source>Fronius solar storage</source>
|
||||
<extracomment>The name of the ThingClass ({b00139fa-7386-48b1-8697-2fdd21a57ced})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="273"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="276"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="279"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="282"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="91"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="94"/>
|
||||
<source>Current power</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: currentPower, ID: {5a89cd3f-3abf-4f51-ab2b-4039f1d211d9})
|
||||
----------
|
||||
The name of the StateType ({5a89cd3f-3abf-4f51-ab2b-4039f1d211d9}) of ThingClass storage
|
||||
----------
|
||||
The name of the ParamType (ThingClass: inverter, EventType: currentPower, ID: {788accbc-b86e-471b-b37f-14c9c6411526})
|
||||
<extracomment>The name of the StateType ({5a89cd3f-3abf-4f51-ab2b-4039f1d211d9}) of ThingClass storage
|
||||
----------
|
||||
The name of the StateType ({788accbc-b86e-471b-b37f-14c9c6411526}) of ThingClass inverter</extracomment>
|
||||
<translation>Aktuelle Leistung</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="327"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="330"/>
|
||||
<source>Default language</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: defaultlang, ID: {18b250e2-080a-4991-b368-177c4da83eca})
|
||||
----------
|
||||
The name of the StateType ({18b250e2-080a-4991-b368-177c4da83eca}) of ThingClass datalogger</extracomment>
|
||||
<translation>Standardsprache</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="333"/>
|
||||
<source>Default language changed</source>
|
||||
<extracomment>The name of the EventType ({18b250e2-080a-4991-b368-177c4da83eca}) of ThingClass datalogger</extracomment>
|
||||
<translation>Standardsprache geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="336"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="339"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="342"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="109"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="112"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="115"/>
|
||||
<source>Device ID</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, Type: thing, ID: {49087f31-abf5-4bb8-946b-a3626ee80566})
|
||||
----------
|
||||
@ -306,128 +126,50 @@ The name of the ParamType (ThingClass: inverter, Type: thing, ID: {f2f8c2f5-dd6a
|
||||
<translation>Geräte ID</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="354"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="357"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="118"/>
|
||||
<source>Energy Consumed</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: totalEnergyConsumed, ID: {f3451818-48d2-42a5-94fd-ad094c06967f})
|
||||
----------
|
||||
The name of the StateType ({f3451818-48d2-42a5-94fd-ad094c06967f}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({f3451818-48d2-42a5-94fd-ad094c06967f}) of ThingClass meter</extracomment>
|
||||
<translation>Energie verbraucht</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="360"/>
|
||||
<source>Energy consumption changed</source>
|
||||
<extracomment>The name of the EventType ({f3451818-48d2-42a5-94fd-ad094c06967f}) of ThingClass meter</extracomment>
|
||||
<translation>Energieverbrauch geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="363"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="366"/>
|
||||
<source>Energy of current day</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: inverter, EventType: eday, ID: {b6af1bf5-753d-47b6-a151-e4d801fe6ff8})
|
||||
----------
|
||||
The name of the StateType ({b6af1bf5-753d-47b6-a151-e4d801fe6ff8}) of ThingClass inverter</extracomment>
|
||||
<translation>Energie dieses Tages</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="369"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="372"/>
|
||||
<source>Energy of current year</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: inverter, EventType: eyear, ID: {7fd2fa28-9bcc-4f01-a823-459437d185f6})
|
||||
----------
|
||||
The name of the StateType ({7fd2fa28-9bcc-4f01-a823-459437d185f6}) of ThingClass inverter</extracomment>
|
||||
<translation>Energie dieses Jahres</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="375"/>
|
||||
<source>Energy of day changed</source>
|
||||
<extracomment>The name of the EventType ({b6af1bf5-753d-47b6-a151-e4d801fe6ff8}) of ThingClass inverter</extracomment>
|
||||
<translation>Energie dieses Tages geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="378"/>
|
||||
<source>Energy of year changed</source>
|
||||
<extracomment>The name of the EventType ({7fd2fa28-9bcc-4f01-a823-459437d185f6}) of ThingClass inverter</extracomment>
|
||||
<translation>Energie dieses Jahres geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="381"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="384"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="121"/>
|
||||
<source>Energy produced</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: totalEnergyProduced, ID: {ca14cca5-d9f0-49c5-a8f7-907d4c0825f0})
|
||||
----------
|
||||
The name of the StateType ({ca14cca5-d9f0-49c5-a8f7-907d4c0825f0}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({ca14cca5-d9f0-49c5-a8f7-907d4c0825f0}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="387"/>
|
||||
<source>Energy production changed</source>
|
||||
<extracomment>The name of the EventType ({ca14cca5-d9f0-49c5-a8f7-907d4c0825f0}) of ThingClass meter</extracomment>
|
||||
<translation>Energieproduktion geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="237"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="240"/>
|
||||
<source>Charging</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: charging, ID: {2de34a1f-de2e-43ad-8998-8a5460dff9ae})
|
||||
----------
|
||||
The name of the StateType ({2de34a1f-de2e-43ad-8998-8a5460dff9ae}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="243"/>
|
||||
<source>Charging changed</source>
|
||||
<extracomment>The name of the EventType ({2de34a1f-de2e-43ad-8998-8a5460dff9ae}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="285"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="288"/>
|
||||
<source>Current power changed</source>
|
||||
<extracomment>The name of the EventType ({5a89cd3f-3abf-4f51-ab2b-4039f1d211d9}) of ThingClass storage
|
||||
----------
|
||||
The name of the EventType ({788accbc-b86e-471b-b37f-14c9c6411526}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="318"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="321"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="106"/>
|
||||
<source>Current power usage</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPower, ID: {e5056ea1-88a2-410b-9c5e-6322aca4cb17})
|
||||
----------
|
||||
The name of the StateType ({e5056ea1-88a2-410b-9c5e-6322aca4cb17}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({e5056ea1-88a2-410b-9c5e-6322aca4cb17}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="324"/>
|
||||
<source>Current power usage changed</source>
|
||||
<extracomment>The name of the EventType ({e5056ea1-88a2-410b-9c5e-6322aca4cb17}) of ThingClass meter</extracomment>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="79"/>
|
||||
<source>Charging state</source>
|
||||
<extracomment>The name of the StateType ({7a045257-d829-4e58-a769-047b3aeec7c5}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="345"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="348"/>
|
||||
<source>Discharging</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: discharging, ID: {be90d35c-081c-485b-b4cc-8271e7da5796})
|
||||
----------
|
||||
The name of the StateType ({be90d35c-081c-485b-b4cc-8271e7da5796}) of ThingClass storage</extracomment>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="124"/>
|
||||
<source>Energy produced today</source>
|
||||
<extracomment>The name of the StateType ({b6af1bf5-753d-47b6-a151-e4d801fe6ff8}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="351"/>
|
||||
<source>Discharging changed</source>
|
||||
<extracomment>The name of the EventType ({be90d35c-081c-485b-b4cc-8271e7da5796}) of ThingClass storage</extracomment>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="127"/>
|
||||
<source>Energy produced year</source>
|
||||
<extracomment>The name of the StateType ({7fd2fa28-9bcc-4f01-a823-459437d185f6}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="399"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="133"/>
|
||||
<source>Fronius</source>
|
||||
<extracomment>The name of the vendor ({2286fc38-afd9-4128-ab7e-0fba527d53ba})</extracomment>
|
||||
<translation>Fronius</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="402"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="405"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="136"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="139"/>
|
||||
<source>Fronius Solar</source>
|
||||
<extracomment>The name of the ThingClass ({4fd79fed-42f1-4df9-be64-3df7b2e0bda2})
|
||||
----------
|
||||
@ -435,277 +177,79 @@ The name of the plugin fronius ({02319cfc-8b55-49ba-99bc-0588bbfab063})</extraco
|
||||
<translation>Fronius Solar</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="408"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="142"/>
|
||||
<source>Fronius Solar Inverter</source>
|
||||
<extracomment>The name of the ThingClass ({540aa956-8b8f-4982-9f58-343a76cea846})</extracomment>
|
||||
<translation>Fronius Solar Inverter</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="417"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="420"/>
|
||||
<source>Hardware version</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: hwversion, ID: {3b4206e5-74c7-4708-96b8-2abfab0c41d6})
|
||||
----------
|
||||
The name of the StateType ({3b4206e5-74c7-4708-96b8-2abfab0c41d6}) of ThingClass datalogger</extracomment>
|
||||
<translation>Hardwareversion</translation>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="154"/>
|
||||
<source>Mac address</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: connection, Type: thing, ID: {2237972e-385b-4458-b5d3-1d1fb4ae8756})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="423"/>
|
||||
<source>Hardware version changed</source>
|
||||
<extracomment>The name of the EventType ({3b4206e5-74c7-4708-96b8-2abfab0c41d6}) of ThingClass datalogger</extracomment>
|
||||
<translation>Hardwareversion geändert</translation>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="181"/>
|
||||
<source>Version</source>
|
||||
<extracomment>The name of the StateType ({8fd0c0ed-af89-4887-bf0f-040b13c25268}) of ThingClass connection</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="426"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="151"/>
|
||||
<source>Host address</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, Type: thing, ID: {52da0197-4b78-4fec-aa72-70f949e26edc})</extracomment>
|
||||
<extracomment>The name of the ParamType (ThingClass: connection, Type: thing, ID: {52da0197-4b78-4fec-aa72-70f949e26edc})</extracomment>
|
||||
<translation>Adresse</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="429"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="432"/>
|
||||
<source>Inverter active</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: inverter, EventType: active, ID: {e763baa7-5eaf-438c-83f0-4fa6c0f7eeb0})
|
||||
----------
|
||||
The name of the StateType ({e763baa7-5eaf-438c-83f0-4fa6c0f7eeb0}) of ThingClass inverter</extracomment>
|
||||
<translation>Inverter aktiv</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="435"/>
|
||||
<source>Inverter active changed</source>
|
||||
<extracomment>The name of the EventType ({e763baa7-5eaf-438c-83f0-4fa6c0f7eeb0}) of ThingClass inverter</extracomment>
|
||||
<translation>Inverter aktiv geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="438"/>
|
||||
<source>MAC address</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, Type: thing, ID: {2237972e-385b-4458-b5d3-1d1fb4ae8756})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="441"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="444"/>
|
||||
<source>Platform ID</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: platformid, ID: {65c068e6-4a0b-4672-9724-ae95216c4c9c})
|
||||
----------
|
||||
The name of the StateType ({65c068e6-4a0b-4672-9724-ae95216c4c9c}) of ThingClass datalogger</extracomment>
|
||||
<translation>Plattform ID</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="447"/>
|
||||
<source>Platform ID changed</source>
|
||||
<extracomment>The name of the EventType ({65c068e6-4a0b-4672-9724-ae95216c4c9c}) of ThingClass datalogger</extracomment>
|
||||
<translation>Plattform-ID geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="450"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="453"/>
|
||||
<source>Power management relay</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: powerManagmentRelay, ID: {b217acf6-0c5e-4a3e-a50c-4c0133c871c2})
|
||||
----------
|
||||
The name of the StateType ({b217acf6-0c5e-4a3e-a50c-4c0133c871c2}) of ThingClass datalogger</extracomment>
|
||||
<translation>Leistungsmanagement Relais</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="456"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="459"/>
|
||||
<source>Power management relay reason</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: powerManagmentRelayReason, ID: {5650ce9b-0d7d-4c52-b410-ea618889b4bb})
|
||||
----------
|
||||
The name of the StateType ({5650ce9b-0d7d-4c52-b410-ea618889b4bb}) of ThingClass datalogger</extracomment>
|
||||
<translation>Leistungsmanagement Relais Grund</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="462"/>
|
||||
<source>Power management relay reason changed</source>
|
||||
<extracomment>The name of the EventType ({5650ce9b-0d7d-4c52-b410-ea618889b4bb}) of ThingClass datalogger</extracomment>
|
||||
<translation>Leistungsmanagement Relais Grund geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="465"/>
|
||||
<source>Power management relay status changed</source>
|
||||
<extracomment>The name of the EventType ({b217acf6-0c5e-4a3e-a50c-4c0133c871c2}) of ThingClass datalogger</extracomment>
|
||||
<translation>Leistungsmanagement Relais Status geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="468"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="471"/>
|
||||
<source>Product ID</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: productid, ID: {b22052ef-14da-43d2-982b-f2c2d8c03206})
|
||||
----------
|
||||
The name of the StateType ({b22052ef-14da-43d2-982b-f2c2d8c03206}) of ThingClass datalogger</extracomment>
|
||||
<translation>Produkt-ID</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="474"/>
|
||||
<source>Product ID changed</source>
|
||||
<extracomment>The name of the EventType ({b22052ef-14da-43d2-982b-f2c2d8c03206}) of ThingClass datalogger</extracomment>
|
||||
<translation>Produkt-ID geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="477"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="480"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="483"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="486"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="489"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="492"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="495"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="498"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="157"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="160"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="163"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="166"/>
|
||||
<source>Reachable</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: connected, ID: {2f7e1267-b0be-4b78-9aa3-832b86c4efad})
|
||||
----------
|
||||
The name of the StateType ({2f7e1267-b0be-4b78-9aa3-832b86c4efad}) of ThingClass storage
|
||||
----------
|
||||
The name of the ParamType (ThingClass: meter, EventType: connected, ID: {b70b61a4-54cb-47ec-b62a-b498eb1f650e})
|
||||
<extracomment>The name of the StateType ({2f7e1267-b0be-4b78-9aa3-832b86c4efad}) of ThingClass storage
|
||||
----------
|
||||
The name of the StateType ({b70b61a4-54cb-47ec-b62a-b498eb1f650e}) of ThingClass meter
|
||||
----------
|
||||
The name of the ParamType (ThingClass: inverter, EventType: connected, ID: {eda29c50-73ac-40e0-9c92-26fee352e688})
|
||||
----------
|
||||
The name of the StateType ({eda29c50-73ac-40e0-9c92-26fee352e688}) of ThingClass inverter
|
||||
----------
|
||||
The name of the ParamType (ThingClass: datalogger, EventType: connected, ID: {98e4476f-e745-4a7f-b795-19269cb70c40})
|
||||
----------
|
||||
The name of the StateType ({98e4476f-e745-4a7f-b795-19269cb70c40}) of ThingClass datalogger</extracomment>
|
||||
The name of the StateType ({98e4476f-e745-4a7f-b795-19269cb70c40}) of ThingClass connection</extracomment>
|
||||
<translation>Erreichbar</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="501"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="504"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="507"/>
|
||||
<source>Reachable changed</source>
|
||||
<extracomment>The name of the EventType ({2f7e1267-b0be-4b78-9aa3-832b86c4efad}) of ThingClass storage
|
||||
----------
|
||||
The name of the EventType ({b70b61a4-54cb-47ec-b62a-b498eb1f650e}) of ThingClass meter
|
||||
----------
|
||||
The name of the EventType ({eda29c50-73ac-40e0-9c92-26fee352e688}) of ThingClass inverter</extracomment>
|
||||
<translation>Erreichbar geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="510"/>
|
||||
<source>Search new devices</source>
|
||||
<extracomment>The name of the ActionType ({c217fdc1-de18-41dc-b5d8-8072f84e7b6c}) of ThingClass datalogger</extracomment>
|
||||
<translation>Suche neue Geräte</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="513"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="516"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="169"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="172"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="175"/>
|
||||
<source>Serial number</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, Type: thing, ID: {8b6c7053-5ba5-4808-8ff4-9024c624d77d})
|
||||
----------
|
||||
The name of the ParamType (ThingClass: meter, Type: thing, ID: {dfc2eeef-38b2-4089-9953-48186aaee060})</extracomment>
|
||||
The name of the ParamType (ThingClass: meter, Type: thing, ID: {dfc2eeef-38b2-4089-9953-48186aaee060})
|
||||
----------
|
||||
The name of the ParamType (ThingClass: inverter, Type: thing, ID: {5e073a9d-f2de-4ff4-95f1-065a0ef4d51b})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="519"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="522"/>
|
||||
<source>Software version</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: swversion, ID: {31743ca5-4353-4f26-b2ad-5da43e5b9d86})
|
||||
----------
|
||||
The name of the StateType ({31743ca5-4353-4f26-b2ad-5da43e5b9d86}) of ThingClass datalogger</extracomment>
|
||||
<translation>Softwareversion</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="525"/>
|
||||
<source>Software version changed</source>
|
||||
<extracomment>The name of the EventType ({31743ca5-4353-4f26-b2ad-5da43e5b9d86}) of ThingClass datalogger</extracomment>
|
||||
<translation>Softwareversion geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="546"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="549"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="178"/>
|
||||
<source>Total produced energy</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: inverter, EventType: totalEnergyProduced, ID: {d6dbb879-4cbc-4db3-830e-b92ba91a13e5})
|
||||
----------
|
||||
The name of the StateType ({d6dbb879-4cbc-4db3-830e-b92ba91a13e5}) of ThingClass inverter</extracomment>
|
||||
<extracomment>The name of the StateType ({d6dbb879-4cbc-4db3-830e-b92ba91a13e5}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="552"/>
|
||||
<source>Total produced energy changed</source>
|
||||
<extracomment>The name of the EventType ({d6dbb879-4cbc-4db3-830e-b92ba91a13e5}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="528"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="531"/>
|
||||
<source>Time zone</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: tzone, ID: {6bdfeeda-7a47-4043-a011-5eb96308a7d6})
|
||||
----------
|
||||
The name of the StateType ({6bdfeeda-7a47-4043-a011-5eb96308a7d6}) of ThingClass datalogger</extracomment>
|
||||
<translation>Zeitzone</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="534"/>
|
||||
<source>Time zone changed</source>
|
||||
<extracomment>The name of the EventType ({6bdfeeda-7a47-4043-a011-5eb96308a7d6}) of ThingClass datalogger</extracomment>
|
||||
<translation>Zeitzone geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="537"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="540"/>
|
||||
<source>Timezone location</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: tzoneloc, ID: {d034f59d-dc34-450a-a6f3-68264767a3e4})
|
||||
----------
|
||||
The name of the StateType ({d034f59d-dc34-450a-a6f3-68264767a3e4}) of ThingClass datalogger</extracomment>
|
||||
<translation>Zeitzone Ort</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="543"/>
|
||||
<source>Timezone location changed</source>
|
||||
<extracomment>The name of the EventType ({d034f59d-dc34-450a-a6f3-68264767a3e4}) of ThingClass datalogger</extracomment>
|
||||
<translation>Zeitzone Ort geändert</translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="555"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="558"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="184"/>
|
||||
<source>Voltage phase A</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: voltagePhaseA, ID: {267bc59f-1113-4aff-a502-4618a591aa16})
|
||||
----------
|
||||
The name of the StateType ({267bc59f-1113-4aff-a502-4618a591aa16}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({267bc59f-1113-4aff-a502-4618a591aa16}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="561"/>
|
||||
<source>Voltage phase A changed</source>
|
||||
<extracomment>The name of the EventType ({267bc59f-1113-4aff-a502-4618a591aa16}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="564"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="567"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="187"/>
|
||||
<source>Voltage phase B</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: voltagePhaseB, ID: {bbcedb80-30f1-493e-81f0-5f77f2847353})
|
||||
----------
|
||||
The name of the StateType ({bbcedb80-30f1-493e-81f0-5f77f2847353}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({bbcedb80-30f1-493e-81f0-5f77f2847353}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="570"/>
|
||||
<source>Voltage phase B changed</source>
|
||||
<extracomment>The name of the EventType ({bbcedb80-30f1-493e-81f0-5f77f2847353}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="573"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="576"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="190"/>
|
||||
<source>Voltage phase C</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: voltagePhaseC, ID: {8037557b-40dc-411b-8937-bcd1695f898a})
|
||||
----------
|
||||
The name of the StateType ({8037557b-40dc-411b-8937-bcd1695f898a}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({8037557b-40dc-411b-8937-bcd1695f898a}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="579"/>
|
||||
<source>Voltage phase C changed</source>
|
||||
<extracomment>The name of the EventType ({8037557b-40dc-411b-8937-bcd1695f898a}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="582"/>
|
||||
<source>logger reachable changed</source>
|
||||
<extracomment>The name of the EventType ({98e4476f-e745-4a7f-b795-19269cb70c40}) of ThingClass datalogger</extracomment>
|
||||
<translation>Logger erriechbar geändert</translation>
|
||||
</message>
|
||||
</context>
|
||||
</TS>
|
||||
|
||||
@ -9,17 +9,17 @@
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../integrationpluginfronius.cpp" line="136"/>
|
||||
<source>Device not reachable</source>
|
||||
<location filename="../integrationpluginfronius.cpp" line="122"/>
|
||||
<source>The device is not reachable</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../integrationpluginfronius.cpp" line="145"/>
|
||||
<source>Please try again</source>
|
||||
<location filename="../integrationpluginfronius.cpp" line="131"/>
|
||||
<source>Unable to read the data. Please try again.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../integrationpluginfronius.cpp" line="154"/>
|
||||
<location filename="../integrationpluginfronius.cpp" line="141"/>
|
||||
<source>The firmware version 1.6-2 of this Fronius data logger has a broken API. Please update your Fronius device.</source>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
@ -27,276 +27,96 @@
|
||||
<context>
|
||||
<name>fronius</name>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="165"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="168"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="67"/>
|
||||
<source>Battery level</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: batteryLevel, ID: {5c6da672-9662-41bc-8c8c-aa0f32481251})
|
||||
----------
|
||||
The name of the StateType ({5c6da672-9662-41bc-8c8c-aa0f32481251}) of ThingClass storage</extracomment>
|
||||
<extracomment>The name of the StateType ({5c6da672-9662-41bc-8c8c-aa0f32481251}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="171"/>
|
||||
<source>Battery level changed</source>
|
||||
<extracomment>The name of the EventType ({5c6da672-9662-41bc-8c8c-aa0f32481251}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="174"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="177"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="70"/>
|
||||
<source>Battery level critical</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: batteryCritical, ID: {e5396312-b50e-4d6f-b628-5b51448971d3})
|
||||
----------
|
||||
The name of the StateType ({e5396312-b50e-4d6f-b628-5b51448971d3}) of ThingClass storage</extracomment>
|
||||
<extracomment>The name of the StateType ({e5396312-b50e-4d6f-b628-5b51448971d3}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="180"/>
|
||||
<source>Battery level critical changed</source>
|
||||
<extracomment>The name of the EventType ({e5396312-b50e-4d6f-b628-5b51448971d3}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="183"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="186"/>
|
||||
<source>CO2 factor</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: co2factor, ID: {8ab01225-7be5-4482-a99b-314108ae0e2b})
|
||||
----------
|
||||
The name of the StateType ({8ab01225-7be5-4482-a99b-314108ae0e2b}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="189"/>
|
||||
<source>CO2 factor changed</source>
|
||||
<extracomment>The name of the EventType ({8ab01225-7be5-4482-a99b-314108ae0e2b}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="192"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="195"/>
|
||||
<source>CO2 unit</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: co2unit, ID: {b0e655f8-27d0-4add-918b-461cadc8efcc})
|
||||
----------
|
||||
The name of the StateType ({b0e655f8-27d0-4add-918b-461cadc8efcc}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="198"/>
|
||||
<source>CO2 unit changed</source>
|
||||
<extracomment>The name of the EventType ({b0e655f8-27d0-4add-918b-461cadc8efcc}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="201"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="204"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="73"/>
|
||||
<source>Capacity</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: capacity, ID: {3b163deb-67a2-41d1-8441-b2d53ad846ef})
|
||||
----------
|
||||
The name of the StateType ({3b163deb-67a2-41d1-8441-b2d53ad846ef}) of ThingClass storage</extracomment>
|
||||
<extracomment>The name of the StateType ({3b163deb-67a2-41d1-8441-b2d53ad846ef}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="207"/>
|
||||
<source>Capacity changed</source>
|
||||
<extracomment>The name of the EventType ({3b163deb-67a2-41d1-8441-b2d53ad846ef}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="210"/>
|
||||
<source>Cash Currency changed</source>
|
||||
<extracomment>The name of the EventType ({84da30c8-a7fb-49c6-884c-9521f9f62bbc}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="213"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="216"/>
|
||||
<source>Cash currency</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: cashcurrency, ID: {84da30c8-a7fb-49c6-884c-9521f9f62bbc})
|
||||
----------
|
||||
The name of the StateType ({84da30c8-a7fb-49c6-884c-9521f9f62bbc}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="219"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="222"/>
|
||||
<source>Cash factor</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: cashfactor, ID: {bc18595b-17c7-4a1f-8002-b908a3d9239d})
|
||||
----------
|
||||
The name of the StateType ({bc18595b-17c7-4a1f-8002-b908a3d9239d}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="225"/>
|
||||
<source>Cash factor changed</source>
|
||||
<extracomment>The name of the EventType ({bc18595b-17c7-4a1f-8002-b908a3d9239d}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="228"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="231"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="76"/>
|
||||
<source>Cell temperature</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: cellTemperature, ID: {4417499c-1757-4309-868a-be5cf3455c4a})
|
||||
----------
|
||||
The name of the StateType ({4417499c-1757-4309-868a-be5cf3455c4a}) of ThingClass storage</extracomment>
|
||||
<extracomment>The name of the StateType ({4417499c-1757-4309-868a-be5cf3455c4a}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="234"/>
|
||||
<source>Cell temperature changed</source>
|
||||
<extracomment>The name of the EventType ({4417499c-1757-4309-868a-be5cf3455c4a}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="246"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="249"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="82"/>
|
||||
<source>Current phase A</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPhaseA, ID: {a9673688-d84a-4848-8583-a70739130252})
|
||||
----------
|
||||
The name of the StateType ({a9673688-d84a-4848-8583-a70739130252}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({a9673688-d84a-4848-8583-a70739130252}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="252"/>
|
||||
<source>Current phase A changed</source>
|
||||
<extracomment>The name of the EventType ({a9673688-d84a-4848-8583-a70739130252}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="255"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="258"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="85"/>
|
||||
<source>Current phase B</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPhaseB, ID: {15632e49-95f9-496d-830c-53a31ca6d98e})
|
||||
----------
|
||||
The name of the StateType ({15632e49-95f9-496d-830c-53a31ca6d98e}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({15632e49-95f9-496d-830c-53a31ca6d98e}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="261"/>
|
||||
<source>Current phase B changed</source>
|
||||
<extracomment>The name of the EventType ({15632e49-95f9-496d-830c-53a31ca6d98e}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="264"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="267"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="88"/>
|
||||
<source>Current phase C</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPhaseC, ID: {10a24ba9-a57a-48a9-98f3-52671c09e855})
|
||||
----------
|
||||
The name of the StateType ({10a24ba9-a57a-48a9-98f3-52671c09e855}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({10a24ba9-a57a-48a9-98f3-52671c09e855}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="270"/>
|
||||
<source>Current phase C changed</source>
|
||||
<extracomment>The name of the EventType ({10a24ba9-a57a-48a9-98f3-52671c09e855}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="291"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="294"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="97"/>
|
||||
<source>Current power phase A</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPowerPhaseA, ID: {6dbbb062-447b-47d6-b2e4-dceac9aff795})
|
||||
----------
|
||||
The name of the StateType ({6dbbb062-447b-47d6-b2e4-dceac9aff795}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({6dbbb062-447b-47d6-b2e4-dceac9aff795}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="297"/>
|
||||
<source>Current power phase A changed</source>
|
||||
<extracomment>The name of the EventType ({6dbbb062-447b-47d6-b2e4-dceac9aff795}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="300"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="303"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="100"/>
|
||||
<source>Current power phase B</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPowerPhaseB, ID: {f230e78e-15b0-47a4-b494-bae65be00755})
|
||||
----------
|
||||
The name of the StateType ({f230e78e-15b0-47a4-b494-bae65be00755}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({f230e78e-15b0-47a4-b494-bae65be00755}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="306"/>
|
||||
<source>Current power phase B changed</source>
|
||||
<extracomment>The name of the EventType ({f230e78e-15b0-47a4-b494-bae65be00755}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="309"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="312"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="103"/>
|
||||
<source>Current power phase C</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPowerPhaseC, ID: {56b5d550-d902-4c33-9288-8ee972735a75})
|
||||
----------
|
||||
The name of the StateType ({56b5d550-d902-4c33-9288-8ee972735a75}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({56b5d550-d902-4c33-9288-8ee972735a75}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="315"/>
|
||||
<source>Current power phase C changed</source>
|
||||
<extracomment>The name of the EventType ({56b5d550-d902-4c33-9288-8ee972735a75}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="390"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="393"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="130"/>
|
||||
<source>Frequency</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: frequency, ID: {9ff64b29-e023-4395-abd4-b6c366acfd9e})
|
||||
----------
|
||||
The name of the StateType ({9ff64b29-e023-4395-abd4-b6c366acfd9e}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({9ff64b29-e023-4395-abd4-b6c366acfd9e}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="396"/>
|
||||
<source>Frequency changed</source>
|
||||
<extracomment>The name of the EventType ({9ff64b29-e023-4395-abd4-b6c366acfd9e}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="411"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="145"/>
|
||||
<source>Fronius smart meter</source>
|
||||
<extracomment>The name of the ThingClass ({c3cb53a4-32dd-434d-9d9c-aada41f8129c})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="414"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="148"/>
|
||||
<source>Fronius solar storage</source>
|
||||
<extracomment>The name of the ThingClass ({b00139fa-7386-48b1-8697-2fdd21a57ced})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="273"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="276"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="279"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="282"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="91"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="94"/>
|
||||
<source>Current power</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: currentPower, ID: {5a89cd3f-3abf-4f51-ab2b-4039f1d211d9})
|
||||
----------
|
||||
The name of the StateType ({5a89cd3f-3abf-4f51-ab2b-4039f1d211d9}) of ThingClass storage
|
||||
----------
|
||||
The name of the ParamType (ThingClass: inverter, EventType: currentPower, ID: {788accbc-b86e-471b-b37f-14c9c6411526})
|
||||
<extracomment>The name of the StateType ({5a89cd3f-3abf-4f51-ab2b-4039f1d211d9}) of ThingClass storage
|
||||
----------
|
||||
The name of the StateType ({788accbc-b86e-471b-b37f-14c9c6411526}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="327"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="330"/>
|
||||
<source>Default language</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: defaultlang, ID: {18b250e2-080a-4991-b368-177c4da83eca})
|
||||
----------
|
||||
The name of the StateType ({18b250e2-080a-4991-b368-177c4da83eca}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="333"/>
|
||||
<source>Default language changed</source>
|
||||
<extracomment>The name of the EventType ({18b250e2-080a-4991-b368-177c4da83eca}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="336"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="339"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="342"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="109"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="112"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="115"/>
|
||||
<source>Device ID</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, Type: thing, ID: {49087f31-abf5-4bb8-946b-a3626ee80566})
|
||||
----------
|
||||
@ -306,128 +126,50 @@ The name of the ParamType (ThingClass: inverter, Type: thing, ID: {f2f8c2f5-dd6a
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="354"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="357"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="118"/>
|
||||
<source>Energy Consumed</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: totalEnergyConsumed, ID: {f3451818-48d2-42a5-94fd-ad094c06967f})
|
||||
----------
|
||||
The name of the StateType ({f3451818-48d2-42a5-94fd-ad094c06967f}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({f3451818-48d2-42a5-94fd-ad094c06967f}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="360"/>
|
||||
<source>Energy consumption changed</source>
|
||||
<extracomment>The name of the EventType ({f3451818-48d2-42a5-94fd-ad094c06967f}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="363"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="366"/>
|
||||
<source>Energy of current day</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: inverter, EventType: eday, ID: {b6af1bf5-753d-47b6-a151-e4d801fe6ff8})
|
||||
----------
|
||||
The name of the StateType ({b6af1bf5-753d-47b6-a151-e4d801fe6ff8}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="369"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="372"/>
|
||||
<source>Energy of current year</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: inverter, EventType: eyear, ID: {7fd2fa28-9bcc-4f01-a823-459437d185f6})
|
||||
----------
|
||||
The name of the StateType ({7fd2fa28-9bcc-4f01-a823-459437d185f6}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="375"/>
|
||||
<source>Energy of day changed</source>
|
||||
<extracomment>The name of the EventType ({b6af1bf5-753d-47b6-a151-e4d801fe6ff8}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="378"/>
|
||||
<source>Energy of year changed</source>
|
||||
<extracomment>The name of the EventType ({7fd2fa28-9bcc-4f01-a823-459437d185f6}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="381"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="384"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="121"/>
|
||||
<source>Energy produced</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: totalEnergyProduced, ID: {ca14cca5-d9f0-49c5-a8f7-907d4c0825f0})
|
||||
----------
|
||||
The name of the StateType ({ca14cca5-d9f0-49c5-a8f7-907d4c0825f0}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({ca14cca5-d9f0-49c5-a8f7-907d4c0825f0}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="387"/>
|
||||
<source>Energy production changed</source>
|
||||
<extracomment>The name of the EventType ({ca14cca5-d9f0-49c5-a8f7-907d4c0825f0}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="237"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="240"/>
|
||||
<source>Charging</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: charging, ID: {2de34a1f-de2e-43ad-8998-8a5460dff9ae})
|
||||
----------
|
||||
The name of the StateType ({2de34a1f-de2e-43ad-8998-8a5460dff9ae}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="243"/>
|
||||
<source>Charging changed</source>
|
||||
<extracomment>The name of the EventType ({2de34a1f-de2e-43ad-8998-8a5460dff9ae}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="285"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="288"/>
|
||||
<source>Current power changed</source>
|
||||
<extracomment>The name of the EventType ({5a89cd3f-3abf-4f51-ab2b-4039f1d211d9}) of ThingClass storage
|
||||
----------
|
||||
The name of the EventType ({788accbc-b86e-471b-b37f-14c9c6411526}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="318"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="321"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="106"/>
|
||||
<source>Current power usage</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: currentPower, ID: {e5056ea1-88a2-410b-9c5e-6322aca4cb17})
|
||||
----------
|
||||
The name of the StateType ({e5056ea1-88a2-410b-9c5e-6322aca4cb17}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({e5056ea1-88a2-410b-9c5e-6322aca4cb17}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="324"/>
|
||||
<source>Current power usage changed</source>
|
||||
<extracomment>The name of the EventType ({e5056ea1-88a2-410b-9c5e-6322aca4cb17}) of ThingClass meter</extracomment>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="79"/>
|
||||
<source>Charging state</source>
|
||||
<extracomment>The name of the StateType ({7a045257-d829-4e58-a769-047b3aeec7c5}) of ThingClass storage</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="345"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="348"/>
|
||||
<source>Discharging</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: discharging, ID: {be90d35c-081c-485b-b4cc-8271e7da5796})
|
||||
----------
|
||||
The name of the StateType ({be90d35c-081c-485b-b4cc-8271e7da5796}) of ThingClass storage</extracomment>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="124"/>
|
||||
<source>Energy produced today</source>
|
||||
<extracomment>The name of the StateType ({b6af1bf5-753d-47b6-a151-e4d801fe6ff8}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="351"/>
|
||||
<source>Discharging changed</source>
|
||||
<extracomment>The name of the EventType ({be90d35c-081c-485b-b4cc-8271e7da5796}) of ThingClass storage</extracomment>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="127"/>
|
||||
<source>Energy produced year</source>
|
||||
<extracomment>The name of the StateType ({7fd2fa28-9bcc-4f01-a823-459437d185f6}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="399"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="133"/>
|
||||
<source>Fronius</source>
|
||||
<extracomment>The name of the vendor ({2286fc38-afd9-4128-ab7e-0fba527d53ba})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="402"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="405"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="136"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="139"/>
|
||||
<source>Fronius Solar</source>
|
||||
<extracomment>The name of the ThingClass ({4fd79fed-42f1-4df9-be64-3df7b2e0bda2})
|
||||
----------
|
||||
@ -435,276 +177,78 @@ The name of the plugin fronius ({02319cfc-8b55-49ba-99bc-0588bbfab063})</extraco
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="408"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="142"/>
|
||||
<source>Fronius Solar Inverter</source>
|
||||
<extracomment>The name of the ThingClass ({540aa956-8b8f-4982-9f58-343a76cea846})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="417"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="420"/>
|
||||
<source>Hardware version</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: hwversion, ID: {3b4206e5-74c7-4708-96b8-2abfab0c41d6})
|
||||
----------
|
||||
The name of the StateType ({3b4206e5-74c7-4708-96b8-2abfab0c41d6}) of ThingClass datalogger</extracomment>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="154"/>
|
||||
<source>Mac address</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: connection, Type: thing, ID: {2237972e-385b-4458-b5d3-1d1fb4ae8756})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="423"/>
|
||||
<source>Hardware version changed</source>
|
||||
<extracomment>The name of the EventType ({3b4206e5-74c7-4708-96b8-2abfab0c41d6}) of ThingClass datalogger</extracomment>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="181"/>
|
||||
<source>Version</source>
|
||||
<extracomment>The name of the StateType ({8fd0c0ed-af89-4887-bf0f-040b13c25268}) of ThingClass connection</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="426"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="151"/>
|
||||
<source>Host address</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, Type: thing, ID: {52da0197-4b78-4fec-aa72-70f949e26edc})</extracomment>
|
||||
<extracomment>The name of the ParamType (ThingClass: connection, Type: thing, ID: {52da0197-4b78-4fec-aa72-70f949e26edc})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="429"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="432"/>
|
||||
<source>Inverter active</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: inverter, EventType: active, ID: {e763baa7-5eaf-438c-83f0-4fa6c0f7eeb0})
|
||||
----------
|
||||
The name of the StateType ({e763baa7-5eaf-438c-83f0-4fa6c0f7eeb0}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="435"/>
|
||||
<source>Inverter active changed</source>
|
||||
<extracomment>The name of the EventType ({e763baa7-5eaf-438c-83f0-4fa6c0f7eeb0}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="438"/>
|
||||
<source>MAC address</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, Type: thing, ID: {2237972e-385b-4458-b5d3-1d1fb4ae8756})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="441"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="444"/>
|
||||
<source>Platform ID</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: platformid, ID: {65c068e6-4a0b-4672-9724-ae95216c4c9c})
|
||||
----------
|
||||
The name of the StateType ({65c068e6-4a0b-4672-9724-ae95216c4c9c}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="447"/>
|
||||
<source>Platform ID changed</source>
|
||||
<extracomment>The name of the EventType ({65c068e6-4a0b-4672-9724-ae95216c4c9c}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="450"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="453"/>
|
||||
<source>Power management relay</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: powerManagmentRelay, ID: {b217acf6-0c5e-4a3e-a50c-4c0133c871c2})
|
||||
----------
|
||||
The name of the StateType ({b217acf6-0c5e-4a3e-a50c-4c0133c871c2}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="456"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="459"/>
|
||||
<source>Power management relay reason</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: powerManagmentRelayReason, ID: {5650ce9b-0d7d-4c52-b410-ea618889b4bb})
|
||||
----------
|
||||
The name of the StateType ({5650ce9b-0d7d-4c52-b410-ea618889b4bb}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="462"/>
|
||||
<source>Power management relay reason changed</source>
|
||||
<extracomment>The name of the EventType ({5650ce9b-0d7d-4c52-b410-ea618889b4bb}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="465"/>
|
||||
<source>Power management relay status changed</source>
|
||||
<extracomment>The name of the EventType ({b217acf6-0c5e-4a3e-a50c-4c0133c871c2}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="468"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="471"/>
|
||||
<source>Product ID</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: productid, ID: {b22052ef-14da-43d2-982b-f2c2d8c03206})
|
||||
----------
|
||||
The name of the StateType ({b22052ef-14da-43d2-982b-f2c2d8c03206}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="474"/>
|
||||
<source>Product ID changed</source>
|
||||
<extracomment>The name of the EventType ({b22052ef-14da-43d2-982b-f2c2d8c03206}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="477"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="480"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="483"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="486"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="489"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="492"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="495"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="498"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="157"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="160"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="163"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="166"/>
|
||||
<source>Reachable</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, EventType: connected, ID: {2f7e1267-b0be-4b78-9aa3-832b86c4efad})
|
||||
----------
|
||||
The name of the StateType ({2f7e1267-b0be-4b78-9aa3-832b86c4efad}) of ThingClass storage
|
||||
----------
|
||||
The name of the ParamType (ThingClass: meter, EventType: connected, ID: {b70b61a4-54cb-47ec-b62a-b498eb1f650e})
|
||||
<extracomment>The name of the StateType ({2f7e1267-b0be-4b78-9aa3-832b86c4efad}) of ThingClass storage
|
||||
----------
|
||||
The name of the StateType ({b70b61a4-54cb-47ec-b62a-b498eb1f650e}) of ThingClass meter
|
||||
----------
|
||||
The name of the ParamType (ThingClass: inverter, EventType: connected, ID: {eda29c50-73ac-40e0-9c92-26fee352e688})
|
||||
----------
|
||||
The name of the StateType ({eda29c50-73ac-40e0-9c92-26fee352e688}) of ThingClass inverter
|
||||
----------
|
||||
The name of the ParamType (ThingClass: datalogger, EventType: connected, ID: {98e4476f-e745-4a7f-b795-19269cb70c40})
|
||||
----------
|
||||
The name of the StateType ({98e4476f-e745-4a7f-b795-19269cb70c40}) of ThingClass datalogger</extracomment>
|
||||
The name of the StateType ({98e4476f-e745-4a7f-b795-19269cb70c40}) of ThingClass connection</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="501"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="504"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="507"/>
|
||||
<source>Reachable changed</source>
|
||||
<extracomment>The name of the EventType ({2f7e1267-b0be-4b78-9aa3-832b86c4efad}) of ThingClass storage
|
||||
----------
|
||||
The name of the EventType ({b70b61a4-54cb-47ec-b62a-b498eb1f650e}) of ThingClass meter
|
||||
----------
|
||||
The name of the EventType ({eda29c50-73ac-40e0-9c92-26fee352e688}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="510"/>
|
||||
<source>Search new devices</source>
|
||||
<extracomment>The name of the ActionType ({c217fdc1-de18-41dc-b5d8-8072f84e7b6c}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="513"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="516"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="169"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="172"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="175"/>
|
||||
<source>Serial number</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: storage, Type: thing, ID: {8b6c7053-5ba5-4808-8ff4-9024c624d77d})
|
||||
----------
|
||||
The name of the ParamType (ThingClass: meter, Type: thing, ID: {dfc2eeef-38b2-4089-9953-48186aaee060})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="519"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="522"/>
|
||||
<source>Software version</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: swversion, ID: {31743ca5-4353-4f26-b2ad-5da43e5b9d86})
|
||||
The name of the ParamType (ThingClass: meter, Type: thing, ID: {dfc2eeef-38b2-4089-9953-48186aaee060})
|
||||
----------
|
||||
The name of the StateType ({31743ca5-4353-4f26-b2ad-5da43e5b9d86}) of ThingClass datalogger</extracomment>
|
||||
The name of the ParamType (ThingClass: inverter, Type: thing, ID: {5e073a9d-f2de-4ff4-95f1-065a0ef4d51b})</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="525"/>
|
||||
<source>Software version changed</source>
|
||||
<extracomment>The name of the EventType ({31743ca5-4353-4f26-b2ad-5da43e5b9d86}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="546"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="549"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="178"/>
|
||||
<source>Total produced energy</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: inverter, EventType: totalEnergyProduced, ID: {d6dbb879-4cbc-4db3-830e-b92ba91a13e5})
|
||||
----------
|
||||
The name of the StateType ({d6dbb879-4cbc-4db3-830e-b92ba91a13e5}) of ThingClass inverter</extracomment>
|
||||
<extracomment>The name of the StateType ({d6dbb879-4cbc-4db3-830e-b92ba91a13e5}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="552"/>
|
||||
<source>Total produced energy changed</source>
|
||||
<extracomment>The name of the EventType ({d6dbb879-4cbc-4db3-830e-b92ba91a13e5}) of ThingClass inverter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="528"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="531"/>
|
||||
<source>Time zone</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: tzone, ID: {6bdfeeda-7a47-4043-a011-5eb96308a7d6})
|
||||
----------
|
||||
The name of the StateType ({6bdfeeda-7a47-4043-a011-5eb96308a7d6}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="534"/>
|
||||
<source>Time zone changed</source>
|
||||
<extracomment>The name of the EventType ({6bdfeeda-7a47-4043-a011-5eb96308a7d6}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="537"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="540"/>
|
||||
<source>Timezone location</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: datalogger, EventType: tzoneloc, ID: {d034f59d-dc34-450a-a6f3-68264767a3e4})
|
||||
----------
|
||||
The name of the StateType ({d034f59d-dc34-450a-a6f3-68264767a3e4}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="543"/>
|
||||
<source>Timezone location changed</source>
|
||||
<extracomment>The name of the EventType ({d034f59d-dc34-450a-a6f3-68264767a3e4}) of ThingClass datalogger</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="555"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="558"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="184"/>
|
||||
<source>Voltage phase A</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: voltagePhaseA, ID: {267bc59f-1113-4aff-a502-4618a591aa16})
|
||||
----------
|
||||
The name of the StateType ({267bc59f-1113-4aff-a502-4618a591aa16}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({267bc59f-1113-4aff-a502-4618a591aa16}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="561"/>
|
||||
<source>Voltage phase A changed</source>
|
||||
<extracomment>The name of the EventType ({267bc59f-1113-4aff-a502-4618a591aa16}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="564"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="567"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="187"/>
|
||||
<source>Voltage phase B</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: voltagePhaseB, ID: {bbcedb80-30f1-493e-81f0-5f77f2847353})
|
||||
----------
|
||||
The name of the StateType ({bbcedb80-30f1-493e-81f0-5f77f2847353}) of ThingClass meter</extracomment>
|
||||
<extracomment>The name of the StateType ({bbcedb80-30f1-493e-81f0-5f77f2847353}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="570"/>
|
||||
<source>Voltage phase B changed</source>
|
||||
<extracomment>The name of the EventType ({bbcedb80-30f1-493e-81f0-5f77f2847353}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="573"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="576"/>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="190"/>
|
||||
<source>Voltage phase C</source>
|
||||
<extracomment>The name of the ParamType (ThingClass: meter, EventType: voltagePhaseC, ID: {8037557b-40dc-411b-8937-bcd1695f898a})
|
||||
----------
|
||||
The name of the StateType ({8037557b-40dc-411b-8937-bcd1695f898a}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="579"/>
|
||||
<source>Voltage phase C changed</source>
|
||||
<extracomment>The name of the EventType ({8037557b-40dc-411b-8937-bcd1695f898a}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
<message>
|
||||
<location filename="../../../build-nymea-plugins-Desktop-Debug/fronius/plugininfo.h" line="582"/>
|
||||
<source>logger reachable changed</source>
|
||||
<extracomment>The name of the EventType ({98e4476f-e745-4a7f-b795-19269cb70c40}) of ThingClass datalogger</extracomment>
|
||||
<extracomment>The name of the StateType ({8037557b-40dc-411b-8937-bcd1695f898a}) of ThingClass meter</extracomment>
|
||||
<translation type="unfinished"></translation>
|
||||
</message>
|
||||
</context>
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user