Skip to content
  • Home
  • 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
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. gelöst-wie writeFile() in js script nutzen

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    16
    1
    1.9k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    916

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

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

Scheduled Pinned Locked Moved JavaScript
javascript
117 Posts 17 Posters 22.5k 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.
  • apollon77A apollon77

    @liv-in-sky Was für einen Fehler bekommst Du denn?

    Ich würde es ggf im iqontrol meta Bereich ablegen ... da landen alle Userspezifischen Files. Also quasi "iqontrol.meta" als ersten Parameter.

    Wenn das tut bitte mach mal Issue auf das Doku falsch bzw code im JS Adapter auch ;-)

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

    @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

    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 AlCalzoneA 2 Replies Last reply
    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

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

      @liv-in-sky Sehr Strange ... Die Funktion ist da im Code ... keine Ahnung warum er meckert. Muss BF schauen.Leg bitte Issue bei Javascript 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 Reply Last reply
      0
      • apollon77A apollon77

        @liv-in-sky Sehr Strange ... Die Funktion ist da im Code ... keine Ahnung warum er meckert. Muss BF schauen.Leg bitte Issue bei Javascript an

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

        @apollon77 ich werde gerne ein issue anlegen

        aber eine frage hätte ich noch um besser zu verstehen - dieses writeFile kommt eigentlich fast garnicht im forum vor - es wird eigendlich immer mit fs.writfile gearbeitet - ich vermute mal, dass dies alles erst wichtig wird, weil mit dem controllerv2 redis auch die files verwaltet - das ging ja bis da :-(

        wie muss ich mir das mit der redis datenbank vorstellen ?
        1- werden die inhalte der dateien in die datenbank geschrieben als ein datensatz oder
        2- wird nur ein neuer datensatz mit einem link zu dieser datei erzeugt und die datei irgendwo anders (system intern) hinkopiert

        im 2ten fall muss doch auch beim lesen des files mit readFile gearbeitet werden ?

        @s-bormann - wie greifst du in der popup kachel auf die files zu ? nutzt du die readFile() funktion ? die kachel ist so definiert

        Image 1.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 Reply Last reply
        0
        • liv-in-skyL liv-in-sky

          @apollon77 ich werde gerne ein issue anlegen

          aber eine frage hätte ich noch um besser zu verstehen - dieses writeFile kommt eigentlich fast garnicht im forum vor - es wird eigendlich immer mit fs.writfile gearbeitet - ich vermute mal, dass dies alles erst wichtig wird, weil mit dem controllerv2 redis auch die files verwaltet - das ging ja bis da :-(

          wie muss ich mir das mit der redis datenbank vorstellen ?
          1- werden die inhalte der dateien in die datenbank geschrieben als ein datensatz oder
          2- wird nur ein neuer datensatz mit einem link zu dieser datei erzeugt und die datei irgendwo anders (system intern) hinkopiert

          im 2ten fall muss doch auch beim lesen des files mit readFile gearbeitet werden ?

          @s-bormann - wie greifst du in der popup kachel auf die files zu ? nutzt du die readFile() funktion ? die kachel ist so definiert

          Image 1.png

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

          @liv-in-sky Aaaaalso. Der Fehler liegt meiner Meinung nach irgendwie im js-Adapter. Generell funktioniert alles.

          iqontrol nutzt für die Anzeige im Admin die Funktion "readDir" via socket.io. Im "Live Frontend" wird das ganze vom web-Adapter geregelt, der ganz einfach per Pfad erlaubt auf alles im Storage zuzugreifen (unter /iqontrol liegen die Files vom Adapter und in iqontrol.meta liegen soweit ich weiss die Userfiles).

          Und zu Deiner ersten Frage:
          Das man Files nun optional auch im Redis ablegen kann (und ja, da landen dann die kompletten File-Inhalte also "binär Daten im Redis, der kann das und Objects/Files in Redis ist eine Vorstufe zu High Availabiltiy Themen für die Zukunft) ist nur ein Randthema. Im js-controller haben wir die State und Objects-Datenbanken komplett neu geschrieben.

          In dem Zuge ist der Code jetzt aber so ausgerichtet das auch bei nutzung von "file" als DB-Typ hier das Redis-Protokoll für die Kommunikation genutzt wird. Bei einer "file" DB simulieren wir quasi einen Redis auf der Datenebene und alle Funktionen dahinter sind entsprechend gekapselt. Dadurch haben sich ein paar Dinge geändert wie im Detail auf die Daten im "IoBroker-File-Storage" zugegriffen wird. Früher war dies einfach ein Filesystem-Zugriff, jetzt ist das etwas mehr weggekapselt. Wir haben auch aus Sicherheitsüberlegungen das ganze etwas besser abgesichert - keiner der beteiligten Entwickler ist von der Kreativität ausgegangen das hier massiv Dateien an den "Regeln" vorbei eingeschleust werden ;-)) Genau diese Themen fallen jetzt auf.

          Alle Lösungen mit "fs.write" gehen bei einem Single-Host System gut. Schon bei Master/Slave muss man darauf achten welche der Adapter wo laufen damit das alles zusammenspielt. Weiter gedacht für ein High Availablity System (sei es nur Failover System oder eine Art Cluster wo Adapter - ausser die mit lokalen Schnittstellenabhängigkeiten - quasi überall laufen könnten) ist es damit vorbei.

          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 Aaaaalso. Der Fehler liegt meiner Meinung nach irgendwie im js-Adapter. Generell funktioniert alles.

            iqontrol nutzt für die Anzeige im Admin die Funktion "readDir" via socket.io. Im "Live Frontend" wird das ganze vom web-Adapter geregelt, der ganz einfach per Pfad erlaubt auf alles im Storage zuzugreifen (unter /iqontrol liegen die Files vom Adapter und in iqontrol.meta liegen soweit ich weiss die Userfiles).

            Und zu Deiner ersten Frage:
            Das man Files nun optional auch im Redis ablegen kann (und ja, da landen dann die kompletten File-Inhalte also "binär Daten im Redis, der kann das und Objects/Files in Redis ist eine Vorstufe zu High Availabiltiy Themen für die Zukunft) ist nur ein Randthema. Im js-controller haben wir die State und Objects-Datenbanken komplett neu geschrieben.

            In dem Zuge ist der Code jetzt aber so ausgerichtet das auch bei nutzung von "file" als DB-Typ hier das Redis-Protokoll für die Kommunikation genutzt wird. Bei einer "file" DB simulieren wir quasi einen Redis auf der Datenebene und alle Funktionen dahinter sind entsprechend gekapselt. Dadurch haben sich ein paar Dinge geändert wie im Detail auf die Daten im "IoBroker-File-Storage" zugegriffen wird. Früher war dies einfach ein Filesystem-Zugriff, jetzt ist das etwas mehr weggekapselt. Wir haben auch aus Sicherheitsüberlegungen das ganze etwas besser abgesichert - keiner der beteiligten Entwickler ist von der Kreativität ausgegangen das hier massiv Dateien an den "Regeln" vorbei eingeschleust werden ;-)) Genau diese Themen fallen jetzt auf.

            Alle Lösungen mit "fs.write" gehen bei einem Single-Host System gut. Schon bei Master/Slave muss man darauf achten welche der Adapter wo laufen damit das alles zusammenspielt. Weiter gedacht für ein High Availablity System (sei es nur Failover System oder eine Art Cluster wo Adapter - ausser die mit lokalen Schnittstellenabhängigkeiten - quasi überall laufen könnten) ist es damit vorbei.

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

            @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

            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 - 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
              wrote on last edited by
              #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 Reply Last reply
              1
              • apollon77A Offline
                apollon77A Offline
                apollon77
                wrote on last edited by
                #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 Reply Last reply
                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
                  wrote on last edited by
                  #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 Reply Last reply
                  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
                    wrote on last edited by
                    #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 Reply Last reply
                    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
                      wrote on last edited by 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 Reply Last reply
                      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
                        wrote on last edited by
                        #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 Reply Last reply
                        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
                          wrote on last edited by
                          #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 Reply Last reply
                          0
                          • coyoteC Offline
                            coyoteC Offline
                            coyote
                            Most Active
                            wrote on last edited by
                            #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 Reply Last reply
                            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
                              wrote on last edited by 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 Reply Last reply
                              0
                              • s.bormannS Offline
                                s.bormannS Offline
                                s.bormann
                                Most Active
                                wrote on last edited by
                                #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 Reply Last reply
                                0
                                • liv-in-skyL Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  wrote on last edited by
                                  #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 Reply Last reply
                                  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
                                    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
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          301

                                          Online

                                          32.6k

                                          Users

                                          82.2k

                                          Topics

                                          1.3m

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

                                          • Don't have an account? Register

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