NEWS
[Vorlage] Generische Batteriestandsüberwachung + Vis-ausgabe
-
@pittini said in [Vorlage] Generische Batteriestandsüberwachung + Vis-ausgabe:
50....na das is ja mal ne Ansage. Ich werd sehen was ich tun kann, gib mir mal nen Screenshot vom Raw eines dieser Datenpunkte.
Hey Pittini. Konntest Du Dir das schon ansehen?
-
Ich bekomme momentan eine Pushnachricht, dass bei dem im Bild unter Info gekennzeichneten Sensor die Batteriespannung unter Limit sei. Im Bild ist jedoch zu erkennen, dass der nicht unter Limit ist. Das was das Script anzeigt ist alles richtig, hab ich soweit überprüft, die Frage ist nun warum bekomm ich die Meldung das die Batteriespannung unter Limit ist?
-
@dominik-f der Entwickler wollte sein Script noch Anpassen, das unterm Limit < erst die Meldung kommt. <=
-
Okay super. Ich hatte in Erinnerung das es ein Problem gab wenn U ist = U Limit ist und dann die Meldung fälschlicherweise kommt.
-
Hm hab paar Homematic Geräte hinzugefügt ( Zigbee keine Probleme ) Die HM Geräte tauchen ALLE nicht auf nirgendwo. Im Script hab ich folgende Fehler:
20:04:08.621 info javascript.0 (12421) script.js.common.batteriecheck: Reaching MakeTable 20:04:08.623 error javascript.0 (12421) at MakeTable (script.js.common.batteriecheck:557:81) 20:04:08.623 error javascript.0 (12421) at CheckDeadBatt (script.js.common.batteriecheck:351:13) 20:04:08.623 error javascript.0 (12421) at main (script.js.common.batteriecheck:235:5) 20:04:08.623 error javascript.0 (12421) at Object.<anonymous> (script.js.common.batteriecheck:106:13)
Im Log:
javascript.0 2021-05-06 20:06:45.712 error at processImmediate (internal/timers.js:463:21) javascript.0 2021-05-06 20:06:45.712 error at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1976:38) javascript.0 2021-05-06 20:06:45.712 error at Object.<anonymous> (script.js.common.batteriecheck:106:13) javascript.0 2021-05-06 20:06:45.712 error at main (script.js.common.batteriecheck:235:5) javascript.0 2021-05-06 20:06:45.712 error at CheckDeadBatt (script.js.common.batteriecheck:351:13) javascript.0 2021-05-06 20:06:45.712 error at MakeTable (script.js.common.batteriecheck:557:81) javascript.0 2021-05-06 20:06:45.711 error Error in callback: TypeError: Cannot read property 'toFixed' of undefined
-
@chrisxy Zeig mal nen Screenshot der Objektliste wo ich die Zuweisug zu den HM Geräten seh. Und nen Log bei im Skript aktiviertem logging.
-
@pittini hi das Log war aktiv sind die ersten meldungen.
-
Du hast keine Räume definiert
-
@dominik-f ja nutze ich nie auch bei Zigbee nicht da gehts aber hm
-
@chrisxy sagte in [Vorlage] Generische Batteriestandsüberwachung + Vis-ausgabe:
ja nutze ich nie auch bei Zigbee nicht da gehts aber hm
- Halt Dich an die Anweisung bzgl. der Räume oder lass es, gibt jedenfalls keinen Support wenn nicht.
- Battery State hat nen null Wert, was soll das Skript damit anfangen? Gibts nicht wenigstens, wie bei den meisten HM Geräten nen lowbat Datenpunkt? Dann nimm den.
-
@pittini sorry hab nicht lang genug gewartet für den Screen da steht 3,2
Hab mir noch kein Plan mit den Räumen gemacht. Zigbee hat auch ohne Raum geklappt deswegen für mich unnötig. Das würde die Anzeige im bis auch zu lang machen. Hab das rooms schon raus gemacht für Telegramm und vis. Aber hab zum Test das Original 1:1 am laufen. Versteh das nicht wieso es da zu Fehlern kommt. Aber Werd ich die Räume wohl Mal zuweisen müssen. -
Das Skript braucht einfach die Zuweisung der Räume weil es dementsprechend programmiert ist, daher kommt es dann zu Fehlern.
Es ist schon wichtig, dass du dich an die Anweisungen von Pittini hälst. Falls es durch Zufall vorher funktioniert hat, dann war das wirklich nur Zufall. 99% der Fehler oder Probleme die hier auftauchen haben meistens damit zu tun, dass die Anleitung nicht befolgt wird. -
Irgendwie bin ich zu blöd den Adapter zu installieren.
ich benutze folgende Url
https://github.com/Pittini/iobroker-Batterienauswertung.git
mit der Katze.
Während der Installation bekomme ich immer folgende log
$ ./iobroker url "https://github.com/Pittini/iobroker-Batterienauswertung.git" --debug install Pittini/iobroker-Batterienauswertung#f8762c8c34b9ec20e5e283c910fabcf32fbbb786 NPM version: 6.14.12 npm install Pittini/iobroker-Batterienauswertung#f8762c8c34b9ec20e5e283c910fabcf32fbbb786 --loglevel error --prefix "/opt/iobroker" (System call) npm ERR! premature close npm ERR! A complete log of this run can be found in:npm ERR! /home/iobroker/.npm/_logs/2021-05-14T16_49_52_483Z-debug.log ERROR: host.raspberrypi Cannot install Pittini/iobroker-Batterienauswertung#f8762c8c34b9ec20e5e283c910fabcf32fbbb786: 1 ERROR: process exited with code 25
-
@torsten_mg sagte in [Vorlage] Generische Batteriestandsüberwachung + Vis-ausgabe:
Irgendwie bin ich zu blöd den Adapter zu installieren.
Das ist ein Skript und kein Adapter!
-
ok, das habe ich auch probiert und kriege das auch irgendwie nicht hin.
Ich habe die zip runtergeladen, dann bei Scripte => oben bei den 3 Punkten auf scripts importieren geklickt.
Anschließend hatte ich folgendes Script:
{ "compileOnSave": true, "compilerOptions": { // do not compile anything, this file is just to configure type checking "noEmit": true, // check JS files "allowJs": true, "checkJs": true, "module": "commonjs", "moduleResolution": "node", // this is necessary for the automatic typing of the adapter config "resolveJsonModule": true, // Set this to false if you want to disable the very strict rules (not recommended) "strict": true, // Or enable some of those features for more fine-grained control // "strictNullChecks": true, // "strictPropertyInitialization": true, // "strictBindCallApply": true, "noImplicitAny": false, "noUnusedLocals": true, "noUnusedParameters": true, // Consider targetting es2017 or higher if you require the new NodeJS 8+ features "target": "es2017", }, "include": [ "**/*.js", "**/*.d.ts" ], "exclude": [ "node_modules/**", "admin/**" ] }
und da komme ich dann nicht weiter
ich bekomme folgende Fehlermeldung
14.5.2021, 19:23:15.964 [info ]: javascript.0 (3186) Stop script script.js.iobroker-Batterienauswertung-master.tsconfig 14.5.2021, 19:23:15.984 [info ]: javascript.0 (3186) Start javascript script.js.iobroker-Batterienauswertung-master.tsconfig 14.5.2021, 19:23:15.991 [error]: javascript.0 (3186) script.js.iobroker-Batterienauswertung-master.tsconfig compile failed: at script.js.iobroker-Batterienauswertung-master.tsconfig:2
-
@torsten_mg sagte in [Vorlage] Generische Batteriestandsüberwachung + Vis-ausgabe:
Ich habe die zip runtergeladen, dann bei Scripte => oben bei den 3 Punkten auf scripts importieren geklickt.
Nein, nicht eine Zip runterladen.
Die .js anklicken und dann den Inhalt kopieren und im Script-Adapter als neues JS anlegen, Text einfügen und an dich anpassen.
-
Hallo
Ich hab das Script von Github in Betrieb genommen - laut Der DemoWidgetTable funktioniert auch.
Nun möchte ich primär via Telegram informiert werden.Ich bekomme aber DeadDetect-Meldungen "Ausfall oder disconnect im Garten bei Gerät TradfriSwitch2" statt LowBat Meldungen, die ich erwartet hätte. Dabei habe ich die Function für DeadDetect nicht gesetzt für irgendwelche Geräte.
Nur "BatterieSpannung_30" habe ich gesetzt.
Und diese DeadDetect-Meldung kommt über den Tag auch einige Male, also nicht nur einmalig, was sehr merkwürdig ist.Was mache ich falsch?
Gruss -
-
@adarof Klingt mir danach dass die Zeit für den DeadCheck zu kurz eingestellt ist. D.h. das Script prüft IMMER ob der Batterie Datenpunkt aktualisiert wird innerhalb einer einstellbaren Zeit, wenn nicht kommt diese Meldung. Wenn jetzt nach der Meldung das Gerät dann doch aktualisiert, wird intern wieder auf alive gesetzt und dann wird wieder die Zeit überschritten usw. Jetzt gibts dafür zwei Lösungsansätze. Zum einen die Zeit erhöhen in Zeile 20 oder den zusätzlichen DeadCheck auf nen anderen Datenpunkt des Gerätes legen welcher öfter aktualisiert wird.
-
@pittini Dankeschön. D.h. es wird auch für die mit BatterieSpannung_30 usw per Function "markierten" Geräte ein DeadCheck durchgeführt, selbst wenn die DeadCheck Function nicth explizit gesetzt wurde? Bei mir sind das Beispielsweise Tradfri Schalter, die ich überwachen möchte. Die werden Tagelang nicht gedrückt (letzte Aktuallisierung habe ich gerade am 15.5. ... da hab ich wohl das letzte mal das Garagentor auf gemacht ...) und damit nicht aktuallisiert - das ist völlig OK für mich, auch wenn die Batteriespannung nur alle paar Tage überprüft wird.
Andere Geräte würde ich liebend gern per Deadcheck überprüfen - z.B. den Bewegungsmelder von Tradfri, wenn der 1x am Tag keine Helligkeitsänderung geschickt hat ... ist er vermutlich "weggelaufen".
Kann ich die beiden Funktionen DeadCheck + BatterieSpannung entkoppeln? -
@adarof Du hasts noch nicht ganz verstanden, entkoppeln kann nicht gehen weil das Skript IMMER den DeadCheck für den Batteriedatenpunkt ausführt weil alle Geräte welche ich kenne, mit wenigen Ausnahmen diesen DP regelmäßig aktualisieren. Nur die Tradfris nicht, hab selber zwei die mich ärgern. Da es aber noch andere Geräte gibt die sehr selten aktualisieren, gibts quasi als zweite Stufe den separaten Deadcheck. Also Skript macht DeadCheck auf BatterieDp, wenn da tot rauskommt, wird geguggt obs nen zweiten extra Deadcheck gibt und nur wenn der auch tot meldet wird gemeldet. Gibts keinen extra DeadCheck wird sofort gemeldet. Bin aber tatsächlich am überlegen ob ich nicht tatsächlich das als zwei Funktionen mach, hab nur grad wenig Zeit.