Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. moelski

    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

    • Profile
    • Following 0
    • Followers 2
    • Topics 32
    • Posts 215
    • Best 11
    • Groups 2

    moelski

    @moelski

    27
    Reputation
    112
    Profile views
    215
    Posts
    2
    Followers
    0
    Following
    Joined Last Online
    Location NRW

    moelski Follow
    Pro Starter

    Best posts made by moelski

    • RE: Echo Show 5

      Howto "Hack" my Echo 5 for VIS 🙂

      Ok hier also nun die Anleitung wie ich meine Alexa Show 5 dazu knechte nur meine VIS anzuzeigen. Derzeit sind (aus meiner Sicht) 2 von 3 Probleme davon gelöst ...

      (1) Verhindern das Alexa nach 5-10 Minuten den FireFox beendet und wieder den Startbildschirm anzeigt.
      Das kann man lösen indem man ein HTML Widget nutzt und darin ein HTML5 Video Tag platziert. Ich habe das mal als Widget exportiert:

      [{"tpl":"tplHtml","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":true,"g_css_background":true,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"0","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,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"html":"<video autoplay muted loop=\"true\">\n    <source src=\"http://192.168.30.22:8082/vis.0/black.mp4\" type=\"video/mp4\">\n</video>\n<!--\nhttps://www.reddit.com/r/amazonecho/comments/f2pgq4/keep_browser_open_on_echo_show/\n-->"},"style":{"left":"3px","top":"4px","width":"34px","height":"23px","z-index":"3","color":"#000","background":"#000"},"widgetSet":"basic"}]
      

      Und der HTML Teil dabei schaut so:

      <video autoplay muted loop="true">
          <source src="http://192.168.30.22:8082/vis.0/black.mp4" type="video/mp4">
      </video>
      <!--
      https://www.reddit.com/r/amazonecho/comments/f2pgq4/keep_browser_open_on_echo_show/
      -->
      

      Das Video habe ich in ioBroker gespeichert und zwar hier:
      /opt/iobroker/iobroker-data/files/vis.0
      Testen kann man das dann mittels
      http://<ip>:8082/vis.0/black.mp4

      Hinweis
      Habe festgestellt das man die Videos mit dem Upload der VIS hochladen sollte. Weil die sonst nicht in der Auflistung im Server erscheinen. Also in der VIS auf Bildauswahl, dann in den Ordnern einen zurück und auf vis.0. Und hier mittels Upload die Datei einfügen !

      Hier noch das Video zum download:
      A black screen with no sound.zip
      Ich habe das Original noch etwas komprimiert 🙂

      Damit bleibt Alexa dann im Browser, weil das Video immer und imemr wieder gespielt wird. Ich hatte gestern Abend mal ein Problem das die Anzeige nicht sauber war im Browser. Das kann aber Zufall gewesen sein ... Die Zeit wird zeigen ob es dauerhaft gut funktioniert 😉

      (2) Das lästeige Zoomen des Echo Show 5
      Wie schon mal geschrieben zoomt der Echo 5 bei einigen Webseiten auf 150%. wenn ich das richtig gedeutet habe kommt es auf die Schriftgrößen der Seite an. Dieses Problem umschiffe ich einfach indem ich mein Fullscreen Script aufrufe. 🙂
      Das nutze ich an meinem 10" Bildschirm um die VIS in und aus dem Vollbildmodus zu bekommen. Tja und was soll ich sagen ... Das funzt bei der Alexa Show ebensogut. Und das beste ... Dabei wird der 150% Zoom ausgehebelt 🙂

      setTimeout(function () {
      $('#w00004').click(function () { 
             toggleFullscreen();
      });
      }, 1000);
      
      function toggleFullscreen(e) {
        var d = document, done;
        e = e || d.documentElement;
        '-frsexit ms-FRsExit moz-FRSCancel webkit-FRsExit'.replace(/(\w*)-(f)(r)(s)(\w+)/gi, function(_, p, f, r, s, c) {
          if (!done) {
            s = 'ull' + s + 'creen';
            if (d[p + f + s + 'Element'] && d[c = p + c + 'F' + s]) {
              d[c]();
              done = 1;
            }
            else if (done = e[r = p + r + 'equestF' + s]) {
              e[r]();
            }
          }
        });
      }
      

      Das Script ist übrigens nicht aus meiner Feder. Mal irgendwo gefunden ...

      Ok einbinden ist easy ... Einfach das Script im VIS Editor in den Scripts Berecih kopieren:
      prusa-slicer_fD7MftFHAb.png

      Und jetzt muss man sich ein Element in der VIS suchen mit dem man bei Click Zoomen will. In meinem Fall ist das einfach die Überschrift meiner Visu:
      firefox_SgzKgt8iax.png

      Das w00004 trägt man im Script in der 2ten Zeile ein hinter dem #
      Danach kann man Vollbild nutzen und voila ... Nix mehr mit Zoom 😉

      (3) Internetradio mit Tunein
      Das ist mir gestern noch aufgefallen ... Wenn man Firefox auf hat und sagt "Alexa spiele Radio Bob" dann geht Tunein auf und der Firefox zu. Das ist unschön weil man dann immer wieder den Firefox öffnen muss um zur Visu zu kommen. Ich hätte es viel lieber wenn die Visu an bleibt und er dennoch Radio spielt. Und ich denke ich habe dazu auch eine Idee. Ich verwende eben nicht das normale Alexa Zeugs, sondern erstelle mir einen kleinen Webplayer der dann meinen gewünschten Sender abspielt. Ich ignoriere damit also Tunein von Alexa.
      Grundlegend kann Alexa auch INet Radio abspielen - heute morgen getestet.
      Jetzt muss ich nur noch schauen wie ich das mit einfachen HTML mitteln einbinden kann ... Wenn da jemand schon was kennt ... Gerne her damit.
      Tja und Rdaio starten über Sprache ... Auch das sollte machbar sein. Dafür würde ich den Alexa Adapter vom ioBroker nutzen. Der in Verbindung mit BluePrints ... das sollte gehen. Aber erstmal muss das INet Radio generell funktionieren. Und dann sehen wir weiter.

      Soweit mein kurzer Ausflug ins Alexa VIS Hacking 👨‍🔧

      posted in ioBroker Allgemein
      moelski
      moelski
    • RE: Internet Filter in der Fritzbox mit JavaScript setzen

      Moin !

      Gestern Abend doch glatt am TV verschlummert 🙄 Aber nun ...

      Hier aber nun das Script:

      /*******************************************************
      * Basis: 
      * https://community.openhab.org/t/disable-internet-connection-of-specific-echo-device-on-fritz-box-via-script/91374
      * https://forum.fhem.de/index.php?topic=109689.0
      * https://www.kuketz-blog.de/fritzbox-wlan-toggle-per-skript/
      *******************************************************/ 
      
      /*******************************************************
      * Script SetDeviceFilter
      * 
      * 13.09.20 V1.09    Regex mit Escape beim . und Fix für Liste
      * 12.09.20 V1.08    Regex um . erweitert
      * 12.09.20 V1.07    Erweritertes Logging aktivierbar für Fehlersuche
      * 08.09.20 V1.06    Anpassungen an FirtzOS 7.20 (Regex Auswertung für Listenerstellung)
      * 05.09.20 V1.05    Ausgabe einer Device / Filter Liste möglich als JSON 
      *                   Logging reduziert wenn FbListOnly = false
      * 04.09.20 V1.04    Fix für doppelte Einträge in Listen
      * 02.09.20 V1.03    Erweiterung zum automatischen Start mittels ioB Datenpunkt
      * 02.09.20 V1.02    Script Abbruch wenn der Login nicht geklappt hat
      * 02.09.20 V1.01    Regex Erweiterung, Login auch mit User/Passwort
      * 01.09.20 V1.00    erste öffentliches Release
      *******************************************************/ 
      const Version = "1.09";
      
      // TODO
      // * Liste erzeugen mit Devices und aktuellem Filter
      //   > als JSON in einen DP speichern -> für Tabellenauswertung
      
      // https://forum.iobroker.net/topic/16184/http-request-in-javascript/5
      var request = require('request');
      var headers = { 
          'Content-Type': 'application/x-www-form-urlencoded', 
          'User-Agent': 'curl/7.64.0', 
          'Accept': '*/*'
      }; 
      
      /*******************************************************
      * E I N S T E L L U N G E N 
      *******************************************************/
      
      // Die IP Der Fritzbox
      const FbIp          = "192.168.30.1";              
      // Der User der Fritzbox 
      // HINWEIS : Den Benutzer leer lassen wenn die Anmeldung an der FB nur mit Passwort erfolgt !
      const FbUser        = ""; 
      // Das Password der Fritzbox                  
      const FbPassword    = "";   
      // welcher Rechner soll "bearbeitet" werden                
      var   FbDevice      = "Comp-L-Pi";   
      // Das neue Profil für den Rechner              
      var   FbProfile     = "filtprof4";  
      // erweitertes Logging aktivieren für Fehlersuche
      const FbDebugging   = false;
      // Keine Änderung an der Fritzbox (true) -> Listet dann nur alle Profile und Rechner               
      const FbListOnly    = false; 
      // Device / Filter Liste erzeugen Ja (true), Nein (false)
      const FbCreateList  = true; 
      // Datenpunkt (string) für einen automatischen Script Start (muss angelegt werden!)
      // Der Datenpunkt wir mit Device;Profil beschrieben. Bsp: Comp-L-Pi;filtprof1
      const FbIobObject   = "Global.0.Fritzbox.ChangeDeviceFilter"  
      // Datenpunkt in den die Device / Filter Liste als JSON geschrieben wird                    
      const FbIobJsonList = "Global.0.Fritzbox.DeviceFilterListJson" 
      
      var secChallenge;
      var secMd5;
      var secLogin;
      var secSid;
      var secProfileNames = [];
      var secProfileIds   = [];
      var secDeviceNames  = [];
      var secDeviceIds    = [];
      var JsonList        = "";
      
      /*******************************************************
      * Object Trigger Version
      * Wenn auf einen Datenpunkt getriggert werden soll, dann muss der folgende Block auskommentiert werden. 
      * FbIobObject muss mit einem string Datenpunkt versehen werden.
      * Den Static Teil dann auskommentieren !
      * Diese Variante erlaubt es das Script dynamisch für alle Devices / Profile der FB zu verwenden. 
      *******************************************************/
      on({id: FbIobObject, change: "ne"}, function (obj) {
          console.log("Profile Changer started ... (Version : " + Version + ")");
          var data = obj.state.val.split(";");
          if (data.length != 2) {
              console.log("Wrong parameter : " + obj.state.val);
              return;
          }
      
          if (FbDebugging){
              console.log(" > Datapoint : " + data);
          }
      
          console.log("Computer : " + data[0]);
          console.log("Filter   : " + data[1]);
          FbDevice  = data[0];
          FbProfile = data[1];
      
          getFbChallenge();
          
          console.log("Profile Changer done");
      });
      
      /*******************************************************
      * Static Version
      * Die folgenden 3 Zeilen lassen das Script  sofort laufen. 
      * Dabei sollte der Object Trigger Block auskommentiert werden. 
      *******************************************************/
      // console.log("Profile Changer started ... (Version : " + Version + ")");
      // getFbChallenge();
      // console.log("Profile Changer done");
      
      // Get the Challenge String from the FritzBox
      // Compute the md5 Hash
      function getFbChallenge(){
          console.log("function getFbChallenge");
          request.get({
              url:        'http://' + FbIp + '/login_sid.lua?username=' + FbUser,
              headers:    headers
          }, function(error, response, body) {
              if (error) log(error, 'error');
              //console.log(response);
              // https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Global_Objects/RegExp
              // <?xml version="1.0" encoding="utf-8"?><SessionInfo><SID>0000000000000000</SID><Challenge>d36de231</Challenge><BlockTime>0</BlockTime><Rights></Rights></SessionI
              secChallenge = body.match(/Challenge>(.*)<\/Challenge/)[1];
              console.log(" > Challenge : " + secChallenge);
      
              var uft16le = str2rstr_utf16le(secChallenge + "-" +FbPassword );
              var md5     = rstr_md5(uft16le);
              secMd5      = rstr2hex(md5);
                      
              console.log(" > MD5       : " + secMd5);   
      
              // response="${challenge}-${md5}"
              // sid=$(curl -i -s -k -d "response=${response}&username=" "http://$1" | grep -Po -m 1 '(?<=sid=)[a-f\d]+' | tail -1)
              secLogin = "response=" + secChallenge + "-" + secMd5 + "&username=" + FbUser;
      
              console.log(" > Login     : " + secLogin);
      
              getFbSid();
          });
      }
      
      // Get the SID from the Fritzbox
      function getFbSid() {
          console.log("function getFbSid");
      
          request.post({
              url:        'http://' + FbIp,
              headers:    headers, 
              form:       secLogin
          }, function(error, response, body) {
              if (error) log(error, 'error');
              // SID filtern 
              // "sid":"c503b24dae458086"
              try {
                  secSid = response.body.match(/\"sid\":\"(.*)\"/)[1];
              }
              catch (e) {
                  if (secSid == undefined) {
                      console.log("Your login was not successful. End Script", Error)
                      return;
                  }
              }
      
              console.log(" > SID       : " + secSid);
      
              //getFbDeviceInfos();
              getFbProfiles();
          });
      } 
      
      // TBD: 
      // Netzwerkinfos mit allen Devices lesen: 
      // var req = "xhr=1&sid=" + secSid + "&lang=de&page=netDev&xhrId=cleanup&useajax=1&no_sidrenew=" 
      function getFbDeviceInfos(){
          console.log("function getFbDeviceInfos");
          var req = "xhr=1&sid=" + secSid + "&lang=de&page=netDev&xhrId=cleanup&useajax=1&no_sidrenew=" 
      
          request.post({
              url:        'http://' + FbIp + '/data.lua',
              headers:    headers, 
              form:       req
          }, function(error, response, body) {
              if (error) log(error, 'error');
              console.log(response.body);
          });    
      }
      
      // Get all Profiles from the Fritzbox
      function getFbProfiles() {
          console.log("function getFbProfiles");
          // #curl -d "xhr=1&sid=${sid}&lang=de&no_sidrenew=&page=kidPro" "http://$1/data.lua"
          var req = "xhr=1&sid=" + secSid + "&lang=de&no_sidrenew=&page=kidPro";
      
          request.post({
              url:        'http://' + FbIp + '/data.lua',
              headers:    headers, 
              form:       req
          }, function(error, response, body) {
              if (error) log(error, 'error');
              
              if (FbDebugging){
                  console.log(" > response.body : \n" + response.body);
              }
      
              secProfileIds   = [];
              secProfileNames = [];
      
              console.log(" > Decode Names")
              var rx = new RegExp( /class=\"name\"\stitle=\"([a-zA-Z0-9 äöüÄÖÜ\-\_\.]*)\"\sdatalabel/g );
              while( (match = rx.exec( body )) != null ) {
                  secProfileNames.push(match[1]);
              }
              if (FbDebugging){
                  console.log(" > secProfileNames : \n" + secProfileNames);
              }
      
              console.log(" > Decode Filters")
              // submit" name="edit" value="
              rx = new RegExp( /submit\"\sname=\"edit\"\svalue=\"([a-zA-Z0-9 äöüÄÖÜ\-\_\.]*)\"\sclass=\"icon/g );
              while( (match = rx.exec( body )) != null ) {
                  secProfileIds.push(match[1]);
              }
              if (FbDebugging){
                  console.log(" > secProfileIds : \n" + secProfileIds);
              }
      
              if (FbListOnly) {
                  console.log("Filter Count : " + secProfileIds.length);
                  for (var i = 0; i < secProfileIds.length; i++) {
                      console.log("Filter named '"+ secProfileNames[i] + "' has ID : " + secProfileIds[i]);
                  }
              }
      
              getFbDevices();
          });
      }
      
      // IMPORTANT: 
      // The DeviceId changes when you switch the profile. 
      // If you use default profiles it is something like "landevice308962"
      // If you use your own profiles it is something like "user7749"
      function getFbDevices() {
          console.log("function getFbDevices");
          // xhr=1&sid=5f5ba302815594d8&lang=de&no_sidrenew=&page=kidLis
          var req = "xhr=1&sid=" + secSid + "&lang=de&no_sidrenew=&page=kidLis";
      
          request.post({
              url:        'http://' + FbIp + '/data.lua',
              headers:    headers, 
              form:       req
          }, function(error, response, body) {
              if (error) log(error, 'error');
              if (FbDebugging){
                  console.log(" > response.body : \n" + response.body);
              }
      
              // TESTING
              //body = getState("Global.0.Testing.StringValue").val;
      
              secDeviceNames = [];
              secDeviceIds   = [];
      
              console.log(" > Decode Device Names")
              var rx = new RegExp( /class=\"name"\stitle=\"([a-zA-Z0-9 äöüÄÖÜ\-\_\.]*)\"\sdatalabel/g );
              while( (match = rx.exec( body )) != null ) {
                  secDeviceNames.push(match[1]);
              }
              if (FbDebugging){
                  console.log(" > secDeviceNames : \n" + secDeviceNames);
              }
      
              console.log(" > Decode Device Ids")
              rx = new RegExp( /name=\"profile:([a-zA-Z0-9 äöüÄÖÜ\-\_\.]*)\"><option/g );
              while( (match = rx.exec( body )) != null ) {
                  secDeviceIds.push(match[1]);
              }
              if (FbDebugging){
                  console.log(" > secDeviceIds : \n" + secDeviceIds);
              }
              
              if (FbListOnly) {
                  console.log("Device Count : " + secDeviceIds.length);
                  for (var i = 0; i < secDeviceNames.length; i++) {
                      console.log(i + " - Device named '"+ secDeviceNames[i] + "' has ID : " + secDeviceIds[i]);
                  }
              }
      
              if (!FbListOnly) { 
                  setFbSperre(); 
              } else { 
                  console.log("DONE : Listmode - No Device blocking ..."); 
              }
          });
      }
      
      //curl -d "sid=${sid}&edit=$3&time=$4&budget=unlimited&apply=&page=kids_profileedit" "http://$1/data.lua" >/dev/null 2>&1
      function setFbSperre() {
          console.log("function setFbSperre");
          
          // Device suchen ... 
          var devId = -1;
          for (var i = 0; i < secDeviceNames.length; i++) {
              if (secDeviceNames[i] == FbDevice) {
                  devId = i;
              }
          }
          
          console.log(" > Device Nr   : " + devId); 
          console.log(" > Device ID   : " + secDeviceIds[devId]); 
          console.log(" > Device Name : " + secDeviceNames[devId]);
          //var profile = "filtprof4";
          //var profile = "filtprof3079";
      
          // xhr=1&sid=b46f3d48b3b0fcc2&lang=de&no_sidrenew=&profile%3Alandevice308962=filtprof4&apply=&oldpage=%2Finternet%2Fkids_userlist.lua
          var req2 = "xhr=1&sid=" + secSid + "&lang=de&no_sidrenew=&profile%3A" + secDeviceIds[devId] + "=" + FbProfile + "&apply=&oldpage=%2Finternet%2Fkids_userlist.lua";
          console.log(" > req : " + req2);
          //var req2 = "xhr=1&sid=" + sid + "&lang=de&no_sidrenew=&profile%3Alandevice308962=filtprof3079&profile%3Auser7725=filtprof4&profile%3Alandevice2671=filtprof1&profile%3Alandevice2444=filtprof1&profile%3Alandevice2330=filtprof1&profile%3Alandevice2195=filtprof1&profile%3Alandevice229903=filtprof1&profile%3Alandevice8486=filtprof1&profile%3Alandevice1908=filtprof1&profile%3Alandevice1865=filtprof1&profile%3Alandevice516865=filtprof1&profile%3Alandevice518551=filtprof1&profile%3Alandevice169594=filtprof1&profile%3Alandevice171398=filtprof1&profile%3Alandevice175510=filtprof1&profile%3Alandevice177635=filtprof1&profile%3Alandevice178875=filtprof1&profile%3Alandevice179702=filtprof1&profile%3Alandevice180995=filtprof1&profile%3Alandevice182196=filtprof1&profile%3Alandevice183607=filtprof1&profile%3Alandevice184405=filtprof1&profile%3Alandevice638220=filtprof1&profile%3Alandevice634583=filtprof1&profile%3Alandevice7650=filtprof1&profile%3Alandevice353720=filtprof1&profile%3Auser7731=filtprof4&profile%3Alandevice170191=filtprof1&profile%3Alandevice941076=filtprof1&profile%3Alandevice358722=filtprof1&profile%3Alandevice2859=filtprof1&profile%3Auser7739=filtprof4&profile%3Alandevice8035=filtprof1&profile%3Auser7733=filtprof4&profile%3Auser7740=filtprof4&profile%3Alandevice1333=filtprof1&profile%3Alandevice6211=filtprof1&profile%3Alandevice35977=filtprof1&profile%3Alandevice8101=filtprof1&profile%3Alandevice8174=filtprof1&profile%3Auser7729=filtprof4&profile%3Alandevice1125=filtprof1&profile%3Alandevice1124=filtprof1&profile%3Alandevice7715=filtprof1&profile%3Alandevice52361=filtprof1&profile%3Alandevice30084=filtprof1&profile%3Alandevice26151=filtprof1&profile%3Alandevice26138=filtprof1&profile%3Alandevice6162=filtprof1&profile%3Alandevice5204=filtprof1&profile%3Alandevice1129367=filtprof1&profile%3Alandevice9399=filtprof1&profile%3Alandevice232149=filtprof1&profile%3Alandevice6935=filtprof1&profile%3Alandevice941333=filtprof1&profile%3Alandevice941569=filtprof1&apply=&oldpage=%2Finternet%2Fkids_userlist.lua";
          //var req2 = "xhr=1&sid=" + sid + "&lang=de&no_sidrenew=&profile:landevice308962=filtprof4&apply=&oldpage=/internet/kids_userlist.lua";
      
          request.post({
              url:        'http://' + FbIp + '/data.lua',
              headers:    headers, 
              form:       req2
          }, function(error, response, body) {
              if (error) log(error, 'error');
              if (FbDebugging){
                  console.log(" > response : \n" + response);
              }
      
              console.log("Change done. Check your FB / Device if it worked :-)");
      
              if (FbCreateList) {
                  getFbDeviceFilterList();
              }
          });    
      }
      
      function getFbDeviceFilterList() {
          console.log("function getFbDeviceFilterList");
          
          // xhr=1&sid=e2d99419592fb780&lang=de&no_sidrenew=&page=kidLis
          var req = "xhr=1&sid=" + secSid + "&lang=de&no_sidrenew=&page=kidLis";
      
          request.post({
              url:        'http://' + FbIp + '/data.lua',
              headers:    headers, 
              form:       req
          }, function(error, response, body) {
              //if (error) log(error, 'error');
              //console.log(response.body);
      
              JsonList = "";
              var tmpDevices      = [];
              var tmpUsage        = [];
              var tmpProfilesId   = [];
              var tmpProfilesName = [];
              var tmpTimes        = [];
      
              // TESTING
              //body = getState("Global.0.Testing.StringValue").val;
              
              console.log(" > Decode Device Names")
              var rx = new RegExp(/class=\"name"\stitle=\"([a-zA-Z0-9 äöüÄÖÜ\-\_\.]*)\"\sdatalabel/g);
              while ((match = rx.exec(body)) != null) {
                  tmpDevices.push(match[1]);
              }
              //console.log(" > " + tmpDevices);
      
              console.log(" > Decode Device Profile ID");
              //rx = new RegExp(/button\s.*?value=\"([a-zA-Z0-9 äöüÄÖÜ]*?)\"/g);
              rx = new RegExp(/option\svalue=\"([a-zA-Z0-9 äöüÄÖÜ\-]*?)\"\sselected/g);
              while ((match = rx.exec(body)) != null) {
                  tmpProfilesId.push(match[1]);
              }
              //console.log(" > " + tmpProfilesId);
      
              console.log(" > Decode Device Profile Names");
              for (var i = 0; i < tmpProfilesId.length; i++) {
                  for (var j = 0; j < secProfileIds.length; j++) { 
                      //console.log(tmpProfilesId[i] + " > " + secProfileIds[j]);
                      if (tmpProfilesId[i] == secProfileIds[j]){
                          tmpProfilesName.push(secProfileNames[j]);
                      }
                  }
              }
              //console.log(" > " + tmpProfilesName);
      
              console.log(" > Decode Internetnutzung")
              rx = new RegExp(/td\sdatalabel=\"[a-zA-Z0-9 äöüÄÖÜ\-]+\"\sclass=\"usage\">(.*?)<\/td>/g);
              while ((match = rx.exec(body)) != null) { 
                  var tmp = match[1];
                  tmp = tmp.replace("<span>", "").replace("<\/span>", "");
                  tmpUsage.push(tmp);
              }
              //console.log(" > " + tmpUsage);
      
              console.log(" > Decode Times")
              rx = new RegExp(/td\sdatalabel=\"[a-zA-Z0-9 äöüÄÖÜ\-]+\"\sclass=\"bar\stime\">(.*?)<\/td>/g);
              while ((match = rx.exec(body)) != null) {
                  var tmp = match[1];
                  if (tmp.includes("\"")) {
                      tmp = tmp.replace("<span title=\"", "");
                      tmp = tmp.slice(0, tmp.indexOf("\""));
                      tmpTimes.push(tmp);
                  } else {
                      tmpTimes.push(tmp);
                  }
              }
              //console.log(" > " + tmpTimes);
      
              // console.log("Device Count : " + secDeviceIds.length);
              JsonList = "[";
              for (var i = 0; i < tmpDevices.length; i++) {
                  JsonList += "{";
                  JsonList += "\"Device\": \"" + tmpDevices[i] + "\"," 
                  JsonList += "\"Profile ID\": \"" + tmpProfilesId[i] + "\","
                  JsonList += "\"Profile Name\": \"" + tmpProfilesName[i] + "\","
                  JsonList += "\"Usage\": \"" + tmpUsage[i] + "\","
                  JsonList += "\"Time\": \"" + tmpTimes[i] + "\""
                  if (i != tmpDevices.length - 1) { JsonList += "},"; } else { JsonList += "}"; }
              }
              JsonList += "]";
      
              //console.log(JsonList);
              setState(FbIobJsonList,  JsonList, true);
      
              console.log("DONE : List generated ...");
          });   
      }
      
      
      // https://gist.githubusercontent.com/josedaniel/951664/raw/33c7a6b44d6cc53dc75cb5230fb551bc4ba7a46a/md5.js
      // http://pajhome.org.uk/crypt/md5/instructions.html
      
      /*
       * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message
       * Digest Algorithm, as defined in RFC 1321.
       * Version 2.2 Copyright (C) Paul Johnston 1999 - 2009
       * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet
       * Distributed under the BSD License
       * See http://pajhome.org.uk/crypt/md5 for more info.
       */
      
      /*
       * Configurable variables. You may need to tweak these to be compatible with
       * the server-side, but the defaults work in most cases.
       */
      var hexcase = 0;   /* hex output format. 0 - lowercase; 1 - uppercase        */
      var b64pad  = "";  /* base-64 pad character. "=" for strict RFC compliance   */
      
      /*
       * These are the functions you'll usually want to call
       * They take string arguments and return either hex or base-64 encoded strings
       */
      function hex_md5(s)    { return rstr2hex(rstr_md5(str2rstr_utf8(s))); }
      function b64_md5(s)    { return rstr2b64(rstr_md5(str2rstr_utf8(s))); }
      function any_md5(s, e) { return rstr2any(rstr_md5(str2rstr_utf8(s)), e); }
      function hex_hmac_md5(k, d)
        { return rstr2hex(rstr_hmac_md5(str2rstr_utf8(k), str2rstr_utf8(d))); }
      function b64_hmac_md5(k, d)
        { return rstr2b64(rstr_hmac_md5(str2rstr_utf8(k), str2rstr_utf8(d))); }
      function any_hmac_md5(k, d, e)
        { return rstr2any(rstr_hmac_md5(str2rstr_utf8(k), str2rstr_utf8(d)), e); }
      
      /*
       * Perform a simple self-test to see if the VM is working
       */
      function md5_vm_test()
      {
        return hex_md5("abc").toLowerCase() == "900150983cd24fb0d6963f7d28e17f72";
      }
      
      /*
       * Calculate the MD5 of a raw string
       */
      function rstr_md5(s)
      {
        return binl2rstr(binl_md5(rstr2binl(s), s.length * 8));
      }
      
      /*
       * Calculate the HMAC-MD5, of a key and some data (raw strings)
       */
      function rstr_hmac_md5(key, data)
      {
        var bkey = rstr2binl(key);
        if(bkey.length > 16) bkey = binl_md5(bkey, key.length * 8);
      
        var ipad = Array(16), opad = Array(16);
        for(var i = 0; i < 16; i++)
        {
          ipad[i] = bkey[i] ^ 0x36363636;
          opad[i] = bkey[i] ^ 0x5C5C5C5C;
        }
      
        var hash = binl_md5(ipad.concat(rstr2binl(data)), 512 + data.length * 8);
        return binl2rstr(binl_md5(opad.concat(hash), 512 + 128));
      }
      
      /*
       * Convert a raw string to a hex string
       */
      function rstr2hex(input)
      {
        try { hexcase } catch(e) { hexcase=0; }
        var hex_tab = hexcase ? "0123456789ABCDEF" : "0123456789abcdef";
        var output = "";
        var x;
        for(var i = 0; i < input.length; i++)
        {
          x = input.charCodeAt(i);
          output += hex_tab.charAt((x >>> 4) & 0x0F)
                 +  hex_tab.charAt( x        & 0x0F);
        }
        return output;
      }
      
      /*
       * Convert a raw string to a base-64 string
       */
      function rstr2b64(input)
      {
        try { b64pad } catch(e) { b64pad=''; }
        var tab = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
        var output = "";
        var len = input.length;
        for(var i = 0; i < len; i += 3)
        {
          var triplet = (input.charCodeAt(i) << 16)
                      | (i + 1 < len ? input.charCodeAt(i+1) << 8 : 0)
                      | (i + 2 < len ? input.charCodeAt(i+2)      : 0);
          for(var j = 0; j < 4; j++)
          {
            if(i * 8 + j * 6 > input.length * 8) output += b64pad;
            else output += tab.charAt((triplet >>> 6*(3-j)) & 0x3F);
          }
        }
        return output;
      }
      
      /*
       * Convert a raw string to an arbitrary string encoding
       */
      function rstr2any(input, encoding)
      {
        var divisor = encoding.length;
        var i, j, q, x, quotient;
      
        /* Convert to an array of 16-bit big-endian values, forming the dividend */
        var dividend = Array(Math.ceil(input.length / 2));
        for(i = 0; i < dividend.length; i++)
        {
          dividend[i] = (input.charCodeAt(i * 2) << 8) | input.charCodeAt(i * 2 + 1);
        }
      
        /*
         * Repeatedly perform a long division. The binary array forms the dividend,
         * the length of the encoding is the divisor. Once computed, the quotient
         * forms the dividend for the next step. All remainders are stored for later
         * use.
         */
        var full_length = Math.ceil(input.length * 8 /
                                          (Math.log(encoding.length) / Math.log(2)));
        var remainders = Array(full_length);
        for(j = 0; j < full_length; j++)
        {
          quotient = Array();
          x = 0;
          for(i = 0; i < dividend.length; i++)
          {
            x = (x << 16) + dividend[i];
            q = Math.floor(x / divisor);
            x -= q * divisor;
            if(quotient.length > 0 || q > 0)
              quotient[quotient.length] = q;
          }
          remainders[j] = x;
          dividend = quotient;
        }
      
        /* Convert the remainders to the output string */
        var output = "";
        for(i = remainders.length - 1; i >= 0; i--)
          output += encoding.charAt(remainders[i]);
      
        return output;
      }
      
      /*
       * Encode a string as utf-8.
       * For efficiency, this assumes the input is valid utf-16.
       */
      function str2rstr_utf8(input)
      {
        var output = "";
        var i = -1;
        var x, y;
      
        while(++i < input.length)
        {
          /* Decode utf-16 surrogate pairs */
          x = input.charCodeAt(i);
          y = i + 1 < input.length ? input.charCodeAt(i + 1) : 0;
          if(0xD800 <= x && x <= 0xDBFF && 0xDC00 <= y && y <= 0xDFFF)
          {
            x = 0x10000 + ((x & 0x03FF) << 10) + (y & 0x03FF);
            i++;
          }
      
          /* Encode output as utf-8 */
          if(x <= 0x7F)
            output += String.fromCharCode(x);
          else if(x <= 0x7FF)
            output += String.fromCharCode(0xC0 | ((x >>> 6 ) & 0x1F),
                                          0x80 | ( x         & 0x3F));
          else if(x <= 0xFFFF)
            output += String.fromCharCode(0xE0 | ((x >>> 12) & 0x0F),
                                          0x80 | ((x >>> 6 ) & 0x3F),
                                          0x80 | ( x         & 0x3F));
          else if(x <= 0x1FFFFF)
            output += String.fromCharCode(0xF0 | ((x >>> 18) & 0x07),
                                          0x80 | ((x >>> 12) & 0x3F),
                                          0x80 | ((x >>> 6 ) & 0x3F),
                                          0x80 | ( x         & 0x3F));
        }
        return output;
      }
      
      /*
       * Encode a string as utf-16
       */
      function str2rstr_utf16le(input)
      {
        var output = "";
        for(var i = 0; i < input.length; i++)
          output += String.fromCharCode( input.charCodeAt(i)        & 0xFF,
                                        (input.charCodeAt(i) >>> 8) & 0xFF);
        return output;
      }
      
      function str2rstr_utf16be(input)
      {
        var output = "";
        for(var i = 0; i < input.length; i++)
          output += String.fromCharCode((input.charCodeAt(i) >>> 8) & 0xFF,
                                         input.charCodeAt(i)        & 0xFF);
        return output;
      }
      
      /*
       * Convert a raw string to an array of little-endian words
       * Characters >255 have their high-byte silently ignored.
       */
      function rstr2binl(input)
      {
        var output = Array(input.length >> 2);
        for(var i = 0; i < output.length; i++)
          output[i] = 0;
        for(var i = 0; i < input.length * 8; i += 8)
          output[i>>5] |= (input.charCodeAt(i / 8) & 0xFF) << (i%32);
        return output;
      }
      
      /*
       * Convert an array of little-endian words to a string
       */
      function binl2rstr(input)
      {
        var output = "";
        for(var i = 0; i < input.length * 32; i += 8)
          output += String.fromCharCode((input[i>>5] >>> (i % 32)) & 0xFF);
        return output;
      }
      
      /*
       * Calculate the MD5 of an array of little-endian words, and a bit length.
       */
      function binl_md5(x, len)
      {
        /* append padding */
        x[len >> 5] |= 0x80 << ((len) % 32);
        x[(((len + 64) >>> 9) << 4) + 14] = len;
      
        var a =  1732584193;
        var b = -271733879;
        var c = -1732584194;
        var d =  271733878;
      
        for(var i = 0; i < x.length; i += 16)
        {
          var olda = a;
          var oldb = b;
          var oldc = c;
          var oldd = d;
      
          a = md5_ff(a, b, c, d, x[i+ 0], 7 , -680876936);
          d = md5_ff(d, a, b, c, x[i+ 1], 12, -389564586);
          c = md5_ff(c, d, a, b, x[i+ 2], 17,  606105819);
          b = md5_ff(b, c, d, a, x[i+ 3], 22, -1044525330);
          a = md5_ff(a, b, c, d, x[i+ 4], 7 , -176418897);
          d = md5_ff(d, a, b, c, x[i+ 5], 12,  1200080426);
          c = md5_ff(c, d, a, b, x[i+ 6], 17, -1473231341);
          b = md5_ff(b, c, d, a, x[i+ 7], 22, -45705983);
          a = md5_ff(a, b, c, d, x[i+ 8], 7 ,  1770035416);
          d = md5_ff(d, a, b, c, x[i+ 9], 12, -1958414417);
          c = md5_ff(c, d, a, b, x[i+10], 17, -42063);
          b = md5_ff(b, c, d, a, x[i+11], 22, -1990404162);
          a = md5_ff(a, b, c, d, x[i+12], 7 ,  1804603682);
          d = md5_ff(d, a, b, c, x[i+13], 12, -40341101);
          c = md5_ff(c, d, a, b, x[i+14], 17, -1502002290);
          b = md5_ff(b, c, d, a, x[i+15], 22,  1236535329);
      
          a = md5_gg(a, b, c, d, x[i+ 1], 5 , -165796510);
          d = md5_gg(d, a, b, c, x[i+ 6], 9 , -1069501632);
          c = md5_gg(c, d, a, b, x[i+11], 14,  643717713);
          b = md5_gg(b, c, d, a, x[i+ 0], 20, -373897302);
          a = md5_gg(a, b, c, d, x[i+ 5], 5 , -701558691);
          d = md5_gg(d, a, b, c, x[i+10], 9 ,  38016083);
          c = md5_gg(c, d, a, b, x[i+15], 14, -660478335);
          b = md5_gg(b, c, d, a, x[i+ 4], 20, -405537848);
          a = md5_gg(a, b, c, d, x[i+ 9], 5 ,  568446438);
          d = md5_gg(d, a, b, c, x[i+14], 9 , -1019803690);
          c = md5_gg(c, d, a, b, x[i+ 3], 14, -187363961);
          b = md5_gg(b, c, d, a, x[i+ 8], 20,  1163531501);
          a = md5_gg(a, b, c, d, x[i+13], 5 , -1444681467);
          d = md5_gg(d, a, b, c, x[i+ 2], 9 , -51403784);
          c = md5_gg(c, d, a, b, x[i+ 7], 14,  1735328473);
          b = md5_gg(b, c, d, a, x[i+12], 20, -1926607734);
      
          a = md5_hh(a, b, c, d, x[i+ 5], 4 , -378558);
          d = md5_hh(d, a, b, c, x[i+ 8], 11, -2022574463);
          c = md5_hh(c, d, a, b, x[i+11], 16,  1839030562);
          b = md5_hh(b, c, d, a, x[i+14], 23, -35309556);
          a = md5_hh(a, b, c, d, x[i+ 1], 4 , -1530992060);
          d = md5_hh(d, a, b, c, x[i+ 4], 11,  1272893353);
          c = md5_hh(c, d, a, b, x[i+ 7], 16, -155497632);
          b = md5_hh(b, c, d, a, x[i+10], 23, -1094730640);
          a = md5_hh(a, b, c, d, x[i+13], 4 ,  681279174);
          d = md5_hh(d, a, b, c, x[i+ 0], 11, -358537222);
          c = md5_hh(c, d, a, b, x[i+ 3], 16, -722521979);
          b = md5_hh(b, c, d, a, x[i+ 6], 23,  76029189);
          a = md5_hh(a, b, c, d, x[i+ 9], 4 , -640364487);
          d = md5_hh(d, a, b, c, x[i+12], 11, -421815835);
          c = md5_hh(c, d, a, b, x[i+15], 16,  530742520);
          b = md5_hh(b, c, d, a, x[i+ 2], 23, -995338651);
      
          a = md5_ii(a, b, c, d, x[i+ 0], 6 , -198630844);
          d = md5_ii(d, a, b, c, x[i+ 7], 10,  1126891415);
          c = md5_ii(c, d, a, b, x[i+14], 15, -1416354905);
          b = md5_ii(b, c, d, a, x[i+ 5], 21, -57434055);
          a = md5_ii(a, b, c, d, x[i+12], 6 ,  1700485571);
          d = md5_ii(d, a, b, c, x[i+ 3], 10, -1894986606);
          c = md5_ii(c, d, a, b, x[i+10], 15, -1051523);
          b = md5_ii(b, c, d, a, x[i+ 1], 21, -2054922799);
          a = md5_ii(a, b, c, d, x[i+ 8], 6 ,  1873313359);
          d = md5_ii(d, a, b, c, x[i+15], 10, -30611744);
          c = md5_ii(c, d, a, b, x[i+ 6], 15, -1560198380);
          b = md5_ii(b, c, d, a, x[i+13], 21,  1309151649);
          a = md5_ii(a, b, c, d, x[i+ 4], 6 , -145523070);
          d = md5_ii(d, a, b, c, x[i+11], 10, -1120210379);
          c = md5_ii(c, d, a, b, x[i+ 2], 15,  718787259);
          b = md5_ii(b, c, d, a, x[i+ 9], 21, -343485551);
      
          a = safe_add(a, olda);
          b = safe_add(b, oldb);
          c = safe_add(c, oldc);
          d = safe_add(d, oldd);
        }
        return Array(a, b, c, d);
      }
      
      /*
       * These functions implement the four basic operations the algorithm uses.
       */
      function md5_cmn(q, a, b, x, s, t)
      {
        return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s),b);
      }
      function md5_ff(a, b, c, d, x, s, t)
      {
        return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t);
      }
      function md5_gg(a, b, c, d, x, s, t)
      {
        return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t);
      }
      function md5_hh(a, b, c, d, x, s, t)
      {
        return md5_cmn(b ^ c ^ d, a, b, x, s, t);
      }
      function md5_ii(a, b, c, d, x, s, t)
      {
        return md5_cmn(c ^ (b | (~d)), a, b, x, s, t);
      }
      
      /*
       * Add integers, wrapping at 2^32. This uses 16-bit operations internally
       * to work around bugs in some JS interpreters.
       */
      function safe_add(x, y)
      {
        var lsw = (x & 0xFFFF) + (y & 0xFFFF);
        var msw = (x >> 16) + (y >> 16) + (lsw >> 16);
        return (msw << 16) | (lsw & 0xFFFF);
      }
      
      /*
       * Bitwise rotate a 32-bit number to the left.
       */
      function bit_rol(num, cnt)
      {
        return (num << cnt) | (num >>> (32 - cnt));
      }
      

      Ursprung
      Das Script basiert auf einem Post den ich mal gefunden habe und zwar hier:
      https://community.openhab.org/t/disable-internet-connection-of-specific-echo-device-on-fritz-box-via-script/91374
      Das ist nur ein 5 Zeilen Shell Script und ich habe mir gedacht dass das auch in JavaScript gehen müsste - tut es auch 🙂

      Funktionsweise
      Das Script läuft in mehreren Stufen ab ... Erst muss eine "Challange" von der FB abgeholt werden. Damit wird dann zusammen mit dem Passwort ein MD5 Hash gebildet.
      Das nutzt man dann wiederum um die SID von der Fritzbox zu bekommen. Jetzt kann man mit der SID diverse Anfragen an die FB stellen.
      Ich lese dann z.B. alle verfügbaren Filter Profile aus und die bekannten Geräte in der Fritzbox nebst ihren IDs.
      Dieser Part ist in dem ursprünglichen Script etwas rudimentär. Da geht es dann mit F12 und Developer Tools ans eingemachte. Aber das lasse ich hier erstmal weg.
      Am Ende ruft das Script dann eine Seite der FB auf und setzt damit dann den neuen Filter für das Device.

      Ich sage es mal gleich vorweg ... Die ist keine FB API ! Im Grunde ist es ein Hack der den Login und die Datenbewegung der FB Webseite nutzt - nur eben ohne die Webseite.
      Und ja ... Man kann mit diesem "Toolset" noch mehr anstellen. Ich kann z.B. alle Geräte der FB lesen mit ihren IPs. Im Grunde muss man über die Developer Tools nur mal schauen was die Webseite so an Daten schiebt wenn man etwas einstellt.
      Daraus kann man dann interessante Rückschlüsse ziehen. Aber das ist out of Scope hier ...

      Einrichtung und Nutzung
      Tja ihr müsst das Script kopieren und im JavaScript Adapter ein neues JavaScript erstellen. Da dann den Inhalt rein kopieren. 90% erledigt 🙂
      Jetzt etwas "Schnüffeln" und Settings setzen.

      • Zum Testen solltet ihr erstmal die "Static Version" nutzen. Damit läuft das Script nur 1x durch. Wie man das aktiviert steht im Script. Wenn das Script dann sauber läuft kann man auf die "Object Trigger Version" umschwenken und alles über einen Datenpunkt in ioB steuern. Infos dazu stehen im Script.
      • Erstmal müsst ihr natürlich bei FbIp und FbPassword die entsprechenden Werte eintragen. Also einmal die FB IP und das FB Passwort.
      • Wenn der Login auf eure FritzBox mittels User und Passwort erfolgt, dann muss in FbUser der User noch eingetragen werden. Ansonsten dieses Feld einfach leer lassen.
      • FbListOnly jetzt auf true setzen. Denn wir wollen erstmal nur sehen ob es a) klappt und b) die Filter und Devices listen.
      • Wenn alles eingetragen ist (FbDevice & FbProfile sind an dieser Stelle noch unwichtig) dann mal das Script abspulen lassen ...
      • Ihr bekommt jetzt im Logging diverse Ausgaben (hoffentlich keine Fehler). Einmal folgendes:
      06:29:58.055	info	javascript.0 (20276) script.js.Fritzbox.CurlTestFB: > Decode Filters
      06:29:58.056	info	javascript.0 (20276) script.js.Fritzbox.CurlTestFB: Filter named 'Standard' has ID : filtprof1
      06:29:58.057	info	javascript.0 (20276) script.js.Fritzbox.CurlTestFB: Filter named 'Gast' has ID : filtprof2
      06:29:58.057	info	javascript.0 (20276) script.js.Fritzbox.CurlTestFB: Filter named 'Unbeschränkt' has ID : filtprof3
      06:29:58.057	info	javascript.0 (20276) script.js.Fritzbox.CurlTestFB: Filter named 'Gesperrt' has ID : filtprof4
      

      Und dann noch sowas:

      06:30:01.191	info	javascript.0 (20276) script.js.Fritzbox.CurlTestFB: Device named 'Comp-L-Acer-L' has ID : user2482
      06:30:01.191	info	javascript.0 (20276) script.js.Fritzbox.CurlTestFB: Device named 'Comp-L-Pi' has ID : landevice37174
      06:30:01.192	info	javascript.0 (20276) script.js.Fritzbox.CurlTestFB: Device named 'Comp-M-Tablet-W' has ID : landevice2671
      

      Wenn das gelistet wird dann funktioniert def. schon mal der Zugriff auf die FB. Wenn nicht ... Nun dann müssen wir mal guggn 🙂

      • Was wir jetzt brauchen ist erstmal das Gerät was wir einstellen wollen. Ihr nehmt also aus der Device Liste die ID.
        Beispiel:
        Device named 'Comp-L-Acer-L' has ID : user2482
        Wir brauchen den Namen und NICHT die ID!! Also kopieren wir uns Comp-L-Acer-L als Beispiel.
        Diesen Namen kopieren wir im Script hinter FbDevice.
      • Jetzt brauchen wir noch den Filter. Auch die wurden ja im ersten Lauf gelistet.
        Beispiel:
        Filter named 'Gesperrt' has ID : filtprof4
        Wir brauchen die ID und NICHT den Namen. Wir kopieren uns also filtprof4 als Beispiel.
        Diese ID tragen wir dann bei FbProfile ein.
        Anmerkung ... Ok das könnte man noch auf den Namen umstellen merke ich gerade 🙂
      • FbListOnly jetzt auf false setzen.
      • Jetzt kommt der Teil wo die Kuh ins Gras beisst 🙂 Wir lassen das Script laufen.
        Und wenn nicht alles daneben geht, dann ändert sich wie von Zauberhand der Filter für den entsprechenden Rechner.
        Und in meinem Fall gingen 2 Jahre Lösungssuche für dieses Problem zu Ende ....

      Hinweise
      Mir ist bewusst das man an dem Script noch einiges verbessern könnte. Und ich würde es demnächst auch in github einstellen inkl. Anleitung.
      Man könnte es auch in einen Adapter überführen. Aber erstmal wäre gut zu wissen ob es bei anderen auch klappt ...
      Wenn man das Script mit der VIS verheiraten will, dann muss man da noch etwas dran umbauen. Da braucht es dann 2-3 Datenpunkte.
      Aber ein riesen Drama sollte das nicht sein ...

      Ok jetzt bin ich gespannt auf das Feedback 🙂

      Bis dahin ...

      posted in JavaScript
      moelski
      moelski
    • RE: Internet Filter in der Fritzbox mit JavaScript setzen

      Moin !

      Ich habe mal Version 1.03 im 7ten Posting eingefügt.

      Changelog:

      • 02.09.20 V1.03 Erweiterung zum automatischen Start mittels ioB Datenpunkt
      • 02.09.20 V1.02 Script Abbruch wenn der Login nicht geklappt hat
      • 02.09.20 V1.01 Regex Erweiterung, Login auch mit User/Passwort
      • 01.09.20 V1.00 erste öffentliches Release

      Also damit sollte der Login mit Username klappen und man kann das Script auch über einen Datenpunkt im ioB anschubsen. Dazu muss man nur einen Datenpunkt anlegen in den man dann "Comp-L-Pi;filtprof1" als Beispiel schreibt. Also <Computername>;<Profil>.

      Infos wie man das einrichtet habe ich ins Script gepackt 🙂

      Als nächstes würde ich dann noch einen Umbau vornehmen so das man die Profilnamen und nicht die Profil ID verwenden kann.

      Grüße

      posted in JavaScript
      moelski
      moelski
    • RE: Fritzbox Zugangsprofile per Skript steuern

      Moin !

      Nur um das mal eben hier kundzutun ...
      Das Script in seiner ersten Version findet ihr hier:
      https://forum.iobroker.net/topic/36095/internet-filter-in-der-fritzbox-mit-javascript-setzen

      posted in Praktische Anwendungen (Showcase)
      moelski
      moelski
    • RE: Internet Filter in der Fritzbox mit JavaScript setzen

      Ok hat sich ja noch dies und das im Script geändert. Und @jack99n hat ja auch noch Stress. Also eine kurze Anleitung wie man mit dem aktuellen Script am schnellsten voran kommt 🙂

      • Das Script in den JavaScript Adapter bringen und zwar als JavaScript - nicht Blockly oder sonstwas
      • FbIp anpassen mit der IP deiner Fritzbox
      • FbUser anpassen - das wäre der User den du beim Fritzbox Login brauchst. Wenn du nur passwort verwendest dann hier = "" verwenden
      • FbPassword Das Passwort von deinem Fritzbox Login kommt hier hin
      • FbDebugging auf false
      • FbListOnly auf true
      • FbIobObject hier den Datenpunkt eintragen den du erzeugt hast (Typ String) wo Änderungen eingefügt werden
      • FbIobJsonList Hier kommt der Datenpunkt hin wo die JSON Liste erzeugt wird. Die musst du ebenfalls anlegen als String

      Soweit die Vorbereitung .... Alles andere im Script so lassen wie es ist 🙂

      Jetzt gehst du in die Objekte und änderst den Datenpunkt den du bei FbIobObject eingetragen hast. Dort einfach mal Test;test eintragen. Da wird nur die Listen haben wollen mit den Devices und Filtern ist es egal was hier rein kommt. Wichtig ist nur ... 2 Wörter mit Semikolon getrennt.

      Jetzt findest du im Logging Einträge mit Filter named ... und Device named

      Such dir das Device raus was du umbiegen willst. Davon brauchst du den Namen. Also das was im Log in den '' steht.
      Bei den Filtern brauchst du die ID. Das ist das was rechts neben dem : steht.
      Raus kommt dann sowas wie Laptop_Junior;filtprof4

      Das merken wir uns gerade ... Im Script jetzt FbListOnly auf false setzen.
      Jetzt werden Änderungen auch in der Fritzbox übernommen.

      So jetzt den Schnipsel von eben nehmen Laptop_Junior;filtprof4 (als Beispiel) und in deinen Datenpunkt eintragen der bei FbIobObject hinterlegt ist.
      Nun sollte das Gerät den neuen Filter zugewiesen kriegen.

      posted in JavaScript
      moelski
      moelski
    • ZigBee und die Anbindungen - Verwirrung

      Moin !
      Ich habe gestern Abend versucht meinen CC2531 in IOB (am Pi3) ans Laufen zu bekommen. Leider noch ohne jeden Erfolg. Mein Motion Sensor hat sich zwar 1x verbunden, aber ohne Readings. Inzwischen blinkt der Stick nur noch Rot wenn man sich mit ihm verbindet (hoffe das neues Flashen da heute Abhilfe schafft ...).
      Was mir gestern aufgefallen ist das es scheinbar einige Versionen für ZigBee und IOB gibt.

      • Einmal der aktuelle ZigBee Adapter für IOB (schainbar bei mir Version 0.10.2)
      • Dann gibts davon noch 1 oder 2 Forks im Github
      • Dann gib es noch das Projekt Mqtt2Zigbee

      und evtl. noch das ein oder andere was ich noch nicht gesehen habe.

      Was ist denn jetzt die beste Variante die man nutzen sollte um möglichst viele Geräte im IOB mit ZigBee nutzen zu können? Kann das ZigBee Iob Adapter generell auch alle Geräte die Mqtt2Zigbee unterstützt? Oder müssen neue Geräte immer in jedem Projekt eingepflegt werden?
      Und was ist eigentlich im Moment der neuste Stand vom ZigBee IOB Adapter?
      Und wenn wir gerade bei dem Wirrwarr sind ... Was genau macht eigentlich diese "zigbee-shepherd" Bibliothek?

      Vielleicht kann ja mal jemand ein paar klärende Worte finden 🙂 Danke

      Grüße Dominik

      posted in Hardware
      moelski
      moelski
    • RE: Echo Show 5

      Moin !

      @Hermanito33 said in Echo Show 5:

      Gibt es da mittlerweile was neues zu? Würde auch gerne auf einem Echo Show 5 meine Vis anzeigen lassen. Aber halt gerne dauerhaft.

      Ist zwar schon was älter der Thread hier, aber angeblich klappt es wenn man in Dauerschleife ein Video anzeigen lässt.

      <video autoplay muted loop="true">
          <source src="http://192.168.30.22:8082/vis.0/black.mp4" type="video/mp4">
      </video>
      <!--
      https://www.reddit.com/r/amazonecho/comments/f2pgq4/keep_browser_open_on_echo_show/
      -->
      

      Das ganze packt man in ein HTML Widget.

      Aber ich habs heute morgen erst eingerichtet. Test mache ich heute Nachmittag ...

      posted in ioBroker Allgemein
      moelski
      moelski
    • Internet Filter in der Fritzbox mit JavaScript setzen

      Moin !

      Ich habe vor einigen Tagen hier ein Shell Script gefunden um in der Fritzbox Internet Filter zu setzen ohne sich an der FB-Oberfläche anmelden zu müssen:
      https://community.openhab.org/t/disable-internet-connection-of-specific-echo-device-on-fritz-box-via-script/91374

      Es geht um diese Einstellungen hier:
      Screenshot_2020-08-21_10-04-25.png

      Hintergrund ist, dass ich gerne bei einigen Geräten in unserem Netzwerk das Internet (oder bestimmte Seiten) auf Knopfdruck sperren können möchte. Alle mit Kindern und INet Zugang wissen sicher wieso und warum 🙂

      Jedenfalls habe ich das Shell Script als Grundlage genutzt und in JavaScript umgesetzt. Funktioniert inzwischen auch wie gewollt.

      Update
      Das Script findet ihr inzwischen in Post 7 inkl. einer kurzen Anleitung:
      https://forum.iobroker.net/topic/36095/internet-filter-in-der-fritzbox-mit-javascript-setzen/7

      Grüße Dominik

      posted in JavaScript
      moelski
      moelski
    • RE: Echo Show 5

      (3) Problem mit Tunein Internetradio
      So ich denke das habe ich auch gelöst - also zumindest für mich ist es eine Lösung 😉

      Wie schon angemerkt ist es nervig wenn beim Starten des Radios die VIS verschwindet und TuneIn auf geht. Dabei gibt es auch noch das problem das beim Beenden vom Radio der Show manchmal nicht zurück zum Browser geht ...

      Meine Lösung dafür ... Ich nutze das HTML5 Audio Element. Wir haben eh nur eine begrenzte Anzahl von Default Radio Sendern die wir auf dem Ding hören. Also mache ich das jetzt wie folgt:
      Erstmal legt man ein HTML Element in die VIS. Und das bekommt folgenden HTML Inhalt:

      <!DOCTYPE html>
      	<html>
      		<head>
      			<title>Schmidts INet Radio</title>
      		</head>
      		<body <audio src="http://wdr-wdr2-ostwestfalenlippe.icecast.wdr.de/wdr/wdr2/ostwestfalenlippe/mp3/128/stream.mp3" id="iradio">
      			</audio>
      		</body>
      	</html>
      

      Wichtig dabei ist im Audio Element das ID Tag ...

      Ok nun brauchen wir noch ein paar Buttons. Ich habe derer 4 zum Testen.
      2x Radio auswählen und Play / Pause.

      setTimeout(function () {
      
      $('#w00028').click(function () { 
          var audio = document.getElementById("iradio");
          audio.play();
      });
      
      $('#w00029').click(function () { 
          var audio = document.getElementById("iradio");
          audio.pause();
      });
      
      $('#w00026').click(function () { 
          var audio = document.getElementById("iradio");
          audio.src = "http://wdr-wdr2-ostwestfalenlippe.icecast.wdr.de/wdr/wdr2/ostwestfalenlippe/mp3/128/stream.mp3"; 
          audio.play();
      });
      
      $('#w00027').click(function () { 
          var audio = document.getElementById("iradio");
          audio.src = "http://streams.radiobob.de/live-nrw-mitte/mp3-192/mediaplayer"; 
          audio.play();
      });
      
      }, 1000);
      

      Das Script kommt in den Script Bereich der VIS. Die IDs wie z.B. w00027 könnt ihr sehen wenn ihr eure Buttons anklickt. Muss dann entsprechend angepasst werden - logisch ...
      Tja und das wars dann im Grunde auch schon ... Klickt ist auf einen Radiosender Button wird der Sender gespielt. Denn das audio HTML5 Element kann MP3 und OGG dekodieren 😊

      Jetzt bleibt für mich nur noch eine Hürde ... Ich will ja auch sowas sagen können wie ... "Alexa, WDR2". Und das soll ja dann automatisch das Radio starten. Ich glaube auch das bekomme ich hin. Aber da muss man einen kleinen Kunstgriff machen. Denn in einem VIS Script kann man nicht auf die Objekte des JavaScript Adapters zugreifen. Lösung ... Wir schreiben aus JavaScript in ein Objekt. In der VIS nehmen wir ein normales "Basic - string" Element und verknüpfen es mit dem Objekt. Jetzt müssen wir im VIS JavaScript nur noch einen Listener auf das Element einrichten und können so die Variable lesen. 👨‍💻
      So ist jedenfalls der Plan ... Wenn es tut geb ich bescheit - wenn es jemanden interessiert 🤗

      posted in ioBroker Allgemein
      moelski
      moelski
    • RE: Internet Filter in der Fritzbox mit JavaScript setzen

      @Negalein

      Ich habe mal kurz F12 wieder genutzt um mir die Daten anzusehen ....

      <tr>
      	<td class="name" title="Comp-L-Pi" datalabel="Comp-L-Pi">
      		<span>Comp-L-Pi</span>
      	</td>
      	<td datalabel="Internetnutzung" class="usage">unbeschränkt</td>
      	<td datalabel="Onlinezeit heute" class="bar time">
      		<span title="00:00 von 24:00 Stunden">
      			<span style="width:0%;"/>
      		</span>
      	</td>
      	<td datalabel="Zugangsprofil" class="profile">
      		<select name="profile:landevice37174">
      			<option value="filtprof1" selected>Standard</option>
      			<option value="filtprof3">Unbeschränkt</option>
      			<option value="filtprof4">Gesperrt</option>
      			<option value="filtprof1118">Lennard ohne Youtube</option>
      			<option value="filtprof3079">Lennard Tablet</option>
      			<option value="filtprof4042">Test-Whi_te</option>
      			<option value="filtprof3827">TV ohne YT</option>
      		</select>
      	</td>
      	<td datalabel="" class="btncolumn">
      		<button type="submit" name="edit" id="uiEdit:landevice37174" value="filtprof1" class="icon edit" title="Bearbeiten"/>
      	</td>
      </tr>
      

      Also mit ein bissel Regex kriege ich da alle Infos zusammen 👨‍🚀

      posted in JavaScript
      moelski
      moelski

    Latest posts made by moelski

    • RE: SOLVED : notarget No matching version found for XYZ@<ver>

      Sooo, um es kurz zu machen.
      Der Fehler war zum Teil hausgemacht.

      1. Man sollte keine Kindersicherung in der Fritzbox für den iob aktiv haben. Warum auch immer die an war ... Danach war auch inet wieder da in iob 🙂
      2. NPM auf Version 6 gebracht
      3. mit Thomas' Infos nodejs und node wieder gerade gezogen

      Und nun laufen die Updates.

      Danke trotzdem allen für die schnelle Hilfe.

      Grüße Dominik

      posted in ioBroker Allgemein
      moelski
      moelski
    • RE: SOLVED : notarget No matching version found for XYZ@<ver>

      @thomas-braun said in notarget No matching version found for XYZ@<ver>:

      @moelski sagte in notarget No matching version found for XYZ@<ver>:

      sudo apt update liefert nämlich auch nur Fehler.

      Geheime Fehler?
      Das sind die schlimmsten...
      Du scheinst da aber ein Netzwerkproblem zu haben.

      Ja definitiv Netzwerk erstmal.
      Ich geb mal Feedback was ich rausgefunden habe ...

      posted in ioBroker Allgemein
      moelski
      moelski
    • RE: SOLVED : notarget No matching version found for XYZ@<ver>

      @thomas-braun said in notarget No matching version found for XYZ@<ver>:

      @moelski
      Schau in meiner Signatur wie man unter Debian nodeJS (inkl. npm) sauber installiert.

      Mache ich. Danke.

      Aber ich glaube ich hab da noch ein anderes Problem.
      Irgendwie scheint der ganze Server mehr oder minder offline.
      sudo apt update liefert nämlich auch nur Fehler.

      Ich forsche mal weiter. Danke erstmal

      posted in ioBroker Allgemein
      moelski
      moelski
    • RE: SOLVED : notarget No matching version found for XYZ@<ver>

      @fredf
      Ok, und wie komme ich zurück nach 6 ?

      posted in ioBroker Allgemein
      moelski
      moelski
    • SOLVED : notarget No matching version found for XYZ@<ver>

      Moinsen !

      In meinem iob stehen 9 Adapter zur Aktuualisierung bereit. Ich wollte mal den Telegramm Adapter updaten, bekomme aber folgenden Fehler:

      $ ./iobroker upgrade telegram
      Update telegram from @1.8.1 to @1.9.0
      host.SHome-IoBroker Adapter "system.adapter.telegram.0" is stopped.
      NPM version: 7.16.0
      npm install iobroker.telegram@1.9.0 --loglevel error --prefix "/opt/iobroker" (System call)
      npm ERR! code ETARGET
      npm ERR! notarget No matching version found for iobroker.telegram@1.9.0.
      npm ERR! notarget In most cases you or one of your dependencies are requestingnpm ERR! notarget a package version that doesn't exist.
      npm ERR! A complete log of this run can be found in:npm ERR!     /home/iobroker/.npm/_logs/2021-08-09T13_24_58_625Z-debug.log
      upload [6] telegram.admin /opt/iobroker/node_modules/iobroker.telegram/admin/words.js words.js application/javascript
      Update "system.adapter.telegram.0"
      upload [5] telegram.admin /opt/iobroker/node_modules/iobroker.telegram/admin/telegram.png telegram.png image/png
      upload [4] telegram.admin /opt/iobroker/node_modules/iobroker.telegram/admin/jsonCustom.json jsonCustom.json application/json
      upload [3] telegram.admin /opt/iobroker/node_modules/iobroker.telegram/admin/index_m.html index_m.html text/html
      upload [2] telegram.admin /opt/iobroker/node_modules/iobroker.telegram/admin/index.html index.html text/html
      upload [1] telegram.admin /opt/iobroker/node_modules/iobroker.telegram/admin/custom_m.html custom_m.html text/html
      upload [0] telegram.admin /opt/iobroker/node_modules/iobroker.telegram/admin/blockly.js blockly.js application/javascript
      Adapter "telegram" updated
      host.SHome-IoBroker Adapter "system.adapter.telegram.0" is started
      process exited with code 0
      

      Auch andere Adapter bringen den gleichen Fehler.

      NPN und Node:

      dominik@SHome-IoBroker:/opt/iobroker$ npm -v
      7.16.0
      dominik@SHome-IoBroker:/opt/iobroker$ node -v
      v14.17.0
      
      

      js-controller ist auf Version 3.2.16.

      Ich habe mal ein

      curl -sL https://iobroker.net/fix.sh | bash -
      

      probiert, aber da passiert gar nichts. Null Ausgabe - es kommt einfach ein neuer Prompt und das wars.

      Kann mir vielleicht wer einen Tip geben was ich nun machen könnte ?

      Grüße Dominik

      posted in ioBroker Allgemein
      moelski
      moelski
    • RE: Internet Filter in der Fritzbox mit JavaScript setzen

      @juge
      Moin !
      Ne das geht nicht aus der Command Line. Da fehlen alle Libs von ioBroker ...

      Wenn es dir nur um das Sperren von ein paar Seiten geht dann ist PiHole sicher der effizientere Weg.
      Ich mach das bei meinem Junior auch. Das schöne ist, dass man pro Gerät Sperrungen definieren kann in PiHole.
      Aber das wird hier dann langsam etwas OT vermutlich ...

      posted in JavaScript
      moelski
      moelski
    • Button Bild durch JSON setzen ?

      Moin !
      Ich würde gerne das Bild eine "Jquery - ctrl - Icon State" Buttons durch einen bestimmten JSON Wert setzen lassen. Mein JSON sieht so aus:

      [{
              "Device": "Comp-L-Acer-L",
              "Profile ID": "filtprof1",
              "Profile Name": "Standard",
              "Usage": "Unbeschränkt",
              "Time": "00:00 von 24:00 Stunden"
          }, {
              "Device": "Comp-L-Acer-W",
              "Profile ID": "filtprof1",
              "Profile Name": "Standard",
              "Usage": "Unbeschränkt",
              "Time": "00:00 von 24:00 Stunden"
          }
      ]
      

      Das Icon soll nach dem Wert von Profile ID gesetzt werden aber für ein bestimmtes Device.

      Konkret der Wert Profile ID bei "Device": "Comp-L-Acer-L" auf filtprof1 steht dann möchte ich BILD1, steht er auf einem anderen Wert, dann eben BILD2.

      Ich weiß das man Bilder über Datenpunkte mittels Bindings direkt setzen kann. Bsp:

      {v:Global.0.Alexa.Selected;v == 'alexa2.0.Echo-Devices.G090XG08945606VC' ? '/icons-mfd-png/control_clear.png' : '/icons-mfd-png/status_light_off.png'}
      

      Nur geht das eben auch mittels JSON Wert ?

      Grüße Dominik

      posted in Visualisierung
      moelski
      moelski
    • RE: Echo Show 5

      @freaktech
      Kann es heute mal testen.

      posted in ioBroker Allgemein
      moelski
      moelski
    • RE: [gelöst] Globale Scripte mit Codevervollständigung

      @pk68
      Ok das scheint dann wohl ein Cache Problem zu sein.
      Habe den Browser Cache mal leer gemacht und nun habe ich auch meine Logger2 Funktion 🙂

      posted in JavaScript
      moelski
      moelski
    • RE: [gelöst] Globale Scripte mit Codevervollständigung

      Hmm habe ich versucht ... Bringt nichts.
      Ausser das jetzt die unbekannte Funktion nicht mehr rot unterstrichen wird ... 🤔

      Evtl. mache ich auch beim Anlegen was falsch ...

      Habe in global ein JS angelegt das schimpft sich Logging_Helper.
      Inhalt bis jetzt nur das:

      function Logger2(logText, logPrefix = "", sendConsole = true, sendTelegram = true, sendDoro = false) {
          if (sendConsole == true) {
              console.log(logText);
          }
          if (sendTelegram == true) {
              sendTo("telegram", "send", {
                  text: logPrefix + logText,
                  user: 'xyz'
              }); 
          }
      }
      

      Ist da irgendwas dran verkehrt? Hab ich was vergessen?

      posted in JavaScript
      moelski
      moelski
    Community
    Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
    The ioBroker Community 2014-2023
    logo