Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [gelöst] Javascript Objekte Zugriff

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] Javascript Objekte Zugriff

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

      Das Problem ist ja, dass ich den Namen nicht kenne, bzw ermittlen muss

      das wird nicht gehen oder ?

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

        Mal als Idee…

        Über Javascript aufs Dateisystem zugreifen, die objects.json einlesen und auswerten?

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

          Ich werde mich mal belesen, ich makiere den Fred dann als gelöst wenns funktioniert 😄

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

            @strackfi:

            Das Problem ist ja, dass ich den Namen nicht kenne, bzw ermittlen muss, das wird nicht gehen oder ? `
            Den Namen ermitteln kann man nicht. Der Name wird allerdings beim Erstellen des Schedules von Dir vergeben.
            @ruhr70:

            Über Javascript aufs Dateisystem zugreifen, die objects.js einlesen und auswerten? `
            Die Datei objects.json einzulesen, ist wegen ihrer Größe wohl eher eine theoretische Möglichkeit.

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

              @paul53:

              @strackfi:

              Das Problem ist ja, dass ich den Namen nicht kenne, bzw ermittlen muss, das wird nicht gehen oder ? `
              Den Namen ermitteln kann man nicht. Der Name wird allerdings beim Erstellen des Schedules von Dir vergeben.
              @ruhr70:

              Über Javascript aufs Dateisystem zugreifen, die objects.js einlesen und auswerten? Die Datei __objects.json__ einzulesen, ist wegen ihrer Größe wohl eher eine theoretische Möglichkeit.

              Ich habe das mal gerade ausprobiert. Funktioniert auch praktisch:

              var datei = "/opt/iobroker/objects.json.test";
              
              var fs = require('fs');
              
              fs.readFile(datei, function(err, json) {
                 if(err) log('Fehler Datei lesen: ' + err, 'error');
                 else {
                  log("Abfrage durchgeführt");
                  var obj = JSON.parse(json);
              
                  for(var index in obj) { 
                      // var indexObj = JSON.stringify(obj);
                      if (/^fullcalendar/gi.test(index)) {
                          log(index); 
                          log(JSON.stringify(obj[index]));
                      }
                  }
              
                  }
              });   
              
              

              Ergebnis hier im Beispiel:

              • Name aller vorhandenen Objekte im Fullcalendar und deren Inhalt
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: {"_id":"fullcalendar.0.2018-04-18T17_16_121","common":{"name":"Test","enabled":true},"native":{"id":1524064572152,"start":"2018-04-19T10:00:00","type":"single","durationEditable":false
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: fullcalendar.0.2018-04-18T17_16_121
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: {"_id":"fullcalendar.0.info","type":"channel","common":{"name":"Information"},"native":{},"from":"system.host.iobrokerng2.cli","ts":1512216110134,"acl":{"object":1636,"owner":"system.u
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: fullcalendar.0.info
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: {"_id":"fullcalendar.0.info.lastConfiguredEvent","type":"state","common":{"role":"state","name":"Last configured event","type":"json","read":true,"write":false},"native":{},"from":"sys
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: fullcalendar.0.info.lastConfiguredEvent
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: {"_id":"fullcalendar.0.info.lastEvent","type":"state","common":{"role":"state","name":"Any last event","type":"json","read":true,"write":false},"native":{},"from":"system.host.iobroker
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: fullcalendar.0.info.lastEvent
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: {"type":"meta","common":{"name":"fullcalendar","type":"www"},"from":"system.host.iobrokerng2.cli","ts":1512216110017,"native":{},"_id":"fullcalendar","acl":{"object":1636,"owner":"syst
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: fullcalendar
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: {"type":"meta","common":{"name":"admin","type":"admin"},"from":"system.host.iobrokerng2.cli","ts":1512216109147,"native":{},"_id":"fullcalendar.admin","acl":{"object":1636,"owner":"sys
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: fullcalendar.admin
              javascript.1	2018-04-18 18:27:40.873	info	script.js.test: Abfrage durchgeführt
              javascript.1	2018-04-18 18:27:40.328	info	script.js.test: registered 0 subscriptions and 0 schedules
              javascript.1	2018-04-18 18:27:40.327	info	Start javascript script.js.test
              
              

              Da ich noch ein Rechteproblem beim Einlesen der objects.json hatte (habe ich nicht weiter verfolgt), habe ich die Datei als objects.json.test eine Ebene höher kopiert.

              Wenn das weiter verfolgt werden soll, muss man sich einmal das Rechtethema ansehen.

              Das Grundgerüst zum einlesen der Datei ist von Paul53 geklaut.

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

                Der Durchlauf und die Verarbeitung hat 500ms gedauert.

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

                  @ruhr70:

                      var obj = JSON.parse(json);
                  
                      for(var index in obj) { 
                          // var indexObj = JSON.stringify(obj);
                          if (/^fullcalendar/gi.test(index)) {
                              log(index); 
                              log(JSON.stringify(obj[index]));
                          }
                      }
                  
                  ```` `  
                  

                  Das Erzeugen des riesigen Objektes per JSON.parse(json) würde ich sparen (Speicherbedarf !) und die IDs folgendermassen ermitteln:

                          var pos = 0;
                          do {
                              pos = json.indexOf('fullcalendar.0.20', pos + 60);
                              var id = json.substr(pos, 35);
                              if(id.indexOf('pos') == -1 && id.length == 35) {
                                  log(id); // Hier kann mit getObject(id) die Auswertung erfolgen
                              }    
                          } while(pos != -1);
                  
                  

                  Wenn man die ID hat, kommt man mit getObject(id) an alle Eigenschaften.

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

                    Dann kommt aber leider die Fehlermeldung

                    TypeError: json.substr is not a function
                    

                    Edit:

                    Habs jetzt hinbekommen anscheinend ist 'json' ein Objekt und kein String. (Stimmt das ?)

                    Deshalb hab ichs jetzt mal so probiert (php Kentnisse sei Dank :D)

                    json.toString().substr
                    

                    Und es geht

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

                      Bei mir funktioniert https://wiki.selfhtml.org/wiki/JavaScript/Objekte/String/substr.

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

                        @strackfi:

                        anscheinend ist 'json' ein Objekt und kein String. (Stimmt das ?) `
                        Nein, json ist ein String. Die Datei objects.json enthält einen JSON-String.

                        Hast Du die Datei eingelesen ?

                        const datei = "/opt/iobroker/iobroker-data/objects.json";
                        
                        
                        1 Reply Last reply Reply Quote 0
                        • S
                          strackfi last edited by

                          Ja wobei bei mir ein Rechteproblem auftritt 😞

                          Welche Rechte muss ich den geben ?

                          Selbst mit chmod 777 gehts nicht

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

                            @strackfi:

                            Ja wobei bei mir ein Rechteproblem auftritt `
                            Ich vermute das Problem eher dadurch, dass die Datei durch ioBroker geöffnet ist.

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

                              Die Fehlermeldung lautet aber:

                              Error: Permission denied
                                       May not read /opt/iobroker/iobroker-data/objects.json
                              
                              1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 last edited by

                                @strackfi:

                                Die Fehlermeldung lautet aber: `
                                Vielleicht hat node.js fs ein Problem mit der Dateiendung .json ?

                                Unter Windows habe ich mal die Datei kopiert und dann die Kopie eingelesen, was funktioniert

                                exec('copy C://Program Files//ioBroker//iobroker-data//objects.json G://opt//iobroker//iobroker-data//objects.test');
                                
                                const datei = "G://opt//iobroker//iobroker-data//objects.test";
                                
                                

                                Und Du hast recht: Man muss .toString() anwenden

                                        json = json.toString();
                                        var pos = 0;
                                        do {
                                
                                
                                1 Reply Last reply Reply Quote 0
                                • S
                                  strackfi last edited by

                                  Wenn ich die Datei kopiere und umbenenne in z.B nur "obj.json" im gleichen Verzeichnis, dann funktioniert das ganze 😄

                                  Macht irgendwie keinen Sinn, wiee ich finde

                                  Edit:

                                  Diese Funktion gibt den Fehler aus:

                                  
                                      mods.fs.readFile = function () {
                                          if (mods.path.normalize(arguments[0]).replace(/\\/g, '/').indexOf('-data/objects.json') !== -1) {
                                              if (adapter) {
                                                  adapter.log.error('May not read ' + arguments[0]);
                                              } else {
                                                  console.error('May not read ' + arguments[0]);
                                              }
                                              throw new Error('Permission denied');
                                          }
                                  
                                          return mods.fs._readFile.apply(this, arguments);
                                      };
                                  
                                  

                                  Die if-Abfrage prüft ob der angegebene Pfad '-data/objects.json' enthält, dass ist anscheinend nicht gewollt ?

                                  Gruß Finn

                                  Edit2: habs gelöst. Ich kopiere einfach die Datei in eine obj.json und lese dann diese aus.

                                  Vielen Dank für eure Hilfe 😄 😄

                                  1 Reply Last reply Reply Quote 0
                                  • First post
                                    Last post

                                  Support us

                                  ioBroker
                                  Community Adapters
                                  Donate

                                  768
                                  Online

                                  31.7k
                                  Users

                                  79.9k
                                  Topics

                                  1.3m
                                  Posts

                                  4
                                  26
                                  3496
                                  Loading More Posts
                                  • Oldest to Newest
                                  • Newest to Oldest
                                  • Most Votes
                                  Reply
                                  • Reply as topic
                                  Log in to reply
                                  Community
                                  Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                  The ioBroker Community 2014-2023
                                  logo