NEWS
Wie Namen aller Objekte erhalten
-
danke für das klasse script ich bekomme leider immer wieder folgenden Fehler:
javascript.0 2018-03-17 08:45:00.923 warn at script.js.Homematic.Servicemeldungen:65:9 javascript.0 2018-03-17 08:45:00.923 warn at count (script.js.Homematic.Servicemeldungen:41:22) javascript.0 2018-03-17 08:45:00.922 warn getState "hm-rpc.1.CUX9000002.0.LOWBAT" not found (3) states[id]=null javascript.0 2018-03-17 08:45:00.922 warn at script.js.Homematic.Servicemeldungen:53:9 javascript.0 2018-03-17 08:45:00.922 warn at count (script.js.Homematic.Servicemeldungen:41:22) javascript.0 2018-03-17 08:45:00.921 warn getState "hm-rpc.1.CUX0200107.0.UNREACH" not found (3) states[id]=null javascript.0 2018-03-17 08:45:00.921 warn at script.js.Homematic.Servicemeldungen:53:9 javascript.0 2018-03-17 08:45:00.921 warn at count (script.js.Homematic.Servicemeldungen:41:22) javascript.0 2018-03-17 08:45:00.921 warn getState "hm-rpc.1.CUX0200105.0.UNREACH" not found (3) states[id]=null javascript.0 2018-03-17 08:45:00.920 warn at script.js.Homematic.Servicemeldungen:53:9 javascript.0 2018-03-17 08:45:00.919 warn at count (script.js.Homematic.Servicemeldungen:41:22) javascript.0 2018-03-17 08:45:00.918 warn getState "hm-rpc.1.CUX0200101.0.UNREACH" not found (3) states[id]=null javascript.0 2018-03-17 08:45:00.918 warn at script.js.Homematic.Servicemeldungen:53:9 javascript.0 2018-03-17 08:45:00.918 warn at count (script.js.Homematic.Servicemeldungen:41:22) javascript.0 2018-03-17 08:45:00.917 warn getState "hm-rpc.1.CUX0200002.0.UNREACH" not found (3) states[id]=null javascript.0 2018-03-17 08:45:00.917 warn at script.js.Homematic.Servicemeldungen:53:9 javascript.0 2018-03-17 08:45:00.916 warn at count (script.js.Homematic.Servicemeldungen:41:22) javascript.0 2018-03-17 08:45:00.915 warn getState "hm-rpc.1.CUX0200001.0.UNREACH" not found (3) states[id]=null
-
@pix:Hallo paul53,
vielen Dank für das Skript. Es fasst nochmal alles zusammen. Leider stimmt die Zahl der Servicemeldungen nicht mit denen der CCU-Webui überein. Es werden 12 statt 1 angezeigt :shock:
Bildschirmfoto 2015-08-03 um 23.18.21.jpg
Bildschirmfoto 2015-08-03 um 23.18.55.jpg
Ich habe den Code übernommen und die Ausgabe etwas angepasst (neue Zeile nach jeder Meldung, ioBroker-Variablen tiefer gestaffelt, Aufruf jede 15min und bei scriptstart), aber nichts Einschneidendes.
! ````
/* System Homematic Servicemeldungen
Skript erstellt Variablen Service.Homematic.*
http://forum.iobroker.org/viewtopic.php?f=21&t=914#p9153
! erstellt: 03.08.2015 von paul53 - angepasst von pix
! /
! // Service Meldungen
! createState('Servicemeldungen.Homematic.Anzahl', 0, {"name": "Homematic Servicemeldungen Anzahl"}); // Anzahl der Service-Alarme
createState('Servicemeldungen.Homematic.Text', "", {"name": "Homematic Servicemeldungen Text"}); // Service-Alarme, als Variable unter Javascript.0 anlegen
! var SelectorUNREACH = $('channel[state.id=.UNREACH]');
var SelectorSTICKY_UNREACH = $('channel[state.id=.STICKY_UNREACH]');
var SelectorLOWBAT = $('channel[state.id=.LOWBAT]');
var SelectorCONFIG_PENDING = $('channel[state.id=*.CONFIG_PENDING]');
! function countService(obj) {
var anzahl = 0;
var text = "";
! function count(id) {
var status = getState(id).val; // Zustand abfragen (jedes Element)
if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
text = text + id + ",
"; // Zu String hinzufügen
++anzahl; // Zählt die Anzahl der Service-Alarme
}
}SelectorUNREACH.each(function (id, i) {
count(id);
});SelectorSTICKY_UNREACH.each(function (id, i) {
count(id);
});SelectorLOWBAT.each(function (id, i) {
count(id);
});SelectorCONFIG_PENDING.each(function (id, i) {
count(id);
});! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon Service zutreffend) ausgegeben
log("Homematic-Servicemeldungen: " + text);
log("Anzahl Homematic-Servicemeldungen: " + anzahl);
! // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert
if (!anzahl) {
text = "kein Service-Alarm";
}
setState("Servicemeldungen.Homematic.Text", text); // Schreibt die IDs der Datenpunkte mit Service Meldung
setState("Servicemeldungen.Homematic.Anzahl", anzahl); // Schreibt die aktuelle Anzahl der Service Meldungen
}
! SelectorUNREACH.on(function(obj) { // bei Zustandänderung *.UNREACH in allen Gewerken
countService(obj);
});
! SelectorSTICKY_UNREACH.on(function(obj) { // bei Zustandänderung *.STICKY_UNREACH in allen Gewerken
countService(obj);
});
! SelectorLOWBAT.on(function(obj) { // bei Zustandänderung *.LOWBAT in allen Gewerken
countService(obj);
});
! SelectorCONFIG_PENDING.on(function(obj) { // bei Zustandänderung .CONFIG_PENDING in allen Gewerken
countService(obj);
});
! // alternative Abfrage jede Minute
schedule("/15 * * * *", function () {
countService();
});
! // Ausführung bei Scriptstart
countService();VIS Widget(zwei übereinander):Bildschirmfoto 2015-08-03 um 23.22.20.jpg >! ```` [{"tpl":"tplMetroTileDialogStatic","data":{"visibility-cond":"==","visibility-val":1,"hover":false,"transform":"true","bg_class":"bg-transparent","icon_class":"","icon_badge":"","badge_bg_class":"","brand_bg_class":"","dialog_draggable":"true","dialog_icon_class":"","name":"System Homematic Servicemeldung","label":"","content_oid":"","html":"{javascript.0.Servicemeldungen.Homematic.Text}","dialog_width":"800px","dialog_height":"500px","dialog_title":"CCU Servicemeldungen","dialog_shadow":true,"comment":"nach Skript von paul53"},"style":{"left":"864px","top":"427px","z-index":"30","width":"137px","height":"137px"},"widgetSet":"metro"},{"tpl":"tplMetroTileString","data":{"visibility-cond":"==","visibility-val":1,"bg_class_true":"ribbed-yellow","bg_class_false":"bg-transparent","icon_class_true":"icon-thumbs-down","icon_class_false":"icon-thumbs-up","badge_bg_class_true":"","badge_bg_class_false":"","icon_badge_true":"","icon_badge_false":"","brand_bg_class_true":"","brand_bg_class_false":"","name":"Servicemeldungen Homematic Anzahl","visibility-oid":"","content_prepend":"Servicemeldungen ","content_append":"","content_oid":"javascript.0.Servicemeldungen.Homematic.Anzahl","label_prepend":"","label_append":"","label_id":"","state_oid":"javascript.0.Servicemeldungen.Homematic.Anzahl","transform":false,"select_on_true":false,"icon":"/vis.0/main/img/schritte.png","icon_width":"50%","icon_height":"50%","icon_false":"","icon_top":"52","icon_left":"44","hover":false},"style":{"left":"864px","top":"427px","width":"137px","height":"137px","z-index":"15","font-family":"","color":"","font-size":""},"widgetSet":"metro"}]
Danke!
Gruß
Pix `
Hallo Pix,
ist es mögich in deinem Skript irgendwie die Namen der Aktoren anzugeben?
Mit den normalen Seriennummern kann ich nicht wirklich was anfangen, ohne erst im System zu suchen…
-
Mit folgendem Script, das die Datenpunkt-ID zur Anzeige verwendet, kann man die Service-Meldungen selektieren:
// Service Meldungen createState('Service.anzahl', 0); // Anzahl der Service-Alarme createState('Service.text', ""); // Service-Alarme, als Variable unter Javascript.0 anlegen var SelectorUNREACH = $('channel[state.id=*.UNREACH]'); var SelectorLOWBAT = $('channel[state.id=*.LOWBAT]'); var SelectorCONFIG_PENDING = $('channel[state.id=*.CONFIG_PENDING]'); function countService(obj) { var anzahl = 0; var text = ""; function count(id) { if(!getState(id)) return; var status = getState(id).val; // Zustand abfragen (jedes Element) if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt text = text + id + ","; // Zu String hinzufügen ++anzahl; // Zählt die Anzahl der Service-Alarme } } SelectorUNREACH.each(function (id, i) { count(id); }); SelectorLOWBAT.each(function (id, i) { count(id); }); SelectorCONFIG_PENDING.each(function (id, i) { count(id); }); // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon Service zutreffend) ausgegeben // log("Alarme: " + text); // log("Anzahl Service-Alarme: " + anzahl); // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert if (!anzahl) { text = "kein Service-Alarm"; } setState("Service.text", text); // Schreibt die IDs der Datenpunkte mit Service Meldung setState("Service.anzahl", anzahl); // Schreibt die aktuelle Anzahl der Service Meldungen } SelectorUNREACH.on(function(obj) { // bei Zustandänderung *.UNREACH in allen Gewerken countService(obj); }); SelectorLOWBAT.on(function(obj) { // bei Zustandänderung *.LOWBAT in allen Gewerken countService(obj); }); SelectorCONFIG_PENDING.on(function(obj) { // bei Zustandänderung *.CONFIG_PENDING in allen Gewerken countService(obj); }); countService(); // Scriptstart
EDIT: STICKY_UNREACH entfernt. `
Manche (z.B.) UNREACH sind bei mir noch leer, warum auch immer. Deswegen erscheint natürlich ne Warnung bei "if(!getState(id)) return;".
Woran könnte es liegen, dass z.B. UNREACH noch leer ist (anstatt false) - oder gibt es einen Weg die Warnung wegzubekommen?
-
-
-
Könnte man hier noch Telegram einfügen? Wenn ja, wie am besten? Was mir an dem Script noch aufgefallen ist:
- Ich nutze RaspberryMatic und hier kann man auch nicht vorhandene, aber parametrierte Geräte von den Servicemeldungen ausblenden lassen. Leider werden aber die BatterieLOW Daten trotzdem an den Broker gesendet. Dies ermittelt das Script weiterhin. Gibt es eine Lösung hierfür?
-
Vielleicht kann man hier noch die Benachrichtigung via Telegram einbinden? Das wäre nice und würde das Script abrunden?
-
Diese beiden Datenpunkte werden durch das Skript beschrieben.
setState("Service.text", text); setState("Service.anzahl", anzahl);
Wenn du sie nun im Reiter Objekte in Admin suchst und sie durch Klick auf das Symbol "Schraubenschlüssel" bearbeitest,
kannst du die Benachrichtigung in Telegram (wenn telegram installiert ist) aktivieren.Das geht natürlich mit jedem Datenpunkt und ist unabhängig von diesem Skript.
Gruß
Pix -
Hallo zusammen,
ich nutze seit Jahren dieses Script und es funktioniert bislang immer super.
Seit kurzem habe ich den Adapter IQontrol im Einsatz (Visualisierung).
Diese legt in einem separaten Verzeichnis visualisierte Geräte an und zwar inkl. einem "unreach"-Status.
Dieser hat jedoch keinen Wert...
Die Folge ist jetzt natürlich, dass ich etliche Meldungen doppelt oder zusätzlich als Ausgabe dieses Scriptes habe.
Kann mir jemand sagen, wie ich einen Ausschluss für alle Objekte, die unter iqontrol.0 liegen, in das Script einbauen kann?Vielen Dank im Voraus
Grüße
Frank -
@deifel
Versuche es mal so:var SelectorUNREACH = $('channel[state.id=hm-rpc.*.UNREACH]'); var SelectorLOWBAT = $('channel[state.id=hm-rpc.*.LOWBAT]'); var SelectorCONFIG_PENDING = $('channel[state.id=hm-rpc.*.CONFIG_PENDING]');
-
@paul53 said in Wie Namen aller Objekte erhalten:
state.id=hm-rpc.*.CONFIG_PENDING
Danke für Deine schnelle Hilfe!
Habe es damit versucht, aber leider zeigt er mir dann gar keine Meldungen mehr an.
Oder hab ich einen Fehler drin?
Hier mein komplettes Script- hast Du noch eine Idee?:/* System Homematic Servicemeldungen Skript erstellt Variablen Service.Homematic.* http://forum.iobroker.org/viewtopic.php?f=21&t=914#p9153 erstellt: 04.08.2015 von paul53 angepasst von pix 05.10.2015 STICKY UNREACH wird jetzt auf true gesetzt und damit gelöscht http://forum.iobroker.org/viewtopic.php?f=21&t=914&p=9200&hilit=sticky#p9173 04.02.2016 Instanz Variable */ instanz = 'javascript.0.'; // Service Meldungen createState('Servicemeldungen.Homematic.Anzahl', 0, { name: 'Homematic Servicemeldungen Anzahl', desc: 'Zahl der Homematic Servicemeldungen', type: 'number' }); createState('Servicemeldungen.Homematic.Text', "", { name: 'Homematic Servicemeldungen Text', desc: 'Liste der Geräte, die Servicemeldungen produzieren', type: 'string' }); var idAnzahl = instanz + 'Servicemeldungen.Homematic.Anzahl', idText = instanz + 'Servicemeldungen.Homematic.Text'; var SelectorUNREACH = $('channel[state.id=hm-rpc.*.UNREACH]'), SelectorSTICKY_UNREACH = $('channel[state.id=hm-rpc=*.STICKY_UNREACH]'), SelectorLOWBAT = $('channel[state.id=hm-rpc.*.LOWBAT]'), SelectorCONFIG_PENDING = $('state.id=hm-rpc.*.CONFIG_PENDING]'); var blockdevice = "XEQ012345678"; function countService(obj) { var anzahl = 0; var text_VIS = ""; function count(id) { var status = getState(id).val; // Zustand abfragen (jedes Element) if (status) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt text_VIS = text_VIS + formatText(id) + "<br>"; // Zu String hinzufügen ++anzahl; // Zählt die Anzahl der Service-Alarme } } SelectorUNREACH.each(function (id, i) { count(id); }); SelectorSTICKY_UNREACH.each(function (id, i) { var status = getState(id).val; // Zustand abfragen (jedes Element) if (status) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt log('STICKY_UNREACH Meldung: ' + id + ' wurde auf <true> gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.'); setState(id, false); // STICKY_UNREACH werden gelöscht } }); SelectorLOWBAT.each(function (id, i) { count(id); }); SelectorCONFIG_PENDING.each(function (id, i) { count(id); }); // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert if (!anzahl) { text_VIS = "keine Servicemeldungen"; } // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon Service zutreffend) ausgegeben log("Homematic-Servicemeldungen: " + text_VIS); log("Anzahl Homematic-Servicemeldungen: " + anzahl); setState(idText, text_VIS); // Schreibt die IDs der Datenpunkte mit Service Meldung setState(idAnzahl, anzahl); // Schreibt die aktuelle Anzahl der Service Meldungen } function formatText(id) { var idS = id.split('.'); var serial = idS[2]; var status = idS[4]; // Zustand abfragen var obj = getObject(id); var name = getObject(id).common.name; var devicename = name.substring(0, name.indexOf(":")); var type = getObject(id).native.TYPE; // funktioniert nicht var ival = getState(id).val; var stime = formatDate(getState(id).ts, "TT.MM.YYYY SS:mm"); if (serial != blockdevice) { if (status == "CONFIG_PENDING") { status = "Konfigurationsdaten stehen zur Übertragung an"; } if (status == "LOWBAT") { status = "Batteriestand niedrig"; } if (status == "STICKY_UNREACH") { status = "Kommunikation war gestört"; } if (status == "UNREACH") { status = "Kommunikation zur Zeit gestört"; } if (status == "LOWBAT") { return devicename + ": Batterien für " + type + " bestellen"; } else { return devicename + ": " + status + " seit: " + stime + " Uhr"; } } } SelectorUNREACH.on(function(obj) { // bei Zustandänderung *.UNREACH in allen Gewerken countService(obj); }); SelectorSTICKY_UNREACH.on(function(obj) { // bei Zustandänderung *.STICKY_UNREACH in allen Gewerken countService(obj); }); SelectorLOWBAT.on(function(obj) { // bei Zustandänderung *.LOWBAT in allen Gewerken countService(obj); }); SelectorCONFIG_PENDING.on(function(obj) { // bei Zustandänderung *.CONFIG_PENDING in allen Gewerken countService(obj); }); // Ausführung bei Scriptstart countService();
-
@deifel sagte:
leider zeigt er mir dann gar keine Meldungen mehr an.
Das wundert mich. Dann nimm "hm-rpc." wieder raus und versuche es so:
SelectorUNREACH.each(function (id, i) { if(id.split('.')[0] != 'iqontrol') count(id); });
-
@paul53 said in Wie Namen aller Objekte erhalten:
SelectorUNREACH.each(function (id, i) { if(id.split('.')[0] != 'iqontrol') count(id); });
Zusätzlich oder ersetzen?
Habe es jetzt ergänzt, bekomme jetzt aber plötzlich die ganzen unreach-alarm=true angezeigt...Hier das Script und vielen Dank für Deine Hilfe!!!:
/* System Homematic Servicemeldungen Skript erstellt Variablen Service.Homematic.* http://forum.iobroker.org/viewtopic.php?f=21&t=914#p9153 erstellt: 04.08.2015 von paul53 angepasst von pix 05.10.2015 STICKY UNREACH wird jetzt auf true gesetzt und damit gelöscht http://forum.iobroker.org/viewtopic.php?f=21&t=914&p=9200&hilit=sticky#p9173 04.02.2016 Instanz Variable */ instanz = 'javascript.0.'; // Service Meldungen createState('Servicemeldungen.Homematic.Anzahl', 0, { name: 'Homematic Servicemeldungen Anzahl', desc: 'Zahl der Homematic Servicemeldungen', type: 'number' }); createState('Servicemeldungen.Homematic.Text', "", { name: 'Homematic Servicemeldungen Text', desc: 'Liste der Geräte, die Servicemeldungen produzieren', type: 'string' }); var idAnzahl = instanz + 'Servicemeldungen.Homematic.Anzahl', idText = instanz + 'Servicemeldungen.Homematic.Text'; var SelectorUNREACH.each(function (id, i) { if(id.split('.')[0] != 'iqontrol') count(id); }); SelectorUNREACH = $('channel[state.id=*.UNREACH]'), SelectorSTICKY_UNREACH = $('channel[state.id=*.STICKY_UNREACH]'), SelectorLOWBAT = $('channel[state.id=*.LOWBAT]'), SelectorCONFIG_PENDING = $('channel[state.id=*.CONFIG_PENDING]'); var blockdevice = "XEQ012345678"; function countService(obj) { var anzahl = 0; var text_VIS = ""; function count(id) { var status = getState(id).val; // Zustand abfragen (jedes Element) if (status) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt text_VIS = text_VIS + formatText(id) + "<br>"; // Zu String hinzufügen ++anzahl; // Zählt die Anzahl der Service-Alarme } } SelectorUNREACH.each(function (id, i) { count(id); }); SelectorSTICKY_UNREACH.each(function (id, i) { var status = getState(id).val; // Zustand abfragen (jedes Element) if (status) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt log('STICKY_UNREACH Meldung: ' + id + ' wurde auf <true> gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.'); setState(id, false); // STICKY_UNREACH werden gelöscht } }); SelectorLOWBAT.each(function (id, i) { count(id); }); SelectorCONFIG_PENDING.each(function (id, i) { count(id); }); // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert if (!anzahl) { text_VIS = "keine Servicemeldungen"; } // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon Service zutreffend) ausgegeben log("Homematic-Servicemeldungen: " + text_VIS); log("Anzahl Homematic-Servicemeldungen: " + anzahl); setState(idText, text_VIS); // Schreibt die IDs der Datenpunkte mit Service Meldung setState(idAnzahl, anzahl); // Schreibt die aktuelle Anzahl der Service Meldungen } function formatText(id) { var idS = id.split('.'); var serial = idS[2]; var status = idS[4]; // Zustand abfragen var obj = getObject(id); var name = getObject(id).common.name; var devicename = name.substring(0, name.indexOf(":")); var type = getObject(id).native.TYPE; // funktioniert nicht var ival = getState(id).val; var stime = formatDate(getState(id).ts, "TT.MM.YYYY SS:mm"); if (serial != blockdevice) { if (status == "CONFIG_PENDING") { status = "Konfigurationsdaten stehen zur Übertragung an"; } if (status == "LOWBAT") { status = "Batteriestand niedrig"; } if (status == "STICKY_UNREACH") { status = "Kommunikation war gestört"; } if (status == "UNREACH") { status = "Kommunikation zur Zeit gestört"; } if (status == "LOWBAT") { return devicename + ": Batterien für " + type + " bestellen"; } else { return devicename + ": " + status + " seit: " + stime + " Uhr"; } } } SelectorUNREACH.on(function(obj) { // bei Zustandänderung *.UNREACH in allen Gewerken countService(obj); }); SelectorSTICKY_UNREACH.on(function(obj) { // bei Zustandänderung *.STICKY_UNREACH in allen Gewerken countService(obj); }); SelectorLOWBAT.on(function(obj) { // bei Zustandänderung *.LOWBAT in allen Gewerken countService(obj); }); SelectorCONFIG_PENDING.on(function(obj) { // bei Zustandänderung *.CONFIG_PENDING in allen Gewerken countService(obj); }); // Ausführung bei Scriptstart countService();
-
@deifel sagte:
Zusätzlich oder ersetzen?
Nicht zusätzlich: Ursprüngliche Zeilen 48 bis 50 ersetzen (Änderung nur in Zeile 49) !
-
@paul53 said in Wie Namen aller Objekte erhalten:
SelectorUNREACH.each(function (id, i) { if(id.split('.')[0] != 'iqontrol') count(id); });
ok, habe es kapiert und korrekt ergänzt.
Dann zeigt er mir wieder keine (0) Servicemeldungen an
bekommen wir das Ding noch zum Laufen?Habe es mit diesem Script versucht:
/* System Homematic Servicemeldungen Skript erstellt Variablen Service.Homematic.* http://forum.iobroker.org/viewtopic.php?f=21&t=914#p9153 erstellt: 04.08.2015 von paul53 angepasst von pix 05.10.2015 STICKY UNREACH wird jetzt auf true gesetzt und damit gelöscht http://forum.iobroker.org/viewtopic.php?f=21&t=914&p=9200&hilit=sticky#p9173 04.02.2016 Instanz Variable */ instanz = 'javascript.0.'; // Service Meldungen createState('Servicemeldungen.Homematic.Anzahl', 0, { name: 'Homematic Servicemeldungen Anzahl', desc: 'Zahl der Homematic Servicemeldungen', type: 'number' }); createState('Servicemeldungen.Homematic.Text', "", { name: 'Homematic Servicemeldungen Text', desc: 'Liste der Geräte, die Servicemeldungen produzieren', type: 'string' }); var idAnzahl = instanz + 'Servicemeldungen.Homematic.Anzahl', idText = instanz + 'Servicemeldungen.Homematic.Text'; var SelectorUNREACH = $('channel[state.id=*.UNREACH]'), SelectorSTICKY_UNREACH = $('channel[state.id=*.STICKY_UNREACH]'), SelectorLOWBAT = $('channel[state.id=*.LOWBAT]'), SelectorCONFIG_PENDING = $('channel[state.id=*.CONFIG_PENDING]'); var blockdevice = "XEQ012345678"; function countService(obj) { var anzahl = 0; var text_VIS = ""; function count(id) { var status = getState(id).val; // Zustand abfragen (jedes Element) if (status) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt text_VIS = text_VIS + formatText(id) + "<br>"; // Zu String hinzufügen ++anzahl; // Zählt die Anzahl der Service-Alarme } } SelectorUNREACH.each(function (id, i) { if(id.split('.')[0] != 'iqontrol') count(id); }); SelectorSTICKY_UNREACH.each(function (id, i) { var status = getState(id).val; // Zustand abfragen (jedes Element) if (status) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt log('STICKY_UNREACH Meldung: ' + id + ' wurde auf <true> gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.'); setState(id, false); // STICKY_UNREACH werden gelöscht } }); SelectorLOWBAT.each(function (id, i) { count(id); }); SelectorCONFIG_PENDING.each(function (id, i) { count(id); }); // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert if (!anzahl) { text_VIS = "keine Servicemeldungen"; } // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon Service zutreffend) ausgegeben log("Homematic-Servicemeldungen: " + text_VIS); log("Anzahl Homematic-Servicemeldungen: " + anzahl); setState(idText, text_VIS); // Schreibt die IDs der Datenpunkte mit Service Meldung setState(idAnzahl, anzahl); // Schreibt die aktuelle Anzahl der Service Meldungen } function formatText(id) { var idS = id.split('.'); var serial = idS[2]; var status = idS[4]; // Zustand abfragen var obj = getObject(id); var name = getObject(id).common.name; var devicename = name.substring(0, name.indexOf(":")); var type = getObject(id).native.TYPE; // funktioniert nicht var ival = getState(id).val; var stime = formatDate(getState(id).ts, "TT.MM.YYYY SS:mm"); if (serial != blockdevice) { if (status == "CONFIG_PENDING") { status = "Konfigurationsdaten stehen zur Übertragung an"; } if (status == "LOWBAT") { status = "Batteriestand niedrig"; } if (status == "STICKY_UNREACH") { status = "Kommunikation war gestört"; } if (status == "UNREACH") { status = "Kommunikation zur Zeit gestört"; } if (status == "LOWBAT") { return devicename + ": Batterien für " + type + " bestellen"; } else { return devicename + ": " + status + " seit: " + stime + " Uhr"; } } } SelectorUNREACH.on(function(obj) { // bei Zustandänderung *.UNREACH in allen Gewerken countService(obj); }); SelectorSTICKY_UNREACH.on(function(obj) { // bei Zustandänderung *.STICKY_UNREACH in allen Gewerken countService(obj); }); SelectorLOWBAT.on(function(obj) { // bei Zustandänderung *.LOWBAT in allen Gewerken countService(obj); }); SelectorCONFIG_PENDING.on(function(obj) { // bei Zustandänderung *.CONFIG_PENDING in allen Gewerken countService(obj); }); // Ausführung bei Scriptstart countService();
-
Kommando zurück.
Das Script stimmt jetzt! Das Problem ist, dass die Objekte im IOBroker bei unreach den Status "false" haben.
Allerdings in Homematic definitiv nicht erreichbar (zum Testen Gerät nicht an Strom angeschlossen).
Warum wird hier nicht der korrekte Wert übergeben bzw. woran kann das liegen?Danke und Grüße
Frank -
Ich habe im RPC-Adapter alle Gerät neu synchronisieren lassen, jetzt scheint es richtig zu funktionieren!
Vielen Dank nochmals für Deine Hilfe