Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Korrekte Liste der Entgangenen Anrufe Mittels Fritzbox-Adapter und einer Skripte-Erweiterung ermitteln

    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

    Korrekte Liste der Entgangenen Anrufe Mittels Fritzbox-Adapter und einer Skripte-Erweiterung ermitteln

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      Semenchkare last edited by

      Hallo Ruhr70,

      vielen Dank.

      Ich probier's aus.

      Was vermutlich bei JSON dann nicht mehr geht, ist, dass ich noch den VCARD-Adapter mit dem gespeicheren Fritz-Telefonbuch (ca 120 Nummern) drüber laufen lassen kann.

      So habe ich bisher die Namensauflösung einwandfrei hinbekommen.

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

        pote mal bitte das dazugehörige Skript

        1 Reply Last reply Reply Quote 0
        • S
          Semenchkare last edited by

          Ein Skript gibt es da nicht, da ich lediglich im vcard-Adapter den Datenpunkt in Deinem Fritzbox-Adapter-Datenpunkt für die "MissedTableHTML" angeben musste.

          Dann hat das bisher wunderbar funktioniert, nur eben bei den "echten" missed calls.

          Im Vis habe ich bisher dann den entsprechenden Datenpunkt im VCARD-Adapter angezeigt.

          D.h. jetzt hätte ich eben den Datenpunkt unter dem javascript angesprochen. Das Teste ich nun.

          1 Reply Last reply Reply Quote 0
          • S
            Semenchkare last edited by

            Hallo,

            siehe LOG, Dein script funktioniert nicht. Der Datenpunkt "Entgangene Anrufe" existiert, aber leer.

            Auszug aus dem LOG

            javascript-0 2016-10-23 18:10:03.652 warn State "javascript." + instance + ".ErfolgloseAnrufe" not found

            javascript-0 2016-10-23 18:10:03.651 info script.js.Diverses.EntgangeneAnrufe1: del: 11

            javascript-0 2016-10-23 18:10:03.650 info script.js.Diverses.EntgangeneAnrufe1: del: 10

            javascript-0 2016-10-23 18:10:03.650 info script.js.Diverses.EntgangeneAnrufe1: del: 9

            javascript-0 2016-10-23 18:10:03.650 info script.js.Diverses.EntgangeneAnrufe1: del: 8

            javascript-0 2016-10-23 18:10:03.650 info script.js.Diverses.EntgangeneAnrufe1: del: 7

            javascript-0 2016-10-23 18:10:03.649 info script.js.Diverses.EntgangeneAnrufe1: del: 6

            javascript-0 2016-10-23 18:10:03.649 info script.js.Diverses.EntgangeneAnrufe1: del: 5

            javascript-0 2016-10-23 18:10:03.649 info script.js.Diverses.EntgangeneAnrufe1: del: 4

            javascript-0 2016-10-23 18:10:03.648 info script.js.Diverses.EntgangeneAnrufe1: del: 3

            javascript-0 2016-10-23 18:10:03.648 info script.js.Diverses.EntgangeneAnrufe1: del: 2

            javascript-0 2016-10-23 18:10:03.648 info script.js.Diverses.EntgangeneAnrufe1: del: 1

            javascript-0 2016-10-23 18:10:03.647 info script.js.Diverses.EntgangeneAnrufe1: del: 0

            fritzbox-0 2016-10-23 18:10:02.617 info data from 192.168.169.1: 23.10.16 18:10:02;DISCONNECT;0;0;

            ich habe hier diverse Anrufe in der Fritzbox-Adapter-Liste, die werden alle rausgelöscht, obwohl zB ein AB-Anruf und auch ein normaler Missed-Call ausgelöst war.

            Auch wird der Inhalt des Datenpunkts bei nochmaligem Anruf nicht erneuert…

            Irgendwas stimmt im Script noch nicht....

            1 Reply Last reply Reply Quote 0
            • Homoran
              Homoran Global Moderator Administrators last edited by

              @Semenchkare:

              Der Datenpunkt "Entgangene Anrufe" existiert, aber leer. `
              Dito 😞

              Gruß

              Rainer

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

                Ich schau mal.

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

                  @Semenchkare:

                  Hallo,

                  javascript-0 2016-10-23 18:10:03.652 warn State "javascript." + instance + ".ErfolgloseAnrufe" not found

                  Irgendwas stimmt im Script noch nicht…. `

                  Die Zeile:

                     setState('javascript." + instance + ".ErfolgloseAnrufe',ergebnis);
                  

                  muss gegen diese getauscht werden:

                     setState('javascript.' + instance + '.ErfolgloseAnrufe',ergebnis);
                  
                  

                  Ich hatte in Javascript Instanz 2 getestet. Um es für alle Instanzen gültig zu haben, hatte ich die 2 gegen "+ instance +" ersetzt.

                  Der String beginnt aber mit Hochkomma statt mit Gänsefüßchen.

                  An der Logzeile, die ich oben stehen lassen ahbe, sieht man das schon.

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

                    @Semenchkare:

                    ich habe hier diverse Anrufe in der Fritzbox-Adapter-Liste, die werden alle rausgelöscht, obwohl zB ein AB-Anruf und auch ein normaler Missed-Call ausgelöst war.

                    Auch wird der Inhalt des Datenpunkts bei nochmaligem Anruf nicht erneuert…

                    Irgendwas stimmt im Script noch nicht.... `

                    Nach der Beschreibung wird das Skript auch mit korrigierten Gänsefüßchen nicht funktionieren.

                    Als ob bei Dir im JSON der rote Pfeil anders beschrieben wäre:

                    ' **->X**'
                    
                    1 Reply Last reply Reply Quote 0
                    • S
                      Semenchkare last edited by

                      es läuft jetzt was:

                      Das ist der Inhalt vom neuen Datenpunkt:

                      [null,null,{"date":"23.10.16 18:26:21","externalNumber":"01xxxxxxxxxx","callSymbolColor":" ->>","extensionLine":"40","ownNumber":"2096110","lineType":"SIP0","durationForm":" 5"},null,null,null,null,null,null,null,null,null]

                      aber der nicht auf den AB gelandeten Anruf wird nicht angezeigt…

                      jetzt mal die Fritzadapter-json:

                      [{"date":"23.10.16 19:27:10","externalNumber":"xxxxxxxxx","callSymbolColor":" ->X","extensionLine":"","ownNumber":"yyyyy","lineType":"SIP2","durationForm":" -"},{"date":"23.10.16 18:34:21","externalNumber":"xxxxxxxx","callSymbolColor":" ->X","extensionLine":"","ownNumber":"yyyy","lineType":"SIP0","durationForm":" -"},{"date":"23.10.16 18:26:21","externalNumber":"xxxxxxx","callSymbolColor":" ->>","extensionLine":"40","ownNumber":"yyyyy","lineType":"SIP0","durationForm":" 5"},{"date":"23.10.16 18:10:02","externalNumber":"xxxxxxx","callSymbolColor":" ->X","extensionLine":"","ownNumber":"yyyyyy","lineType":"SIP3","durationForm":" -"},{"date":"23.10.16 15:00:53","externalNumber":"xxxxxxx","callSymbolColor":"<<- ","extensionLine":"13","ownNumber":"yyyyyyy","lineType":"SIP0","durationForm":" 22:26"},{"date":"23.10.16 14:38:15","externalNumber":"xxxxxxx","callSymbolColor":"<<- ","extensionLine":"13","ownNumber":"yyyyyyyy","lineType":"SIP0","durationForm":" 20"},{"date":"23.10.16 14:36:57","externalNumber":"xxxxxx","callSymbolColor":"<<- ","extensionLine":"13","ownNumber":"yyyyyyy","lineType":"SIP0","durationForm":" 18:35"},{"date":"23.10.16 14:18:12","externalNumber":"xxxxxxx","callSymbolColor":"<<- ","extensionLine":"13","ownNumber":"yyyyyyyy","lineType":"SIP0","durationForm":" 9:40"},{"date":"23.10.16 14:08:13","externalNumber":"xxxxxxxxxx","callSymbolColor":"<<- ","extensionLine":"13","ownNumber":"yyyyyyyyy","lineType":"SIP0","durationForm":" 14"},{"date":"23.10.16 14:07:52","externalNumber":"xxxxxxxxxx","callSymbolColor":" ->>","extensionLine":"13","ownNumber":"yyyyyyyy","lineType":"SIP0","durationForm":" 16:49"},{"date":"23.10.16 13:24:06","externalNumber":"xxxxxxxxxx","callSymbolColor":"<<- ","extensionLine":"15","ownNumber":"yyyyyyyy","lineType":"SIP0","durationForm":"2:33:10"},{"date":"23.10.16 08:53:55","externalNumber":"xxxxxxxx","callSymbolColor":" ->X","extensionLine":"","ownNumber":"yyyyyyyy","lineType":"SIP4","durationForm":" 13"}]

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

                        @Semenchkare: `

                        Sieht der JSON String vom Fritzbox Adapter wirklich so aus? D.h. mit den Backslashs im String ()?

                        Zum schnellen Test mal die Zeile:

                         `if(jsonAll[i].callSymbolColor != ' **->X**') {`
                        
                        gegen:
                        `~~[code]~~        if(jsonAll[i].callSymbolColor != ' **->X**') {`
                        
                        tauschen.
                        
                        Alternativ (wahrscheinlich beste Variante. Bei mir getestet und OK):
                        
                        `~~[code]~~        if(jsonAll[i].callSymbolColor.indexOf("->X") == -1) {`[/i][/code][/i][/code][/i]
                        
                        1 Reply Last reply Reply Quote 0
                        • S
                          Semenchkare last edited by

                          Funktioniert jetzt mit der "besten Variante"!

                          nun lass ich noch den vcard-Apdapter drüberlaufen und kümmer mich danach um das widget, an dem ich wohl noch Anpassungen vornehmen muss…

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

                            Eine Variante, bei der man komplett flexibel ist und nicht schon aufgebaute Listen wieder auseinandernehmen muss, ist der Datenpunkt:

                            fritzbox.0.cdr.missedJSON

                            Dort findet man alle Infos am Ende eines Gesprächs als JSON, inkl. der Vorbereitung von TXT und HTML Ausgaben.

                            Vom Prinzip würde das so funktionieren:

                            • Logik, ob das Gespräch relevant ist (verpasst und Gespräche zum AB)

                            • Zusammenbau des HTML aus den mitgelieferten Daten

                            • eigene Ereignisliste in beliebiger Länge

                            1 Reply Last reply Reply Quote 0
                            • S
                              Semenchkare last edited by

                              hallo,

                              ich mach mal oben weiter, habe den json jetzt geändert d.h. mit vcard die Namen eingebaut und muss jetzt das widget anpassen…

                              Das mit dem CDRMisseJSON zeigt aber wieder nur die "missed" calls an wenn dann müsste man die "CDR.All" nehmen.

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

                                @Semenchkare:

                                ich mach mal oben weiter, habe den json jetzt geändert d.h. mit vcard die Namen eingebaut und muss jetzt das widget anpassen… `

                                Hat es funktioniert?

                                @Semenchkare:

                                Das mit dem CDRMisseJSON zeigt aber wieder nur die "missed" calls an wenn dann müsste man die "CDR.All" nehmen. `

                                Ups… stimmt.

                                der richtige Datenpunkt wäre: fritzbox.0.cdr.json

                                1 Reply Last reply Reply Quote 0
                                • S
                                  Semenchkare last edited by

                                  Hallo Ruhr 70,

                                  Du bist der Hammer!

                                  Ja, es hat funktioniert! Ich habe den von Dir "erschaffenen" Datenpunkt durch den VCD-Adapter laufen lassen, siehe da, der dortige Datenpunkt entspricht Deinem, hat aber die Telefonnummern ersetzt durch Namen! Super!

                                  Ich habe dann das Widget importiert - und soweit möglich - geändert. D.h. nicht benötigte Spalten via "Eigenschaften" rausgenommen und -WICHTIG- den Datenpunkt auf den VCD Datenpunkt geändert.

                                  [{"tpl":"tplTableBody","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":true,"g_css_background":true,"g_css_shadow_padding":false,"g_css_border":true,"g_gestures":false,"g_signals":false,"static_value":"[{\"Title\": \"first\", \"Value\": 1, \"_Description\": \"Value1\"}, {\"Title\": \"second\", \"Value\": 2, \"_Description\": \"Value2\"}]","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"colCount":"3","table_oid":"vcard.0.Outputs.ReplacedPhoneNumbersCh5","g_header_§0":true,"colWidth2":"22%","colAttr2":"","colName3":" ","colWidth3":"5%","colName4":"Nbst","colWidth4":"5%","colName7":"Dauer","colAttr6":"","colWidth6":"8%","colName6":"Ltg.","colWidth7":"15%","colName2":" ","colName1":" ","hide_header":true,"colWidth1":"20%","views":null,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide"},"style":{"left":"278px","top":"651px","width":"269px","height":"160px","color":"#ffffff","background-color":"","font-family":"Arial, Helvetica, sans-serif","z-index":"1","font-size":"small"},"widgetSet":"basic"}]
                                  
                                  

                                  Heraus kommt -bis jetzt- folgendes Bild:

                                  ~~![](</s><URL url=)http://www.joe-lion.de/old/korrekte-Liste.JPG" />

                                  Was ich momentan nicht "hinbekomme":

                                  1. Zeitanzeige ohne Sekunden (Platzbedarf) kann man da im funktionierenden Script ändern, damit die Zeit im Datenpunkt ohne Sekunden ankommt??
                                  `createState('ErfolgloseAnrufe', '');
                                  
                                  function listeBereinigen(jsonAll){
                                      for (var i = 0; i < jsonAll.length; i++) {
                                          if(jsonAll[i].callSymbolColor.indexOf("->X") == -1) {
                                              if(jsonAll[i].extensionLine != "40") {
                                                  delete jsonAll[i];
                                                  log("del: " + i);
                                              }
                                          }
                                      }
                                      return JSON.stringify(jsonAll);
                                  }
                                  
                                  on({id: 'fritzbox.0.history.allTableJSON'}, function (obj) {  
                                     var ergebnis = listeBereinigen(JSON.parse(obj.state.val));
                                     setState('javascript.' + instance + '.ErfolgloseAnrufe',ergebnis);
                                  });`
                                  
                                  2\. Ich kann den Zellenhintergrund (hellgrau/dunkelgrau) in VIS nicht in "durchsichtig" verändern. Wo kann ich das tun? (wäre viel universeller, wenn es durchsichtig anstatt hellgrau-dunkelgrau wäre)
                                  
                                  3\. Ich kann die Schriftfarbe nicht in "weiß" ändern..., zumindest nicht in den "VIS-Eigenschaften" Wenn ich da was ändere, bewirke ich "nichts". Kommt da Änderung bereits mit dem Code vom Datenpunkt rüber?
                                  
                                  hast Du hierfür noch "Abhilfen"
                                  
                                  Untertänigsten Dank![/i][/i][/i]
                                  ```~~
                                  1 Reply Last reply Reply Quote 0
                                  • ruhr70
                                    ruhr70 last edited by

                                    Ich würde noch die Spalte Gesprächsdauer mit reinnehmen. Dann siehst Du in der Liste, ob jemand draufgesprochen hat (Anruf länger als x Sekunden) oder bei der Ansage aufgelegt hat.

                                    Die Gespräche, bei denen eine Nachricht hinterlassen wurde (Anzahl Sekunden nach Ansagedauer) könnte man jetzt auch wieder aus Deiner Liste rausfiltern.

                                    @Semenchkare:

                                    1. Zeitanzeige ohne Sekunden (Platzbedarf) kann man da im funktionierenden Script ändern, damit die Zeit im Datenpunkt ohne Sekunden ankommt?? `

                                    Ich habe noch eine Funktion eingebaut, in der Du Dir das Datum und die Zeit kürzen kannst, wie Du willst.

                                    Im Beispiel habe ich die Jahreszahl und die Sekunden rausgenommen.

                                    ! ```
                                    createState('ErfolgloseAnrufe', ''); ! function kuerzeDatum(str) { var datumStr = str.substr(0,5); // Datum kürzen var zeitStr = str.substr(9,5); // Zeit kürzen return datumStr + " / " + zeitStr; } ! function listeBereinigen(jsonAll){ for (var i = 0; i < jsonAll.length; i++) { jsonAll[i].date = kuerzeDatum(jsonAll[i].date); // Datum und Zeit kürzen if(jsonAll[i].callSymbolColor.indexOf("->X") == -1) { if(jsonAll[i].extensionLine != "40") { delete jsonAll[i]; log("del: " + i); } } } return JSON.stringify(jsonAll); } ! on({id: 'fritzbox.0.history.allTableJSON'}, function (obj) { var ergebnis = listeBereinigen(JSON.parse(obj.state.val)); setState('javascript.' + instance + '.ErfolgloseAnrufe',ergebnis); });
                                    ! [quote]
                                    ! 2. Ich kann den Zellenhintergrund (hellgrau/dunkelgrau) in VIS nicht in "durchsichtig" verändern. Wo kann ich das tun? (wäre viel universeller, wenn es durchsichtig anstatt hellgrau-dunkelgrau wäre)
                                    ! 3. Ich kann die Schriftfarbe nicht in "weiß" ändern..., zumindest nicht in den "VIS-Eigenschaften" Wenn ich da was ändere, bewirke ich "nichts". Kommt da Änderung bereits mit dem Code vom Datenpunkt rüber?

                                    ! Hier müssen die Widgets/CSS Experten ran.
                                    ! Stell die Frage am besten im Forum unter VIS/Widgets.
                                    ! Was jetzt sonst noch machbar wäre, das Skript oben so umbauen, dass dann statt dem JSON wieder eine HTML Tabelle erzeugt wird.[/i][/i][/i][/i][/i]

                                    1 Reply Last reply Reply Quote 0
                                    • S
                                      Semenchkare last edited by

                                      Hallo,

                                      vielen herzlichen Dank! Ich habe jetzt auch noch die Zeit in eine Spalte nach dem Symbol angefügt, wie von Dir vorgeschlagen. Klappt bestens!

                                      Funktional habe ich nun alles, was ich mir wünsche!

                                      Danke nochmals, alleine hätte ich die Funktion so nicht hinbekommen.

                                      Ich gehe nun ins Vis-Forum, vielleicht bekomme ich/bzw. wir das mit dem Zellenhintergrund da auch noch hin.

                                      1 Reply Last reply Reply Quote 0
                                      • S
                                        Semenchkare last edited by

                                        Hallo,

                                        Das Skript läuft nun einige Wochen/Monate, und auch das Widget wird in gewünschter Form dargestellt. Diese Anzeige ist eine Verbesserung um Welten gegenüber zum vorigen Zustand.

                                        Ich hätte noch einen kleinen Verbesserungsvorschlag:

                                        Erfahrungsgemäß finden viele zustandegekommene Gespräche von intern nach außen oder umgekehrt statt. Dies sorgt dafür, dass die Liste der erfolglosen Anrufe relativ schnell wieder "vom Schirm verschwindet", da ja nur ca. 12 Anrufe auf der Fritzbox-Liste geführt werden.

                                        Für mich jetzt folgende Frage:

                                        Wenn die Liste bzw. der Datenpunkt im Javascript "ErfolgloseAnrufe" nichts mehr anzeigt, (im Datenpunkt alles als "null" gekennzeichnet),

                                        wäre es dann möglich, genau in diesem Fall auf einen anderen Datenpunkt als ursprung zu nehmen? Beispielsweise: fritzbox.0.cdr.missedJSON statt der leeren Box anzeigen zu lassen?

                                        hier das bisheriges script von ruhr70

                                         `createState('ErfolgloseAnrufe', '');
                                        
                                            function kuerzeDatum(str) {
                                                var datumStr = str.substr(0,6); // Datum kürzen
                                                var zeitStr = str.substr(9,5);  // Zeit kürzen
                                                return datumStr + ": " + zeitStr;
                                            }
                                        
                                            function listeBereinigen(jsonAll){
                                                for (var i = 0; i < jsonAll.length; i++) {
                                                    jsonAll[i].date = kuerzeDatum(jsonAll[i].date); // Datum und Zeit kürzen
                                                    if(jsonAll[i].callSymbolColor.indexOf("->X") == -1) {
                                                        if(jsonAll[i].extensionLine != "40") {
                                                            delete jsonAll[i];
                                                            log("del: " + i);
                                                        }
                                                    }
                                                }
                                                return JSON.stringify(jsonAll);
                                            }
                                        
                                            on({id: 'fritzbox.0.history.allTableJSON'}, function (obj) {  
                                               var ergebnis = listeBereinigen(JSON.parse(obj.state.val));
                                               setState('javascript.' + instance + '.ErfolgloseAnrufe',ergebnis);
                                            });` 
                                        
                                        zugegebenermaßen, würden mehr als 12 Anrufe geloggt, wäre das Problem vermutlich nicht so schnell auftauchend.
                                        
                                        Ich könnte mir vorstellen, einen weiteren Datenpunkt in einem weiteren script zu kreieren, zB. "erfolgloseAnrufe2". In diesem findet eine Abfrage statt "Wenn erfolglose Anrufe = Leer, dann verwende  "fritzbox.0.cdr.missedJSON", ansonsten den Inhalt von "erfolgloseAnrufe"
                                        
                                        Im widget würde ich dann eben "ErfolgloseAnrufe2" als Datenpunkt angeben.
                                        
                                        Mir ist nur nicht klar, wie ich das mit der if-Abfrage machen soll..[/i][/i][/i][/i][/i]
                                        
                                        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

                                        858
                                        Online

                                        31.9k
                                        Users

                                        80.1k
                                        Topics

                                        1.3m
                                        Posts

                                        4
                                        22
                                        4247
                                        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