Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

  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.2k

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

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

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

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascript
117 Beiträge 17 Kommentatoren 20.8k Aufrufe 24 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • liv-in-skyL liv-in-sky

    @apollon77 - bin etwas weiter und vielen dank für deine erklärung und die aufgewendete zeit

    habe jetzt mal ein ganz neues script gemacht

    writeFile('iqontrol.meta', '/htmltest.html', dataHelp, function (error) {
        console.log('file written');
    });
    readFile('iqontrol.meta', '/htmltest.html', function (error, data) {
        console.log("mein text:  ----:"+data.substring(0, 50));  
    });
    

    da funktioniert es

    setzte ich den code in eine existierende function in meinem script, kommen wieder die fehler (cannot invoke ab expression whose type lacks a call signature type boolean has no call signatur")

    erzeuge ich eine neue function mit dem code und rufe ich diese dann auf -> funktioniert es

    ich weiß/verstehe nicht - warum es in einer schon existierenden function - die ohne probleme läuft - nicht geht
    aber das ist soweit ok - hauptsache es läuft - zuminest werden die files jetzt im meta-ordner erzeugt - jetzt muss ich nur noch herausfinden, was ich in der iqontrol kachel angeben muss

    auf jeden fall gehöre ich jetzt nicht mehr zu den "system-vorbei-schauflern" - das ist schon mal was

    und da doch einige in zukunft das problem haben werden, kannst du ja (als neg. beispiel) auf diesen thread verweisen :-)

    vielen dank

    apollon77A Offline
    apollon77A Offline
    apollon77
    schrieb am zuletzt editiert von
    #9

    @liv-in-sky Super das höre ich gern. Ich habe auch @AlCalzone mal gebeten zu schauen. Vllt hat er eine Idee.
    Komisch ist es allemal.

    Ich kann mir nur vorstellen das irgendwie der Sandbox-Ansatz für deine Code-Struktur ausgehebelt wird. Kannst Du mal einen Minimal-Skript bauen wo es nicht tut und hie rposten das man vergleichen kann?
    Danke!

    an sich sollte es per /iqontrol.meta/ erreichbar sein per web-adapter (alternativ lade per iqontrol Admin was hoch, bau es in die Visu ein und schau dir den Pfad an :-)

    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 Antwort Letzte Antwort
    1
    • apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #10

      PS: Der vorteil es offiziell zu schreiben ist das es auch im Backup landet :-)

      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 Antwort Letzte Antwort
      0
      • liv-in-skyL liv-in-sky

        @apollon77 sagte in wie writeFile() in js script nutzen:

        "iqontrol.meta"

        writeFile( "iqontrol.meta",  "/htmlclients.html", dataHelp, function(callback) {log("ee")});
        

        im scripteditor ist alles unterkringelt (egal was in den klammern bei fileWrite() steht) - fährt man darüber steht dann:
        cannot invoke ab expression whose type lacks a call signature type boolean has no call signatur" -starte ich das script trotzdem kommt sowas wie

        			
        javascript.2	2019-10-05 21:35:15.353	error	at Timer.processTimers (timers.js:223:10)
        javascript.2	2019-10-05 21:35:15.353	error	at listOnTimeout (timers.js:263:5)
        javascript.2	2019-10-05 21:35:15.353	error	at tryOnTimeout (timers.js:300:5)
        javascript.2	2019-10-05 21:35:15.353	error	at ontimeout (timers.js:438:13)
        javascript.2	2019-10-05 21:35:15.353	error	at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1888:34)
        javascript.2	2019-10-05 21:35:15.353	error	at Object.<anonymous> (script.js.Armin_Schalter.ALLERLEI.aaaaatestunifiInst2:769:5)
        javascript.2	2019-10-05 21:35:15.352	error	Error in callback: TypeError: writeFile is not a function
        javascript.2	2019-10-05 21:35:15.352	info	script.js.Armin_Schalter.ALLERLEI.aaaaatestunifiInst2: anfang
        javascript.2	2019-10-05 21:34:55.277	error	at Timer.processTimers (timers.js:223:10)
        javascript.2	2019-10-05 21:34:55.277	error	at listOnTimeout (timers.js:263:5)
        javascript.2	2019-10-05 21:34:55.277	error	at tryOnTimeout (timers.js:300:5)
        javascript.2	2019-10-05 21:34:55.277	error	at ontimeout (timers.js:438:13)
        javascript.2	2019-10-05 21:34:55.277	error	at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1888:34)
        javascript.2	2019-10-05 21:34:55.277	error	at Object.<anonymous> (script.js.Armin_Schalter.ALLERLEI.aaaaatestunifiInst2:769:5)
        javascript.2	2019-10-05 21:34:55.277	error	Error in callback: TypeError: writeFile is not a function
        

        Image 1.png

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

        @liv-in-sky sagte in wie writeFile() in js script nutzen:

        type boolean has no call signatur

        Magst du mir mal den gesamten Code zeigen? Klingt für mich nach shadowing einer Variablen

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

        liv-in-skyL 1 Antwort Letzte Antwort
        0
        • AlCalzoneA AlCalzone

          @liv-in-sky sagte in wie writeFile() in js script nutzen:

          type boolean has no call signatur

          Magst du mir mal den gesamten Code zeigen? Klingt für mich nach shadowing einer Variablen

          liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          schrieb am zuletzt editiert von
          #12

          @AlCalzone aber klar - bin doch froh wenn jmd hilft

          scriptunifi- iqontrol-poblem.txt

          momentan geht es - es geht um zeile 769 - die geht - da eine eigene function (paar zeilen drunter ) aufgerufen wird

          die auskommentierten zeilen 771-773 bringen den fehler

          scriptunifi- iqontrol-poblem.txt

          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

          AlCalzoneA 1 Antwort Letzte Antwort
          0
          • apollon77A apollon77

            @liv-in-sky Super das höre ich gern. Ich habe auch @AlCalzone mal gebeten zu schauen. Vllt hat er eine Idee.
            Komisch ist es allemal.

            Ich kann mir nur vorstellen das irgendwie der Sandbox-Ansatz für deine Code-Struktur ausgehebelt wird. Kannst Du mal einen Minimal-Skript bauen wo es nicht tut und hie rposten das man vergleichen kann?
            Danke!

            an sich sollte es per /iqontrol.meta/ erreichbar sein per web-adapter (alternativ lade per iqontrol Admin was hoch, bau es in die Visu ein und schau dir den Pfad an :-)

            liv-in-skyL Offline
            liv-in-skyL Offline
            liv-in-sky
            schrieb am zuletzt editiert von liv-in-sky
            #13

            @apollon77 sagte in wie writeFile() in js script nutzen:

            @liv-in-sky Super das höre ich gern. Ich habe auch @AlCalzone mal gebeten zu schauen. Vllt hat er eine Idee.
            Komisch ist es allemal.

            Ich kann mir nur vorstellen das irgendwie der Sandbox-Ansatz für deine Code-Struktur ausgehebelt wird. Kannst Du mal einen Minimal-Skript bauen wo es nicht tut und hie rposten das man vergleichen kann?
            Danke!

            an sich sollte es per /iqontrol.meta/ erreichbar sein per web-adapter (alternativ lade per iqontrol Admin was hoch, bau es in die Visu ein und schau dir den Pfad an :-)

            danke - das mit dem pfad /iqontrol.meta/file.html in der popup kachel als src funktioniert bei mir mit alten js-controller - @coyote wird dann sicher noch den neuen controller testen

            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 Antwort Letzte Antwort
            0
            • liv-in-skyL liv-in-sky

              @AlCalzone aber klar - bin doch froh wenn jmd hilft

              scriptunifi- iqontrol-poblem.txt

              momentan geht es - es geht um zeile 769 - die geht - da eine eigene function (paar zeilen drunter ) aufgerufen wird

              die auskommentierten zeilen 771-773 bringen den fehler

              scriptunifi- iqontrol-poblem.txt

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

              @liv-in-sky Mein Instinkt war richtig:
              78118757-ebc5-4ff8-8c1f-5fc4d974b96f-grafik.png

              In Zukunft: Rechtsklick -> Gehe zu Definition zeigt dir wo eine Variable definiert ist:
              494fdd4f-edb9-4a8a-ae9b-5bf1e52db65b-grafik.png

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

              liv-in-skyL 1 Antwort Letzte Antwort
              1
              • AlCalzoneA AlCalzone

                @liv-in-sky Mein Instinkt war richtig:
                78118757-ebc5-4ff8-8c1f-5fc4d974b96f-grafik.png

                In Zukunft: Rechtsklick -> Gehe zu Definition zeigt dir wo eine Variable definiert ist:
                494fdd4f-edb9-4a8a-ae9b-5bf1e52db65b-grafik.png

                liv-in-skyL Offline
                liv-in-skyL Offline
                liv-in-sky
                schrieb am zuletzt editiert von
                #15

                @AlCalzone super ich danke dir - doppelt genutzt - wie doof

                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 Antwort Letzte Antwort
                0
                • coyoteC Offline
                  coyoteC Offline
                  coyote
                  Most Active
                  schrieb am zuletzt editiert von
                  #16

                  @liv-in-sky ich probiere nachher gerne nochmal, aber gestern Abend hat dass so nicht funktioniert, ich hatte die HTML Datei einfach zum Test mal nach iqontrol.meta kopiert und dann versucht über die angepasste src darauf zuzugreifen, ging aber leider nicht

                  liv-in-skyL 1 Antwort Letzte Antwort
                  0
                  • coyoteC coyote

                    @liv-in-sky ich probiere nachher gerne nochmal, aber gestern Abend hat dass so nicht funktioniert, ich hatte die HTML Datei einfach zum Test mal nach iqontrol.meta kopiert und dann versucht über die angepasste src darauf zuzugreifen, ging aber leider nicht

                    liv-in-skyL Offline
                    liv-in-skyL Offline
                    liv-in-sky
                    schrieb am zuletzt editiert von liv-in-sky
                    #17

                    @coyote

                    nur rein kopieren wird nicht funktionieren, da dann redis nix weiß von der datei (das funktioniert nur ohne redis(files) - wenn dann nur mit test- script vom anderen thread

                    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 Antwort Letzte Antwort
                    0
                    • s.bormannS Offline
                      s.bormannS Offline
                      s.bormann
                      Most Active
                      schrieb am zuletzt editiert von
                      #18

                      Hi,

                      ich glaube, alles, was ich hier im Moment beisteuern könnte, wurde bereits gesagt. Mit diesem ganzen Datei-Kram war/bin ich auch total überfordert und habe mit dem try'n'error-Prinzip so lange getüftelt, bis es lief. Mir hat hier einfach ein "best practice" oder ein "how to" gefehlt. Die Nachteile sieht man jetzt, wo der 2.0er-Controller etwas strikter ist. Aber egal, so nach und nach wird das ganze immer besser und wird auch mit dem 2.0er irgendwann fehlerfrei laufen.

                      Da ich aber z.Zt. (noch) kein Test-System mit 2.0er-Controller habe, kann ich aktuell leider an dieser Stelle nicht weiter helfen, da mir selbst die Ahnung fehlt. Habe mir den Thread aber hier mal gespeichert - das mit dem writeFile u.s.w. werde ich ja dann - wenn ich es richtig verstanden habe - auch noch bei mir entsprechend anpassen müssen, oder?

                      VG

                      1 Antwort Letzte Antwort
                      0
                      • liv-in-skyL Offline
                        liv-in-skyL Offline
                        liv-in-sky
                        schrieb am zuletzt editiert von
                        #19

                        @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

                        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 Antwort Letzte Antwort
                        0
                        • 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
                          schrieb am zuletzt editiert von
                          #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 Antwort Letzte Antwort
                          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
                            schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                            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
                              schrieb am zuletzt editiert von
                              #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 Antwort Letzte Antwort
                              0
                              • apollon77A apollon77

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

                                liv-in-skyL Offline
                                liv-in-skyL Offline
                                liv-in-sky
                                schrieb am zuletzt editiert von
                                #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 Antwort Letzte Antwort
                                0
                                • apollon77A Offline
                                  apollon77A Offline
                                  apollon77
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  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
                                    schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                    0
                                    • ChaotC Offline
                                      ChaotC Offline
                                      Chaot
                                      schrieb am zuletzt editiert von
                                      #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 Antwort Letzte Antwort
                                      0
                                      • apollon77A Offline
                                        apollon77A Offline
                                        apollon77
                                        schrieb am zuletzt editiert von
                                        #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 Antwort Letzte Antwort
                                        0
                                        • ChaotC Offline
                                          ChaotC Offline
                                          Chaot
                                          schrieb am zuletzt editiert von
                                          #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 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          497

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe