Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Visualisierung
  4. [gelöst] - VIS Intance Id - automatisiert ermitteln

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    22
    1
    1.2k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.5k

[gelöst] - VIS Intance Id - automatisiert ermitteln

Geplant Angeheftet Gesperrt Verschoben Visualisierung
126 Beiträge 13 Kommentatoren 20.4k Aufrufe 12 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • bahnuhrB bahnuhr

    @liv-in-sky

    so, nochmal.
    5715ff6c-99fa-462d-b499-99d15e9b505a-image.png

    Ich habe beide widget eingefügt.
    Das obere hat die Nr. 2256 und das untere die Nr. 2259

    function waitForElement(parent, elementPath, wid, widgetName, callBack, counter = 0, debug = false) {
            if (counter < 100) {
                setTimeout(function () {
                    if (parent.find(elementPath).length > 0) {
                        if (debug) console.log(`[${widgetName} ${wid}] it took ${counter}ms to wait for the element '${elementPath}'`);
                        callBack();
                    } else {
                        if (debug) console.log(`[${widgetName} ${wid}] wait for element '${elementPath}'`);
                        counter++
                        waitForElement(parent, elementPath, wid, widgetName, callBack, counter, debug);
                    }
                }, 1);
            } else {
               if (debug) console.warn(`[${widgetName} ${wid}] stop waiting after ${counter} retries`);
                callBack();
            }
        }
     
    waitForElement($('body'),'#w02256', 'dummy', 'dummy', function () {
            // Widget ist vollständig geladen, wir können irgendwas damit machen
       console.log(vis.instance)
    	$( "#w02256" ).text( 'Test mit warten auf Widget Instance ID: '+vis.instance);
        }, 0, true);
        
    waitForElement($('body'),'vis.instance', 'dummy', 'dummy', function () {
            // Widget ist vollständig geladen, wir können irgendwas damit machen
       console.log(vis.instance)
        $( "#w02259" ).text( 'Warten auf VIS-Instance Instance ID: '+vis.instance);
        }, 0, true);
    

    dein Script eingefügt und die Nr. eingetragen.

    In runtime kommt dann absolut nix.

    Kein Text, keine Instanz.
    f0441fd1-aba7-4c6d-b241-c9af6782f7da-image.png

    liv-in-skyL Offline
    liv-in-skyL Offline
    liv-in-sky
    schrieb am zuletzt editiert von
    #56

    @bahnuhr

    das schaut eigentlich richtig aus - kommt eine fehlermeldung in der entwicklungsumgebung ?

    nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

    1 Antwort Letzte Antwort
    0
    • liv-in-skyL liv-in-sky

      @bahnuhr

      das sind 2 widgets - die haben bei mir die id's #00001 und #00002 - bei dir musst du nachsehen, welche id's erzeugt worden sind

      einmal wird auf #00001 gwartet und dann in das wisget #00001 geschrieben /geändert

      im 2ten widget wird auf vis.instance gewartet - bis das object von der vis erstellt wurde und dann wird der text in #00002 geschrieben

      beide widgets am anfang leer - kein tet enthalten

      BananaJoeB Offline
      BananaJoeB Offline
      BananaJoe
      Most Active
      schrieb am zuletzt editiert von
      #57

      @liv-in-sky @bahnuhr

      So, ich habe es noch mal angepasst, so läuft es bei mir:

      • Widget #00001 ist das (basic -Screen Resolution) Widget
      • Datenpunkt vom Typ String in welches die ID geschrieben wird: 0_userdata.0.Visualisierung.Instanzen.DC.Test-Instanzen
      • folgendes Skript im Reiter Skripte:
      // Funktion die auf ein Widget wartet,
      // Stammt von: https://forum.iobroker.net/topic/48663/howto-skripte-im-vis-editor-mit-jquery
      // Modifiziert: 30 Durchläufe maximal, 1 Sekunde Pause dazwischen
      function waitForElement(parent, elementPath, wid, widgetName, callBack, counter = 0, debug = false) {
               if (counter < 30) {
                   setTimeout(function () {
                       if (parent.find(elementPath).length > 0) {
                           if (debug) console.log(`[${widgetName} ${wid}] it took ${counter}ms to wait for the element '${elementPath}'`);
                           callBack();
                       } else {
                           if (debug) console.log(`[${widgetName} ${wid}] wait for element '${elementPath}'`);
                           counter++
                           waitForElement(parent, elementPath, wid, widgetName, callBack, counter, debug);
                       }
                   }, 1000);
               } else {
                  if (debug) console.warn(`[${widgetName} ${wid}] stop waiting after ${counter} retries`);
                   callBack();
              }
          }
       
      
      // Warten auf das (basic - Scren Resolution) Widget, ID ggf. anpassen
      waitForElement($('body'),'#w00001', 'dummy', 'dummy', function () {
         // Widget ist geladen, auf das Widget klicken, w00001 ist die ID von meinem basic - Screen Resolution Widget
          setTimeout( () => { 
              $('#w00001>div>span>span').trigger('click'); 
          }, 1000);
          // und in einen Datenpunkt schreiben
          setTimeout( () => { 
              vis.setValue('0_userdata.0.Visualisierung.Instanzen.DC.Test-Instanzen', vis.instance);
          }, 3000);
      }, 0, true);
      

      Die waitForElement wartet, wenn einfach so rauskopiert, nämlich nur 100 Durchläufe mit je 1ms pause. Das ist meine ich eindeutig zu wenig. Ich habe die Pausen auf 1 Sekunde und die Durchläufe auf 30 gesetzt.
      Dann wird mit 1 Sekunden Verzögerung auf das Widget geklickt und noch mal 2 Sekunden später der Datenpunkt gesetzt.
      Perfekt wäre jetzt noch eine Schleife die wartet das vis.instance einen Wert hat/gesetzt ist statt der Pause

      Wegen der IP: Ich meine mich erinnern zu können das es so - mit Absicht - nicht möglich ist. Aber man könnte seine "externe" IP herausbekommen. Das geht im Prinzip immer dadurch das einen externe Seite aufgerufen wird und einem zurückmeldet mit welcher IP man sich meldet. Wenn man das intern macht kommt natürlich auch die interne IP.

      ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

      liv-in-skyL 1 Antwort Letzte Antwort
      1
      • BananaJoeB BananaJoe

        @liv-in-sky @bahnuhr

        So, ich habe es noch mal angepasst, so läuft es bei mir:

        • Widget #00001 ist das (basic -Screen Resolution) Widget
        • Datenpunkt vom Typ String in welches die ID geschrieben wird: 0_userdata.0.Visualisierung.Instanzen.DC.Test-Instanzen
        • folgendes Skript im Reiter Skripte:
        // Funktion die auf ein Widget wartet,
        // Stammt von: https://forum.iobroker.net/topic/48663/howto-skripte-im-vis-editor-mit-jquery
        // Modifiziert: 30 Durchläufe maximal, 1 Sekunde Pause dazwischen
        function waitForElement(parent, elementPath, wid, widgetName, callBack, counter = 0, debug = false) {
                 if (counter < 30) {
                     setTimeout(function () {
                         if (parent.find(elementPath).length > 0) {
                             if (debug) console.log(`[${widgetName} ${wid}] it took ${counter}ms to wait for the element '${elementPath}'`);
                             callBack();
                         } else {
                             if (debug) console.log(`[${widgetName} ${wid}] wait for element '${elementPath}'`);
                             counter++
                             waitForElement(parent, elementPath, wid, widgetName, callBack, counter, debug);
                         }
                     }, 1000);
                 } else {
                    if (debug) console.warn(`[${widgetName} ${wid}] stop waiting after ${counter} retries`);
                     callBack();
                }
            }
         
        
        // Warten auf das (basic - Scren Resolution) Widget, ID ggf. anpassen
        waitForElement($('body'),'#w00001', 'dummy', 'dummy', function () {
           // Widget ist geladen, auf das Widget klicken, w00001 ist die ID von meinem basic - Screen Resolution Widget
            setTimeout( () => { 
                $('#w00001>div>span>span').trigger('click'); 
            }, 1000);
            // und in einen Datenpunkt schreiben
            setTimeout( () => { 
                vis.setValue('0_userdata.0.Visualisierung.Instanzen.DC.Test-Instanzen', vis.instance);
            }, 3000);
        }, 0, true);
        

        Die waitForElement wartet, wenn einfach so rauskopiert, nämlich nur 100 Durchläufe mit je 1ms pause. Das ist meine ich eindeutig zu wenig. Ich habe die Pausen auf 1 Sekunde und die Durchläufe auf 30 gesetzt.
        Dann wird mit 1 Sekunden Verzögerung auf das Widget geklickt und noch mal 2 Sekunden später der Datenpunkt gesetzt.
        Perfekt wäre jetzt noch eine Schleife die wartet das vis.instance einen Wert hat/gesetzt ist statt der Pause

        Wegen der IP: Ich meine mich erinnern zu können das es so - mit Absicht - nicht möglich ist. Aber man könnte seine "externe" IP herausbekommen. Das geht im Prinzip immer dadurch das einen externe Seite aufgerufen wird und einem zurückmeldet mit welcher IP man sich meldet. Wenn man das intern macht kommt natürlich auch die interne IP.

        liv-in-skyL Offline
        liv-in-skyL Offline
        liv-in-sky
        schrieb am zuletzt editiert von liv-in-sky
        #58

        @bananajoe sagte in VIS Intance Id - automatisiert ermitteln:

        Die waitForElement wartet, wenn einfach so rauskopiert, nämlich nur 100 Durchläufe mit je 1ms pause

        das kann natürlich zu wenig sein, wenn man eine "volle" vis hat - ich habe ja ein leeres project - da geht das dann schneller

        @bahnuhr
        habe dein gepostetes beispiel genommen - die widgets angeglichen und es läuft

        probiermal die längere pause - also dasbeispiel von @BananaJoe

        function waitForElement(parent, elementPath, wid, widgetName, callBack, counter = 0, debug = false) {
        
                 if (counter < 30) {
        
                     setTimeout(function () {
        
                         if (parent.find(elementPath).length > 0) {
        
                             if (debug) console.log(`[${widgetName} ${wid}] it took ${counter}ms to wait for the element '${elementPath}'`);
        
                             callBack();
        
                         } else {
        
                             if (debug) console.log(`[${widgetName} ${wid}] wait for element '${elementPath}'`);
        
                             counter++
        
                             waitForElement(parent, elementPath, wid, widgetName, callBack, counter, debug);
        
                         }
        
                     }, 1000);
        
                 } else {
        
                    if (debug) console.warn(`[${widgetName} ${wid}] stop waiting after ${counter} retries`);
        
                     callBack();
        
                }
        
            }
        
         
        

        da wird 30 mal eine sekunde gewartet - das sollte reichen

        bei meinem beispiel sind es 100 mal 1ms - das ist kurz - da hatt' er recht

        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

        1 Antwort Letzte Antwort
        0
        • liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          schrieb am zuletzt editiert von
          #59

          und mir ist noch was aufgefallen:#

          waitForElement($('body'),'vis.instance', 'dummy', 'dummy', function () {
          
                   // Widget ist vollständig geladen, wir können irgendwas damit machen
          
             console.log(vis.instance)
          
              $( "#w00002" ).text( 'Warten auf VIS-Instance Instance ID: '+vis.instance);
          
              }, 0, true);
          

          dieser block funktioniert nicht wirklich - es wird nicht gewartet, bis das object vis.instance da ist - daher war es eine gute idee von @BananaJoe auf das basic -Screen Resolution) Widget zu warten

          @scrounger könntest du mir helfen - kann ich mit deiner waitForElement function auch warten, bis vis.instance verfügbar ist

          nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

          bahnuhrB 1 Antwort Letzte Antwort
          0
          • liv-in-skyL liv-in-sky

            und mir ist noch was aufgefallen:#

            waitForElement($('body'),'vis.instance', 'dummy', 'dummy', function () {
            
                     // Widget ist vollständig geladen, wir können irgendwas damit machen
            
               console.log(vis.instance)
            
                $( "#w00002" ).text( 'Warten auf VIS-Instance Instance ID: '+vis.instance);
            
                }, 0, true);
            

            dieser block funktioniert nicht wirklich - es wird nicht gewartet, bis das object vis.instance da ist - daher war es eine gute idee von @BananaJoe auf das basic -Screen Resolution) Widget zu warten

            @scrounger könntest du mir helfen - kann ich mit deiner waitForElement function auch warten, bis vis.instance verfügbar ist

            bahnuhrB Online
            bahnuhrB Online
            bahnuhr
            Forum Testing Most Active
            schrieb am zuletzt editiert von
            #60

            @liv-in-sky
            @BananaJoe

            Script von @BananaJoe hat geklappt.
            Auch bei edge im Kiosk Modus.

            @bananajoe sagte in VIS Intance Id - automatisiert ermitteln:

            Wegen der IP: Ich meine mich erinnern zu können das es so - mit Absicht - nicht möglich ist.

            Das wäre sehr schade. Im Netz gibt es zahlreiche Scripte.
            Nur bekomme ich dies nicht hin.
            Vielleicht ist ja noch ein Spezi da, der mit liest.


            Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
            Danke.
            gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
            ScreenToGif :https://www.screentogif.com/downloads.html

            BananaJoeB 1 Antwort Letzte Antwort
            0
            • bahnuhrB bahnuhr

              @liv-in-sky
              @BananaJoe

              Script von @BananaJoe hat geklappt.
              Auch bei edge im Kiosk Modus.

              @bananajoe sagte in VIS Intance Id - automatisiert ermitteln:

              Wegen der IP: Ich meine mich erinnern zu können das es so - mit Absicht - nicht möglich ist.

              Das wäre sehr schade. Im Netz gibt es zahlreiche Scripte.
              Nur bekomme ich dies nicht hin.
              Vielleicht ist ja noch ein Spezi da, der mit liest.

              BananaJoeB Offline
              BananaJoeB Offline
              BananaJoe
              Most Active
              schrieb am zuletzt editiert von
              #61

              @bahnuhr bin gerade am probieren. Aber es wird darauf hinauslaufen das es einen Dienst im Netzwerk geben muss der dir deine eigene IP verrät. Ich suche gerade nach dem einfachsten Weg dafür.

              Ich hab das sonstin PHP als Unterwebseite auf meinem Apache Webserver liegen ... das klingt aber sehr aufwändig für einen Ottonormal-ioBroker-Benutzer ...

              ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

              bahnuhrB 1 Antwort Letzte Antwort
              0
              • BananaJoeB BananaJoe

                @bahnuhr bin gerade am probieren. Aber es wird darauf hinauslaufen das es einen Dienst im Netzwerk geben muss der dir deine eigene IP verrät. Ich suche gerade nach dem einfachsten Weg dafür.

                Ich hab das sonstin PHP als Unterwebseite auf meinem Apache Webserver liegen ... das klingt aber sehr aufwändig für einen Ottonormal-ioBroker-Benutzer ...

                bahnuhrB Online
                bahnuhrB Online
                bahnuhr
                Forum Testing Most Active
                schrieb am zuletzt editiert von
                #62

                @bananajoe

                natürlich das Script von @Jey-Cee

                und weitere aus dem Netz:

                    window.RTCPeerConnection = window.RTCPeerConnection || window.mozRTCPeerConnection || window.webkitRTCPeerConnection;   //compatibility for firefox and chrome
                    var pc = new RTCPeerConnection({iceServers:[]}), noop = function(){};      
                    pc.createDataChannel("");    //create a bogus data channel
                    pc.createOffer(pc.setLocalDescription.bind(pc), noop);    // create offer and set local description
                    pc.onicecandidate = function(ice){  //listen for candidate events
                        if(!ice || !ice.candidate || !ice.candidate.candidate)  return;
                        var myIP = /([0-9]{1,3}(\.[0-9]{1,3}){3}|[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7})/.exec(ice.candidate.candidate)[1];
                        console.log('my IP: ', myIP);   
                        pc.onicecandidate = noop;
                    };
                
                // cleaned, 363b
                const ip = await new Promise((resolve, reject) => {
                  const conn = new RTCPeerConnection()
                  conn.createDataChannel('')
                  conn.createOffer(offer => conn.setLocalDescription(offer), reject)
                  conn.onicecandidate = ice => {
                    if (ice && ice.candidate && ice.candidate.candidate) {
                      resolve(i.candidate.candidate.split(' ')[4])
                      conn.close()
                    }
                  }
                })
                
                /**
                 * Get the user IP throught the webkitRTCPeerConnection
                 * @param onNewIP {Function} listener function to expose the IP locally
                 * @return undefined
                 */
                function getUserIP(onNewIP) { //  onNewIp - your listener function for new IPs
                    //compatibility for firefox and chrome
                    var myPeerConnection = window.RTCPeerConnection || window.mozRTCPeerConnection || window.webkitRTCPeerConnection;
                    var pc = new myPeerConnection({
                        iceServers: []
                    }),
                    noop = function() {},
                    localIPs = {},
                    ipRegex = /([0-9]{1,3}(\.[0-9]{1,3}){3}|[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7})/g,
                    key;
                
                    function iterateIP(ip) {
                        if (!localIPs[ip]) onNewIP(ip);
                        localIPs[ip] = true;
                    }
                
                     //create a bogus data channel
                    pc.createDataChannel("");
                
                    // create offer and set local description
                    pc.createOffer().then(function(sdp) {
                        sdp.sdp.split('\n').forEach(function(line) {
                            if (line.indexOf('candidate') < 0) return;
                            line.match(ipRegex).forEach(iterateIP);
                        });
                
                        pc.setLocalDescription(sdp, noop, noop);
                    }).catch(function(reason) {
                        // An error occurred, so handle the failure to connect
                    });
                
                    //listen for candidate events
                    pc.onicecandidate = function(ice) {
                        if (!ice || !ice.candidate || !ice.candidate.candidate || !ice.candidate.candidate.match(ipRegex)) return;
                        ice.candidate.candidate.match(ipRegex).forEach(iterateIP);
                    };
                }
                
                // Usage
                
                getUserIP(function(ip){
                    alert("Got IP! :" + ip);
                });
                

                Aber wie gesagt, ich glaube das übersteigt meine Kenntnisse.


                Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                Danke.
                gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                ScreenToGif :https://www.screentogif.com/downloads.html

                liv-in-skyL BananaJoeB 2 Antworten Letzte Antwort
                0
                • bahnuhrB bahnuhr

                  @bananajoe

                  natürlich das Script von @Jey-Cee

                  und weitere aus dem Netz:

                      window.RTCPeerConnection = window.RTCPeerConnection || window.mozRTCPeerConnection || window.webkitRTCPeerConnection;   //compatibility for firefox and chrome
                      var pc = new RTCPeerConnection({iceServers:[]}), noop = function(){};      
                      pc.createDataChannel("");    //create a bogus data channel
                      pc.createOffer(pc.setLocalDescription.bind(pc), noop);    // create offer and set local description
                      pc.onicecandidate = function(ice){  //listen for candidate events
                          if(!ice || !ice.candidate || !ice.candidate.candidate)  return;
                          var myIP = /([0-9]{1,3}(\.[0-9]{1,3}){3}|[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7})/.exec(ice.candidate.candidate)[1];
                          console.log('my IP: ', myIP);   
                          pc.onicecandidate = noop;
                      };
                  
                  // cleaned, 363b
                  const ip = await new Promise((resolve, reject) => {
                    const conn = new RTCPeerConnection()
                    conn.createDataChannel('')
                    conn.createOffer(offer => conn.setLocalDescription(offer), reject)
                    conn.onicecandidate = ice => {
                      if (ice && ice.candidate && ice.candidate.candidate) {
                        resolve(i.candidate.candidate.split(' ')[4])
                        conn.close()
                      }
                    }
                  })
                  
                  /**
                   * Get the user IP throught the webkitRTCPeerConnection
                   * @param onNewIP {Function} listener function to expose the IP locally
                   * @return undefined
                   */
                  function getUserIP(onNewIP) { //  onNewIp - your listener function for new IPs
                      //compatibility for firefox and chrome
                      var myPeerConnection = window.RTCPeerConnection || window.mozRTCPeerConnection || window.webkitRTCPeerConnection;
                      var pc = new myPeerConnection({
                          iceServers: []
                      }),
                      noop = function() {},
                      localIPs = {},
                      ipRegex = /([0-9]{1,3}(\.[0-9]{1,3}){3}|[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7})/g,
                      key;
                  
                      function iterateIP(ip) {
                          if (!localIPs[ip]) onNewIP(ip);
                          localIPs[ip] = true;
                      }
                  
                       //create a bogus data channel
                      pc.createDataChannel("");
                  
                      // create offer and set local description
                      pc.createOffer().then(function(sdp) {
                          sdp.sdp.split('\n').forEach(function(line) {
                              if (line.indexOf('candidate') < 0) return;
                              line.match(ipRegex).forEach(iterateIP);
                          });
                  
                          pc.setLocalDescription(sdp, noop, noop);
                      }).catch(function(reason) {
                          // An error occurred, so handle the failure to connect
                      });
                  
                      //listen for candidate events
                      pc.onicecandidate = function(ice) {
                          if (!ice || !ice.candidate || !ice.candidate.candidate || !ice.candidate.candidate.match(ipRegex)) return;
                          ice.candidate.candidate.match(ipRegex).forEach(iterateIP);
                      };
                  }
                  
                  // Usage
                  
                  getUserIP(function(ip){
                      alert("Got IP! :" + ip);
                  });
                  

                  Aber wie gesagt, ich glaube das übersteigt meine Kenntnisse.

                  liv-in-skyL Offline
                  liv-in-skyL Offline
                  liv-in-sky
                  schrieb am zuletzt editiert von liv-in-sky
                  #63

                  @bahnuhr

                  zur not mach dir eine tabelle mit instance und ip`s dazu - dann kannst du je instance id auch die ip ausgeben

                  muss halt gepflegt werden

                  nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                  bahnuhrB 1 Antwort Letzte Antwort
                  0
                  • liv-in-skyL liv-in-sky

                    @bahnuhr

                    zur not mach dir eine tabelle mit instance und ip`s dazu - dann kannst du je instance id auch die ip ausgeben

                    muss halt gepflegt werden

                    bahnuhrB Online
                    bahnuhrB Online
                    bahnuhr
                    Forum Testing Most Active
                    schrieb am zuletzt editiert von
                    #64

                    @liv-in-sky sagte in VIS Intance Id - automatisiert ermitteln:

                    @bahnuhr

                    zur not mach dir eine tabelle mit instance und ip`s dazu - dann kannst du je instance id auch die ip ausgeben

                    muss halt gepflegt werden

                    genau das geht eben nicht.

                    Hintergrund:
                    Ich wollte auf dem Tablet im Wohnzimmer (win10) edge im kiosk mode einrichten.
                    Nur da wird die Instanz nur erzeugt wenn man klickt. Und diese ändert sich dann ständig.
                    Die IP ist aber immer gleich.

                    Ich müsste also wissen, welche IP die instanz sendet um dann zu beurteilen welcher PC / Laptop neu die VIS aufgebaut hat.


                    Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                    Danke.
                    gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                    ScreenToGif :https://www.screentogif.com/downloads.html

                    liv-in-skyL 1 Antwort Letzte Antwort
                    0
                    • bahnuhrB bahnuhr

                      @liv-in-sky sagte in VIS Intance Id - automatisiert ermitteln:

                      @bahnuhr

                      zur not mach dir eine tabelle mit instance und ip`s dazu - dann kannst du je instance id auch die ip ausgeben

                      muss halt gepflegt werden

                      genau das geht eben nicht.

                      Hintergrund:
                      Ich wollte auf dem Tablet im Wohnzimmer (win10) edge im kiosk mode einrichten.
                      Nur da wird die Instanz nur erzeugt wenn man klickt. Und diese ändert sich dann ständig.
                      Die IP ist aber immer gleich.

                      Ich müsste also wissen, welche IP die instanz sendet um dann zu beurteilen welcher PC / Laptop neu die VIS aufgebaut hat.

                      liv-in-skyL Offline
                      liv-in-skyL Offline
                      liv-in-sky
                      schrieb am zuletzt editiert von liv-in-sky
                      #65

                      @bahnuhr
                      hast du mal den vis-editor im kioskmode mit dem pc aufgemacht - ich glaube, so bekommt man eine feste instance id - kann mich aber auch täuschen - da gab es doch Browser ID erzeugen als menu punkt im editor

                      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                      BananaJoeB 1 Antwort Letzte Antwort
                      0
                      • liv-in-skyL liv-in-sky

                        @bahnuhr
                        hast du mal den vis-editor im kioskmode mit dem pc aufgemacht - ich glaube, so bekommt man eine feste instance id - kann mich aber auch täuschen - da gab es doch Browser ID erzeugen als menu punkt im editor

                        BananaJoeB Offline
                        BananaJoeB Offline
                        BananaJoe
                        Most Active
                        schrieb am zuletzt editiert von
                        #66

                        @liv-in-sky Es geht halt darum zuverlässig zu erkennen welcher Client da kommt. Wenn ich auf meinen PC 3 verschiedene Browser nutze kommen da auch 3 verschiedene Instance ID.

                        Beim Fully Kiosk muss man aufpassen wenn er den Cache löscht / was er löscht.

                        Die Idee hier hinter ist ja das einfach ein paar Datenpunkte hat in denen man nachsehen kann welche ID das Tablet im Wohnzimmer gerade hat. Und das das Tablet die aktualisiert falls di sich ändert :-)

                        ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

                        liv-in-skyL 1 Antwort Letzte Antwort
                        0
                        • BananaJoeB BananaJoe

                          @liv-in-sky Es geht halt darum zuverlässig zu erkennen welcher Client da kommt. Wenn ich auf meinen PC 3 verschiedene Browser nutze kommen da auch 3 verschiedene Instance ID.

                          Beim Fully Kiosk muss man aufpassen wenn er den Cache löscht / was er löscht.

                          Die Idee hier hinter ist ja das einfach ein paar Datenpunkte hat in denen man nachsehen kann welche ID das Tablet im Wohnzimmer gerade hat. Und das das Tablet die aktualisiert falls di sich ändert :-)

                          liv-in-skyL Offline
                          liv-in-skyL Offline
                          liv-in-sky
                          schrieb am zuletzt editiert von liv-in-sky
                          #67

                          @bananajoe

                          das habe ich verstanden

                          ein pc , zwei browser - einmal chrome, einmal edge und die id dazu

                          Image 3.png

                          hier ausgewählt

                          Image 5.png

                          sind auch nach neustart noch da

                          nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                          BananaJoeB 1 Antwort Letzte Antwort
                          0
                          • bahnuhrB bahnuhr

                            @bananajoe

                            natürlich das Script von @Jey-Cee

                            und weitere aus dem Netz:

                                window.RTCPeerConnection = window.RTCPeerConnection || window.mozRTCPeerConnection || window.webkitRTCPeerConnection;   //compatibility for firefox and chrome
                                var pc = new RTCPeerConnection({iceServers:[]}), noop = function(){};      
                                pc.createDataChannel("");    //create a bogus data channel
                                pc.createOffer(pc.setLocalDescription.bind(pc), noop);    // create offer and set local description
                                pc.onicecandidate = function(ice){  //listen for candidate events
                                    if(!ice || !ice.candidate || !ice.candidate.candidate)  return;
                                    var myIP = /([0-9]{1,3}(\.[0-9]{1,3}){3}|[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7})/.exec(ice.candidate.candidate)[1];
                                    console.log('my IP: ', myIP);   
                                    pc.onicecandidate = noop;
                                };
                            
                            // cleaned, 363b
                            const ip = await new Promise((resolve, reject) => {
                              const conn = new RTCPeerConnection()
                              conn.createDataChannel('')
                              conn.createOffer(offer => conn.setLocalDescription(offer), reject)
                              conn.onicecandidate = ice => {
                                if (ice && ice.candidate && ice.candidate.candidate) {
                                  resolve(i.candidate.candidate.split(' ')[4])
                                  conn.close()
                                }
                              }
                            })
                            
                            /**
                             * Get the user IP throught the webkitRTCPeerConnection
                             * @param onNewIP {Function} listener function to expose the IP locally
                             * @return undefined
                             */
                            function getUserIP(onNewIP) { //  onNewIp - your listener function for new IPs
                                //compatibility for firefox and chrome
                                var myPeerConnection = window.RTCPeerConnection || window.mozRTCPeerConnection || window.webkitRTCPeerConnection;
                                var pc = new myPeerConnection({
                                    iceServers: []
                                }),
                                noop = function() {},
                                localIPs = {},
                                ipRegex = /([0-9]{1,3}(\.[0-9]{1,3}){3}|[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7})/g,
                                key;
                            
                                function iterateIP(ip) {
                                    if (!localIPs[ip]) onNewIP(ip);
                                    localIPs[ip] = true;
                                }
                            
                                 //create a bogus data channel
                                pc.createDataChannel("");
                            
                                // create offer and set local description
                                pc.createOffer().then(function(sdp) {
                                    sdp.sdp.split('\n').forEach(function(line) {
                                        if (line.indexOf('candidate') < 0) return;
                                        line.match(ipRegex).forEach(iterateIP);
                                    });
                            
                                    pc.setLocalDescription(sdp, noop, noop);
                                }).catch(function(reason) {
                                    // An error occurred, so handle the failure to connect
                                });
                            
                                //listen for candidate events
                                pc.onicecandidate = function(ice) {
                                    if (!ice || !ice.candidate || !ice.candidate.candidate || !ice.candidate.candidate.match(ipRegex)) return;
                                    ice.candidate.candidate.match(ipRegex).forEach(iterateIP);
                                };
                            }
                            
                            // Usage
                            
                            getUserIP(function(ip){
                                alert("Got IP! :" + ip);
                            });
                            

                            Aber wie gesagt, ich glaube das übersteigt meine Kenntnisse.

                            BananaJoeB Offline
                            BananaJoeB Offline
                            BananaJoe
                            Most Active
                            schrieb am zuletzt editiert von
                            #68

                            @bahnuhr ja, die Beispiele habe ich alle durch.
                            Was ich zum funktionieren bekomme habe, ist z.B. per

                            $.getJSON('http://internerserver/meineip.php', function(data) {
                                        console.log(JSON.stringify(data, null, 2));
                                        alert(data.ipAddress);
                            

                            Die Adresse zu bekommen. Der Webserver muss dafür als Text

                            { "ipAddress":"192.168.1.99" }
                            

                            zurückgeben was mit einem .php Skript ginge:

                            <?php  
                            echo '{ "ipAddress":"'.$_SERVER['REMOTE_ADDR'].'"}';  
                            ?>  
                            

                            Aber wie gesagt suche ich nach einer "ich hab nur den ioBroker Server und will nicht extra einen Webserver aufsetzen" Lösung

                            ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

                            1 Antwort Letzte Antwort
                            0
                            • liv-in-skyL liv-in-sky

                              @bananajoe

                              das habe ich verstanden

                              ein pc , zwei browser - einmal chrome, einmal edge und die id dazu

                              Image 3.png

                              hier ausgewählt

                              Image 5.png

                              sind auch nach neustart noch da

                              BananaJoeB Offline
                              BananaJoeB Offline
                              BananaJoe
                              Most Active
                              schrieb am zuletzt editiert von
                              #69

                              @liv-in-sky jepp. Bis man den Cache löscht. Was Fully meine ich sogar default macht beim Neuladen

                              ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

                              liv-in-skyL 1 Antwort Letzte Antwort
                              0
                              • BananaJoeB BananaJoe

                                @liv-in-sky jepp. Bis man den Cache löscht. Was Fully meine ich sogar default macht beim Neuladen

                                liv-in-skyL Offline
                                liv-in-skyL Offline
                                liv-in-sky
                                schrieb am zuletzt editiert von
                                #70

                                @bananajoe

                                probiert doch das mal aus - evtl gibt das eine feste id pro gerät zurück -

                                import widget - im widget die widget id noch angleichen !

                                [{"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":"<script>\nuuid=function(){\nvar u = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g,\nfunction(c) {\nvar r = Math.random() * 16 | 0,\nv = c == 'x' ? r : (r & 0x3 | 0x8);\nreturn v.toString(16);\n});\nreturn u;\n}\n\n\ngetDeviceId = function(){\nvar current = window.localStorage.getItem(\"_DEVICEID_\")\nif (current) return current;\nvar id = uuid();\nwindow.localStorage.setItem(\"_DEVICEID_\",id);   \nreturn id;\n}\n\nconsole.log(getDeviceId())\n $( \"#w00006\" ).text( getDeviceId());\n\n\n</script>\n"},"style":{"left":"838px","top":"180px","color":"#f4e643","background-color":"#b7aeae"},"widgetSet":"basic"}]
                                

                                Image 6.png

                                nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                1 Antwort Letzte Antwort
                                0
                                • BananaJoeB Offline
                                  BananaJoeB Offline
                                  BananaJoe
                                  Most Active
                                  schrieb am zuletzt editiert von BananaJoe
                                  #71

                                  @liv-in-sky nope, pro Browser und inPrivate Sitzung eine eigene
                                  JavaScript kann das nicht ... und das ist Absicht

                                  ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

                                  liv-in-skyL 2 Antworten Letzte Antwort
                                  0
                                  • BananaJoeB BananaJoe

                                    @liv-in-sky nope, pro Browser und inPrivate Sitzung eine eigene
                                    JavaScript kann das nicht ... und das ist Absicht

                                    liv-in-skyL Offline
                                    liv-in-skyL Offline
                                    liv-in-sky
                                    schrieb am zuletzt editiert von
                                    #72

                                    @bananajoe

                                    also ich bekomme damit einen eindeutigen , nicht vom cache-löschbaren code zurück - getestet mit fully , chrome und edge

                                    ich dachte, dass sucht ihr

                                    nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                    1 Antwort Letzte Antwort
                                    0
                                    • BananaJoeB BananaJoe

                                      @liv-in-sky nope, pro Browser und inPrivate Sitzung eine eigene
                                      JavaScript kann das nicht ... und das ist Absicht

                                      liv-in-skyL Offline
                                      liv-in-skyL Offline
                                      liv-in-sky
                                      schrieb am zuletzt editiert von
                                      #73

                                      @bananajoe und wer macht die vis im private mode auf - oder warum sollte man das

                                      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                      bahnuhrB BananaJoeB 2 Antworten Letzte Antwort
                                      0
                                      • liv-in-skyL liv-in-sky

                                        @bananajoe und wer macht die vis im private mode auf - oder warum sollte man das

                                        bahnuhrB Online
                                        bahnuhrB Online
                                        bahnuhr
                                        Forum Testing Most Active
                                        schrieb am zuletzt editiert von
                                        #74

                                        @liv-in-sky sagte in VIS Intance Id - automatisiert ermitteln:

                                        private mode

                                        Ich wollte im Wohnzimmer ein tablet das im Vollbild öffnet und dass man nicht so einfach mit esc oder f11 raus kommt.
                                        Und das ging halt mit edge kiosk.


                                        Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                                        Danke.
                                        gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                                        ScreenToGif :https://www.screentogif.com/downloads.html

                                        BananaJoeB liv-in-skyL 2 Antworten Letzte Antwort
                                        0
                                        • liv-in-skyL liv-in-sky

                                          @bananajoe und wer macht die vis im private mode auf - oder warum sollte man das

                                          BananaJoeB Offline
                                          BananaJoeB Offline
                                          BananaJoe
                                          Most Active
                                          schrieb am zuletzt editiert von
                                          #75

                                          @liv-in-sky Ich, zum simulieren verschiedener Geräte :-)
                                          Dein Skript erstellt eine zufällige ID und speichert diese, richtig? Also nichts anderes als die Instanz-ID und wird somit auch kein löschen der Caches überleben.

                                          ioBroker@Ubuntu 24.04 LTS (VMware) für: >260 Geräte, 5 Switche, 7 AP, 9 IP-Cam, 1 NAS 42TB, 1 ESXi 15TB, 4 Proxmox 1TB, 1 Hyper-V 48TB, 14 x Echo, 5x FireTV, 5 x Tablett/Handy VIS || >=160 Tasmota/Shelly || >=95 ZigBee || PV 8.1kW / Akku 14kWh || 2x USV 750W kaskadiert || Creality CR-10 SE 3D-Drucker

                                          liv-in-skyL 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          804

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe