Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. gelöst-wie writeFile() in js script nutzen

    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-wie writeFile() in js script nutzen

    This topic has been deleted. Only users with topic management privileges can see it.
    • crunchip
      crunchip Forum Testing Most Active @Peoples last edited by

      @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.

      Peoples 1 Reply Last reply Reply Quote 0
      • apollon77
        apollon77 @Peoples last edited by

        @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

        Peoples 1 Reply Last reply Reply Quote 0
        • Peoples
          Peoples @crunchip last edited by

          @crunchip
          Ich habe da eine "Klingelhistorie" die ich in Bis darstelle, diese würde dann halt gleich mit gesichert beim Backup.
          Zudem weiß ich nicht ob ich die Bilder weiter angezeigt bekomme wenn sie nicht in vis.0 liegen. Weil mit dem Ablageort in Files geht es nicht mehr.

          apollon77 1 Reply Last reply Reply Quote 0
          • Peoples
            Peoples @apollon77 last edited by

            @apollon77
            Ist das dann aber nicht jedesmal Ressourcen verbrennen wenn bei jedem klingeln 50 Bilder eingelesen werden / gelöscht werden / mit dem neuen Dateinamen geschrieben werden nur dass das Bild0 immer das neueste ist.

            Ich kann gerne auch Mal das Script Posten um zu verdeutlichen was ich meine

            apollon77 1 Reply Last reply Reply Quote 0
            • apollon77
              apollon77 @Peoples last edited by

              @Peoples wer sagt denn das du nicht weiterhin vis.0 als Basis nehmen kannst?! Na klar geht das.

              1 Reply Last reply Reply Quote 0
              • apollon77
                apollon77 @Peoples last edited by

                @Peoples dann bitte issue beim JavaScript Adapter anlegen das rename angeboten wird. Ansonsten kann man garantiert Varianten finden das man die files mit nem Namen Mit Datum und Zeit speichert und die History in States speichert und so dynamisch nutzt. Dann brauchst funds auch nichts umzubenennen

                Peoples 1 Reply Last reply Reply Quote 0
                • Peoples
                  Peoples @apollon77 last edited by Peoples

                  @apollon77
                  Das ist ne Idee 👍

                  Der Vollständigkeit halber hier mal das Script

                  // -------------------------------------------------------------------------
                  // Bilder Speichern
                  // -------------------------------------------------------------------------
                  
                  // -------------------------------------------------------------------------
                  // Konfiguration
                  // v1.1 - Initial
                  // v1.2 - 13.07.2019    Kamera-Bild-Sources auf 3 erweitert
                  // v1.3 - 18.07.2019    Inhalt des Objekts für das letze angezeigte Haustürbild
                  //                      geändert. Jetzt kompletter Pfad für Vis
                  // -------------------------------------------------------------------------
                  createState('System.Iobroker.Angezeigtes_Bild_Haustuere',  {def: '/_temp/eingangstuer_0.jpg',type: 'string',name: 'Angezeigtes Bild der Kamera Haustuere'});
                  
                  var source_url_backyard = 'xx';
                  var source_url_trash = 'xx';
                  var source_url_main_door = 'x';
                  
                  
                  
                  
                  
                  
                  //const cam_url = source_url;
                        // Pfadangabe für die Speicherung der Bilder, der Pfad muss existieren
                  const dest_path = '/opt/iobroker/iobroker-data/files/_temp/';
                        // Anzahl der Bilder, die vorgehalten werden sollen
                  const imageCountMax = 50;                
                        // Prefix für die Bildnamen
                  //const imageNamePre = "eingangstuer_"; 
                  
                  // -------------------------------------------------------------------------
                  // Scriptteil
                  // -------------------------------------------------------------------------
                  var request = require('request');
                  var fs      = require('fs');
                  
                  
                  // löscht eine Datei synchron (wartet auf das Ergebnis)
                  function fsUnlinkSync(path) {
                      try {
                          var stats = fs.statSync(path);
                          try { fs.unlinkSync(path); }
                          catch(err) { if (err.code != "ENOENT") log(err); }     
                      }
                      catch(err) { if (err.code != "ENOENT") log(err); }
                  }
                  
                  // benennt eine Datei synchron um (wartet auf das Ergebnis)
                  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); }
                  }
                  
                  // Bild speichern und senden
                  function saveImage(cam_url, imageNamePre) {
                      // Bild imageCountMax-1 löschen
                      fsUnlinkSync( dest_path + imageNamePre + (imageCountMax-1) + ".jpg" );
                      // Bilder 0..imageCountMax-2 umbenennen
                      for (var i=imageCountMax-2; i >= 0; i-- ) { 
                          fsRenameSync(dest_path + imageNamePre + i + ".jpg", dest_path + imageNamePre + (i+1) + ".jpg"); 
                      }
                      // Bild 0 löschen
                      var fname = imageNamePre + "0.jpg";
                      fsUnlinkSync( fname );
                      // Bild holen und speichern
                      request.get({url: cam_url, encoding: 'binary'}, function (err, response, body) {
                          fs.writeFile(dest_path + fname, body, 'binary', function(err) {
                              if (err) {
                                  log('Fehler beim Bild speichern: ' + err, 'warn');
                              } else {
                                  // dem Filesystem 2 Sek Zeit zum Speichern lassen
                  // -----------------------------------------------------------------------------------------------------------
                  //          setTimeout(function() { sendImage(dest_path + fname); }, 2000); 
                  // -----------------------------------------------------------------------------------------------------------
                              }
                          }); 
                      });
                  }
                  
                  // manuelle Ausführung (Test)
                  //saveImage(cam_url, imageNamePre);
                  
                  on({id: "javascript.0.System.Iobroker.Angezeigtes_Bild_Haustuere", change: "ne"}, function(dp) {
                      if(dp.state.val !== 0){
                          setStateDelayed("javascript.0.System.Iobroker.Angezeigtes_Bild_Haustuere",'/_temp/eingangstuer_0.jpg',60000);
                      }
                  });
                  
                  

                  Falls hier jemand nen groben Schnitzer sieht gerne Bescheid geben

                  H 1 Reply Last reply Reply Quote 0
                  • H
                    heinzie @Peoples last edited by

                    @Peoples

                    Das ist das script was ich bisher auch verwendet habe. Das Problem ist wohl diese Zeile
                    fs.writeFile(dest_path + fname, body, 'binary', function(err) {

                    habe es mal hiermit versucht:
                    writeFile('vis.0', '/KameraBilder/' + fname ,body, function(err) {

                    geht aber trotzdem nicht. Speichert zwar aber werden trotzdem nicht richtig angezeigt.

                    Peoples 1 Reply Last reply Reply Quote 0
                    • Peoples
                      Peoples @heinzie last edited by

                      @heinzie
                      Genau so ist es!

                      Ich werde das Mal umschreiben dass es wieder funktioniert

                      H 1 Reply Last reply Reply Quote 0
                      • H
                        heinzie @Peoples last edited by

                        @Peoples
                        Das hört sich klasse an. Mit meinem Wissen komme ich da leider nicht weiter. Kannst Du das dann bitte hier Posten wenn du eine Lösung hast.
                        Danke!

                        Peoples 1 Reply Last reply Reply Quote 0
                        • Z
                          zahnheinrich last edited by

                          @heinzie
                          Es reicht ja schon, das Verzeichnis wegen der neuen Sicherheitsrichtlinien ausserhalb von /iobroker/data zu verlegen.
                          Ich habe einfach ein Verzeichnis /iobroker/DoorBird angelegt und die const dest_path entsprechend geändert.

                          apollon77 H 2 Replies Last reply Reply Quote 0
                          • apollon77
                            apollon77 @zahnheinrich last edited by

                            @zahnheinrich Dann kann aber vis nicht drauf zugreifen oder ?!

                            1 Reply Last reply Reply Quote 0
                            • H
                              heinzie @zahnheinrich last edited by

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

                              @heinzie
                              Es reicht ja schon, das Verzeichnis wegen der neuen Sicherheitsrichtlinien ausserhalb von /iobroker/data zu verlegen.
                              Ich habe einfach ein Verzeichnis /iobroker/DoorBird angelegt und die const dest_path entsprechend geändert.

                              Und welchen Pfad (bzw. mit welcher Syntax) hast du unter Quelle in dem Widget angegeben?
                              Über den Dateimanger komme ich bei mir hicht höher als
                              O:\iobroker_mount\iobroker-data\files
                              Die Bilder liegen jetzt hier: O:\iobroker_mount\KameraBilder
                              Was muss denn genau unter Quelle angegeben werden? wenn ich dort O:\iobroker_mount\KameraBilder\eingang_0.jpg
                              findet er das Bild nicht.

                              Z 1 Reply Last reply Reply Quote 0
                              • Z
                                zahnheinrich @heinzie last edited by

                                @heinzie
                                Jooo,
                                im VIS anzuzeigen geht (noch) nicht. Da arbeiten die Experten dran.
                                Ich speichere meine snapshots von der DoorBird in dem Verzeichnis und schicke mir die Bilder per telegram.
                                Sorry für die Verwechslung!

                                H 1 Reply Last reply Reply Quote 0
                                • H
                                  heinzie @zahnheinrich last edited by

                                  @zahnheinrich
                                  Alles klar, Danke.

                                  1 Reply Last reply Reply Quote 0
                                  • Peoples
                                    Peoples @heinzie last edited by Peoples

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

                                    @Peoples
                                    Das hört sich klasse an. Mit meinem Wissen komme ich da leider nicht weiter. Kannst Du das dann bitte hier Posten wenn du eine Lösung hast.
                                    Danke!

                                    Hi Heinzie,

                                    ich hab mal was zusammen geschrieben, probiere das mal bitte aus ob das bei dir läuft.

                                    Wichtig:

                                    • den Speicherordner in Vis anlegen
                                    • deine Daten im Script eintragen

                                    Wenn du es dann Startest sollte das erste Bild gleich gespeichert werden. Den Auslösetrigger müsste man halt noch anpassen.

                                    // *******************************************************************************************************
                                    //
                                    // Bilder Speichern und in DB aufnehmen
                                    // Autor: Peoples
                                    //
                                    // v2.0.0 - 23.11.2019  Neue Version - Auf Grund der Änderungen in Js-controller 2x
                                    //
                                    // *******************************************************************************************************
                                    
                                    // -----------------------------------------------------------------------------
                                    // allgemeine Variablen
                                    // -----------------------------------------------------------------------------
                                    var fs = require('fs');
                                    var logging = true;         // Log Meldungen ein/aus schalten
                                    
                                    // Kamera Bildquelle muss beim Funktionsaufruf mit übergeben werden
                                    const source_url_backyard = 'http://xxx.xxx.xxx.x:xxxx/picture/1/current/';       
                                    const source_url_trash = 'http://xxx.xxx.xxx.x:xxxx/picture/2/current/';
                                    const source_url_main_door = 'http://xxx.xxx.xxx.x:xxxx/picture/3/current/';
                                    
                                    const imageCountMax = 5;                            // Anzahl der Bilder, die vorgehalten werden sollen
                                    
                                    const visInstance = 0;
                                    const imageFolder = 'camImages/';                   // Speicherort/Ordner unter Vis - Muss existieren!
                                    
                                    // -----------------------------------------------------------------------------
                                    // Objekte
                                    // -----------------------------------------------------------------------------
                                    
                                    //zu Testzwecken
                                    //createState('System.Iobroker.Angezeigtes_Bild_Haustuere',  {def: '/_temp/eingangstuer_0.jpg',type: 'string',name: 'Angezeigtes Bild der Kamera Haustuere'});
                                    
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Funktion zum löschen der angegebenen Bilddateien                         #
                                    // #                                                                           #
                                    // #############################################################################
                                    function deleteImage(imageFile) {
                                        delFile('vis.'+visInstance, imageFolder+imageFile, function (error) {
                                            log('file' +imageFile +' gelöscht')
                                        }); 
                                    }
                                    
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Funktion zum umbenennen der angegebenen Bilddateien                      #
                                    // #                                                                           #
                                    // #############################################################################
                                    function renameImage(oldName, newName) {
                                        try{
                                            readFile('vis.'+visInstance, imageFolder+oldName+'.jpg', function (error, data) {
                                                    writeFile('vis.'+visInstance, imageFolder+newName+'.jpg', data, function (error) {
                                                    if(logging) log(oldName+'.jpg renamed to '+newName+'jpg');
                                    // Nicht benötigt da überschrieben wird
                                    //                    delFile('vis.0', imageFolder+oldName+'.jpg', function (error) {
                                    //                        if(logging) log(oldName+'.jpg deleted after rename');
                                    //                    });
                                                    });
                                            }); 
                                        }
                                        catch(error) { if (error.code != "ENOENT") log(error); }
                                    }
                                    
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Funktion zum speichern der angegebenen Bilddateien                       #
                                    // #                                                                           #
                                    // #############################################################################
                                    function saveImage(imageNamePre, camUrl) {
                                        deleteImage(imageNamePre+ (imageCountMax-1))
                                    
                                        for (var i=imageCountMax-2; i >= 0; i-- ) { 
                                            renameImage(imageNamePre + i,imageNamePre + (i+1)); 
                                            if(logging) log('renameImage: '+imageNamePre + i+'.jpg , to '+imageNamePre + (i+1)+'jpg')
                                        }
                                        var fname = imageNamePre + "0.jpg";
                                        //deleteImage(fname);
                                               exec('wget --output-document /tmp/image.jpg \''+camUrl+'\'');
                                        var data = fs.readFileSync('/tmp/image.jpg');
                                        writeFile('vis.'+visInstance, imageFolder + fname, data, function (error) {
                                        if(logging) log('file '+fname+' neu gespeichert');
                                        });
                                    }
                                    
                                    // Funktionsaufruf 
                                    // "eingangstuer" wird hier den nummerierten Bildern vorangestellt
                                    saveImage("eingangstuer_", source_url_main_door);
                                    
                                    

                                    Danach bitte Rückinfo

                                    H 1 Reply Last reply Reply Quote 0
                                    • H
                                      heinzie @Peoples last edited by

                                      @Peoples

                                      Hallo @Peoples ,

                                      vielen Dank! Geht wieder wie verückt 🙂
                                      Das hätte ich ohne Deine Hilfe definitiv nicht hinbekommen.

                                      Gruß
                                      heinzie

                                      1 Reply Last reply Reply Quote 0
                                      • A
                                        AST64 last edited by AST64

                                        Danke ... das Script speichert nun wieder Bilder 🙂 Ich habe aber ein seltsames Verhalten.
                                        Bei mir wird mit einem Trigger das Script ausgelöst ... aber das Bild mit xxx_0.jpg ist erst sichtbar, wenn ich nochmal triggere.
                                        Der Namen stimmt allerdings im Ordner. Es ist so, als wäre das aktuellste Bild im "NICHTS" 😉 also im Cache oder so ...
                                        Ich merke das daran, weil meine CAM einen Zeitstempel erzeugt und ich immer nur das 2 aktuellste Bild gezeigt bekomme.
                                        Das Script habe ich 1:1 kopiert und nur den Ordner und den Namen geändert. Im Funktionsaufruf dann noch den Trigger rein.
                                        Kann das einer bestätigen/nachvollziehen?

                                        Danke Andreas

                                        Hier mal ein Bild ... wie ihr sehen könnt ist der erste Abschnitt ein Bild von 14.27 Uhr obwohl ich 14.30 Uhr ausgelöst habe.
                                        Der 2te Abschnitt ist von 14.31 Uhr und zeigt das Bild vom Trigger um 14.30 Uhr, der letzte Abschnitt zeigt wiederum das um 14.32 Uhr getriggerte Bild.
                                        Es ist das Bild vom Trigger um 14.31 Uhr!!!

                                        Bildschirmfoto 2019-11-26 um 14.35.59.png

                                        Peoples 1 Reply Last reply Reply Quote 0
                                        • Peoples
                                          Peoples @AST64 last edited by

                                          @AST64

                                          Den habe ich auch gehabt

                                          kommentiere mal das

                                          //    deleteImage(fname);
                                          

                                          aus Zeile 77 ist das bei mir hab das im Post oben schon geändert. Danach gings bei mir

                                          1 Reply Last reply Reply Quote 0
                                          • L
                                            LoxDUS last edited by

                                            @Peoples

                                            Du hast mir ja in einem anderen post den tipp gegeben das wie hier beschrieben zu machen. Danach funktionierte zumindest das Zugreifen auf die Bilder schon mal.... ABER

                                            Ich habe auch das Problem wie @AST64 das sich das ganze gespeichere um ein Bild verschiebt. D.h. erst beim wiederholten triggern kommt das eigentliche Bild richtig an.

                                            Das

                                            //deleteImage(fname);
                                            

                                            habe ich auch schon auskommentiert.... hilft aber nix. Wenn ich den ganzen Code so umbaue das ich das asynchrone lesen nutze mit

                                            fs.readFile(...);
                                            

                                            werden zwar die Bilder direkt richtig ins Filesystem geschrieben aber ich habe keinen Zugriff mit VIS mehr da drauf.
                                            Wenn ich die

                                             var data = fs.readFileSync('/tmp/image.jpg');
                                            

                                            Funktion nutze habe ich zwar mit VIS zugriff auf die Dateien aber die sind dann immer "verspätet" im System.

                                            Hast Du noch eine Idee was man machen kann damit zum richtigen Zeitpunkt die Daten ins filesystem gesdchrieben werden oder wie man ins Filesystem schriebt damit VIS auch darauf zugreifen kann?

                                            Mittlerweile steige ich da, was javascript im Hintergrund macht, aus und weiß nicht mehr weiter....

                                            Viele Grüße,

                                            Artur

                                            Peoples 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            726
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            javascript
                                            17
                                            117
                                            15141
                                            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