Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. TR-064 Fritzbox Anrufbeantworter

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    TR-064 Fritzbox Anrufbeantworter

    This topic has been deleted. Only users with topic management privileges can see it.
    • falke69
      falke69 @JoJo58 last edited by falke69

      @jojo58

      ich nutze aktuell die v8.3.1. Das alte Script lief tadellos. Alle Adapter sind auf den aktuellen Stand (kein Beta)
      Aktuell nutze ich noch Node.js 18.
      Mit dem Script von @MCU habe ich diese Fehlermeldungen erhalten, Daher habe ich versucht das original Script zu ändern.
      Das was dabei rausgekommen ist, scheint aktuell zu funktionieren.

      JoJo58 1 Reply Last reply Reply Quote 0
      • JoJo58
        JoJo58 @falke69 last edited by

        @falke69

        Okay, dann bin ich leider raus, habe keine Ahnung vom Programmieren. Ich verstehe manche Abschnitte in einem Skript, könnte aber nicht sagen ob das richtig oder falsch ist. Dann musst du doch auf MCU warten, das er eventuell noch mal drüber schaut.

        Gruß, Johannes

        falke69 1 Reply Last reply Reply Quote 0
        • falke69
          falke69 @JoJo58 last edited by

          @jojo58

          kein Problem.
          Ich verstehe es genau so wenig Fehler zu interpretieren, noch dazu die ganzen Befehle in den Scripten.
          Blockly ist schon eher was, wo ich einen gewissen Überblick habe und einige Schlüsse ziehen kann.

          1 Reply Last reply Reply Quote 1
          • M
            MCU @falke69 last edited by

            @falke69
            bc22cea5-84a8-4e84-99c9-a107fdd80445-image.png
            Wie sieht bei dir die Zeile 254 und die Zeile 156 im script aus?

            Aber egal, wenn es mit Deiner Änderung funktioniert ist es ok.
            Du hast direkt body durch response.data ersetzt

            1 Reply Last reply Reply Quote 0
            • falke69
              falke69 last edited by

              @mcu

              ja irgendwie sind die Zeilen bei mir leer. Ich habe gerade mal die vielen großen Abstände und leeren Zeilen rausgenommen und das Script hier angehangen.
              Ich denke mal durch meinen Umbau ist der eine oder andere Abstand entstanden.

              
              
              /*
              https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/6
              https://forum.iobroker.net/topic/14288/tr-064-fritzbox-anrufbeantworter/39
              Kurzbeschreibung
              
              Mit diesem Skript können die Anrufbeantworterdaten der Anrufer aus der Fritzbox ausgelesen werden. Die Informationen werden in einer JSON Struktur zur Verfügung gestellt.
              
              Vorhande Einträge (Indexnummern) auf dem Anrufbeantworter werden ebenfalls in einer JSON Struktur zur verfügung gestellt werden und einzelne Nachrichten auf dem
              
              Anrufbeantworter können auf Basis der Indexnummer gelöscht werden. 
              
              {1}
              
              Einschränkungen:
              
                        - aktuell keine
              
              {1}
              
              {1}
              
              2020-09-03: Initiale Version um Informationen aus der Fritzbox über die API auszulesen
              
                        https://avm.de/service/schnittstellen/?spm=a2c6h.14275010.0.0.202628cfwq7844
              
                        https://forum.iobroker.net/topic/14288/tr-064-fritzbox-anrufbeantworter/21
              
                        https://developer.aliyun.com/mirror/npm/package/iobroker.tr-064
              
              {1}
              
              {1}
              
              2020-09-09: Mit der Funktion Fritzbox_Anrufbeantworter_GetMessageList() werden die auf dem Fritzbox hinterlegten Anrufe auf dem Anrufbeantworter ausgelesen. 
              
                        Getestet mit Fritzbox 7530 SW 7.20, Fritzbox 6590 SW 7.20
              
              {1}
              
              2020-09-12:
              
                        - Konstante NewIndex_Anrufbeantworter eingeführt welche die ID des Anrufbeatworters in der Fritzbox entspricht
              
                        - Mit dem Skript aus https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/5 wird ermittelt ob der Anrufer
              
                          auf den Anrufbeantworter gesprochen hat und es werden die Daten aus der Fritzbox ausgelesen
              
                        - Datenpunkt (Button) eingefügt um manuell das Auslesen der Daten aus dem Anrufbeantworter zu triggern
              
                        - Im Datenpunkt DP_Fritzbox_AnrufbeantworterDeleteMessage wird der Index der Nachricht auf dem Anrufbeantworter eingetragen welcher gelöscht werden soll
              
              {1}
              
              2020-09-13:
              
                        - Im Datenpunkt DP_Fritzbox_AnrufbeantworterIndexMessage_json wird ein JSON String für das Widget "materialdesign - Select" erzeugt, welches die Index Einträge
              
                          der Anrufereinträge auf dem Anrufbeantworter enthält  
              
                          
              
              2020-09-22:
              
                        - 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.               
              
              */
              
              
              
              const debug = true;
              
              
              
              const NewIndex_Anrufbeantworter = 0; //ID des Anrufbeantworters in der Fritzbox. Der erste Anrufbeantworter hat die ID 0
              
              
              
              
              
              const DP_Fritzbox_AnrufbeantworterDaten_json                = "0_userdata.0.Telefon.Anrufbeantworter.Fritzbox_AnrufbeantworterDaten_json";
              
              const DP_Fritzbox_AnrufbeantworterDatenAktualisieren        = "0_userdata.0.Telefon.Anrufbeantworter.Fritzbox_AnrufbeantworterDatenAktualisieren";
              
              const DP_Fritzbox_AnrufbeantworterGesamtAnzahlNachrichten   = "0_userdata.0.Telefon.Anrufbeantworter.Fritzbox_AnrufbeantworterGesamtAnzahlNachrichten";
              
              const DP_Fritzbox_AnrufbeantworterAnzahlNeueNachrichten     = "0_userdata.0.Telefon.Anrufbeantworter.Fritzbox_AnrufbeantworterAnzahlNeueNachrichten"
              
              const DP_Fritzbox_AnrufbeantworterDeleteMessage             = "0_userdata.0.Telefon.Anrufbeantworter.Fritzbox_AnrufbeantworterDeleteMessage";
              
              const DP_Fritzbox_AnrufbeantworterIndexMessage_json         = "0_userdata.0.Telefon.Anrufbeantworter.Fritzbox_AnrufbeantworterIndexMessage_json";
              
              
              
              
              
              createState(DP_Fritzbox_AnrufbeantworterDaten_json, '{}', {name: 'JSON Struktur mit den Daten vom Anrufbeantworter aus der FritzBox', unit: '', type: 'string', role: 'value', def: '{}'});
              
              createState(DP_Fritzbox_AnrufbeantworterDatenAktualisieren, false,{name: 'Manueller Trigger um die Daten aus dem Anrufbeantworter auszulesen', unit: '', read: true, write: true, type: 'boolean', role: 'button', def: false}); 
              
              createState(DP_Fritzbox_AnrufbeantworterGesamtAnzahlNachrichten, 0, {name: 'Gesamtanzahl der Nachrichten auf dem Anrufbeantworter', unit: '', type: 'number', role: 'value', def: 0});
              
              createState(DP_Fritzbox_AnrufbeantworterAnzahlNeueNachrichten, 0, {name: 'Anzahl der neuen Nachrichten auf dem Anrufbeantworter', unit: '', type: 'number', role: 'value', def: 0});
              
              createState(DP_Fritzbox_AnrufbeantworterDeleteMessage, '', {name: 'Zum loeschen ausgewaehlter Eintrag vom Anrufbeantworter', unit: '', read: true, write: true, type: 'string', role: 'value', def: ''});
              
              createState(DP_Fritzbox_AnrufbeantworterIndexMessage_json, '', {name: 'JSON Struktur mit den Anrufbeantworter Index Eintraegen um sie in einem Select Widget darstellen zu koennen', unit: '', read: true, write: true, type: 'string', role: 'value', def: ''});
              
              
              //Funktion Fritzbox_Anrufbeantworter_DeleteMessage() löscht die Nachricht welche als Index übergeben wird und liest danach erneut alle Anrufe vom Anrufbeantworter wieder aus
              
              function Fritzbox_Anrufbeantworter_DeleteMessage(NewMessageIndex){
              
              
                var befehl_DeleteMessage = '{"service": "urn:dslforum-org:service:X_AVM-DE_TAM:1","action": "DeleteMessage","params": {"NewIndex": "'+ NewIndex_Anrufbeantworter + '", "NewMessageIndex": "' + NewMessageIndex + '" }}';
              
              
                setState("tr-064.0.states.command","{}");
              
                setState("tr-064.0.states.command",befehl_DeleteMessage); //Befehl zum loeschen einer Nachricht im Anrufbeantworter
              
                if(debug) console.log("Antwort auf command im State tr-064.0.states.commandResult: " + getState("tr-064.0.states.commandResult").val);
              
              
              
                Fritzbox_Anrufbeantworter_GetMessageList();
              
              }
              
              on({id:DP_Fritzbox_AnrufbeantworterDeleteMessage, change: 'any'}, function(obj) {
              
                if(debug) console.log("Es wird der Eintrag auf dem Anrufebeantworter mit dem Index: " + getState(DP_Fritzbox_AnrufbeantworterDeleteMessage).val + "gelöscht");
              
                Fritzbox_Anrufbeantworter_DeleteMessage(getState(DP_Fritzbox_AnrufbeantworterDeleteMessage).val);
              
              });
              
              
              var AB_Index_DeleteMessageIndex = {};
              
              AB_Index_DeleteMessageIndex.sendTo = function(text, subText = '', value = '', icon = '', iconColor = '') {
              
                let json = getState(DP_Fritzbox_AnrufbeantworterIndexMessage_json).val;
              
              
              
                if (json) {
              
                    try {
              
              
              
                        json = JSON.parse(json);
              
              
              
                    } catch (e) {
              
                        json = [];
              
              //          console.warn('Wert ist kein JSON string! Wert wird ersetzt!');
              
                    }
              
                } else {
              
                    json = [];
              
                }
              
              
              
                json.push(
              
                    {
              
                        text: text,
              
                        subText: subText,
              
                        value: value,
              
                        icon: icon,
              
                        iconColor: iconColor,
              
                    }
              
                )
              
                setState(DP_Fritzbox_AnrufbeantworterIndexMessage_json, JSON.stringify(json), true);
              
              }
              
              // Funktion Fritzbox_Anrufbeantworter_GetMessageList() liest aus der Fritzbox die hinterlegten Informationen zu den Anrufen auf dem 
              
              // Anrufbeantworter aus. Ergebnis als JSON in einen Datenpunkt gespeichert, damit es in VIS einfach dargestellt werden kann. Es werden
              
              // in Datenpunkten gespeichert  wieviele Anrufe im Anrufbeantworter insgesamt vorliegen und wieviele neue Nachrichten vorhanden sind
              
              function Fritzbox_Anrufbeantworter_GetMessageList(){
              
              
              
                //Skript zum parsen von XML zu JSON: https://forum.iobroker.net/topic/623/gel%C3%B6st-xml-daten-einer-url-weiterverarbeiten/19
              
                //Damit das xml geparsed werden kann muss in der Javascript Instanz unter "Zusätzliche NPM Module" noch "xml2js" (mit Enter bestätigen) eintragen werden
              
              
              
                var parseString = require('xml2js').parseString;
              
              //  var request = require('request');
              
              
                var Result_Fritzbox_HyperlinkXmlTAM;
              
                var Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn = 0;
              
                var Fritzbox_AnrufbeantworterDaten_json = "";
              
                var befehl_GetMessageList = '{"service": "urn:dslforum-org:service:X_AVM-DE_TAM:1","action": "GetMessageList","params": {"NewIndex ": "' + NewIndex_Anrufbeantworter + '"}}';
              
              
              
                setState("tr-064.0.states.command","{}");
              
                setState("tr-064.0.states.command",befehl_GetMessageList); //Befehl zum auslesen der Anrufbeantworterdaten in Datenpunkt schreiben
              
                if(debug) console.log("Antwort auf command im State tr-064.0.states.commandResult: " + getState("tr-064.0.states.commandResult").val);
              
              
              
                setState(DP_Fritzbox_AnrufbeantworterIndexMessage_json,"");  //Setzt den aktuellen Inhalt vom Datenpunkt zurück, damit im Verlauf die Index Nummer von den Anrufen neu geschrieben werden können
              
              
                //Das Ergebnis im Datenpunkt commandResult ist ein Link auf ein XML welches die Informationen zu den Anrufen auf dem
              
                //Anrufbeantworter enthält. Das Ergebnis hat folgendes Format: {"NewURL":"http://192.168.178.1:49000/tamcalllist.lua?sid=2a4abe5e5ad61b64&tamindex=0"}
              
                //Aus diesem String wird mittels substring der eigentliche Link extrahiert
              
                Result_Fritzbox_HyperlinkXmlTAM = getState("tr-064.0.states.commandResult").val;
              
                Result_Fritzbox_HyperlinkXmlTAM = Result_Fritzbox_HyperlinkXmlTAM.substring(11, getState("tr-064.0.states.commandResult").val.length -2);  //die reine URL wird extrahiert
              
                if(debug) console.log("Extrahierter Hyperlink aus commandresult. CommandResult: " + getState("tr-064.0.states.commandResult").val + " und der extrahierte Link: " + Result_Fritzbox_HyperlinkXmlTAM);
              
              
                //Das XML File wird geparst und in eine JSON Struktur umgewandelt       
              
                httpGet(Result_Fritzbox_HyperlinkXmlTAM, function(error, response){
              
                //request(Result_Fritzbox_HyperlinkXmlTAM, function (error, response, body) {
              
                    if (!error && response.statusCode == 200) {
              
               //         const body = response.data;
              
               //     if(debug) console.log("Body: " + body);
              
              
                    //Aus dem xml String wird der Wert nach tam calls: extrahiert welcher die Anzahl der Anrufe auf dem Anrufbeantworter angibt
              
                    //Beispiel: ... <!-- tam calls:0 --> </Root> ...
              
                    //https://regex101.com/
              
                    //https://regex101.com/r/Q74grJ/1
              
                    const regex = /<!-- tam calls:[\s\S]*?(\d+)/igm;
              
                    const matches = regex.exec(response.data);
              
                    const FB_xml_TamCalls = parseInt(matches[1]);      
              
              
              
                    if(debug) console.log("FB_xml_TamCalls aus XML extrahiert: "+ FB_xml_TamCalls);
              
                    setState(DP_Fritzbox_AnrufbeantworterGesamtAnzahlNachrichten, FB_xml_TamCalls);
              
              
              
                    parseString(response.data, {
              
                            explicitArray: true, // Always put child nodes in an array if true; otherwise an array is created only if there is more than one.
              
                            mergeAttrs: true //Merge attributes and child elements as properties of the parent, instead of keying attributes off a child attribute object. This option is ignored if ignoreAttrs is true.
              
                        }, 
              
              
              
                        function (err, result) {
              
                            if (err) {
              
                                log("Fehler: " + err);
              
                            } 
              
                            else {
              
                                if(debug) console.log("Result Umwandlung xml in JSON: " + JSON.stringify(result));
              
              
              
              
              
                                //Abhaengig von der Anzahl der Anruf auf dem Anrufbeantworter erfolgt die weitere Verarbeitung der Daten
              
                                if(FB_xml_TamCalls == 0){       //Wenn keine Nachrichten auf dem Anrufbeantworter in der Fritzbox vorliegen
              
                                    
              
                                    //JSON String aus der Fritzbox wenn keine Nachricht auf dem AB ist
              
                                    //JSON: {"Root":"\n\n\n\n"}
              
                                    
              
                                    Fritzbox_AnrufbeantworterDaten_json = '[{"Index":["---"],"Tam":["---"],"Called":["---"],"Date":["---"],"Duration":["---"],"Inbook":["---"],"Name":["---"],"New":["---"],"Number":["---"],"Path":["---"]}]';
              
              
              
                                    setState(DP_Fritzbox_AnrufbeantworterAnzahlNeueNachrichten,0); //Anzahl der neuen Nachrichten auf 0 setzen
              
                                    setState(DP_Fritzbox_AnrufbeantworterDaten_json,Fritzbox_AnrufbeantworterDaten_json);
              
              
              
                                    setTimeout(function(){
              
                                        AB_Index_DeleteMessageIndex.sendTo("Keine Nachricht vorhanden","","","phone-message-outline","red");
              
                                    },500);
              
              
              
              
              
                                }
              
                                else{                           //Mindestens eine Nachricht ist auf dem Anrufbeantworter in der Fritzbox vorhanden
              
                                    
              
                                    //JSON String wenn eine Nachricht auf dem Anrufbeantworter ist
              
                                    //JSON: {"Root":{"Message":[{"Index":["0"],"Tam":["0"],"Called":["0123456789"],"Date":["09.09.20 21:17"],"Duration":["0:01"],"Inbook":["0"],"Name":["Feuersturm"],"New":["1"],"Number":["0987654321"],"Path":["/download.lua?path=/data/tam/rec/rec.0.000"]}]}}
              
              
              
                                    //JSON String wenn zwei Nachrichten auf dem Anrufbeantworter sind
              
                                    //JSON: {"Root":{"Message":[{"Index":["1"],"Tam":["0"],"Called":["0123456789"],"Date":["09.09.20 21:30"],"Duration":["0:01"],"Inbook":["0"],"Name":["Feuersturm"],"New":["1"],"Number":["0987654321"],"Path":["/download.lua?path=/data/tam/rec/rec.0.001"]},{"Index":["0"],"Tam":["0"],"Called":["0123456789"],"Date":["09.09.20 21:17"],"Duration":["0:01"],"Inbook":["0"],"Name":["Feuersturm"],"New":["0"],"Number":["0987654321"],"Path":["/download.lua?path=/data/tam/rec/rec.0.000"]}]}}
              
              
              
                                    Fritzbox_AnrufbeantworterDaten_json = JSON.stringify(result);
              
                                    Fritzbox_AnrufbeantworterDaten_json = Fritzbox_AnrufbeantworterDaten_json.substring(19,JSON.stringify(result).length - 2);
              
                                    setState(DP_Fritzbox_AnrufbeantworterDaten_json,Fritzbox_AnrufbeantworterDaten_json);
              
              
              
                                    if(debug) console.log("result.Root.Message.length: " + JSON.stringify(result.Root.Message.length));
              
              
              
                                    for (let i = 0; i < JSON.stringify(result.Root.Message.length); i++) {
              
              
              
                                        let MessageIndexValue = JSON.stringify(result.Root.Message[i].Index);
              
                                        MessageIndexValue = MessageIndexValue.substring(2,MessageIndexValue.length - 2);
              
              
              
                                        if(debug) console.log("Nachricht neu [i]: [" + i + "]" +  JSON.stringify(result.Root.Message[i].New) + " mit Index: " + JSON.stringify(result.Root.Message[i].Index) + " und gekürzt: " + MessageIndexValue);
              
                                        
              
                                        setTimeout(function(){
              
                                            AB_Index_DeleteMessageIndex.sendTo("AB Index","",MessageIndexValue,"phone-message-outline","red");
              
                                        },i*500);
              
              
              
                                        if( JSON.stringify(result.Root.Message[i].New) === '["1"]') {
              
                                            Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn = Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn + 1; 
              
                                        }
              
                                    }
              
                                    if(debug) console.log("Anzahl Neuer Nachrichten auf dem AB: " + Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn);
              
                                    setState(DP_Fritzbox_AnrufbeantworterAnzahlNeueNachrichten,Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn);
              
                                }
              
                            }
              
                        });
              
                } 
              
                else  {
              
                    log(error);
              
                }
              
                });
              
              }
              
              
              //Über Datenpunkt kann manuell das Auslesen der Daten aus dem Anrufbeantworter getriggert werden
              
              on({id:DP_Fritzbox_AnrufbeantworterDatenAktualisieren, change: 'any'}, function(obj) {
              
                    Fritzbox_Anrufbeantworter_GetMessageList();
              
              });
              
              
              //------------------------- Anrufername oder Telefonnummer ermitteln -----------
              
              //Quelle: https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/5
              
              /*
              
              Steht der Anrufer in Adressbuch wird Vorname und Name ausgegeben, sonst die 
              
              Telefonnummer
              
              {1}
              
              */
              
              
              function telefonname () {
              
                var tokens     =  getState("tr-064.0.callmonitor.inbound.callerName").val.split(",");
              
              var answer     = '';
              
              var vorname    =  tokens[1];
              
              var famname    =  tokens[0];
              
              
              
              if (famname === undefined) famname = '';
              
              if (vorname === undefined) vorname = '';
              
              if (vorname !== '' || famname !== '')
              
                 answer =  vorname + ' ' + famname;
              
              else
              
                 answer = getState("tr-064.0.callmonitor.inbound.caller").val;
              
              return answer; 
              
              }
              
              /*
              
              ---------------------------- Anruf beendet -------------------------------------
              
              Quelle: https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/5
              
              Es werden die Anzahl der Anrufe auf Anrufbeantworter und eine Liste von 
              
              Namen mitgeführt, die Nachrichten hinterlassen haben.
              
              Es werden dazu 'callmonitor.lastCall.type' und 
              
              'tr-064.0.callmonitor.lastCall.extension' ausgewertet.
              
              {1}
              
              Mangels Dok wurde durch Ausprobieren ermittelt, dass
              
              {1}
              
              - type === missed                        : es wurde aufgelegt und nicht gesprochen.
              
              - type === disconnect && extension !== 40: Gespräch wurde geführt und dann aufgelegt
              
              - type === disconnect && extension === 40: Nachricht auf AB
              
              {1}
              
              bedeuten könnte.
              
              */
              
              
              on({id:"tr-064.0.callmonitor.toPauseState", change: 'ne'}, function(obj) {
              
                setTimeout( function() {
              
                if (getState('tr-064.0.callmonitor.toPauseState').val === 'end') {
              
                    var name = telefonname();
              
                    if (getState("tr-064.0.callmonitor.lastCall.type").val === 'missed') {
              
                    //    log(name + " hat aufgelegt und keine Nachricht hinterlassen")
                        ;}
              
                    if (getState("tr-064.0.callmonitor.lastCall.type").val === 'disconnect') {
              
                        if (getState('tr-064.0.callmonitor.lastCall.extension').val == 40) {
              
              
              
                            if(debug) console.log(name + " hat auf den Anrufbeantworter gesprochen. Daten werden aus der Fritzbox ausgelesen...");
              
                            Fritzbox_Anrufbeantworter_GetMessageList(); //Es werden die Informationen aus dem Anrufbeantworter in der Fritzbox ausgelesen
              
                        } else {
              
                       //blub    log("Der Anruf von " + telefonname() + " hat " + getState("tr-064.0.callmonitor.lastCall.duration").val + " sec gedauert");
              
                        }    
              
                    }
              
                }    
              
                }, 3000);
              
              });
              

              Den Hinweis zum Umbau habe ich von hier.
              Ich musste zwar an mehreren Stellen etwas korrigieren, aber es scheint zu funktuinieren.
              Dein geändertes Script schein ja auch zu funktionieren - nur halt nicht bei mir. ¯_(ツ)_/¯

              C 1 Reply Last reply Reply Quote 0
              • C
                chris299 @falke69 last edited by

                @falke69 danke für die Adaption den Scriptes von @Feuersturm
                und @Feuersturm vielen dank für die ursprüngliche Version des Scriptes.
                Ich habe das mal geforked und hoffe das ist für Euch in Ordnung.
                https://github.com/chris299/IOBrokerFritzboxTAMHandling

                In meinem Fork habe ich das Runterladen und Transkribieren von Anrufbeantworternachrichten ergänzt (via MS Azure Speech service im Free Tier)
                ist noch ziemlich ungeschliffen, da ich auch eher Javascript anfänger bin, aber es funktioniert 😉

                Viele Grüße
                Christoph

                falke69 1 Reply Last reply Reply Quote 1
                • falke69
                  falke69 @chris299 last edited by falke69

                  @chris299

                  Vielen Dank

                  muss ich mir mal mit anschauen.
                  Bis zur Firmware 8.xx konnte ich meine Nachrichten mit speex in wav konvertieren.
                  Da AVM die Qualität der Nachrichten erhöt hat funktionierte das nicht mehr.
                  Ich habe versucht eine komfortable Lösung mit den Imap-Adapter (nichts gegen den Adapter) zu finden, aber so richtig gefällt mir das auch nicht, da ich mir die Nachrichten per Mail schicken lassen muss und die immer im Posteingang liegen müssen.
                  Dann habe ich hier ein Script gefunden, was mir schon besser gefällt.

                  Wenn jetzt natürlich alles in einem Script vorhanden ist, dann um so besser. Da brauche ich weder dutzende einzelne Scripte oder gar Adapter. 👍

                  Edit: Vielleicht kannst Du Dein sendTranskript Script ja um Telegram erweitern. 🙂

                  C 1 Reply Last reply Reply Quote 0
                  • C
                    chris299 @falke69 last edited by chris299

                    @falke69 senden des audio wav files per email geht.... telegram habe ich nicht. aber vermutlich muss man da auch nur den pfad an der richtigen Stelle im Aufruf einsetzen.
                    per email ist das so:

                    sendTo('email.1', 'send', {  text: 'Neue AB Nachricht im Anhang', to: 'test@test.de', subject: 'Neue AB Nachricht', 
                           attachments:[ { path: tempFilePath, cid: 'message.wav' },],} );
                    

                    EDIT:
                    scheint ziemlich leicht zu sein, die Wav auch per telegram zu senden, wenn man die o.e. Zeilen gegen die folgenden tauscht:

                    sendTo('telegram.0', 'send', {
                                    text: tempFilePath,
                                    caption: 'Neue AB Nachricht',
                                    user: 'yourUserName1,yourUserName2',
                                });
                    

                    https://github.com/iobroker-community-adapters/ioBroker.telegram/blob/master/docs/en/README.md#usage

                    aber wie gesagt, Telegram hab ich nicht....

                    EDIT 2 :
                    das sendTranscipt.js ist eigentlich ein eher simples blockly....
                    63806c5a-e6b6-49e9-a5ef-a8be8089c5c7-grafik.png
                    das müsstest du mit dem telegram-blockly leicht ergänzen können:
                    https://github.com/chris299/IOBrokerFritzboxTAMHandling/blob/main/sendTranskript_blockly.xml

                    falke69 2 Replies Last reply Reply Quote 0
                    • falke69
                      falke69 @chris299 last edited by

                      @chris299

                      ok, vielen Dank.

                      Schau ich mir mal an.

                      1 Reply Last reply Reply Quote 0
                      • falke69
                        falke69 @chris299 last edited by

                        @chris299

                        ich habe jetzt mal das Script installiert. im Original von Dir funktioniert zumindest der Start ohne Probleme. Sobald ich aber den Pfad unter "userdata" im Script ändere, kommen Fehlermeldungen, beim Start und bei der Ausführung vom Script. (Vielleicht finde ich den Fehler später noch - ist aktuell nicht schlimm).

                        Was mich aktuell verwundert:
                        2025-06-25_114340.jpg

                        Dieses Zeichen erhalte ich auch, in Telegram. Also kein Anhang, sondern nur dieses Zeichen.
                        Bei einem weiteren Anruf mit einer hinterlassenen Nachricht, habe ich dann wieder "The." im Datenpunkt stehen.

                        Also wenn ich das richtig verstanden habe, sollte sich doch eigentlich die Nachricht in den Datenpunkt befinden?

                        Übrigens ich bin nicht für die Adaption den Scriptes verantwortlich - das war @mcu.😊

                        C 1 Reply Last reply Reply Quote 0
                        • C
                          chris299 @falke69 last edited by

                          @falke69 ja, da sollte das Transkript drin sein (nicht das audio file), aber auch nur, wenn der Call zu Azure cognitive services funktioniert hat. was sagt denn das javascript log?

                          falke69 1 Reply Last reply Reply Quote 0
                          • falke69
                            falke69 @chris299 last edited by

                            @chris299

                            hier mal der log:

                            javascript.0
                               2025-06-25 14:33:48.240	info	script.js.Anrufer.Wir.test.Skript_1: "Transkript : The."
                            javascript.0
                               2025-06-25 14:33:48.240	info	script.js.Anrufer.Wir.test.Skript_1: {"durationMilliseconds":6040,"combinedPhrases":[{"text":"The."}],"phrases":[{"offsetMilliseconds":2920,"durationMilliseconds":80,"text":"The.","words":[{"text":"The.","offsetMilliseconds":2920,"durationMilliseconds":80}],"locale":"en-US","confidence":0.25603276}]}
                            javascript.0
                               2025-06-25 14:33:47.702	info	script.js.Anrufer.Wir.test.Skript_1: FormData { _overheadLength: 264, _valueLength: 51, _valuesToMeasure: [ ReadStream { fd: null, path: '/tmp/Anrufer.Wir.test.Skript_1-5OP0qU/message.wav', flags: 'r', mode: 438, start: undefined, end: Infinity, pos: undefined, bytesRead: 0, _events: [Object], _readableState: [ReadableState], _maxListeners: 100, _eventsCount: 3, emit: [Function (anonymous)], [Symbol(kFs)]: [Object], [Symbol(kIsPerformingIO)]: false, [Symbol(shapeMode)]: true, [Symbol(kCapture)]: false } ], writable: false, readable: true, dataSize: 0, maxDataSize: 2097152, pauseStreams: true, _released: false, _streams: [ '----------------------------379925215142652874426000\r\n' + 'Content-Disposition: form-data; name="definitions"\r\n' + '\r\n', '{"locales":["de-DE"], "profanityFilterMode":"None"}', [Function: bound ], '----------------------------379925215142652874426000\r\n' + 'Content-Disposition: form-data; name="audio"; filename="message.wav"\r\n' + 'Content-Type: audio/wave\r\n' + '\r\n', DelayedStream { source: [ReadStream], dataSize: 0, maxDataSize: Infinity, pauseStream: true, _maxDataSizeExceeded: false, _released: false, _bufferedEvents: [Array], _events: [Object: null prototype], _eventsCount: 1 }, [Function: bound ] ], _currentStream: null, _insideLoop: false, _pendingNext: false, _boundary: '--------------------------379925215142652874426000' }
                            javascript.0
                               2025-06-25 14:33:47.700	info	script.js.Anrufer.Wir.test.Skript_1: post form data für azure transcribe:
                            javascript.0
                               2025-06-25 14:33:47.694	info	script.js.Anrufer.Wir.test.Skript_1: Saved to /tmp/Anrufer.Wir.test.Skript_1-5OP0qU/message.wav
                            javascript.0
                               2025-06-25 14:33:47.694	info	script.js.Anrufer.Wir.test.Skript_1: response header:connection: close content-type: audio/x-wav content-disposition: attachment; filename="message.wav"
                            javascript.0
                               2025-06-25 14:33:45.936	info	script.js.Anrufer.Wir.test.Skript_1: Anzahl Neuer Nachrichten auf dem AB: 1
                            javascript.0
                               2025-06-25 14:33:45.936	info	script.js.Anrufer.Wir.test.Skript_1: Nachricht neu [i]: [0]["1"] mit Index: ["0"] und gekürzt: 0
                            javascript.0
                               2025-06-25 14:33:45.936	info	script.js.Anrufer.Wir.test.Skript_1: result.Root.Message.length: 1
                            javascript.0
                               2025-06-25 14:33:45.930	info	script.js.Anrufer.Wir.test.Skript_1: wav download : http://192.168.178.1:49000/download.lua?path=/data/tam/rec/rec.0.000 ; post data : sid=2400874c61e0ae6e
                            javascript.0
                               2025-06-25 14:33:45.929	info	script.js.Anrufer.Wir.test.Skript_1: Pfad zur neusten Message):http://192.168.178.1:49000/download.lua?path=/data/tam/rec/rec.0.000
                            javascript.0
                               2025-06-25 14:33:45.929	info	script.js.Anrufer.Wir.test.Skript_1: no arrays anymore: {"Index":"0","Tam":"0","Called":"XXXXX","Date":"25.06.25 14:33","Duration":"0:01","Inbook":"1","Name":"USER","New":"1","Number":"0172XXXXXXX","Path":"/download.lua?path=/data/tam/rec/rec.0.000"}
                            javascript.0
                               2025-06-25 14:33:45.928	info	script.js.Anrufer.Wir.test.Skript_1: neuesten Message (nach Datum):{"Index":["0"],"Tam":["0"],"Called":["XXXXX"],"Date":["25.06.25 14:33"],"Duration":["0:01"],"Inbook":["1"],"Name":["USER"],"New":["1"],"Number":["0172XXXXXXX"],"Path":["/download.lua?path=/data/tam/rec/rec.0.000"]}
                            javascript.0
                               2025-06-25 14:33:45.927	info	script.js.Anrufer.Wir.test.Skript_1: Index der neuesten Message (nach Datum):0
                            javascript.0
                               2025-06-25 14:33:45.926	info	script.js.Anrufer.Wir.test.Skript_1: TAMCalllist_JSON: {"Root":{"Message":[{"Index":["0"],"Tam":["0"],"Called":["XXXXX"],"Date":["25.06.25 14:33"],"Duration":["0:01"],"Inbook":["1"],"Name":["USER"],"New":["1"],"Number":["0172XXXXXXX"],"Path":["/download.lua?path=/data/tam/rec/rec.0.000"]}]}}
                            javascript.0
                               2025-06-25 14:33:45.926	info	script.js.Anrufer.Wir.test.Skript_1: Ergebnis Umwandlung CallList XML in JSON: {"Root":{"Message":[{"Index":["0"],"Tam":["0"],"Called":["XXXXX"],"Date":["25.06.25 14:33"],"Duration":["0:01"],"Inbook":["1"],"Name":["USER"],"New":["1"],"Number":["0172XXXXXXX"],"Path":["/download.lua?path=/data/tam/rec/rec.0.000"]}]}}
                            javascript.0
                               2025-06-25 14:33:45.920	info	script.js.Anrufer.Wir.test.Skript_1: FB_xml_TamCalls aus XML extrahiert: 1
                            javascript.0
                               2025-06-25 14:33:45.511	info	script.js.Anrufer.Wir.test.Skript_1: sid : 2400874c61e0ae6e ; tamindex : 0
                            javascript.0
                               2025-06-25 14:33:45.509	info	script.js.Anrufer.Wir.test.Skript_1: path from commandResult: http://192.168.178.1:49000/tamcalllist.lua?sid=2400874c61e0ae6e&tamindex=0
                            javascript.0
                               2025-06-25 14:33:45.508	info	script.js.Anrufer.Wir.test.Skript_1: Antwort auf command im State tr-064.0.states.commandResult: {"NewURL":"http://192.168.178.1:49000/tamcalllist.lua?sid=2400874c61e0ae6e&tamindex=0"}
                            tr-064.0
                               2025-06-25 14:33:44.961	info	{"NewURL":"http://192.168.178.1:49000/tamcalllist.lua?sid=2400874c61e0ae6e&tamindex=0"}
                            tr-064.0
                               2025-06-25 14:33:44.914	info	{"NewURL":"http://192.168.178.1:49000/tamcalllist.lua?sid=2400874c61e0ae6e&tamindex=0"}
                            javascript.0
                               2025-06-25 14:33:44.880	info	script.js.Anrufer.Wir.test.Skript_1: Soap Comand : {"service": "urn:dslforum-org:service:X_AVM-DE_TAM:1","action": "GetMessageList","params": {"NewIndex ": "0"}}
                            javascript.0
                               2025-06-25 14:33:44.880	info	script.js.Anrufer.Wir.test.Skript_1: USER hat auf den Anrufbeantworter 0 gesprochen. Daten werden aus der Fritzbox ausgelesen...
                            javascript.0
                               2025-06-25 14:33:44.877	info	script.js.Anrufer.Wir.AB_auf_neue_Nachrichten_prüfen-15-03-25: TypeError: Invalid URL at new URL (node:internal/url:806:29) at dispatchHttpRequest (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:2801:20) at /opt/iobroker/node_modules/axios/dist/node/axios.cjs:2721:5 at new Promise (<anonymous>) at wrapAsync (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:2701:10) at http (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:2739:10) at Axios.dispatchRequest (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:4116:10) at Axios._request (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:4416:33) at Axios.request (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:4271:25) at Axios.<computed> [as get] (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:4442:17) at Function.wrap [as get] (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:31:15) at Fritzbox_Anrufbeantworter_GetMessageList (script.js.Anrufer.Wir.AB_auf_neue_Nachrichten_prüfen-15-03-25:92:10) at Object.<anonymous> (script.js.Anrufer.Wir.AB_auf_neue_Nachrichten_prüfen-15-03-25:189:20) at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:3219:34) at listOnTimeout (node:internal/timers:581:17) at process.processTimers (node:internal/timers:519:7) at Axios.request (/opt/iobroker/node_modules/axios/dist/node/axios.cjs:4276:41) { code: 'ERR_INVALID_URL', input: 'DE_HostListPath":"/devicehostlist.lua?sid=2400874c61e0ae6e' }
                            

                            Ich hoffe, das ich auch soweit alle meine persönlichen Daten unkentlich gemacht habe.

                            C 1 Reply Last reply Reply Quote 0
                            • C
                              chris299 @falke69 last edited by

                              @falke69 sieht eigentlich alles richtig aus. du bekommst als transkript der nachricht tatsächlich "The." zurück. Was sollte das denn sein? und welche Sprache wird da üblicherweise drauf gesprochen?
                              nimm mal die neue version, die ich gerade hochgeladen habe, die ist etwas robuster und gibt mehr mitteilungen im debug mode.

                              falke69 1 Reply Last reply Reply Quote 0
                              • falke69
                                falke69 @chris299 last edited by falke69

                                @chris299

                                jetzt geht es. 🙂
                                Bei uns wird deutsch gesprochen. Alles andere würde ich nicht verstehen. 🙂 🙂 🙂
                                Habe nur bisher nicht drauf gesprochen, sondern nur Geräusche gemacht um den AB
                                voll zu bekommen.

                                Hatte das Script sozusagen vollkommen falsch verstanden.
                                Ich war der Meinung, das es die Nachricht runterläd und in den Datenpunkt speichert.
                                So wie im Log zu sehen:

                                script.js.Anrufer.Wir.test.Skript_1: wav download : http://192.168.178.1:49000/download.lua?path=/data/tam/rec/rec.0.001 ; post data : sid=2400874c61e0ae6e
                                

                                Wo wird den der wav File gespeichert um diese direkt per Telegram, Mail oder WhatsApp mit der Nachricht über den Anrufer zu versenden?

                                C 1 Reply Last reply Reply Quote 0
                                • C
                                  chris299 @falke69 last edited by chris299

                                  @falke69 habe eine neue Version hoch geladen, die einen neuen Datenpunkt auf macht, in dem dann der lokale Pfad zur Wav Datei steht. im Blockly kann man darauf zugreifen und das file versenden.....

                                  falke69 1 Reply Last reply Reply Quote 0
                                  • falke69
                                    falke69 @chris299 last edited by

                                    @chris299

                                    sehr schön. Das mit dem wav File funktioniert. Leider funktioniert die Transkription nicht mehr.
                                    Im Datenpunkt steht: "Transkription fehlgeschlagen".

                                    Hier der Log:
                                    log.txt

                                    Hat leider von der Länge nicht direkt mit reingepasst.

                                    C 1 Reply Last reply Reply Quote 0
                                    • C
                                      chris299 @falke69 last edited by chris299

                                      @falke69 du musst da natürlich deinen eigenen Azure Key einsetzen. anscheinend hast du vorher eine version erwischt, in der ich versehentlich meinen key nicht gelöscht hatte....
                                      und ja, ich muss die fehlermeldung für diesen Fall besser machen. so ist da deine ganze audio datei drin....

                                      EDIT:
                                      neue Version mit besserem logging hochgeladen

                                      falke69 1 Reply Last reply Reply Quote 0
                                      • falke69
                                        falke69 @chris299 last edited by

                                        @chris299

                                        daran wird es wohl liegen.
                                        Könnte man auch die Transkription im Script deaktivieren und nur den Wav File laden?
                                        Habe gerade mir das mit Azure angeschaut - das scheint ja nicht unbedingt einfach zu sein, sich dort einen Key anzulegen. 😞

                                        C 1 Reply Last reply Reply Quote 0
                                        • C
                                          chris299 @falke69 last edited by chris299

                                          @falke69 dastranskribieren abschalten kann man auch:
                                          einfach in der Zeile 61
                                          aus

                                          const transcribe = true;
                                          
                                          const transcribe = false;
                                          

                                          machen....

                                          vielleicht mache ich auch später noch eine Version bei der man das mit einem button in einem datenpunkt ein und ausschalten kann.... mal sehen...
                                          EDIT: neue version damit hochgeladen.

                                          aber eigentlich sollte das Erzeugen einer Ressource und deren Keys im Portal von Azure über den Link, den ich in der Anleitung angegeben habe, nicht so schwer sein:
                                          https://portal.azure.com/#view/Microsoft_Azure_ProjectOxford/CognitiveServicesHub/~/SpeechServices
                                          Man muss ein Abonement anlegen und dann darin die Ressource erstellen, dann kann man den Key abrufen.

                                          falke69 2 Replies Last reply Reply Quote 0
                                          • falke69
                                            falke69 @chris299 last edited by

                                            @chris299

                                            Vielen Dank

                                            ... irgendwie war der Abend gestern noch etwas stressig für mich geworden. Dann war ich schon mit der Registrierung bei Azure überfordert.

                                            Ich werde mir das Script heute Nachmittag mal in Ruhe anschauen und dann berichten.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            832
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            16
                                            88
                                            9626
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo