Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. gelöst-wie writeFile() in js script nutzen

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.1k

gelöst-wie writeFile() in js script nutzen

Scheduled Pinned Locked Moved JavaScript
javascript
117 Posts 17 Posters 20.8k Views 24 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • liv-in-skyL liv-in-sky

    @apollon77 @AlCalzone

    hallo - wollte backup (über console: iobroker backup) für controllerv2 machen - da kam dieser fehler -

    fs.js:114
        throw err;
        ^
    
    Error: ENAMETOOLONG: name too long, mkdir '/opt/iobroker/node_modules/iobroker.js-controller/tmp/backup/files/iqontrol.meta/<!DOCTYPE html><html
    
    • ich habe nicht in diesen ordner geschrieben 🙂 aber evtl habe ich durch die writeFile-tests irgendetwas produziert 😞 der name des files ist eigenlich der inhalt des files

    habe gestern etwas probiert und einen fehler gemacht - meine eigentliche frage: kann ich die beiden files einfach so löschen oder sind die nun irgendwo registriert

    der ordner sieht so aus

    Image 3.png

    der iqontrol.meta:

    Image 4.png

    apollon77A Offline
    apollon77A Offline
    apollon77
    wrote on last edited by
    #20

    @liv-in-sky Es gibt in iobroker-data/files/iqontrol.meta ein File namens _data.json wo der "index" der registrierten Files drin ist.

    Lso iobroker stoppen, das blöde File im verzeichnis lschen, dann das JSON da editieren und auch da rauswerfen. Alternativ versuch "iobroker file del" glaube ich von den CLI kommandos ...

    Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

    • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
    • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
    liv-in-skyL 1 Reply Last reply
    0
    • apollon77A apollon77

      @liv-in-sky Es gibt in iobroker-data/files/iqontrol.meta ein File namens _data.json wo der "index" der registrierten Files drin ist.

      Lso iobroker stoppen, das blöde File im verzeichnis lschen, dann das JSON da editieren und auch da rauswerfen. Alternativ versuch "iobroker file del" glaube ich von den CLI kommandos ...

      liv-in-skyL Offline
      liv-in-skyL Offline
      liv-in-sky
      wrote on last edited by liv-in-sky
      #21

      @apollon77

      vielen dank

      habe es in data.json gelöscht und auch aus beiden verzeichnissen

      • ist aber etwas umständlich - wenn man über längere zeit vergißt, dass irgendein script mal etwas geschrieben hat (oder manchmal weiß man garnicht, dass ein script das machte), bleibt es für quasi für "ewig" im system.
      • würde das nicht bei einem restore zu einem problem führen, wenn man nicht auf redis(file) umgestellt hat - ein neues system aufgesetzt - script nicht mehr da - ein restore ...

      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

      apollon77A 1 Reply Last reply
      0
      • liv-in-skyL liv-in-sky

        @apollon77

        vielen dank

        habe es in data.json gelöscht und auch aus beiden verzeichnissen

        • ist aber etwas umständlich - wenn man über längere zeit vergißt, dass irgendein script mal etwas geschrieben hat (oder manchmal weiß man garnicht, dass ein script das machte), bleibt es für quasi für "ewig" im system.
        • würde das nicht bei einem restore zu einem problem führen, wenn man nicht auf redis(file) umgestellt hat - ein neues system aufgesetzt - script nicht mehr da - ein restore ...
        apollon77A Offline
        apollon77A Offline
        apollon77
        wrote on last edited by
        #22

        @liv-in-sky Was meinst Du mit dem Restore?

        Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

        • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
        • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
        liv-in-skyL 1 Reply Last reply
        0
        • apollon77A apollon77

          @liv-in-sky Was meinst Du mit dem Restore?

          liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          wrote on last edited by
          #23

          @apollon77

          wenn man ein neues system installiert und dann ein restore mit backupfile macht, wird doch die datei in der _data.json stehen (durch den restore) - aber es ist kein script mehr da, das dieses file schreibt - weil script gelöscht oder geändert?

          oder habe ich es immer noch nicht kapiert

          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 Reply Last reply
          0
          • apollon77A Offline
            apollon77A Offline
            apollon77
            wrote on last edited by
            #24

            Ja ein Backup sichert alle files in den Verzeichnissen. Wenn da Leichen drin sind bleiben die da wenn sie nicht gelöscht wurden (wie in jedem normalen Dateisystem auch ;-))

            Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

            • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
            • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
            liv-in-skyL 1 Reply Last reply
            0
            • apollon77A apollon77

              Ja ein Backup sichert alle files in den Verzeichnissen. Wenn da Leichen drin sind bleiben die da wenn sie nicht gelöscht wurden (wie in jedem normalen Dateisystem auch ;-))

              liv-in-skyL Offline
              liv-in-skyL Offline
              liv-in-sky
              wrote on last edited by liv-in-sky
              #25

              @apollon77

              vergiss das - ist erledigt

              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 Reply Last reply
              0
              • ChaotC Offline
                ChaotC Offline
                Chaot
                wrote on last edited by
                #26

                Damit ich nicht das js-controler Thema weiter sprenge (ich glaube apollon77 wird langsam sauer) möchte ich hier um Hilfe bitten.

                Ich nutze ein Script für meine Klingel.
                Dazu habe ich zum erstellen bisher immer den Befehl wget genutzt und die Bilder dann in VIS angezeigt.
                Das geht ja nun wohl nicht mehr.
                Allerdings komme ich mit dem Befehl writeFile absolut nicht zurecht.
                Könnte mir eventuell jemand einen Tip geben wie ich die Bilder so geschreiben bekomme das sie nutzbar sind?
                Komplettscript:

                var sperre = false;  //verhindert das doppeltes Drücken das Script stoppt
                var timeout, timeout2, timeout3, timeout4, timeout5, timeout6, timeout7, timeout8;
                
                on({id: 'sonoff.0.Eingang.POWER2', change: "any"}, function (obj) {
                 if(!sperre) {
                   sperre = true;
                   setState("tr-064-community.0.states.ring"/*ring*/, '**610, 15'); //Klingelt 15 Sekunden auf dem Telefon
                    // Speichert das erste Bild bei Klingeln
                   exec('wget --output-document /opt/iobroker/iobroker-data/files/vis.0/tuer/alarm1.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                   // Es wird 2500ms gewartet um dieses speichern auszuführen
                   timeout = setTimeout(function () {
                     // Und hier wird es versendet
                     sendTo("email", "send", {
                    text: '',
                    to: 'xxxx@gmail.com',
                    subject: 'Klingel',
                    attachments:[
                       {path: '/opt/iobroker/iobroker-data/files/vis.0/tuer/alarm1.jpg', cid: "file1"},
                     ]
                     });
                     sendTo("email", "send", {
                    text: '',
                    to: 'xxxx@gmail.com',
                    subject: 'Klingel',
                    attachments:[
                       {path: '/opt/iobroker/iobroker-data/files/vis.0/tuer/alarm1.jpg', cid: "file1"},
                     ]
                     });
                   }, 2500);
                   // Nach dem ersten Bild wird nach 5000ms das nächste Bild gespeichert
                   timeout2 = setTimeout(function () {
                     exec('wget --output-document /opt/iobroker/iobroker-data/files/vis.0/tuer/alarm2.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                     // Es wird 2500ms gewartet um dieses speichern auszuführen
                     timeout3 = setTimeout(function () {
                       // Und hier wird es versendet
                       sendTo("email", "send", {
                    text: '',
                    to: 'xxxx@gmail.com',
                    subject: 'Klingel',
                    attachments:[
                       {path: '/opt/iobroker/iobroker-data/files/vis.0/tuer/alarm2.jpg', cid: "file1"},
                     ]
                       });
                       sendTo("email", "send", {
                    text: '',
                    to: 'xxxx@gmail.com',
                    subject: 'Klingel',
                    attachments:[
                       {path: '/opt/iobroker/iobroker-data/files/vis.0/tuer/alarm2.jpg', cid: "file1"},
                     ]
                     });
                     }, 2500);
                   }, 5000);
                   timeout7 = setTimeout(function () {
                     exec('wget --output-document /opt/iobroker/iobroker-data/files/vis.0/tuer/alarm3.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                   }, 10000);
                   
                 
                  
                   timeout8 = setTimeout(function () {
                     exec('wget --output-document /opt/iobroker/iobroker-data/files/vis.0/tuer/alarm4.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                   }, 10000);
                  
                   }
                
                    setState("vis.0.control.command", '{"instance": "FFFFFFFF", "command": "changeView", "data": "Neu/Tuer"}'); 
                          // oder
                          //setState("vis.0.control.instance", 'FFFFFFFF');
                          //setState("vis.0.control.data",     'DemoView');
                          //setState("vis.0.control.command",  'changeView'); // muss immer letzte sein
                          
                          // Setze View auf Kamerabild
                          setTimeout(function () {
                                     setState("vis.0.control.command", '{"instance": "FFFFFFFF", "command": "changeView", "data": "Neu/Info"}');
                          }, 60000); // Nach 60 Sekunden, zeige wieder Start View
                       timeout4 = setTimeout(function () {
                   setState("alexa2.0.Echo-Devices.G2A0PxxxxLLE.Player.volume"/*volume*/, 70, true);
                   }, 500); // Setzt Alexa auf 90%
                   timeout5 = setTimeout(function () {
                   setState("alexa2.0.Echo-Devices.G2A0PxxxxLLE.Commands.speak"/*speak*/, 'Es ist jemand an der Tür');
                   }, 1000); // Sprachansage
                   timeout6 = setTimeout(function () {
                   setState("alexa2.0.Echo-Devices.G2A0xxxxLLE.Player.volume"/*volume*/, 30, true);
                   }, 5000); // Setzt Alexa auf 50%
                   setTimeout(function() {
                      sperre = false;
                   }, 5000); //Zeit für Klingelsperre 1.Zeile
                 
                });
                

                oder reicht der Umbau der Codezeile:

                 exec('wget --output-document /opt/iobroker/iobroker-data/files/vis.0/tuer/alarm2.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                      
                

                ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

                1 Reply Last reply
                0
                • apollon77A Offline
                  apollon77A Offline
                  apollon77
                  wrote on last edited by
                  #27

                  Ich werde nicht sauer 🙂

                  Ich würde es (jetzt ohne den Code dafür rauszusuchen, aber da kann vllt jemand unterstützen) wie folgt machen:

                  Option 1 - alles mit Kommandozeilentools:

                  • ein exec mit deinem wget was das File z.B. nach /tmp/bild.jpg runterlädt und speichert
                  • Wenn das ok war ein weiteres exec mit "iobroker file write /tmp/bild.jpg /vis.0/bild.jpg" (befehl: iobroker file write <filesystem-path-to-read> <iobroker-path-to-write>) um upload zu machen.
                    Der Weg hat einen kleinen Overhead weil Kommandozeilen-Tool auch neu mit der DB verbindet und so

                  Option2 - Javscript

                  • ein exec mit deinem wget was das File z.B. nach /tmp/bild.jpg runterlädt und speichert
                  • in JavaScript ein const bild = fs.readFileSync('/tmp/bild.jpg');
                  • in Javascript danach writeFile('vis.0','bild.jpg', bild);

                  Code beispiele Untested

                  Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                  • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                  • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                  1 Reply Last reply
                  0
                  • ChaotC Offline
                    ChaotC Offline
                    Chaot
                    wrote on last edited by
                    #28

                    @apollon77 sagte in gelöst-wie writeFile() in js script nutzen:

                    iobroker file write <filesystem-path-to-read> <iobroker-path-to-write>

                    Danke für deine Hilfe.
                    Das script

                    exec('wget --output-document /tmp/alarm5.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                    exec('iobroker file write /tmp/alarm5.jpg vis.0/alarm5.jpg');
                    
                    
                    

                    ergibt:

                    Error	2019-10-12 23:09:12.818	warn	from InMemDB: Error: ERROR id=vis.0 - EISDIR: illegal operation on a directory, open '/opt/iobroker/iobroker-data/files/vis.0'
                    host.ioBroker	2019-10-12 23:09:12.816	error	Cannot write files: /opt/iobroker/iobroker-data/files/vis.0: EISDIR: illegal operation on a directory, open '/opt/iobroker/iobroker-data/files/vis.0'
                    

                    die andere Variante

                    const bild = fs.readFileSync('/tmp/alarm5.jpg');
                    
                    exec('wget --output-document /tmp/alarm5.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                    writeFile('vis.0','alarm5.jpg', bild);
                    

                    Scheitert an Zeile

                    javascript.0	2019-10-12 23:12:33.714	error	(21185) at Script.runInContext (vm.js:133:20)
                    javascript.0	2019-10-12 23:12:33.714	error	(21185) at script.js.Klingel.TestFileSchreiben:1:14
                    javascript.0	2019-10-12 23:12:33.713	error	(21185) ReferenceError: fs is not defined
                    javascript.0	2019-10-12 23:12:33.713	error	(21185) ^
                    javascript.0	2019-10-12 23:12:33.711	error	(21185) const bild = fs.readFileSync('/tmp/alarm5.jpg');
                    javascript.0	2019-10-12 23:12:33.710	error	(21185) script.js.Klingel.TestFileSchreiben: script.js.Klingel.TestFileSchreiben:1
                    

                    fs is not defined.
                    Muss ich da noch was nachinstallieren?

                    ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

                    apollon77A 1 Reply Last reply
                    0
                    • ChaotC Offline
                      ChaotC Offline
                      Chaot
                      wrote on last edited by
                      #29

                      Ok - Danke dir.
                      Kleiner Denkfehler.
                      So funktioniert das:

                      var fs = require('fs');
                      const bild = fs.readFileSync('/tmp/alarm5.jpg');
                      
                      exec('wget --output-document /tmp/alarm5.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                      writeFile('vis.0','alarm5.jpg', bild);
                      

                      ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

                      apollon77A 1 Reply Last reply
                      0
                      • ChaotC Chaot

                        Ok - Danke dir.
                        Kleiner Denkfehler.
                        So funktioniert das:

                        var fs = require('fs');
                        const bild = fs.readFileSync('/tmp/alarm5.jpg');
                        
                        exec('wget --output-document /tmp/alarm5.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                        writeFile('vis.0','alarm5.jpg', bild);
                        
                        apollon77A Offline
                        apollon77A Offline
                        apollon77
                        wrote on last edited by
                        #30

                        @Chaot Naja ich würde ja das readFileSync HINTER dem exec machen ... sonst liesst Du immer das File was davor da war aber nicht das aktuelle

                        Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                        • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                        • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                        1 Reply Last reply
                        0
                        • ChaotC Offline
                          ChaotC Offline
                          Chaot
                          wrote on last edited by
                          #31

                          Oh, stimmt ja. Danke

                          ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

                          1 Reply Last reply
                          0
                          • ChaotC Chaot

                            @apollon77 sagte in gelöst-wie writeFile() in js script nutzen:

                            iobroker file write <filesystem-path-to-read> <iobroker-path-to-write>

                            Danke für deine Hilfe.
                            Das script

                            exec('wget --output-document /tmp/alarm5.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                            exec('iobroker file write /tmp/alarm5.jpg vis.0/alarm5.jpg');
                            
                            
                            

                            ergibt:

                            Error	2019-10-12 23:09:12.818	warn	from InMemDB: Error: ERROR id=vis.0 - EISDIR: illegal operation on a directory, open '/opt/iobroker/iobroker-data/files/vis.0'
                            host.ioBroker	2019-10-12 23:09:12.816	error	Cannot write files: /opt/iobroker/iobroker-data/files/vis.0: EISDIR: illegal operation on a directory, open '/opt/iobroker/iobroker-data/files/vis.0'
                            

                            die andere Variante

                            const bild = fs.readFileSync('/tmp/alarm5.jpg');
                            
                            exec('wget --output-document /tmp/alarm5.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                            writeFile('vis.0','alarm5.jpg', bild);
                            

                            Scheitert an Zeile

                            javascript.0	2019-10-12 23:12:33.714	error	(21185) at Script.runInContext (vm.js:133:20)
                            javascript.0	2019-10-12 23:12:33.714	error	(21185) at script.js.Klingel.TestFileSchreiben:1:14
                            javascript.0	2019-10-12 23:12:33.713	error	(21185) ReferenceError: fs is not defined
                            javascript.0	2019-10-12 23:12:33.713	error	(21185) ^
                            javascript.0	2019-10-12 23:12:33.711	error	(21185) const bild = fs.readFileSync('/tmp/alarm5.jpg');
                            javascript.0	2019-10-12 23:12:33.710	error	(21185) script.js.Klingel.TestFileSchreiben: script.js.Klingel.TestFileSchreiben:1
                            

                            fs is not defined.
                            Muss ich da noch was nachinstallieren?

                            apollon77A Offline
                            apollon77A Offline
                            apollon77
                            wrote on last edited by
                            #32

                            @Chaotzu dem Kommandozeilen Ding: Ich kann zwar den Fehler nicht nachvollziehen den Du bekommen hast, aber habe nen anderen Fehler gefunden 🙂

                            Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                            • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                            • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                            1 Reply Last reply
                            0
                            • ChaotC Offline
                              ChaotC Offline
                              Chaot
                              wrote on last edited by Chaot
                              #33

                              Sorry das ich dir Arbeit verpasst habe 😕

                              Da das Script läuft und jetzt auch alle 4 Bilder richtig anlegt kann ich mir ja jetzt den Codeschnipsel als Muster gespeichert lassen.
                              Vielleicht hilft das auch anderen weiter.
                              Ich denke mal das Problem "write" wird noch öfter auftauchen.

                              var fs = require('fs');
                              
                              exec('wget --output-document /tmp/alarm5.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                              
                              const bild = fs.readFileSync('/tmp/alarm5.jpg');
                              writeFile('vis.0','alarm5.jpg', bild);
                              

                              ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

                              apollon77A 1 Reply Last reply
                              2
                              • ChaotC Chaot

                                Sorry das ich dir Arbeit verpasst habe 😕

                                Da das Script läuft und jetzt auch alle 4 Bilder richtig anlegt kann ich mir ja jetzt den Codeschnipsel als Muster gespeichert lassen.
                                Vielleicht hilft das auch anderen weiter.
                                Ich denke mal das Problem "write" wird noch öfter auftauchen.

                                var fs = require('fs');
                                
                                exec('wget --output-document /tmp/alarm5.jpg \'http://192.168.8.95:8765/picture/1/current/?_username=xxxx&_signature=ba8317b8fc071dadb725d4d0d9dbf7e606acbf1e\'');
                                
                                const bild = fs.readFileSync('/tmp/alarm5.jpg');
                                writeFile('vis.0','alarm5.jpg', bild);
                                
                                apollon77A Offline
                                apollon77A Offline
                                apollon77
                                wrote on last edited by
                                #34

                                @Chaot Ich habe es in der 2.0er FAQ auch verlinkt

                                Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                liv-in-skyL 1 Reply Last reply
                                0
                                • apollon77A apollon77

                                  @Chaot Ich habe es in der 2.0er FAQ auch verlinkt

                                  liv-in-skyL Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  wrote on last edited by
                                  #35

                                  @apollon77
                                  @Chaot

                                  habe mal einen nachtrag im ersten post geschrieben mit den beiden beispielen von uns

                                  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

                                  ChaotC 1 Reply Last reply
                                  1
                                  • liv-in-skyL liv-in-sky

                                    @apollon77
                                    @Chaot

                                    habe mal einen nachtrag im ersten post geschrieben mit den beiden beispielen von uns

                                    ChaotC Offline
                                    ChaotC Offline
                                    Chaot
                                    wrote on last edited by
                                    #36

                                    @liv-in-sky Danke für den Löschbefehl.
                                    In meinem Fall nicht notwendig/erwünscht weil ich das Bild in der VIS nutze und dann erst wieder das nächste erstellte Bild darstelle.
                                    Wirkt zwar vielleicht seltsam wenn ein 2 Tage altes Bild angezeigt wird, aber ist mir lieber als ein leerer Platz an der Stelle.
                                    @apollon77 Danke. Habe ich gesehen. Und nochmals ganz herzlichen Dank für deine Hilfe.

                                    ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

                                    1 Reply Last reply
                                    0
                                    • PeoplesP Offline
                                      PeoplesP Offline
                                      Peoples
                                      wrote on last edited by
                                      #37

                                      Ich hänge mich hier mal ran, da @apollon77 meinte der andere Thread wäre der falsche.

                                      Ich versuche mein Türklingel-Script so umzubauen dass es auch mit den (für mich unverständlichen Änderungen) des 2er Js-Controllers läuft.

                                      Mittlerweile habe ich es geschafft Bilder meiner Kamera in vis.0 zu speichern, das klappt mit diesem Codeschnipsel:

                                      var fs = require('fs');
                                      
                                      exec('wget --output-document /tmp/image.jpg \'http://xxx.xxx.xxx.x:8765/picture/3/current/\'');
                                      
                                      var data = fs.readFileSync('/tmp/image.jpg');
                                      writeFile('vis.0', '/camImages/1.jpg', data, function (error) {
                                          console.log('file written');
                                      });
                                      
                                      //delFile(adapter, fileName, function (error) {});
                                      

                                      Aber in meinem Script muss ich die Dateien auch immer wieder umbenennen was ich bisher so gemacht habe:

                                      var fs = require('fs');
                                      
                                      function fsRenameSync(oldPath, newPath) {
                                          try {
                                              var stats = fs.statSync(oldPath);
                                              try { fs.renameSync(oldPath, newPath); }
                                              catch(err) { if (err.code != "ENOENT") log(err); }     
                                          }
                                          catch(err) { if (err.code != "ENOENT") log(err); }
                                      }
                                      
                                      fsRenameSync("/vis.0/camImages/1.jpg", "/vis.0/camImages/2.jpg"); 
                                      

                                      Aber auch das funktioniert nicht mehr, kann mir hier jemand auch den Fehler aufzeigen?

                                      Ich beantworte keine Fragen zu Themen via PN

                                      crunchipC apollon77A 2 Replies Last reply
                                      0
                                      • PeoplesP Peoples

                                        Ich hänge mich hier mal ran, da @apollon77 meinte der andere Thread wäre der falsche.

                                        Ich versuche mein Türklingel-Script so umzubauen dass es auch mit den (für mich unverständlichen Änderungen) des 2er Js-Controllers läuft.

                                        Mittlerweile habe ich es geschafft Bilder meiner Kamera in vis.0 zu speichern, das klappt mit diesem Codeschnipsel:

                                        var fs = require('fs');
                                        
                                        exec('wget --output-document /tmp/image.jpg \'http://xxx.xxx.xxx.x:8765/picture/3/current/\'');
                                        
                                        var data = fs.readFileSync('/tmp/image.jpg');
                                        writeFile('vis.0', '/camImages/1.jpg', data, function (error) {
                                            console.log('file written');
                                        });
                                        
                                        //delFile(adapter, fileName, function (error) {});
                                        

                                        Aber in meinem Script muss ich die Dateien auch immer wieder umbenennen was ich bisher so gemacht habe:

                                        var fs = require('fs');
                                        
                                        function fsRenameSync(oldPath, newPath) {
                                            try {
                                                var stats = fs.statSync(oldPath);
                                                try { fs.renameSync(oldPath, newPath); }
                                                catch(err) { if (err.code != "ENOENT") log(err); }     
                                            }
                                            catch(err) { if (err.code != "ENOENT") log(err); }
                                        }
                                        
                                        fsRenameSync("/vis.0/camImages/1.jpg", "/vis.0/camImages/2.jpg"); 
                                        

                                        Aber auch das funktioniert nicht mehr, kann mir hier jemand auch den Fehler aufzeigen?

                                        crunchipC Away
                                        crunchipC Away
                                        crunchip
                                        Forum Testing Most Active
                                        wrote on last edited by
                                        #38

                                        @Peoples sagte in gelöst-wie writeFile() in js script nutzen:

                                        so umzubauen dass es auch mit den (für mich unverständlichen Änderungen) des 2er Js-Controllers läuft.

                                        ich kann zwar nach wie vor nichts mit scripten anfangen( glaub das lern ich nie) aber ich habe keines meiner scripte umgebaut, da ich den Sinn nicht verstehe, warum ich in den Ordner /files/vis.0...schreiben soll. Das Bild ist doch nur ne Momentaufname. Von daher kann ich doch genauso gut ausserhalb von iobroker-data/files... mein Bild ablegen und alles bleibt wie gehabt.

                                        umgestiegen von Proxmox auf Unraid

                                        PeoplesP 1 Reply Last reply
                                        0
                                        • PeoplesP Peoples

                                          Ich hänge mich hier mal ran, da @apollon77 meinte der andere Thread wäre der falsche.

                                          Ich versuche mein Türklingel-Script so umzubauen dass es auch mit den (für mich unverständlichen Änderungen) des 2er Js-Controllers läuft.

                                          Mittlerweile habe ich es geschafft Bilder meiner Kamera in vis.0 zu speichern, das klappt mit diesem Codeschnipsel:

                                          var fs = require('fs');
                                          
                                          exec('wget --output-document /tmp/image.jpg \'http://xxx.xxx.xxx.x:8765/picture/3/current/\'');
                                          
                                          var data = fs.readFileSync('/tmp/image.jpg');
                                          writeFile('vis.0', '/camImages/1.jpg', data, function (error) {
                                              console.log('file written');
                                          });
                                          
                                          //delFile(adapter, fileName, function (error) {});
                                          

                                          Aber in meinem Script muss ich die Dateien auch immer wieder umbenennen was ich bisher so gemacht habe:

                                          var fs = require('fs');
                                          
                                          function fsRenameSync(oldPath, newPath) {
                                              try {
                                                  var stats = fs.statSync(oldPath);
                                                  try { fs.renameSync(oldPath, newPath); }
                                                  catch(err) { if (err.code != "ENOENT") log(err); }     
                                              }
                                              catch(err) { if (err.code != "ENOENT") log(err); }
                                          }
                                          
                                          fsRenameSync("/vis.0/camImages/1.jpg", "/vis.0/camImages/2.jpg"); 
                                          

                                          Aber auch das funktioniert nicht mehr, kann mir hier jemand auch den Fehler aufzeigen?

                                          apollon77A Offline
                                          apollon77A Offline
                                          apollon77
                                          wrote on last edited by
                                          #39

                                          @Peoples generell hat der js-controller auch ein renameFile, aber der JavaScript Adapter bietet das nicht an. Mit readFile/writeFile müsste es aber quasi gehen

                                          Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                          • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                          • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                          PeoplesP 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          748

                                          Online

                                          32.4k

                                          Users

                                          81.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe