NEWS
TR-064 Fritzbox Anrufbeantworter
-
@Feuersturm sagte in TR-064 Fritzbox Anrufbeantworter:
@sigi234 Du musst in der Javascript Instanz unter "Zusätzliche NPM Module" noch "xml2js" (mit Enter bestätigen) eintragen
Habe ich.
javascript.0 2020-09-03 23:14:19.107 error at Parser.exports.Parser.Parser.parseString (C:\Program Files\iobroker\Test\node_modules\iobroker.javascript\node_modules\xml2js\lib\parser.js:323:31)) javascript.0 2020-09-03 23:14:19.107 error at SAXParser.write (C:\Program Files\iobroker\Test\node_modules\iobroker.javascript\node_modules\xml2js\node_modules\sax\lib\sax.js:1436:13) javascript.0 2020-09-03 23:14:19.107 error at closeTag (C:\Program Files\iobroker\Test\node_modules\iobroker.javascript\node_modules\xml2js\node_modules\sax\lib\sax.js:889:7) javascript.0 2020-09-03 23:14:19.107 error at emitNode (C:\Program Files\iobroker\Test\node_modules\iobroker.javascript\node_modules\xml2js\node_modules\sax\lib\sax.js:629:5) javascript.0 2020-09-03 23:14:19.107 error at emit (C:\Program Files\iobroker\Test\node_modules\iobroker.javascript\node_modules\xml2js\node_modules\sax\lib\sax.js:624:35) javascript.0 2020-09-03 23:14:19.107 error at SAXParser.onclosetag (C:\Program Files\iobroker\Test\node_modules\iobroker.javascript\node_modules\xml2js\lib\parser.js:262:26) javascript.0 2020-09-03 23:14:19.107 error at Parser.EventEmitter.emit (domain.js:482:12) javascript.0 2020-09-03 23:14:19.107 error at Parser.emit (events.js:315:20) javascript.0 2020-09-03 23:14:19.107 error at Parser.<anonymous> (C:\Program Files\iobroker\Test\node_modules\iobroker.javascript\node_modules\xml2js\lib\parser.js:304:18) javascript.0 2020-09-03 23:14:19.107 error at script.js.Fritz.Anrufbeantworter:174:74 javascript.0 2020-09-03 23:14:19.107 error (14724) Error in request callback: Error [ERR_UNHANDLED_ERROR]: Unhandled error. (TypeError: Cannot read property 'Index' of undefined javascript.0 2020-09-03 23:14:19.104 info (14724) script.js.Fritz.Anrufbeantworter: Result: {"Root":{"Message":{"Index":"0","Tam":"0","Called":"0000000000000000","Date":"25.07.20 08:48","Duration":"0:01","Inbook":"0","Name":"","New":"0","Number":"
-
@sigi234 Hmm, jetzt gehen mir langsam die Ideen aus. Welche (Adapter) Versionen setzt du ein? Ich habe folgendes im Einsatz:
js-controller: 3.1.6
node: 12.18.0
nodejs: v12.18.0
npm: 6.14.4
Admin: 4.1.7
Java Script Enging: 4.6.26Zum Zeitpunkt 2020-09-03 23:14:19.104 wird der JSON String ja ausgegeben. Der String scheint abgeschnitten zu sein. Hat er die gleiche Struktur wie in meinem Beispiel oben?
-
@Feuersturm sagte in TR-064 Fritzbox Anrufbeantworter:
Zum Zeitpunkt 2020-09-03 23:14:19.104 wird der JSON String ja ausgegeben. Der String scheint abgeschnitten zu sein. Hat er die gleiche Struktur wie in meinem Beispiel oben?
Geht jetzt, habe mal auf den AB gesprochen.
-
@sigi234 Das klingt doch gut
Ich tüftel gerade damit, dass ich den JSON String mit dem widget "basic - table" angezeigt bekomme. Wenn ich den Inhalt aus dem Datenpunkt im Widget angebe wird mir nichts ausgegeben.
Wenn man am Anfang
{"Root": {"Message":
sowie am Ende}}
vom JSON String entfernt, dann lassen sich meine beiden Einträge anzeigen
-
Da kann uns sicher ein Spezialist helfen.
Cool wäre es wenn man den AB Status in einen DP schreiben kann.@apollon77
Das haben wir schon lange gesucht, da kann man ja was machen? -
@sigi234 Die Info das eine neue Nachricht / noch nicht abgehörte Nachrichten vorhanden sind kann man mit ein paar Zeilen garantiert extrahieren.
Mit dem Ausdruckresult.Root.Message.length
kommt man an die Info wieviele Nachrichten auf dem AB sind und dann lässt man eine Schleife durchlaufen wo aufJSON.stringify(result.Root.Message[i].New
== 1 geprüft wird. Wenn mindestens einmal die Prüfung true ist, schreibt man dies in einen neuen Datenpunkt.log("Einträge / Länge: " + JSON.stringify(result.Root.Message.length)); log("Nachricht neu: " + JSON.stringify(result.Root.Message[0].New));
Das werde ich in den nächsten Tagen noch in das Skript einbauen aber nicht mehr heute
-
Ich hänge gerade noch an folgender Stelle.
Im XML ist als Kommentar folgende Information enthalten<!-- tam calls:2 -->
Diese Information wird leider nicht ins JSON Format mit überführt. Ich vermute weil es im XML nur ein Kommentar ist. Gibt es eine einfache Möglichkeit, dass diese Kommentare auch mit in der JSON Struktur landen oder muss man sich das XML zurechntschneiden und wegspeichern, um an die Information zu gelangen?
Diese Info könnte man nutzen, um einfacher die Auswertung vom JSON Format zu machen, da dies in Abhängigkeit von der Anzalhl der Nachrichten etwas anders aufgebaut ist:
Abhängig von der Anzahl der Nachrichten auf dem AB sieht die JSON Sturktur etwas anders aus
//Wenn keine Nachricht auf dem AB ist //JSON: {"Root":"\n\n\n\n"} //Wenn nur eine Nachricht vorhanden ist, dann enthält Message kein Array: //JSON: {"Root":{"Message":{"Index":"0" //Wenn mehr als eine Nachricht vorhanden sind, dann enthält Message ein Array: //JSON: {"Root":{"Message":[{"Index":"1",....},{"Index":"0",...}]}}
-
Nearly all services except GetSecurityPort from the example above need authentication. The best way to achieve this is to add an extra user with its own password.
-
@sigi234 sagte in TR-064 Fritzbox Anrufbeantworter:
Das haben wir schon lange gesucht, da kann man ja was machen?
Details als Issue oder besser ein PR wäre awesome
-
@Feuersturm
Bist du schon weiter? -
@sigi234 Noch nicht aber ich bin guter Dinge, dass ich jetzt am Wochenende abends etwas Zeit dafür habe. Die Idee dass mittelfristig in den Adapter zu überführen finde ich gut. Da ich noch keine Erfahrung mit der Adapter Programmierung habe würde ich erstmal das Skript weiter entwickeln und dann kann man die Mechanismen vermutlich relativ einfach in den Adapter überführen.
Es gibt wohl auch die Möglichkeit, dass man Nachrichten auch löschen kann und das man den Status Neu verändern kann wobei ich noch nicht weiß wofür man das effektiv gebrauchen kann.
-
@apollon77 Details in github sind kein Problem. Für einen PR fehlt mir noch die Erfahrung mit Adapter Programmierung. Ich hab nebenbei schon versucht den Code vom tr-064 zu verstehen bin aber noch ganz weit weg wie das alles zusammen hängt.
-
Und es geht weiter
Ich hab das Skript jetzt so umgebaut / erweitert, dass die Information zu den Anrufern aus dem Anrufbeantworter der Fritzbox ausgelesen und in einen Datenpunkt gespeichert werden. Ebenfalls extrahiere ich die Information wieviele Nachrichten insgesamt und wieviele neue Nachrichten vorliegen. Dies wird ebenfalls in zwei Datenpunkten gespeichert.
Bei mir sind die ersten Tests mit einer Fritzbox 7530 und SW 7.20 erfolgreich gewesen.In den Zeilen 37 und folgende legt ihr fest, wo die Datenpunkt angelegt werden sollen.
Skript
Darstellung in VIS wenn keine Nachrichten vorhanden sind:
Darstellung in VIS wenn Nachrichten vorliegen:
Export vom Widget zum Anzeigen der Anrufbeantwortereinträge
Widget um AB Einträge zu Löschen
Als Beispiel wird das Widget "materialdesign - Select" Widget verwendet
Änderungshistorie
13.09.2020: Skript aktualisiert, Widget zur Darstellung der Anrufer aktualisiert, Widget zum Löschen von Einträgen hinzugefügt
22.09.2020: Wenn keine Nachricht auf dem AB vorhanden ist, wird in den Datenpunkt DP_Fritzbox_AnrufbeantworterIndexMessage_json ein Eintrag hinzugefügt, dass keine Nachricht vorhanden ist. -
@Feuersturm sagte in TR-064 Fritzbox Anrufbeantworter:
Bei mir sind die ersten Tests mit einer Fritzbox 7530 und SW 7.20 erfolgreich gewesen.
Dito mit FB 6590 SW 7.20
-
@sigi234 Danke für die Rückmeldung
Im nächsten Schritt würde ich das Skript jetzt so erweitern, dass die Informationen für den Anrufbeantworter nach einem entsprechenden Trigger aktualisiert werden. Ich hab hierzu dieses Skript https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/5 gefunden. Vielleicht kann man dies ja entsprechend hier mit einbauen.
@sigi234 Hälst du es für sinnvoll, dass man Nachrichten über Datenpunkte / VIS als "abgehört" markieren kann bzw. die Nachrichten löschen kann?
-
@Feuersturm sagte in TR-064 Fritzbox Anrufbeantworter:
@sigi234 Hälst du es für sinnvoll, dass man Nachrichten über Datenpunkte / VIS als "abgehört" markieren kann bzw. die Nachrichten löschen kann?
Ja auf jeden Fall!
-
@sigi234 sagte in TR-064 Fritzbox Anrufbeantworter:
Dito mit FB 6590 SW 7.20
Schon eingebaut in Vis.
-
@sigi234 Ich bin gerade dabei, dass man über ein Dropdown Menü den Index der vorhandenen Nachrichten auswählen kann, so dass diese nach Auswahl dann gelöscht wird. Für heute geht es aber erstmal in die Falle. Wenn ich was neues habe melde ich mich.
-
Ich habe meinen "alten" Beitrag https://forum.iobroker.net/topic/14288/tr-064-fritzbox-anrufbeantworter/39 aktualisiert.
Ich habe dieses Skript (https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/5) hier verwendet, um zu erkennen, ob jemand auf den Anrufbeantworter gesprochen hat. Dies hat bei mir bisher zuverlässig funktioniert. 3s nach dieser Erkennung werden die Informationen aus der Fritzbox ausgelesen und in die entsprechenden Datenpunkte geschrieben.
Es stehen jetzt ebenfalls zwei neue Datenpunkte bereit, um bestehende Nachrichten vom Anrufbeantworter zu löschen. In dem einen Datenpunkt javascript.0.Telefon.Anrufbeantworter.Fritzbox_AnrufbeantworterIndexMessage_json wird für die jeweilige Nachricht der Index eingetragen, so dass man diese Information aus dem Datenpunkt für das "materialdesign - Select" Widget als Input verwenden kann. In den Datenpunkt javascript.0.Telefon.Anrufbeantworter.Fritzbox_AnrufbeantworterDeleteMessage wird dann vom Select Widget die Indexnummer geschrieben welche gelöscht werden soll.
Nach dem Löschen werden die Nachrichten aus dem Anrufbeantworter neu ausgelesen und auch die Inhalte für das Select Widget werden aktualisiert.
@sigi234 Viel Spaß beim testen
-
@Feuersturm sagte in TR-064 Fritzbox Anrufbeantworter:
"materialdesign - Select" Widget als Input
Als ID?