NEWS
Servicemeldungen - All inclusive für Homematic -
-
Hier mal ein optischer Fensterkontakt. Die Instanzen habe ich neu gestartet und auch die Adapter aktualisiert, inklusive upload.
Auf rpc.0 habe ich HMIP und auf rpc.1 normale Homematic(die habe ich aber noch nicht im Script)
-
Ach, ich seh schon, da war ja was….....
LOWBAT . und LOW_BAT
-
Korrekt. LOW_BAT_ALRAM solltest Du verwenden…
Es scheint also das bei den IP-Geräten die Bezeichnung anstelle von LOWBAT einfach LOW_BAT ist. Ich muss mal gucken wir ich da bei mir einbaue. Mich würde die Debug Ausgabe interessieren ob er die Batterien ermittelt wenn Du es auf LOW_BAT_ALARM angepasst hast.
-
SABOTAGE_ALRAM muss ich auch noch aufnehmen…
-
Korrekt. LOW_BAT_ALRAM solltest Du verwenden…
Es scheint also das bei den IP-Geräten die Bezeichnung anstelle von LOWBAT einfach LOW_BAT ist. Ich muss mal gucken wir ich da bei mir einbaue. Mich würde die Debug Ausgabe interessieren ob er die Batterien ermittelt wenn Du es auf LOW_BAT_ALARM angepasst hast. `
Hier mal der "Klassiker" wo es bei mir funktioniert
createState('zählenLowbat.möglicheLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen Geräte createState('zählenLowbat.anzahlLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT createState('zählenLowbat.textLOWBAT', " "); // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen var cacheSelectorLOWBAT = $('channel[state.id=*.LOWBAT]'); var cacheSelectorLOW_BAT = $('channel[state.id=*.LOW_BAT]'); // für Homematic IP, dort LOWBAT in LOW_BAT umbenannt function countLowbat(obj) { // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0 var moeglicheLOWBAT = 0; var anzahlLOWBAT = 0; var textLOWBAT = []; if (obj) { log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat } else { log('Ausgelöst bei Timer'); } cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element) var obj = getObject(id); if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt textLOWBAT.push(obj.common.name); // Zu Array hinzufügen } log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status); ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status }); cacheSelectorLOW_BAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOW_BAT, Homematic IP var status = getState(id).val; // Zustand *.LOW_BAT abfragen (jedes Element) var obj = getObject(id); if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt textLOWBAT.push(obj.common.name); // Zu Array hinzufügen ++anzahlLOWBAT // DAS HIER FEHLTE } log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status); ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status }); // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben log("Text: " + textLOWBAT); log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " + anzahlLOWBAT); // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS) setState("zählenLowbat.textLOWBAT", textLOWBAT.join(', ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung setState("zählenLowbat.anzahlLOWBAT", textLOWBAT.length); // Schreibt die aktuelle Anzahl der Geräte im System setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT); // Schreibt die aktuelle Anzahl der vorhandene Geräte if(anzahlLOWBAT > 0) setTimeout(telegram,2000); // NEU EINGEFÜGT. Telegram wird um 2 Sekunden verzögert geschickt um sicherzugehen, dass alles andere vorher erledigt ist und auch nur, sofern es leere Batterien gibt (was du in deinem Versuch ja quasi simulierst) } cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken countLowbat(obj); }); cacheSelectorLOW_BAT.on(function(obj) { // bei Zustandänderung *. LOW_BAT in allen Gewerken countLowbat(obj); }); schedule("0 */6 * * *", function () { //ausgelöst alle 6 Stunden countLowbat(); }); >! // TELEGRAM ALS FUNKTION NEU EINGEFÜGT: function telegram() { var telegramtext = getState("zählenLowbat.textLOWBAT").val.replace(/ /g , "\n"); // telegram Liste formatieren, entfernt den HTML Zeilenumbruch und ersetzt mit Zeilenumbruch Telegram telegramtext = telegramtext.replace(/_DEV:0.LOW_BAT/g, ""); sendTo('telegram.0', { // Nachricht per Telegram senden text: "Komponenten mit geringem Ladestand:\n\n" + telegramtext }); } //Bei Scriptstart countLowbat();
-
In dem Select wird auf die Datenpunkte ohne ALARM geprüft. Kann man machen. Allerdings war das bei meinen Tests nicht bei allen Fehlermeldungen korrekt. Vorallen UNREACH bzw STICKY_UNREACH. Deshalb nutze ich die *_ALRAM.
-
In dem Select wird auf die Datenpunkte ohne ALARM geprüft. Kann man machen. Allerdings war das bei meinen Tests nicht bei allen Fehlermeldungen korrekt. Vorallen UNREACH bzw STICKY_UNREACH. Deshalb nutze ich die *_ALRAM. ` Dein Script ist ja auch gut so.
(ich wollte Dir nur den LOWBAT und LOW_BAT Unterschied nochmal zeigen, weil ich mich wieder daran erinnert habe das HMIP anders ist.)
-
Ich schicke Dir Morgen nochmal eine Liste mit weiteren Fehlertypen. Auf die könntest Du dann bitte in den Objekten mal filtern. Ich habe da noch welche die ich bei mir nicht zuordnen konnte. Ich vermute das wird dann alles IP-Fehlertypen sein.
ich werde mir wohl doch auch ein paar IP-Geräte kaufen müssen :mrgreen:
-
okay[emoji16]
-
Bitte mal unter Objekte nach folgenden Sachen filtern:
U_SOURCE_FAIL
USBH_POWERFAIL
ERROR_SABOTAGE
STICKY_SABOTAGE
ERROR_REDUCED
ERROR_NON_FLAT_POSITIONING
ERROR_SABOTAGE
SABOTAGE (solltest Du haben unter 0)
LOW_BAT (solltest Du haben unter 0)
Falls Du Treffer hast würde mich interessieren welche Geräte das sind und unter welchen Kanal der Treffer ist.
Filtern einfach:
!
-
Ich habe nur Treffer von diesen beiden…:(alle anderen Suchbegriffe bleiben leer)
-
was hast Du unter hm.rpc.0 und hm.rpc.1?
Unter 0 sind die IP-Geräte und unter 1 normale Homematic? Oder ist das Cuxd oder virtuelle Gruppen?
Werde Deine beiden Fehlermeldungen Morgen oder Übermorgen einbauen. Weiß schon wie ich das umsetze. Die Ermittlung der Batterien lagere ich aus. So kann ich es dann für LOWBAT und LOW_BAT nutzen.
-
LOW_BAT habe ich jetzt drin
sobald ich mehr dazu nehme werden mir wieder 0 mögliche Geräte angezeigt.
! ````
// jshint maxerr:1000
/**************************- Verschickt eine Pushmittteilung bei auftretenden Servicemeldungen bei Homematic-Geräten
- 28.01.19 V1.00 Erste Version
- 30.01.19 V1.01 Bei LowBAT Meldungen wird nun auch der Typ und somit die nötigen Batterien ermittelt
-
UNREACH hinzugefügt
-
STICKY_UNREACH hinzugefügt
-
CONFIG_PENDING hinzugefügt
- 31.01.19 V1.02 Pushnachricht optimiert bei LOWBAT
- 01.02.19 V1.03 UPDATE_PENDING hinzugefügt
-
DEVICE_IN_BOOTLOADER hinzugefügt
-
ERROR hinzugefügt
-
FAULT_REPORTING hinzugefügt
-
Debugging erweitert
- 01.02.19 V1.04 Fehler behoben bei ERROR und FAULT_REPORTING
- 02.02.19 V1.05 Status Texte für ERRPR und FAULT_Reporting hinzugefügt
Pushmitteilung optimiert für ERROR und FAULT_Reporting
Anpassung Debugtexte
Prio ist pro Fehlertyp einstellbar
**************************/
var logging = true;
var debugging = true;
var sendpush = true;
var autoAck = false; //Löschen bestätigbarer Kommunikationsstörungen (true = an, false = aus)
! //pro Fehlertyp kann eine andere Prio genutzt werden
var prio_LOWBAT = 0;
var prio_UNREACH = 0;
var prio_STICKY_UNREACH = 0;
var prio_CONFIG_PENDING = 0;
var prio_UPDATE_PENDING = 0;
var prio_DEVICE_IN_BOOTLOADER = 0;
var prio_ERROR = 0;
var prio_FAULT_REPORTING = 0;
! var _prio;
var _titel;
var _message;
var _device = 'TPhone';
//var _device = 'All';
! //Ab hier eigentliches Script
var cacheSelectorLOWBAT = $('channel[state.id=hm-rpc.0..0.LOW_BAT_ALARM$]');
var cacheSelectorUNREACH = $('channel[state.id=hm-rpc.0..0.UNREACH_ALARM$]');
var cacheSelectorSTICKY_UNREACH = $('channel[state.id=hm-rpc.0..0.STICKY_UNREACH_ALARM$]');
var cacheSelectorCONFIG_PENDING = $('channel[state.id=hm-rpc.0..0.CONFIG_PENDING_ALARM$]');
var cacheSelectorUPDATE_PENDING = $('channel[state.id=hm-rpc.0..0.CONFIG_PENDING_ALARM$]');
var cacheSelectorDEVICE_IN_BOOTLOADER = $('channel[state.id=hm-rpc.0..0.DEVICE_IN_BOOTLOADER_ALARM$]');
var cacheSelectorERROR = $('channel[state.id=hm-rpc.0..1.ERROR$]');
var cacheSelectorFAULT_REPORTING = $('channel[state.id=hm-rpc.0..4.FAULT_REPORTING$]');
! function send_pushover_V4 (_device, _message, _titel, _prio) {
var pushover_Instanz = 'pushover.0';
if (_prio === 0){pushover_Instanz = 'pushover.0'}
else if (_prio == 1){pushover_Instanz = 'pushover.1'}
else if (_prio == 2){pushover_Instanz = 'pushover.2'}
else {pushover_Instanz = 'pushover.3'}
sendTo(pushover_Instanz, {
device: _device,
message: _message,
title: _titel,
priority: _prio,
retry: 60,
expire: 600,
html: 1
});
}
! function LOWBAT(obj) {
// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
var Gesamt = 0;
var Betroffen = 0;
var text = [];
var _message_tmp = ' ';if (obj) {
log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
} else {
log('Ausgelöst durch Scriptneustart.');
}! cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
var status_text;
if(status === 0){
status_text = 'Batterie ok';
}
else if (status == 1){
status_text = 'Batterie niedrig';
}
else if (status == 2){
status_text = 'Batterie ok';
}
var obj = getObject(id);
var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
var id_name = id.split('.')[2];
var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
var datum_neu;
if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;
var Batterie;
var cr2016 = 'HM-RC-4,HM-RC-4-B,HM-RC-Key3,HM-RC-Key3-B,HM-RC-P1,HM-RC-Sec3,HM-RC-Sec3-B,ZEL STG RM HS 4';
var cr2032 = 'HM-PB-2-WM,HM-PB-4-WM,HM-PBI-4-FM,HM-SCI-3-FM,HM-Sec-TiS,HM-SwI-3-FM,HmIP-FCI1';
var lr14x2 = 'HM-Sec-Sir-WM,HM-OU-CFM-TW';
var lr44x2 = "HM-Sec-SC,HM-Sec-SC2,HM-Sec-SC-2,HM-Sec-RHS";
var lr6x2 = "HM-CC-VD,HM-CC-RT-DN,HM-Sec-WDS,HM-Sec-WDS-2,HM-CC-TC,HM-Dis-TD-T,HB-UW-Sen-THPL-I,HM-TC-IT-WM-W-EU,HM-WDS40-TH-I,HM-WDS40-TH-I-2,HM-WDS10-TH-O,HmIP-SMI,HMIP-eTRV,HM-WDS30-OT2-SM-2,HmIP-SMO,HmIP-SMO-A,HmIP-SPI,HmIP-eTRV-2,HmIP-SPDR,HmIP-SWD";
var lr6x3 = "HmIP-SWO-PL,HM-Sec-MDIR,HM-Sec-MDIR-2,HM-Sec-SD,HM-Sec-Key,HM-Sec-Key-S,HM-Sec-Key-O,HM-Sen-Wa-Od,HM-Sen-MDIR,HM-Sen-MDIR-O,HM-Sen-MDIR-O-2,HM-WDS100-C6-O,HM-WDS100-C6-O-2,HM-WDS100-C6-O-2,HmIP-ASIR,HmIP-SWO-B";
var lr6x4 = "HM-CCU-1,HM-ES-TX-WM,HM-WDC7000";
var lr3x1 = "HM-RC-4-2,HM-RC-4-3,HM-RC-Key4-2,HM-RC-Key4-3,HM-RC-Sec4-2,HM-RC-Sec4-3,HM-Sec-RHS-2,HM-Sec-SCo,HmIP-KRC4,HmIP-KRCA,HmIP-RC8,HmIP-SRH,HMIP-SWDO";
var lr3x2 = "HM-Dis-WM55,HM-Dis-EP-WM55,HM-PB-2-WM55,HM-PB-2-WM55-2,HM-PB-6-WM55,HM-PBI-2-FM,HM-RC-8,HM-Sen-DB-PCB,HM-Sen-EP,HM-Sen-MDIR-SM,HM-Sen-MDIR-WM55,HM-WDS30-T-O,HM-WDS30-OT2-SM,HmIP-STH,HmIP-STHD,HMIP-WRC2,HMIP-WRC6,HMIP-WTH,HMIP-WTH-2,HmIP-SAM,HmIP-SLO,HMIP-SWDO-I,HmIP-FCI6";
var lr3x3 = "HM-PB-4Dis-WM,HM-PB-4Dis-WM-2,HM-RC-Dis-H-x-EU,HM-Sen-LI-O";
var lr3x3a = "HM-RC-19,HM-RC-19-B,HM-RC-12,HM-RC-12-B,HM-RC-12-W";
var block9 = "HM-LC-Sw1-Ba-PCB,HM-LC-Sw4-PCB,HM-MOD-EM-8,HM-MOD-Re-8,HM-Sen-RD-O,HM-OU-CM-PCB,HM-LC-Sw4-WM";
var fixed = "HM-Sec-SD-2,HMIP-SWSD";
var recharge = "HM-Sec-Win,HM-Sec-SFA-SM";
var Treffer1 = cr2016.search(native_type);
var Treffer2 = cr2032.search(native_type);
var Treffer3 = lr14x2.search(native_type);
var Treffer4 = lr44x2.search(native_type);
var Treffer5 = lr6x2.search(native_type);
var Treffer6 = lr6x3.search(native_type);
var Treffer7 = lr6x4.search(native_type);
var Treffer8 = lr3x1.search(native_type);
var Treffer9 = lr3x2.search(native_type);
var Treffer10 = lr3x3.search(native_type);
var Treffer11 = lr3x3a.search(native_type);
var Treffer12 = block9.search(native_type);
var Treffer13 = fixed.search(native_type);
var Treffer14 = recharge.search(native_type);
if(Treffer1 >= 0){Batterie = '1x CR2016';}
else if(Treffer2 >= 0){Batterie = '1x CR2032';}
else if(Treffer3 >= 0){Batterie = '2x LR14';}
else if(Treffer4 >= 0){Batterie = '2x LR44/AG13';}
else if(Treffer5 >= 0){Batterie = '2x LR6/AA';}
else if(Treffer6 >= 0){Batterie = '3x LR6/AA';}
else if(Treffer7 >= 0){Batterie = '4x LR6/AA';}
else if(Treffer8 >= 0){Batterie = '1x LR3/AAA';}
else if(Treffer9 >= 0){Batterie = '2x LR3/AAA';}
else if(Treffer10 >= 0){Batterie = '3x LR3/AAA';}
else if(Treffer11 >= 0){Batterie = '3x AAA Akkus - bitte laden';}
else if(Treffer12 >= 0){Batterie = '9Volt Block leer oder unbestimmt';}
else if(Treffer13 >= 0){Batterie = 'Festbatterie leer';}
else if(Treffer14 >= 0){Batterie = 'Akku entladen - bitte aufladen';}
else{Batterie = 'unbekannt';}
var meldungsart = id.split('.')[4];
//const native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;if (status === 1) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt ++Betroffen; text.push(id_name + ' ' +common_name); // Zu Array hinzufügen _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Spannung Batterien/Akkus gering. '+Batterie+'\n'; } ++Gesamt; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status if(debugging){ log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu +' ---' +Batterie); } });
! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
if(Betroffen > 0){
if(logging){
log('Anzahl möglicher Geräte mit Batteriewarnung ' +Gesamt +' Stück, davon Geräte mit LOWBAT: '+Betroffen + ' Stück.');
log('Betroffene Geräte: ' + text.join(', '));} //Push verschicken if(sendpush){ _prio = prio_LOWBAT; _titel = 'Servicemeldung'; _message = 'Batteriewarnung ausgelöst von: '+'\n'; _message = _message + _message_tmp; //_message = "Ausgelöst von: "+'test' +"test2"; send_pushover_V4(_device, _message, _titel, _prio); } } else{ if(debugging){ log('Anzahl möglicher Geräte mit Batteriewarnung ' +Gesamt +' Stück, davon Geräte mit LOWBAT: '+Betroffen + ' Stück.'); } }
}
! function UNREACH(obj) {
// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
var Gesamt = 0;
var Betroffen = 0;
var text = [];
var _message_tmp = ' ';if (obj) {
log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
} else {
log('Ausgelöst durch Scriptneustart.');
}! cacheSelectorUNREACH.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
var status_text;
if(status === 0){
status_text = status;
}
else {
status_text = status;
}var obj = getObject(id); var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':')); var id_name = id.split('.')[2]; var meldungsart = id.split('.')[4]; var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss"); var datum_neu; if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';} var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE; if (status === 1) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt ++Betroffen; text.push(id_name + ' ' +common_name); // Zu Array hinzufügen _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Kommunikation gestört. '+'\n'; } ++Gesamt; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status if(debugging){ log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu); } });
! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
if(Betroffen > 0){
if(logging){
log('Anzahl möglicher Geräte mit UNREACH ' +Gesamt +' Stück, davon Geräte mit UNREACH: '+Betroffen + ' Stück.');
log('Betroffene Geräte: ' + text.join(', '));} //Push verschicken if(sendpush){ _prio = prio_UNREACH; _titel = 'Servicemeldung'; _message = 'Kommunikation gestört von: '+'\n'; _message = _message + _message_tmp; //_message = "Ausgelöst von: "+'test' +"test2"; send_pushover_V4(_device, _message, _titel, _prio); } } else{ if(debugging){ log('Anzahl möglicher Geräte mit UNREACH: ' +Gesamt +' Stück, davon Geräte mit UNREACH: '+Betroffen + ' Stück.'); } }
}
! function STICKY_UNREACH(obj) {
// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
var Gesamt = 0;
var Betroffen = 0;
var text = [];
var _message_tmp = ' ';if (obj) {
log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
} else {
log('Ausgelöst durch Scriptneustart.');
}! cacheSelectorSTICKY_UNREACH.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
var status_text;
if(status === 0){
status_text = status;
}
else {
status_text = status;
}
var obj = getObject(id);
var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
var id_name = id.split('.')[2];
var meldungsart = id.split('.')[4];
var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
var datum_neu;
if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;if (status === 1) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt ++Betroffen; text.push(id_name + ' ' +common_name); // Zu Array hinzufügen if(autoAck){ _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Meldung über bestätigbare Kommunikationsstörung gelöscht. '+'\n'; } else { _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - bestätigbare Kommunikationsstörung. '+'\n'; } } ++Gesamt; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status if(debugging){ log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu); } });
! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
if(Betroffen > 0){
if(logging){
log('Anzahl möglicher Geräte mit STICKY_UNREACH ' +Gesamt +' Stück, davon Geräte mit STICKY_UNREACH: '+Betroffen + ' Stück.');
log('Betroffene Geräte: ' + text.join(', '));} //Push verschicken if(sendpush){ _prio = 0; _titel = 'Servicemeldung'; _message = 'Kommunikation war gestört: '+'\n'; _message = _message + _message_tmp; //_message = "Ausgelöst von: "+'test' +"test2"; send_pushover_V4(_device, _message, _titel, _prio); } } else{ if(debugging){ log('Anzahl möglicher Geräte mit STICKY_UNREACH ' +Gesamt +' Stück, davon Geräte mit STICKY_UNREACH: '+Betroffen + ' Stück.'); } }
}
! function CONFIG_PENDING(obj) {
// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
var Gesamt = 0;
var Betroffen = 0;
var text = [];
var _message_tmp = ' ';if (obj) {
log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
} else {
log('Ausgelöst durch Scriptneustart.');
}! cacheSelectorCONFIG_PENDING.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
var status_text;
if(status === 0){
status_text = status;
}
else {
status_text = status;
}
var obj = getObject(id);
var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
var id_name = id.split('.')[2];
var meldungsart = id.split('.')[4];
var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
var datum_neu;
if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;if (status === 1) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt ++Betroffen; text.push(id_name + ' ' +common_name); // Zu Array hinzufügen _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Konfigurationsdaten stehen zur Übertragung an. '+'\n'; } ++Gesamt; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status if(debugging){ log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu); } });
! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
if(Betroffen > 0){
if(logging){
log('Anzahl möglicher Geräte mit CONFIG_PENDING ' +Gesamt +' Stück, davon Geräte mit CONFIG_PENDING: '+Betroffen + ' Stück.');
log('Betroffene Geräte: ' + text.join(', '));} //Push verschicken if(sendpush){ _prio = prio_UPDATE_PENDING; _titel = 'Servicemeldung'; _message = 'CONFIG_PENDING: '+'\n'; _message = _message + _message_tmp; //_message = "Ausgelöst von: "+'test' +"test2"; send_pushover_V4(_device, _message, _titel, _prio); } } else{ if(debugging){ log('Anzahl möglicher Geräte mit CONFIG_PENDING ' +Gesamt +' Stück, davon Geräte mit CONFIG_PENDING: '+Betroffen + ' Stück.'); } }
}
! function UPDATE_PENDING(obj) {
// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
var Gesamt = 0;
var Betroffen = 0;
var text = [];
var _message_tmp = ' ';if (obj) {
log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
} else {
log('Ausgelöst durch Scriptneustart.');
}! cacheSelectorUPDATE_PENDING.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
var status_text;
if(status === 0){
status_text = status;
}
else {
status_text = status;
}
var obj = getObject(id);
var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
var id_name = id.split('.')[2];
var meldungsart = id.split('.')[4];
var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
var datum_neu;
if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;if (status === 1) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt ++Betroffen; text.push(id_name + ' ' +common_name); // Zu Array hinzufügen _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Update verfügbar. '+'\n'; } ++Gesamt; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status if(debugging){ log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu); } });
! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
if(Betroffen > 0){
if(logging){
log('Anzahl möglicher Geräte mit UPDATE_PENDING ' +Gesamt +' Stück, davon Geräte mit UPDATE_PENDING: '+Betroffen + ' Stück.');
log('Betroffene Geräte: ' + text.join(', '));} //Push verschicken if(sendpush){ _prio = prio_UPDATE_PENDING; _titel = 'Servicemeldung'; _message = 'UPDATE_PENDING: '+'\n'; _message = _message + _message_tmp; //_message = "Ausgelöst von: "+'test' +"test2"; send_pushover_V4(_device, _message, _titel, _prio); } } else{ if(debugging){ log('Anzahl möglicher Geräte mit UPDATE_PENDING ' +Gesamt +' Stück, davon Geräte mit UPDATE_PENDING: '+Betroffen + ' Stück.'); } }
}
! function DEVICE_IN_BOOTLOADER(obj) {
// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
var Gesamt = 0;
var Betroffen = 0;
var text = [];
var _message_tmp = ' ';if (obj) {
log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
} else {
log('Ausgelöst durch Scriptneustart.');
}! cacheSelectorDEVICE_IN_BOOTLOADER.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
var status_text;
if(status === 0){
status_text = status;
}
else {
status_text = status;
}
var obj = getObject(id);
var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
var id_name = id.split('.')[2];
var meldungsart = id.split('.')[4];
var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
var datum_neu;
if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;if (status === 1) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt ++Betroffen; text.push(id_name + ' ' +common_name); // Zu Array hinzufügen _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Gerät startet neu. '+'\n'; } ++Gesamt; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status if(debugging){ log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu); } });
! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
if(Betroffen > 0){
if(logging){
log('Anzahl möglicher Geräte mit DEVICE_IN_BOOTLOADER ' +Gesamt +' Stück, davon Geräte mit DEVICE_IN_BOOTLOADER: '+Betroffen + ' Stück.');
log('Betroffene Geräte: ' + text.join(', '));} //Push verschicken if(sendpush){ _prio = prio_DEVICE_IN_BOOTLOADER; _titel = 'Servicemeldung'; _message = 'DEVICE_IN_BOOTLOADER: '+'\n'; _message = _message + _message_tmp; //_message = "Ausgelöst von: "+'test' +"test2"; send_pushover_V4(_device, _message, _titel, _prio); } } else{ if(debugging){ log('Anzahl möglicher Geräte mit Batteriewarnung ' +Gesamt +' Stück, davon Geräte mit LOWBAT: '+Betroffen + ' Stück.'); } }
}
! function ERROR(obj) {
// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
var Gesamt = 0;
var Betroffen = 0;
var text = [];
var _message_tmp = ' ';if (obj) {
log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
} else {
log('Ausgelöst durch Scriptneustart.');
}! cacheSelectorERROR.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
var status_text;
var obj = getObject(id);
var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
var id_name = id.split('.')[2];
var meldungsart = id.split('.')[4];
var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
var datum_neu;
if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;
if((native_type == 'HM-Sec-RHS') || (native_type == 'HM-Sec-RHS-2') || (native_type == 'HM-Sec-SC') || (native_type == 'HM-Sec-SC-2') ||
(native_type == 'HM-Sec-SCo') || (native_type == 'HM-Sec-MD') || (native_type == 'HM-Sec-MDIR') || (native_type == 'HM-Sec-MDIR-2')){
if(status == 7){
status_text = 'Sabotage';
}
else {
status_text = 'ERROR mit dem Wert: ' +status;
}
}
else if ((native_type=='HM-Sec-Key') || (native_type=='HM-Sec-Key-S') || (native_type=='HM-Sec-Key-O')){
if(status == 1){
status_text = 'Einkuppeln fehlgeschlagen';
}
else if(status == 2){
status_text = 'Motorlauf abgebrochen';
}
else {
status_text = 'ERROR mit dem Wert: ' +status;
}
}
else if (native_type=='HM-CC-VD'){
if(status == 1){
status_text = 'Ventil Antrieb blockiert';
}
else if(status == 2){
status_text = 'Ventil nicht montiert';
}
else if(status == 3){
status_text = 'Stellbereich zu klein';
}
else if(status == 4){
status_text = 'Batteriezustand niedrig';
}
else {
status_text = 'ERROR mit dem Wert: ' +status;
}
}
else {
status_text = 'ERROR mit dem Wert: ' +status;
}
if (status > 0) { // wenn Zustand größer 0, dann wird die Anzahl der Geräte hochgezählt
++Betroffen;
text.push(id_name + ' ' +common_name); // Zu Array hinzufügen
_message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - '+status_text +'. '+'\n';} ++Gesamt; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status if(debugging){ log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu); } });
! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
if(Betroffen > 0){
if(logging){
log('Anzahl möglicher Geräte mit ERROR ' +Gesamt +' Stück, davon Geräte mit ERROR: '+Betroffen + ' Stück.');
log('Betroffene Geräte: ' + text.join(', '));} //Push verschicken if(sendpush){ _prio = prio_ERROR; _titel = 'Servicemeldung'; _message = _message_tmp; //_message = "Ausgelöst von: "+'test' +"test2"; send_pushover_V4(_device, _message, _titel, _prio); } } else{ if(debugging){ log('Anzahl möglicher Geräte mit ERROR ' +Gesamt +' Stück, davon Geräte mit ERROR: '+Betroffen + ' Stück.'); } }
}
! function FAULT_REPORTING(obj) {
// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
var Gesamt = 0;
var Betroffen = 0;
var text = [];
var _message_tmp = ' ';if (obj) {
log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
} else {
log('Ausgelöst durch Scriptneustart.');
}! cacheSelectorFAULT_REPORTING.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
var status_text;
var obj = getObject(id);
var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
var id_name = id.split('.')[2];
var meldungsart = id.split('.')[4];
var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
var datum_neu;
if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;
if(native_type == 'HM-CC-RT-DN'){
if(status === 0){
status_text = 'keine Störung';
}
else if(status == 1){
status_text = 'Ventil blockiert';
}
else if(status == 2){
status_text = 'Einstellbereich Ventil zu groß';
}
else if(status == 3){
status_text = 'Einstellbereich Ventil zu klein';
}
else if(status == 4){
status_text = 'Kommunikationsfehler';
}
else if(status == 6){
status_text = 'Spannung Batterien/Akkus gering';
}
else if(status == 7){
status_text = 'Fehlstellung Ventil';
}
else{
status_text = 'FAULT_REPORTING mit dem Wert: ' +status;
}
}
else{
status_text = 'FAULT_REPORTING mit dem Wert: ' +status;
}
if (status > 0) { // wenn Zustand größer 0, dann wird die Anzahl der Geräte hochgezählt
++Betroffen;
text.push(id_name + ' ' +common_name); // Zu Array hinzufügen
_message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - ' +status_text +'. '+'\n';} ++Gesamt; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status if(debugging){ log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu); } });
! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
if(Betroffen > 0){
if(logging){
log('Anzahl möglicher Geräte mit FAULT_REPORTING ' +Gesamt +' Stück, davon Geräte mit FAULT_REPORTING: '+Betroffen + ' Stück.');
log('Betroffene Geräte: ' + text.join(', '));} //Push verschicken if(sendpush){ _prio = prio_FAULT_REPORTING; _titel = 'Servicemeldung'; _message = _message_tmp; //_message = "Ausgelöst von: "+'test' +"test2"; send_pushover_V4(_device, _message, _titel, _prio); } } else{ if(debugging){ log('Anzahl möglicher Geräte mit FAULT_REPORTING ' +Gesamt +' Stück, davon Geräte mit FAULT_REPORTING: '+Betroffen + ' Stück.'); } }
}
! cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung . LOWBAT in allen Gewerken
LOWBAT(obj);
});
/
cacheSelectorUNREACH.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
UNREACH(obj);
});
! cacheSelectorSTICKY_UNREACH.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
STICKY_UNREACH(obj);
});
! cacheSelectorCONFIG_PENDING.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
CONFIG_PENDING(obj);
});
! cacheSelectorUPDATE_PENDING.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
UPDATE_PENDING(obj);
});
! cacheSelectorDEVICE_IN_BOOTLOADER.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
DEVICE_IN_BOOTLOADER(obj);
});
cacheSelectorERROR.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
ERROR(obj);
});
cacheSelectorFAULT_REPORTING.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
FAULT_REPORTING(obj);
});
*/
! //beim Start
LOWBAT();
//UNREACH();
//STICKY_UNREACH();
//CONFIG_PENDING();
//UPDATE_PENDING();
//DEVICE_IN_BOOTLOADER();
//ERROR();
//FAULT_REPORTING();
! ````IN rpc.0 sind HMIP und in rpc.1 sind normale
(kann aber sein das da noch cuxd und virtuelle rum schwirren, ich habe schon länger nicht aktualisiert bzw. gelöscht. Ich hatte cuxd und virtuell mal probiert.
Kann aber sein das da auch Heizgruppen von der CCU drinn sind ,die sind ja auch virtuell)
PS: in allen Kommentaren steht noch LOWBAT, das sollten wir/Du noch korrigieren)
-
Du hast LOW_BAT sowohl in hm.rpc.0 und 1.
Klapp mal bitte bei Instanzen auf. Und bitte auch jeweils ein Gerät damit ich sehe in welchen Kanal dann etwas ist.
!
Und was heißt sobald ich mehr dazu nehme werden mir wieder 0 mögliche Geräte angezeigt?
-
Neuer Tag neue Version.
Im erstenPost habe ich das aktualisierte Script mit der Version 1.06 vom 03.02.19 veröffentlicht.
Bitte den kompletten Beitrag nochmal lesen. Ich habe Änderungen in der Grundkonfig vorgenommen die man anpassen sollte.
Folgende Sachen habe ich verändert:
03.02.19 V1.06 Batterien ermitteln in eigene function ausgelagert
-
LOW_BAT aufgenommen
-
SABOTAGE aufgenommen
-
Neu Configmöglichkeit onetime für einmaliges prüfem
-
Neue Configmöglichkeit observation für Dauerhafte Überwachung
-
Fehler CONFIG_PENDING behoben
-
-
Vor dem richtigen Einsatz solltet Ihr etwas testen. Dazu die Variable "intime" auf true und "oberservation" auf false. Das Script Speichern und einmal im Log nachschauen. Dort solltet Ihr dann z. B sowas sehen:
Bei Fragen: fragen :mrgreen: `
Bin ich blind, ich sehe keine Variable von intime
-
Habe es korrigiert. Sollte "onetime" heißen.
-
Habe es korrigiert. Sollte "onetime" heißen. `
Danke, dachte es mir….
Teste gerade, schaut gut aus. LowBat muss ich noch abklären....
Ich habe die cUXD auf 0 und die Homematic auf 1, das muss ich dann noch anpassen.....
> Desweiteren werden derzeit nur Fehler gemeldet die auf der Instanz 0 laufen. Solltet Ihr mehrere Instanzen von Homematic RPC haben müsst Ihr das Script anpassen.
Ja, und wo genau?
Ich denke hier diese von 0 auf 1 ändern?
-
Ich werde es wahrscheinlich noch anpassen so dass, das Script auf alle Instanzen prüft. Das ein oder andere in Deinem Log gefällt mir auch noch nicht so ganz, das werde ich auch mal anpassen. Soweit schaut es aber gut.
Danke fürs Log.
-
Ja genau. Schmeiß einfach mal das erste „.0“ daraus. Wichtig auch den „.“ vor der 0.
Sollte dann so aus sehen:
var cacheSelectorLOWBAT = $('channel[state.id=hm-rpc.*.0.LOWBAT_ALARM$]');
Das jeweils bei allen cacheSelectorXXXX die Zahl vor dem Fehlertyp sollte so bleiben…