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.
    • paul53
      paul53 last edited by

      @strackfi:

      Ist das so überhaupt möglich `
      Ich kenne keine Möglichkeit.

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

        Wüsstest du ansonsten noch eine Möglichkeit die Events aus dem Calender Schedule Adapter auszulesen ?

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

          Ein Zugriff ist (meiner Meinung nach) nur bei Kenntnis der Objekt-ID oder des Namens möglich. Bei Zugriff über den Namen muss dieser eindeutig sein.

          const idEvent = getIdByName('name');
          
          var event = null;
          if(typeof idEvent == 'string') event = getObject(idEvent);  // Schedule Objekt
          
          
          1 Reply Last reply Reply Quote 0
          • 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

                                        615
                                        Online

                                        31.7k
                                        Users

                                        79.8k
                                        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