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

      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

                        877
                        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