NEWS
[Lösungsvorschlag] Innogy/Livisi Probleme mit Szenarien?
-
Schon einige Zeit habe ich mich über die Szenarien mit der Innogy App geärgert, man konnte nicht per Default die normalen Szenarien laufen lassen und diese mit einem Status wie "Sommermodus" oder "Urlaub" überschreiben. Dazu musste man ein Szenario schreiben, das auf eine Änderung der Zieltemperatur reagiert, also quasi:
- Standardszenario setzt die Raumtemperatur auf 21°C
- SommerSzenario erkennt die Änderung und ändert wieder zurück auf 18°C
Nachdem jetzt heute auch noch eine dieser Rückschreibaktionen nicht mehr funktionierte und ich nicht herausgefunden habe, was los war, hab ich mich dran gesetzt und was eigenes geschrieben, das quasi nun das Gewünschte macht, allerdings aus ioBroker heraus.
Anpassungen und Erweiterungen etc. sind natürlich gern gesehen und ausdrücklich erwünscht, genau wie weitere Ideen!
Konfiguration ioBroker-Raumname (kann frei definiert werden) zu Innogy-/Livisi-Raumname:
{ "RoomTranslation": { "ioBrokerRoomName": "LivisiRoomName", "anotherOne": "whateverOne" } }Konfiguration für Heizzeiten/Temperaturen pro Raum (Beispiel):
{ "Bathroom": { "defaultTemperature": 18, "daily": [ { "start": "16:00", "end": "17:00", "temperature": 23 } ], "weekday": [ { "start": "6:00", "end": "8:00", "temperature": 21 }, { "start": "18:00", "end": "22:00", "temperature": 21 } ], "weekend": [ { "start": "10:00", "end": "12:00". "temperature": 23 } ] } }Sommermodus Config:
{ "daily": [ { "start": "0:00", "end": "24:00", "temperature": 16 } ] }Als letztes braucht es noch einen Schalter für den Sommermodus (s.h. die ersten 4 Zeilen im folgenden Code, für die Obj-Ids (sind natürlich frei wählbar und nur an dieser Stelle einmal hinterlegt).
ACHTUNG !!! Der folgende Code enthält zwei Funktionen, die ich bei mir global gebaut habe. Ich denke aber, die könnt Ihr mit eigenen ersetzen. Bei Problemen, gern nachfragen.
Zu ersetzende Funktionen:
- logStr
- testCurrDateTimeBetween
var roomTranslationDict = JSON.parse(getState('0_userdata.0.DeviceState.Heatage.RoomTranslation').val); var summerModeTemperatureConfig = JSON.parse(getState('0_userdata.0.DeviceState.Heatage.SummerModeTemperatureConfig').val); var summerModeActive = getState('0_userdata.0.DeviceState.Heatage.Summermode').val; var roomTemperatureConfigDict = JSON.parse(getState('0_userdata.0.DeviceState.Heatage.TemperatureConfig').val); function getCurrentActiveTemperature(temperatureConfig) { var targetTemperature = 0; var moment = require('moment'); var currWeekDayName = moment().format('dddd'); var currWeekDayNum = new Date().getDay(); var matchFound = false; if(currWeekDayName in temperatureConfig) { var todayConfig = temperatureConfig[currWeekDayName]; for(const configItemDict of todayConfig) { if(testCurrDateTimeBetween(configItemDict['start'], configItemDict['end'])) { targetTemperature = configItemDict['temperature']; matchFound = true; } } } if(!matchFound) { logStr('no matching config found for ' + currWeekDayName); if(!(currWeekDayNum in [0,6]) && 'weekday' in temperatureConfig) { logStr('config found for weekdays'); var todayConfig = temperatureConfig['weekday']; for(const configItemDict of todayConfig) { if(testCurrDateTimeBetween(configItemDict['start'], configItemDict['end'])) { targetTemperature = configItemDict['temperature']; matchFound = true; } } } else if(currWeekDayNum in [0,6] && 'weekend' in temperatureConfig) { logStr('config found for weekends'); var todayConfig = temperatureConfig['weekend']; for(const configItemDict of todayConfig) { if(testCurrDateTimeBetween(configItemDict['start'], configItemDict['end'])) { targetTemperature = configItemDict['temperature']; matchFound = true; } } } else if('daily' in temperatureConfig) { logStr('config found for daily'); var todayConfig = temperatureConfig['daily']; for(const configItemDict of todayConfig) { if(testCurrDateTimeBetween(configItemDict['start'], configItemDict['end'])) { logStr('target temperature found in ' + JSON.stringify(configItemDict)); targetTemperature = configItemDict['temperature']; matchFound = true; } } } } if(!matchFound) { logStr('no matching config found in ' + JSON.stringify(temperatureConfig)); logStr('setting target temperature from defaultTemperature'); targetTemperature = temperatureConfig['defaultTemperature']; } return targetTemperature; } function handleCurrentTemperatureSetting(objId, sourceTargetTemperature) { var roomName = objId.split('.')[2]; var roomConfigName = Object.keys(roomTranslationDict).find(key => roomTranslationDict[key] === roomName); if(!roomConfigName) { roomConfigName = roomName; } logStr('checking current temperature for room ' + roomName + '/' + roomConfigName + ' (value: ' + sourceTargetTemperature + ')'); var targetTemperature = 1; if(summerModeActive) { targetTemperature = getCurrentActiveTemperature(summerModeTemperatureConfig); } else if(roomConfigName in roomTemperatureConfigDict) { targetTemperature = getCurrentActiveTemperature(roomTemperatureConfigDict[roomConfigName]); } else { logStr('ERROR: No configuration found for room ' + roomName + '/' + roomConfigName + ' !', 'warn'); } if(targetTemperature != sourceTargetTemperature) { logStr('setting ' + roomConfigName + ' temperature back to target: ' + targetTemperature.toString()); setState(objId, targetTemperature); } } $('state[id=innogy-smarthome.0.*.Raumklima-*.SetpointTemperature]').each(function(objid, i) { handleCurrentTemperatureSetting(objid); on({id: objid, change: 'ne'}, function(obj) { handleCurrentTemperatureSetting(obj.id, obj.state.val); }) })Viel Spass und viel Erfolg!
-
Schon einige Zeit habe ich mich über die Szenarien mit der Innogy App geärgert, man konnte nicht per Default die normalen Szenarien laufen lassen und diese mit einem Status wie "Sommermodus" oder "Urlaub" überschreiben. Dazu musste man ein Szenario schreiben, das auf eine Änderung der Zieltemperatur reagiert, also quasi:
- Standardszenario setzt die Raumtemperatur auf 21°C
- SommerSzenario erkennt die Änderung und ändert wieder zurück auf 18°C
Nachdem jetzt heute auch noch eine dieser Rückschreibaktionen nicht mehr funktionierte und ich nicht herausgefunden habe, was los war, hab ich mich dran gesetzt und was eigenes geschrieben, das quasi nun das Gewünschte macht, allerdings aus ioBroker heraus.
Anpassungen und Erweiterungen etc. sind natürlich gern gesehen und ausdrücklich erwünscht, genau wie weitere Ideen!
Konfiguration ioBroker-Raumname (kann frei definiert werden) zu Innogy-/Livisi-Raumname:
{ "RoomTranslation": { "ioBrokerRoomName": "LivisiRoomName", "anotherOne": "whateverOne" } }Konfiguration für Heizzeiten/Temperaturen pro Raum (Beispiel):
{ "Bathroom": { "defaultTemperature": 18, "daily": [ { "start": "16:00", "end": "17:00", "temperature": 23 } ], "weekday": [ { "start": "6:00", "end": "8:00", "temperature": 21 }, { "start": "18:00", "end": "22:00", "temperature": 21 } ], "weekend": [ { "start": "10:00", "end": "12:00". "temperature": 23 } ] } }Sommermodus Config:
{ "daily": [ { "start": "0:00", "end": "24:00", "temperature": 16 } ] }Als letztes braucht es noch einen Schalter für den Sommermodus (s.h. die ersten 4 Zeilen im folgenden Code, für die Obj-Ids (sind natürlich frei wählbar und nur an dieser Stelle einmal hinterlegt).
ACHTUNG !!! Der folgende Code enthält zwei Funktionen, die ich bei mir global gebaut habe. Ich denke aber, die könnt Ihr mit eigenen ersetzen. Bei Problemen, gern nachfragen.
Zu ersetzende Funktionen:
- logStr
- testCurrDateTimeBetween
var roomTranslationDict = JSON.parse(getState('0_userdata.0.DeviceState.Heatage.RoomTranslation').val); var summerModeTemperatureConfig = JSON.parse(getState('0_userdata.0.DeviceState.Heatage.SummerModeTemperatureConfig').val); var summerModeActive = getState('0_userdata.0.DeviceState.Heatage.Summermode').val; var roomTemperatureConfigDict = JSON.parse(getState('0_userdata.0.DeviceState.Heatage.TemperatureConfig').val); function getCurrentActiveTemperature(temperatureConfig) { var targetTemperature = 0; var moment = require('moment'); var currWeekDayName = moment().format('dddd'); var currWeekDayNum = new Date().getDay(); var matchFound = false; if(currWeekDayName in temperatureConfig) { var todayConfig = temperatureConfig[currWeekDayName]; for(const configItemDict of todayConfig) { if(testCurrDateTimeBetween(configItemDict['start'], configItemDict['end'])) { targetTemperature = configItemDict['temperature']; matchFound = true; } } } if(!matchFound) { logStr('no matching config found for ' + currWeekDayName); if(!(currWeekDayNum in [0,6]) && 'weekday' in temperatureConfig) { logStr('config found for weekdays'); var todayConfig = temperatureConfig['weekday']; for(const configItemDict of todayConfig) { if(testCurrDateTimeBetween(configItemDict['start'], configItemDict['end'])) { targetTemperature = configItemDict['temperature']; matchFound = true; } } } else if(currWeekDayNum in [0,6] && 'weekend' in temperatureConfig) { logStr('config found for weekends'); var todayConfig = temperatureConfig['weekend']; for(const configItemDict of todayConfig) { if(testCurrDateTimeBetween(configItemDict['start'], configItemDict['end'])) { targetTemperature = configItemDict['temperature']; matchFound = true; } } } else if('daily' in temperatureConfig) { logStr('config found for daily'); var todayConfig = temperatureConfig['daily']; for(const configItemDict of todayConfig) { if(testCurrDateTimeBetween(configItemDict['start'], configItemDict['end'])) { logStr('target temperature found in ' + JSON.stringify(configItemDict)); targetTemperature = configItemDict['temperature']; matchFound = true; } } } } if(!matchFound) { logStr('no matching config found in ' + JSON.stringify(temperatureConfig)); logStr('setting target temperature from defaultTemperature'); targetTemperature = temperatureConfig['defaultTemperature']; } return targetTemperature; } function handleCurrentTemperatureSetting(objId, sourceTargetTemperature) { var roomName = objId.split('.')[2]; var roomConfigName = Object.keys(roomTranslationDict).find(key => roomTranslationDict[key] === roomName); if(!roomConfigName) { roomConfigName = roomName; } logStr('checking current temperature for room ' + roomName + '/' + roomConfigName + ' (value: ' + sourceTargetTemperature + ')'); var targetTemperature = 1; if(summerModeActive) { targetTemperature = getCurrentActiveTemperature(summerModeTemperatureConfig); } else if(roomConfigName in roomTemperatureConfigDict) { targetTemperature = getCurrentActiveTemperature(roomTemperatureConfigDict[roomConfigName]); } else { logStr('ERROR: No configuration found for room ' + roomName + '/' + roomConfigName + ' !', 'warn'); } if(targetTemperature != sourceTargetTemperature) { logStr('setting ' + roomConfigName + ' temperature back to target: ' + targetTemperature.toString()); setState(objId, targetTemperature); } } $('state[id=innogy-smarthome.0.*.Raumklima-*.SetpointTemperature]').each(function(objid, i) { handleCurrentTemperatureSetting(objid); on({id: objid, change: 'ne'}, function(obj) { handleCurrentTemperatureSetting(obj.id, obj.state.val); }) })Viel Spass und viel Erfolg!
Bevor ich es vergesse, der Code unterstützt auch Wochennamen in der Konfiguration (statt weekday, weekend oder daily) andere Ranges habe ich (noch) nicht eingebaut. Allerdings lässt sich mit "daily" eine Grundkonfiguration machen, die man dann an einzelnen Tagen mit einer Konfiguration für den Wochentag überschreiben kann.
Wenn einer von Euch das evtl. in den Livisi Adapter mit reinbauen möchte, oder mir helfen möchte daraus einen neuen Adapter zu machen, bitte gerne melden.
Freu mich auf Eure Rückmeldungen. Aber bitte berücksichtigt, dass der Code incl. Konfiguration etc. in 2h zusammengeschrieben wurde ;-)
-
Bevor ich es vergesse, der Code unterstützt auch Wochennamen in der Konfiguration (statt weekday, weekend oder daily) andere Ranges habe ich (noch) nicht eingebaut. Allerdings lässt sich mit "daily" eine Grundkonfiguration machen, die man dann an einzelnen Tagen mit einer Konfiguration für den Wochentag überschreiben kann.
Wenn einer von Euch das evtl. in den Livisi Adapter mit reinbauen möchte, oder mir helfen möchte daraus einen neuen Adapter zu machen, bitte gerne melden.
Freu mich auf Eure Rückmeldungen. Aber bitte berücksichtigt, dass der Code incl. Konfiguration etc. in 2h zusammengeschrieben wurde ;-)
@great-sun Danke für deinen Beitrag. Sieht interessant aus. Ich wollte dich nur noch darauf aufmerksam machen, dass in Kürze der Beta-Test für das lokale Smarthome von Livisi (ex Innogy) beendet wird und damit fast alle Funktionen der App lokal, also ohne Cloud funktionieren. Wenn du dich näher informieren willst schau doch mal hier rein: https://community.livisi.de/forum/board/4-livisi/
Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.
Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.
Mit deinem Input könnte dieser Beitrag noch besser werden 💗
Registrieren Anmelden