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. Entwicklung
  4. Klärung von AdpaterEntwicklungs Fragen

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.1k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Klärung von AdpaterEntwicklungs Fragen

Geplant Angeheftet Gesperrt Verschoben Entwicklung
adapter entwicklung
48 Beiträge 6 Kommentatoren 2.6k Aufrufe 7 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.
  • OliverIOO OliverIO

    @AlCalzone
    ah ok, noch nie was von typ folder in einem adapter gesehen.
    allerdings hab ich bisher noch keine vorteile gesehen, diese Unterscheidungen von devices, channels und folders zu treffen.
    in meinen adapter verwende ich mittlerweile immer nur states unterhalb einer adapter instanz.

    AlCalzoneA Offline
    AlCalzoneA Offline
    AlCalzone
    Developer
    schrieb am zuletzt editiert von
    #22

    @OliverIO sagte in Klärung von AdpaterEntwicklungs Fragen:

    allerdings hab ich bisher noch keine vorteile gesehen, diese Unterscheidungen von devices, channels und folders

    In Z-Wave 2 hab ich ein gutes Bespiel:
    Der Adapter spricht über den Z-Wave Stick mit mehreren Geräten, die alle als device abgebildet sind. Jedes Gerät hat mehrere Funktionen (z.B. Batterie, schalten, ...), die in Channels gruppiert sind. Jeder Status bzw. Steuermöglichkeit dieser Funktionen sind States innerhalb der Channels.

    folder ist eher dafür gedacht, States zu gruppieren, die nicht in diese strikte Struktur passen bzw. den "Ordnern" im Admin eine Definition mitzugeben. Streng genommen muss jeder dargestellte Ordner ein Objekt haben (ist aber oft nicht korrekt umgesetzt).

    Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

    1 Antwort Letzte Antwort
    0
    • PeoplesP Offline
      PeoplesP Offline
      Peoples
      schrieb am zuletzt editiert von Peoples
      #23

      @OliverIO @AlCalzone
      was mich halt verwirrt:

      • wenn ich delState mache wird der Inhalt des States gelöscht -> sprich das True oder die Zahl oder was auch immer.(Also der "Inhalt")
      • wenn ich nun mit delObject den Inhalt des "Überordners" lösche ist dessen Inhalt -> sprich alle States die darin waren "augenscheinlich" weg. Muss ich dann den State für sich noch löschen, denn er ist ja schon nicht mehr da (zu sehen).

      Und wenn ich das delObject weg lasse und mit deleteState den State löschen möchte bekomme ich bei nachfolgender Funktion diesen Fehler:

      viewswitch.0	2020-10-19 22:54:34.475	error	(13553) cannot delete state : viewswitch.0.Views.einfacheinetestview.isHomeView Error: Not exists
      viewswitch.0	2020-10-19 22:54:34.475	error	(13553) cannot delete state : viewswitch.0.Views.einfacheinetestview.isLockView Error: Not exists
      viewswitch.0	2020-10-19 22:54:34.475	error	(13553) cannot delete state : viewswitch.0.Views.einfacheinetestview.sWSec Error: Not exists
      viewswitch.0	2020-10-19 22:54:34.475	error	(13553) cannot delete state : viewswitch.0.Views.einfacheinetestview.showIAV Error: Not exists
      

      Funktion:

      async function deleteVisObjects(arr){
              adapter.getStates('Views'+ '.*', async function (err, states) {
                  for (const idS in states) {
                      let nmb = idS.split('.');
                      if(arr.includes(nmb[3])){
                          adapter.log.info('View vorhanden: '+idS)
                      } else {
                          adapter.log.info('View NICHT vorhanden: '+idS)
                          adapter.deleteState(idS, function(err){
                              if (err) {
                                  adapter.log.error('cannot delete state : ' + idS + ' Error: ' + err);
                              }
                       });
                    }
              }
      });
      

      Wobei die Objekte aber noch vorhanden sind, da ich sie noch ausgeben kann:

      viewswitch.0	2020-10-19 22:58:25.435	info	(13621) View NICHT vorhanden: viewswitch.0.Views.einfacheinetestview.isHomeView
      viewswitch.0	2020-10-19 22:58:25.435	info	(13621) View NICHT vorhanden: viewswitch.0.Views.einfacheinetestview.isLockView
      viewswitch.0	2020-10-19 22:58:25.435	info	(13621) View NICHT vorhanden: viewswitch.0.Views.einfacheinetestview.sWSec
      viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View NICHT vorhanden: viewswitch.0.Views.einfacheinetestview.showIAV
      viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.test.isHomeView
      viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.test.isLockView
      viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.test.sWSec
      viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.test.showIAV
      viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.DemoView.isHomeView
      viewswitch.0	2020-10-19 22:58:25.433	info	(13621) View vorhanden: viewswitch.0.Views.DemoView.isLockView
      viewswitch.0	2020-10-19 22:58:25.433	info	(13621) View vorhanden: viewswitch.0.Views.DemoView.sWSec
      viewswitch.0	2020-10-19 22:58:25.426	info	(13621) View vorhanden: viewswitch.0.Views.DemoView.showIAV
      

      Nur zur erklärung das "Nicht mehr vorhanden" heißt dass sie in der Projekt Json nicht mehr vorhanden ist. Als Objekt aber schon

      Ich beantworte keine Fragen zu Themen via PN

      AlCalzoneA 1 Antwort Letzte Antwort
      0
      • PeoplesP Peoples

        @OliverIO @AlCalzone
        was mich halt verwirrt:

        • wenn ich delState mache wird der Inhalt des States gelöscht -> sprich das True oder die Zahl oder was auch immer.(Also der "Inhalt")
        • wenn ich nun mit delObject den Inhalt des "Überordners" lösche ist dessen Inhalt -> sprich alle States die darin waren "augenscheinlich" weg. Muss ich dann den State für sich noch löschen, denn er ist ja schon nicht mehr da (zu sehen).

        Und wenn ich das delObject weg lasse und mit deleteState den State löschen möchte bekomme ich bei nachfolgender Funktion diesen Fehler:

        viewswitch.0	2020-10-19 22:54:34.475	error	(13553) cannot delete state : viewswitch.0.Views.einfacheinetestview.isHomeView Error: Not exists
        viewswitch.0	2020-10-19 22:54:34.475	error	(13553) cannot delete state : viewswitch.0.Views.einfacheinetestview.isLockView Error: Not exists
        viewswitch.0	2020-10-19 22:54:34.475	error	(13553) cannot delete state : viewswitch.0.Views.einfacheinetestview.sWSec Error: Not exists
        viewswitch.0	2020-10-19 22:54:34.475	error	(13553) cannot delete state : viewswitch.0.Views.einfacheinetestview.showIAV Error: Not exists
        

        Funktion:

        async function deleteVisObjects(arr){
                adapter.getStates('Views'+ '.*', async function (err, states) {
                    for (const idS in states) {
                        let nmb = idS.split('.');
                        if(arr.includes(nmb[3])){
                            adapter.log.info('View vorhanden: '+idS)
                        } else {
                            adapter.log.info('View NICHT vorhanden: '+idS)
                            adapter.deleteState(idS, function(err){
                                if (err) {
                                    adapter.log.error('cannot delete state : ' + idS + ' Error: ' + err);
                                }
                         });
                      }
                }
        });
        

        Wobei die Objekte aber noch vorhanden sind, da ich sie noch ausgeben kann:

        viewswitch.0	2020-10-19 22:58:25.435	info	(13621) View NICHT vorhanden: viewswitch.0.Views.einfacheinetestview.isHomeView
        viewswitch.0	2020-10-19 22:58:25.435	info	(13621) View NICHT vorhanden: viewswitch.0.Views.einfacheinetestview.isLockView
        viewswitch.0	2020-10-19 22:58:25.435	info	(13621) View NICHT vorhanden: viewswitch.0.Views.einfacheinetestview.sWSec
        viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View NICHT vorhanden: viewswitch.0.Views.einfacheinetestview.showIAV
        viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.test.isHomeView
        viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.test.isLockView
        viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.test.sWSec
        viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.test.showIAV
        viewswitch.0	2020-10-19 22:58:25.434	info	(13621) View vorhanden: viewswitch.0.Views.DemoView.isHomeView
        viewswitch.0	2020-10-19 22:58:25.433	info	(13621) View vorhanden: viewswitch.0.Views.DemoView.isLockView
        viewswitch.0	2020-10-19 22:58:25.433	info	(13621) View vorhanden: viewswitch.0.Views.DemoView.sWSec
        viewswitch.0	2020-10-19 22:58:25.426	info	(13621) View vorhanden: viewswitch.0.Views.DemoView.showIAV
        

        Nur zur erklärung das "Nicht mehr vorhanden" heißt dass sie in der Projekt Json nicht mehr vorhanden ist. Als Objekt aber schon

        AlCalzoneA Offline
        AlCalzoneA Offline
        AlCalzone
        Developer
        schrieb am zuletzt editiert von
        #24

        @Peoples sagte in Klärung von AdpaterEntwicklungs Fragen:

        wenn ich nun mit delObject den Inhalt des "Überordners"

        Wenn du dem "Überordner" kein Objekt zugeordnet hast, dürfte delObject gar nix machen. Und schon gar nicht die untergeordneten Objekte löschen.

        @Peoples sagte in Klärung von AdpaterEntwicklungs Fragen:

        Und wenn ich das delObject weg lasse und mit deleteState den State löschen möchte bekomme ich bei nachfolgender Funktion diesen Fehler:

        Wenn du die vorher mit delState gelöscht hast, ist das Objekt auch weg.

        Am besten exportierst du mal nach jedem Schritt den Objektbaum - ich kann dir jedenfalls gerade nicht ganz folgen.

        Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

        PeoplesP 1 Antwort Letzte Antwort
        0
        • AlCalzoneA AlCalzone

          @Peoples sagte in Klärung von AdpaterEntwicklungs Fragen:

          wenn ich nun mit delObject den Inhalt des "Überordners"

          Wenn du dem "Überordner" kein Objekt zugeordnet hast, dürfte delObject gar nix machen. Und schon gar nicht die untergeordneten Objekte löschen.

          @Peoples sagte in Klärung von AdpaterEntwicklungs Fragen:

          Und wenn ich das delObject weg lasse und mit deleteState den State löschen möchte bekomme ich bei nachfolgender Funktion diesen Fehler:

          Wenn du die vorher mit delState gelöscht hast, ist das Objekt auch weg.

          Am besten exportierst du mal nach jedem Schritt den Objektbaum - ich kann dir jedenfalls gerade nicht ganz folgen.

          PeoplesP Offline
          PeoplesP Offline
          Peoples
          schrieb am zuletzt editiert von Peoples
          #25

          @AlCalzone

          habe das Löschen hinbekommen: https://github.com/peoples0815/iobroker.viewswitch/blob/master/main.js#L245

          Und bastel jetzt mal an der Admin Oberfläche weiter bis die nächste Frage kommt und die kommt bestimmt.

          Ich finde es jedenfalls klasse wie Ihr hier unterstützt!

          Ich beantworte keine Fragen zu Themen via PN

          AlCalzoneA 1 Antwort Letzte Antwort
          0
          • PeoplesP Peoples

            @AlCalzone

            habe das Löschen hinbekommen: https://github.com/peoples0815/iobroker.viewswitch/blob/master/main.js#L245

            Und bastel jetzt mal an der Admin Oberfläche weiter bis die nächste Frage kommt und die kommt bestimmt.

            Ich finde es jedenfalls klasse wie Ihr hier unterstützt!

            AlCalzoneA Offline
            AlCalzoneA Offline
            AlCalzone
            Developer
            schrieb am zuletzt editiert von
            #26

            @Peoples Kleiner Tipp noch - dieses Konstrukt macht nicht wirklich Sinn:

            async function deleteVisObjects(arr){
                adapter.getStates('Views'+ '.*', async function (err, states) {
            

            In deleteVisObjects nutzt du kein await, daher muss sie nicht als async definiert werden. Allerdings könntest du auch gleich die async-Variante von getStates nutzen:

            async function deleteVisObjects(arr){
                try {
                    const states = await adapter.getStatesAsync('Views'+ '.*');
                    for (const idS in states) {
                        // ...
                    }
                } catch (err) {
                    // Fehler behandeln oder loggen oder...
                }
            }
            

            Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

            PeoplesP 1 Antwort Letzte Antwort
            1
            • AlCalzoneA AlCalzone

              @Peoples Kleiner Tipp noch - dieses Konstrukt macht nicht wirklich Sinn:

              async function deleteVisObjects(arr){
                  adapter.getStates('Views'+ '.*', async function (err, states) {
              

              In deleteVisObjects nutzt du kein await, daher muss sie nicht als async definiert werden. Allerdings könntest du auch gleich die async-Variante von getStates nutzen:

              async function deleteVisObjects(arr){
                  try {
                      const states = await adapter.getStatesAsync('Views'+ '.*');
                      for (const idS in states) {
                          // ...
                      }
                  } catch (err) {
                      // Fehler behandeln oder loggen oder...
                  }
              }
              
              PeoplesP Offline
              PeoplesP Offline
              Peoples
              schrieb am zuletzt editiert von
              #27

              @AlCalzone
              Danke für den Tipp genau so mach ich das

              Ich beantworte keine Fragen zu Themen via PN

              1 Antwort Letzte Antwort
              0
              • PeoplesP Offline
                PeoplesP Offline
                Peoples
                schrieb am zuletzt editiert von
                #28

                So, ich versuche nun die Admin-Oberfläche mit Leben zu befüllen und komme wie erwartet nicht weiter.

                Ich möchte die Lokale Iobroker-Strucktur des Vis Ordners auslesen, um die Projekte in einem Select oder ähnlichem aufzulisten. Nur wie ich das angehe ist mir nicht klar.

                In der main.js kann ich mit:

                 var fs = require("fs");
                        var dirPath        = '/opt/iobroker/iobroker-data/files/vis.0/';
                        var viewsJsonFile  = '/vis-views.json'
                
                        function generateProjectList(dirPath, viewsJsonFile){
                            var text = '';
                            fs.readdir(dirPath, (err, files) => { 
                                if(err){
                                        console.log('Cannot parse views file "' + dirPath + file + 'vis-views.json"');
                                        window.alert('Cannot parse views file "' + dirPath + file + 'vis-views.json');
                                } else { 
                                        files.forEach(file => { 
                                            var isDirExists = fs.existsSync(dirPath + file) && fs.lstatSync(dirPath + file).isDirectory();
                                            if(isDirExists === true){
                                                if(fs.existsSync(dirPath + file + viewsJsonFile)){
                                                        
                                                            text += '<option value="Wandtablet" class="translate">'+file+'</option>';
                                                }
                                            }
                                        })
                                       // $('#select_projects').html(text); 
                                } 
                            }) 
                            adapter.log.info('funktioniert!'+dirPath+viewsJsonFile);
                        }
                

                Die Projekte auflisten, aber das geht in der index_m.html so natürlich nicht weil es (soweit ich gelesen habe) require("fs") aus Sicherheitsgründen nicht gibt.

                Wie kann ich nun die Datei einlesen?

                Kann ich vielleicht in der main.js den Auslesevorgang machen und die Werte irgendwie in eine adapter.config.variable schreiben?

                Ich beantworte keine Fragen zu Themen via PN

                OliverIOO 1 Antwort Letzte Antwort
                0
                • PeoplesP Peoples

                  So, ich versuche nun die Admin-Oberfläche mit Leben zu befüllen und komme wie erwartet nicht weiter.

                  Ich möchte die Lokale Iobroker-Strucktur des Vis Ordners auslesen, um die Projekte in einem Select oder ähnlichem aufzulisten. Nur wie ich das angehe ist mir nicht klar.

                  In der main.js kann ich mit:

                   var fs = require("fs");
                          var dirPath        = '/opt/iobroker/iobroker-data/files/vis.0/';
                          var viewsJsonFile  = '/vis-views.json'
                  
                          function generateProjectList(dirPath, viewsJsonFile){
                              var text = '';
                              fs.readdir(dirPath, (err, files) => { 
                                  if(err){
                                          console.log('Cannot parse views file "' + dirPath + file + 'vis-views.json"');
                                          window.alert('Cannot parse views file "' + dirPath + file + 'vis-views.json');
                                  } else { 
                                          files.forEach(file => { 
                                              var isDirExists = fs.existsSync(dirPath + file) && fs.lstatSync(dirPath + file).isDirectory();
                                              if(isDirExists === true){
                                                  if(fs.existsSync(dirPath + file + viewsJsonFile)){
                                                          
                                                              text += '<option value="Wandtablet" class="translate">'+file+'</option>';
                                                  }
                                              }
                                          })
                                         // $('#select_projects').html(text); 
                                  } 
                              }) 
                              adapter.log.info('funktioniert!'+dirPath+viewsJsonFile);
                          }
                  

                  Die Projekte auflisten, aber das geht in der index_m.html so natürlich nicht weil es (soweit ich gelesen habe) require("fs") aus Sicherheitsgründen nicht gibt.

                  Wie kann ich nun die Datei einlesen?

                  Kann ich vielleicht in der main.js den Auslesevorgang machen und die Werte irgendwie in eine adapter.config.variable schreiben?

                  OliverIOO Offline
                  OliverIOO Offline
                  OliverIO
                  schrieb am zuletzt editiert von
                  #29

                  @Peoples

                  Hier hatte ich dir schon einmal geschrieben wie vis an die Daten kommt. Den Code kannst du doch direkt benützen Bzw. etwas adaptieren
                  https://forum.iobroker.net/topic/37589/vorhandene-vis-projekte-bzw-vis-views-auslesen/6

                  Meine Adapter und Widgets
                  TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                  Links im Profil

                  PeoplesP 1 Antwort Letzte Antwort
                  0
                  • OliverIOO OliverIO

                    @Peoples

                    Hier hatte ich dir schon einmal geschrieben wie vis an die Daten kommt. Den Code kannst du doch direkt benützen Bzw. etwas adaptieren
                    https://forum.iobroker.net/topic/37589/vorhandene-vis-projekte-bzw-vis-views-auslesen/6

                    PeoplesP Offline
                    PeoplesP Offline
                    Peoples
                    schrieb am zuletzt editiert von Peoples
                    #30

                    @OliverIO
                    Da fehlts halt ein wenig am können weil ich bekomme das einfach nicht zum laufen.

                    Mir ist schon garnicht klar was ich da mit angeben muss dass ich nicht immer folgenden Fehler bekomme.

                    Uncaught TypeError: Cannot read property 'readProjects' of undefined
                    

                    Ich beantworte keine Fragen zu Themen via PN

                    OliverIOO 2 Antworten Letzte Antwort
                    0
                    • PeoplesP Peoples

                      @OliverIO
                      Da fehlts halt ein wenig am können weil ich bekomme das einfach nicht zum laufen.

                      Mir ist schon garnicht klar was ich da mit angeben muss dass ich nicht immer folgenden Fehler bekomme.

                      Uncaught TypeError: Cannot read property 'readProjects' of undefined
                      
                      OliverIOO Offline
                      OliverIOO Offline
                      OliverIO
                      schrieb am zuletzt editiert von
                      #31

                      @Peoples
                      Und wie hast du das jetzt aufgerufen, das die Fehlermeldung erzeugt wird.

                      Meine Adapter und Widgets
                      TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                      Links im Profil

                      1 Antwort Letzte Antwort
                      0
                      • PeoplesP Peoples

                        @OliverIO
                        Da fehlts halt ein wenig am können weil ich bekomme das einfach nicht zum laufen.

                        Mir ist schon garnicht klar was ich da mit angeben muss dass ich nicht immer folgenden Fehler bekomme.

                        Uncaught TypeError: Cannot read property 'readProjects' of undefined
                        
                        OliverIOO Offline
                        OliverIOO Offline
                        OliverIO
                        schrieb am zuletzt editiert von
                        #32

                        @Peoples
                        Im Zweifel kann man im Browser einen breakpoint setzen und dann mal schauen was vis da genau macht
                        Wenn mal den im chrome öffnete eröffnet sich eine komplett neue Welt
                        https://developers.google.com/web/tools/chrome-devtools

                        Meine Adapter und Widgets
                        TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                        Links im Profil

                        1 Antwort Letzte Antwort
                        0
                        • PeoplesP Offline
                          PeoplesP Offline
                          Peoples
                          schrieb am zuletzt editiert von Peoples
                          #33

                          Also, ich habe nun einiges versucht und auch mit den Developer Tools rumprobiert, konnte auch folgende funktion finden:

                          readDir:          function (dirname, callback) {
                                  //socket.io
                                  if (this._socket === null) {
                                      console.log('socket.io not initialized');
                                      return;
                                  }
                                  if (!dirname) dirname = '/';
                                  var parts = dirname.split('/');
                                  var adapter = parts[1];
                                  parts.splice(0, 2);
                          
                                  this._socket.emit('readDir', adapter, parts.join('/'), {filter: true}, function (err, data) {
                                      if (callback) callback(err, data);
                                  });
                              },
                          

                          und

                           readProjects:     function (callback) {
                                  var that = this;
                                  this.readDir('/' + this.namespace, function (err, dirs) {
                                      var result = [];
                                      var count = 0;
                                      for (var d = 0; d < dirs.length; d++) {
                                          if (dirs[d].isDir) {
                                              count++;
                                              that._detectViews(dirs[d].file, function (subErr, project) {
                                                  if (project) result.push(project);
                          
                                                  err = err || subErr;
                                                  if (!(--count)) callback(err, result);
                                              });
                                          }
                                      }
                                  });
                              },
                          

                          Ich habe wirklich viel gegooglet begreife es aber nicht.
                          Ich habe verstanden dass ich fs.readdir nicht nutzen kann da require('fs') clientseitig anscheinend nicht funktioniert.

                          Aber wie funktioniert dann this.readDir? https://github.com/ioBroker/ioBroker.vis/blob/a3d4ae6139ee5e20253a1257136f7fe0e7a635f0/www/js/conn.js#L1288

                          Erklärung zu this:
                          this ist ein Verweis auf das Objekt, das die aktuelle Javascript-Funktion aufgerufen hat. ... Bei jedem Aufruf der Funktion wird dieses Argument - sozusagen hinter den Kulissen - zusammen mit einem Zeiger auf das Objekt, das die Funktion aufrief, übergeben.

                          Ich verstehe nur Bahnhof :angry:
                          Kann ich die funktion oben nun irgendwie umschreiben dass ich sie nutzen kann oder geht das nicht.

                          Fakt ist, wenn ich hier nicht weiter komme bzw das begreife, wird das auch nix mit dem Adapter :joy:

                          Ich beantworte keine Fragen zu Themen via PN

                          OliverIOO simatecS 3 Antworten Letzte Antwort
                          0
                          • PeoplesP Peoples

                            Also, ich habe nun einiges versucht und auch mit den Developer Tools rumprobiert, konnte auch folgende funktion finden:

                            readDir:          function (dirname, callback) {
                                    //socket.io
                                    if (this._socket === null) {
                                        console.log('socket.io not initialized');
                                        return;
                                    }
                                    if (!dirname) dirname = '/';
                                    var parts = dirname.split('/');
                                    var adapter = parts[1];
                                    parts.splice(0, 2);
                            
                                    this._socket.emit('readDir', adapter, parts.join('/'), {filter: true}, function (err, data) {
                                        if (callback) callback(err, data);
                                    });
                                },
                            

                            und

                             readProjects:     function (callback) {
                                    var that = this;
                                    this.readDir('/' + this.namespace, function (err, dirs) {
                                        var result = [];
                                        var count = 0;
                                        for (var d = 0; d < dirs.length; d++) {
                                            if (dirs[d].isDir) {
                                                count++;
                                                that._detectViews(dirs[d].file, function (subErr, project) {
                                                    if (project) result.push(project);
                            
                                                    err = err || subErr;
                                                    if (!(--count)) callback(err, result);
                                                });
                                            }
                                        }
                                    });
                                },
                            

                            Ich habe wirklich viel gegooglet begreife es aber nicht.
                            Ich habe verstanden dass ich fs.readdir nicht nutzen kann da require('fs') clientseitig anscheinend nicht funktioniert.

                            Aber wie funktioniert dann this.readDir? https://github.com/ioBroker/ioBroker.vis/blob/a3d4ae6139ee5e20253a1257136f7fe0e7a635f0/www/js/conn.js#L1288

                            Erklärung zu this:
                            this ist ein Verweis auf das Objekt, das die aktuelle Javascript-Funktion aufgerufen hat. ... Bei jedem Aufruf der Funktion wird dieses Argument - sozusagen hinter den Kulissen - zusammen mit einem Zeiger auf das Objekt, das die Funktion aufrief, übergeben.

                            Ich verstehe nur Bahnhof :angry:
                            Kann ich die funktion oben nun irgendwie umschreiben dass ich sie nutzen kann oder geht das nicht.

                            Fakt ist, wenn ich hier nicht weiter komme bzw das begreife, wird das auch nix mit dem Adapter :joy:

                            OliverIOO Offline
                            OliverIOO Offline
                            OliverIO
                            schrieb am zuletzt editiert von
                            #34

                            @Peoples

                            Vis (client) fragt den Server und dort funktioniert fs

                            Meine Adapter und Widgets
                            TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                            Links im Profil

                            1 Antwort Letzte Antwort
                            0
                            • PeoplesP Peoples

                              Also, ich habe nun einiges versucht und auch mit den Developer Tools rumprobiert, konnte auch folgende funktion finden:

                              readDir:          function (dirname, callback) {
                                      //socket.io
                                      if (this._socket === null) {
                                          console.log('socket.io not initialized');
                                          return;
                                      }
                                      if (!dirname) dirname = '/';
                                      var parts = dirname.split('/');
                                      var adapter = parts[1];
                                      parts.splice(0, 2);
                              
                                      this._socket.emit('readDir', adapter, parts.join('/'), {filter: true}, function (err, data) {
                                          if (callback) callback(err, data);
                                      });
                                  },
                              

                              und

                               readProjects:     function (callback) {
                                      var that = this;
                                      this.readDir('/' + this.namespace, function (err, dirs) {
                                          var result = [];
                                          var count = 0;
                                          for (var d = 0; d < dirs.length; d++) {
                                              if (dirs[d].isDir) {
                                                  count++;
                                                  that._detectViews(dirs[d].file, function (subErr, project) {
                                                      if (project) result.push(project);
                              
                                                      err = err || subErr;
                                                      if (!(--count)) callback(err, result);
                                                  });
                                              }
                                          }
                                      });
                                  },
                              

                              Ich habe wirklich viel gegooglet begreife es aber nicht.
                              Ich habe verstanden dass ich fs.readdir nicht nutzen kann da require('fs') clientseitig anscheinend nicht funktioniert.

                              Aber wie funktioniert dann this.readDir? https://github.com/ioBroker/ioBroker.vis/blob/a3d4ae6139ee5e20253a1257136f7fe0e7a635f0/www/js/conn.js#L1288

                              Erklärung zu this:
                              this ist ein Verweis auf das Objekt, das die aktuelle Javascript-Funktion aufgerufen hat. ... Bei jedem Aufruf der Funktion wird dieses Argument - sozusagen hinter den Kulissen - zusammen mit einem Zeiger auf das Objekt, das die Funktion aufrief, übergeben.

                              Ich verstehe nur Bahnhof :angry:
                              Kann ich die funktion oben nun irgendwie umschreiben dass ich sie nutzen kann oder geht das nicht.

                              Fakt ist, wenn ich hier nicht weiter komme bzw das begreife, wird das auch nix mit dem Adapter :joy:

                              OliverIOO Offline
                              OliverIOO Offline
                              OliverIO
                              schrieb am zuletzt editiert von OliverIO
                              #35

                              @Peoples
                              Hast du dir mal die Funktionen angeschaut auf die ich schon mal verwiesen habe?
                              Ich denke mit deinem aktuellen Lösungsweg bist du auf der falschen fährte
                              Welches Problem willst du aktuell nochmal lösen? Projekte oder views auflisten?

                              Meine Adapter und Widgets
                              TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                              Links im Profil

                              PeoplesP 1 Antwort Letzte Antwort
                              0
                              • PeoplesP Peoples

                                Also, ich habe nun einiges versucht und auch mit den Developer Tools rumprobiert, konnte auch folgende funktion finden:

                                readDir:          function (dirname, callback) {
                                        //socket.io
                                        if (this._socket === null) {
                                            console.log('socket.io not initialized');
                                            return;
                                        }
                                        if (!dirname) dirname = '/';
                                        var parts = dirname.split('/');
                                        var adapter = parts[1];
                                        parts.splice(0, 2);
                                
                                        this._socket.emit('readDir', adapter, parts.join('/'), {filter: true}, function (err, data) {
                                            if (callback) callback(err, data);
                                        });
                                    },
                                

                                und

                                 readProjects:     function (callback) {
                                        var that = this;
                                        this.readDir('/' + this.namespace, function (err, dirs) {
                                            var result = [];
                                            var count = 0;
                                            for (var d = 0; d < dirs.length; d++) {
                                                if (dirs[d].isDir) {
                                                    count++;
                                                    that._detectViews(dirs[d].file, function (subErr, project) {
                                                        if (project) result.push(project);
                                
                                                        err = err || subErr;
                                                        if (!(--count)) callback(err, result);
                                                    });
                                                }
                                            }
                                        });
                                    },
                                

                                Ich habe wirklich viel gegooglet begreife es aber nicht.
                                Ich habe verstanden dass ich fs.readdir nicht nutzen kann da require('fs') clientseitig anscheinend nicht funktioniert.

                                Aber wie funktioniert dann this.readDir? https://github.com/ioBroker/ioBroker.vis/blob/a3d4ae6139ee5e20253a1257136f7fe0e7a635f0/www/js/conn.js#L1288

                                Erklärung zu this:
                                this ist ein Verweis auf das Objekt, das die aktuelle Javascript-Funktion aufgerufen hat. ... Bei jedem Aufruf der Funktion wird dieses Argument - sozusagen hinter den Kulissen - zusammen mit einem Zeiger auf das Objekt, das die Funktion aufrief, übergeben.

                                Ich verstehe nur Bahnhof :angry:
                                Kann ich die funktion oben nun irgendwie umschreiben dass ich sie nutzen kann oder geht das nicht.

                                Fakt ist, wenn ich hier nicht weiter komme bzw das begreife, wird das auch nix mit dem Adapter :joy:

                                simatecS Online
                                simatecS Online
                                simatec
                                Developer Most Active
                                schrieb am zuletzt editiert von simatec
                                #36

                                @Peoples
                                schaue mal hier ... Bei schoolfree lese ich so die "locations.json" aus und fülle damit dann die Config

                                • Besuche meine Github Seite
                                • Beitrag hat geholfen oder willst du mich unterstützen
                                • HowTo Restore ioBroker
                                1 Antwort Letzte Antwort
                                0
                                • OliverIOO OliverIO

                                  @Peoples
                                  Hast du dir mal die Funktionen angeschaut auf die ich schon mal verwiesen habe?
                                  Ich denke mit deinem aktuellen Lösungsweg bist du auf der falschen fährte
                                  Welches Problem willst du aktuell nochmal lösen? Projekte oder views auflisten?

                                  PeoplesP Offline
                                  PeoplesP Offline
                                  Peoples
                                  schrieb am zuletzt editiert von
                                  #37

                                  @OliverIO
                                  Ja ich habe das schon angeschaut, aber komme da nicht weiter. Ich möchte im enddefekt so wie im vorherigen Post bei readProjects die Projekte Ordner / Projekte auslesen um diese dann in dein dropdown zu packen.

                                  In der main.js ist das überhaupt kein Problem aber in der index_m.html finde ich keine Möglichkeit.

                                  Hier fehlt es mir schlicht und ergreiffend an Wissen.

                                  Ich beantworte keine Fragen zu Themen via PN

                                  OliverIOO 1 Antwort Letzte Antwort
                                  0
                                  • PeoplesP Peoples

                                    @OliverIO
                                    Ja ich habe das schon angeschaut, aber komme da nicht weiter. Ich möchte im enddefekt so wie im vorherigen Post bei readProjects die Projekte Ordner / Projekte auslesen um diese dann in dein dropdown zu packen.

                                    In der main.js ist das überhaupt kein Problem aber in der index_m.html finde ich keine Möglichkeit.

                                    Hier fehlt es mir schlicht und ergreiffend an Wissen.

                                    OliverIOO Offline
                                    OliverIOO Offline
                                    OliverIO
                                    schrieb am zuletzt editiert von OliverIO
                                    #38

                                    @Peoples
                                    Wenn du einen Breakpoint in readprojects setzt und im edit Modus neu ladest, dann landest du in dieser Funktion und kannst schauen welche Parameter du übergeben musst und welches Ergebnis sie zurück liefert

                                    Meine Adapter und Widgets
                                    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                                    Links im Profil

                                    1 Antwort Letzte Antwort
                                    0
                                    • PeoplesP Offline
                                      PeoplesP Offline
                                      Peoples
                                      schrieb am zuletzt editiert von
                                      #39

                                      Nach ewigem probieren, bin ich so weit:

                                      function loadProjects() {
                                        return new Promise(resolve => {
                                          socket.emit('getState', 'viewswitch.0.existingProjects' , function (err, state) {
                                              if (state && state.val) {
                                                var projects = state.val.split(',');
                                                var text = '<option value="undefined" class="translate">Platzhalter</option>';
                                                if(projects.length){
                                                      for (var d = 0; d < (projects.length -1); d++) {
                                                      text +='<option value="'+ projects[d] +'" class="translate">'+ projects[d] +'</option>';
                                                      }
                                                resolve(text);
                                                } 
                                              }
                                          });
                                        });
                                      }
                                      
                                        loadProjects().then(result => alert(result));      
                                      

                                      ausgegeben wird mir dann folgendes:

                                      <option value="undefined" class="translate">Platzhalter</option>
                                      <option value="Wandtablet" class="translate">Wandtablet</option>
                                      <option value="main" class="translate">main</option>
                                      

                                      Nun möchte ich natürlich ein in der Admin-Oberfläche vorhandenes Select mit diesen Daten befüllen. Wenn ich es so mache:

                                      let visProjects = '<option value="undefined" class="translate">Platzhalter</option>';
                                                  visProjects += '<option value="Wandtablet" class="translate">Wandtablet</option>';
                                                  visProjects += '<option value="main" class="translate">main</option>';
                                                  $('#visProjects').html(visProjects);
                                      

                                      funktioniert das bestens.
                                      Aber wenn ich versuche die Daten meiner Funktion mit:

                                      loadProjects().then(result => $('#select_projects').html(result));
                                      

                                      versuche funktioniert das nicht.

                                      Leider hört die von mir gefundene Doku auch bei admin.html auf, und ich habe auch sonst nichts gefunden das ein wenig den Aufbau bzw. die Richtlinien der index_m.html erklärt.

                                      Kann mir einer sagen warum die Ausgabe meiner Funktion keine Füllung des Selects bewirkt?

                                      Ich beantworte keine Fragen zu Themen via PN

                                      OliverIOO AlCalzoneA 2 Antworten Letzte Antwort
                                      0
                                      • PeoplesP Peoples

                                        Nach ewigem probieren, bin ich so weit:

                                        function loadProjects() {
                                          return new Promise(resolve => {
                                            socket.emit('getState', 'viewswitch.0.existingProjects' , function (err, state) {
                                                if (state && state.val) {
                                                  var projects = state.val.split(',');
                                                  var text = '<option value="undefined" class="translate">Platzhalter</option>';
                                                  if(projects.length){
                                                        for (var d = 0; d < (projects.length -1); d++) {
                                                        text +='<option value="'+ projects[d] +'" class="translate">'+ projects[d] +'</option>';
                                                        }
                                                  resolve(text);
                                                  } 
                                                }
                                            });
                                          });
                                        }
                                        
                                          loadProjects().then(result => alert(result));      
                                        

                                        ausgegeben wird mir dann folgendes:

                                        <option value="undefined" class="translate">Platzhalter</option>
                                        <option value="Wandtablet" class="translate">Wandtablet</option>
                                        <option value="main" class="translate">main</option>
                                        

                                        Nun möchte ich natürlich ein in der Admin-Oberfläche vorhandenes Select mit diesen Daten befüllen. Wenn ich es so mache:

                                        let visProjects = '<option value="undefined" class="translate">Platzhalter</option>';
                                                    visProjects += '<option value="Wandtablet" class="translate">Wandtablet</option>';
                                                    visProjects += '<option value="main" class="translate">main</option>';
                                                    $('#visProjects').html(visProjects);
                                        

                                        funktioniert das bestens.
                                        Aber wenn ich versuche die Daten meiner Funktion mit:

                                        loadProjects().then(result => $('#select_projects').html(result));
                                        

                                        versuche funktioniert das nicht.

                                        Leider hört die von mir gefundene Doku auch bei admin.html auf, und ich habe auch sonst nichts gefunden das ein wenig den Aufbau bzw. die Richtlinien der index_m.html erklärt.

                                        Kann mir einer sagen warum die Ausgabe meiner Funktion keine Füllung des Selects bewirkt?

                                        OliverIOO Offline
                                        OliverIOO Offline
                                        OliverIO
                                        schrieb am zuletzt editiert von
                                        #40

                                        @Peoples

                                        darf ich fragen wo dein code lebt? auf dem server oder auf dem client?

                                        Meine Adapter und Widgets
                                        TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                                        Links im Profil

                                        PeoplesP 1 Antwort Letzte Antwort
                                        0
                                        • OliverIOO OliverIO

                                          @Peoples

                                          darf ich fragen wo dein code lebt? auf dem server oder auf dem client?

                                          PeoplesP Offline
                                          PeoplesP Offline
                                          Peoples
                                          schrieb am zuletzt editiert von Peoples
                                          #41

                                          @OliverIO
                                          klar Oliver, die steht in der index.m.html und sollte somit im client abgearbeitet werden. (Denke ich :-))

                                          Ich beantworte keine Fragen zu Themen via PN

                                          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

                                          762

                                          Online

                                          32.7k

                                          Benutzer

                                          82.3k

                                          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