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

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Probleme mit js2fs adapter: Skripte werden doppelt gestartet und ausgeführt

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.0k

Probleme mit js2fs adapter: Skripte werden doppelt gestartet und ausgeführt

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
67 Beiträge 8 Kommentatoren 5.9k Aufrufe
  • Ä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.
  • apollon77A Offline
    apollon77A Offline
    apollon77
    schrieb am zuletzt editiert von
    #23

    @ruhr70:

    @apollon77:

    Ich hab per Atom.io ein scp Plugin womit ich die files auf den iobroker Host übertrage mach Änderungen.

    Sowas gibt’s für vscode auch `

    Und das funktioniert in beiden Richtungen? `

    Schau dir mal "ftp-sync" Extension zu VSCode an. Kann auch sftp … Das hatte ich genommen. Und ja geht in beide Richtungen

    @ruhr70:

    Die Skripte werden dann gestartet, in dem Moment, wo ich die Datei speichere (bzw. per SCP oder was auch immer, rüberschiebe)?

    Fürs Log muss ich dann wieder in den Admin wechseln? `

    du syncst das File (on save oder manuell, ich hab mich für manuell entschieden das man auch mal zwischendurch speichern kann). Das erkennt der js2fs Adapter und updatet es in ioBroker. Danach wird es automatisch neu gestartet.

    Ja zum Log musst Du ins Logfile schauen.

    @ruhr70:

    Skripte werden wahrscheinlich weiter im Admin gestoppt. `

    Jain, js2fs ist viel cooler (theoretisch … weil ich habs noch nicht verwendet).

    Du kannst bestimmte Kommentare in die erste Zeile schreiben um Skripte zu aktivieren, deaktivieren und so.

    Ich glaube mit

    //!!enable
    //!!disable
    

    Musst Du mal versuchen :-))

    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
    • AlCalzoneA Offline
      AlCalzoneA Offline
      AlCalzone
      Developer
      schrieb am zuletzt editiert von
      #24

      https://github.com/ioBroker/ioBroker.javascript/pull/75 sollte das Problem mit createState fixen. Hatte ein paar mögliche Überladungen vergessen.

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

      1 Antwort Letzte Antwort
      0
      • ruhr70R Offline
        ruhr70R Offline
        ruhr70
        schrieb am zuletzt editiert von
        #25

        super, teste ich heute Abend:-)

        Gesendet von iPhone mit Tapatalk

        Adapter: Fritzbox, Unify Circuit
        Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

        1 Antwort Letzte Antwort
        0
        • ruhr70R Offline
          ruhr70R Offline
          ruhr70
          schrieb am zuletzt editiert von
          #26

          @AlCalzone:

          https://github.com/ioBroker/ioBroker.javascript/pull/75 sollte das Problem mit createState fixen. Hatte ein paar mögliche Überladungen vergessen. `

          Sieht schon besser aus :-)

          Scheint aber noch etwas zu fehlen:

          327_2018-02-08_create_state.png

          Adapter: Fritzbox, Unify Circuit
          Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

          1 Antwort Letzte Antwort
          0
          • ruhr70R Offline
            ruhr70R Offline
            ruhr70
            schrieb am zuletzt editiert von
            #27

            @apollon77:

            du syncst das File (on save oder manuell, ich hab mich für manuell entschieden das man auch mal zwischendurch speichern kann). Das erkennt der js2fs Adapter und updatet es in ioBroker. Danach wird es automatisch neu gestartet. `

            Ich scheitere schon am Verständnis in VSCode bei den Verzeichnissen/Arbeitsbereichen.

            In der Beschreibung zu ftp-sync steht:

            ` > Ftp-sync: Init

            Initializes a default FTP-Sync configuration file in the .vscode directory. Options can be customised as follows: `

            Welches ist das .vscode Verzeichnis?

            Adapter: Fritzbox, Unify Circuit
            Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

            1 Antwort Letzte Antwort
            0
            • AlCalzoneA Offline
              AlCalzoneA Offline
              AlCalzone
              Developer
              schrieb am zuletzt editiert von
              #28

              @ruhr70:

              Welches ist das .vscode Verzeichnis? `
              Eigentlich ganz einfach. Ein Ordner in deinem Projektordner mit Namen ".vscode". Wird angelegt, wenn du irgendwelche projektbezogenen Einstellungen vornimmst.
              1097_vscode.png

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

              1 Antwort Letzte Antwort
              0
              • AlCalzoneA Offline
                AlCalzoneA Offline
                AlCalzone
                Developer
                schrieb am zuletzt editiert von
                #29

                @ruhr70:

                Scheint aber noch etwas zu fehlen: `
                In deinem common-Objekt fehlt read/write. Anscheinend vergibt ioBroker da noch etwas mehr als meine Definitionen :D
                1097_unbenannt.png

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

                1 Antwort Letzte Antwort
                0
                • ruhr70R Offline
                  ruhr70R Offline
                  ruhr70
                  schrieb am zuletzt editiert von
                  #30

                  @AlCalzone:

                  In deinem common-Objekt fehlt read/write. Anscheinend vergibt ioBroker da noch etwas mehr als meine Definitionen :D

                  Unbenannt.PNG `

                  Stimmt. Wenn ich read/write ergänzen ist die rote Markierung weg.

                  Ich dachte das sind keine Pflichtangaben und man gibt nur die Elemente in dem common-Objekt an, die man benötigt.

                  Die ganzen Skripte im Forum erhalten nur Teilmengen aus dem Objekt.

                  Adapter: Fritzbox, Unify Circuit
                  Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                  1 Antwort Letzte Antwort
                  0
                  • ruhr70R Offline
                    ruhr70R Offline
                    ruhr70
                    schrieb am zuletzt editiert von
                    #31

                    @AlCalzone:

                    Eigentlich ganz einfach. Ein Ordner in deinem Projektordner mit Namen ".vscode". Wird angelegt, wenn du irgendwelche projektbezogenen Einstellungen vornimmst. `

                    Danke, ich bin schon mal einen Schritt weiter :-)

                    Ich kämpfe aber noch. :? :mrgreen:

                    Was ich jetzt probiert habe:

                    • Ordner anlegen

                    • Ordner öffnen

                    • Einstellungen

                    • in Einstellungen auf Arbeitsbereicheinstellungen -> .vscode wird angelegt

                    327_2018-02-08_vscode.png

                    In .vscode enthalten ist die settings.json

                    Speichere ich mir jetzt noch einen Arbeitsbereich?

                    Es sieht eigentlich so aus, als ob es reicht, wenn ich den Ordner öffne.

                    Dann````
                    STRG+P: >Ftp-sync: Init

                    
                    Ich probier dann mal weiter :)
                    
                    Arbeitsbereich nötig/sinnvoll?
                    
                    Ich vermute mal, dass alle Dateien in dem Ordner liegen, in dem ich später die Skripte synchronisieren will, von der Synchronisation ausgeschlossen (ignore) werden müssen, wie z.B. die Datei "javascript.d.ts".
                    
                    [EDIT]
                    
                    Das Verzeichnis ****.vscode**** wird auch angelegt, wenn man ftp-sync initalisiert.
                    

                    STRG+P: >Ftp-sync: Init

                    Adapter: Fritzbox, Unify Circuit
                    Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                    1 Antwort Letzte Antwort
                    0
                    • AlCalzoneA Offline
                      AlCalzoneA Offline
                      AlCalzone
                      Developer
                      schrieb am zuletzt editiert von
                      #32

                      @ruhr70:

                      Speichere ich mir jetzt noch einen Arbeitsbereich?

                      Es sieht eigentlich so aus, als ob es reicht, wenn ich den Ordner öffne. `
                      Arbeitsbereiche sind ein recht neues Feature, ich öffne immer nur einzelne Ordner - dann funktioniert git auch ohne Probleme.

                      @ruhr70:

                      Ich dachte das sind keine Pflichtangaben und man gibt nur die Elemente in dem common-Objekt an, die man benötigt.

                      Die ganzen Skripte im Forum erhalten nur Teilmengen aus dem Objekt. `
                      => https://github.com/ioBroker/ioBroker.javascript/pull/77

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

                      1 Antwort Letzte Antwort
                      0
                      • ruhr70R Offline
                        ruhr70R Offline
                        ruhr70
                        schrieb am zuletzt editiert von
                        #33

                        @AlCalzone:

                        @ruhr70:

                        Ich dachte das sind keine Pflichtangaben und man gibt nur die Elemente in dem common-Objekt an, die man benötigt.

                        Die ganzen Skripte im Forum erhalten nur Teilmengen aus dem Objekt. => [https://github.com/ioBroker/ioBroker.javascript/pull/77](https://github.com/ioBroker/ioBroker.javascript/pull/77)

                        Danke! Probiere ich nachher und gebe eine Rückmeldung :-)

                        Adapter: Fritzbox, Unify Circuit
                        Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                        1 Antwort Letzte Antwort
                        0
                        • ruhr70R Offline
                          ruhr70R Offline
                          ruhr70
                          schrieb am zuletzt editiert von
                          #34

                          @AlCalzone:

                          @ruhr70:

                          Ich dachte das sind keine Pflichtangaben und man gibt nur die Elemente in dem common-Objekt an, die man benötigt.

                          Die ganzen Skripte im Forum erhalten nur Teilmengen aus dem Objekt. => [https://github.com/ioBroker/ioBroker.javascript/pull/77](https://github.com/ioBroker/ioBroker.javascript/pull/77)

                          Funktioniert! Danke!

                          Adapter: Fritzbox, Unify Circuit
                          Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                          1 Antwort Letzte Antwort
                          0
                          • ruhr70R Offline
                            ruhr70R Offline
                            ruhr70
                            schrieb am zuletzt editiert von
                            #35

                            @AlCalzone:

                            <== großer Fan von VSCode

                            Vor allem kann es mit https://github.com/ioBroker/ioBroker.javascript/blob/master/lib/javascript.d.ts Autovervollständigung und Typüberprüfung für die Funktionen der ioBroker-Schnittstelle, wenn du am Anfang deines Skripts diesen Kommentar einfügst:

                            /// <reference path="javascript.d.ts">
                            // @ts-check</reference>
                            ```` `  
                            

                            Hier bin ich auch noch etwas verwirrt.

                            Ich habe mich gefragt, wie der Kopf im Skript für Skripte in Unterordnern aussehen muss.

                            Wenn ich beide Zeilen in einem Skript in einem Unterordner reinschreibe wird die Datei "javascript.d.ts" angemeckert.

                            Ein:

                            /// 
                            

                            in einem Skript mit einem Unterordner eine Ebene tiefer funktioniert.

                            Dann habe ich testweise in allen Skripten nur noch den Teil

                            // @ts-check
                            

                            stehen lassen und alle Dateien gespeichert. Die Typprüfung funktionier damit in allen Skripten trotzdem. :?

                            Argh… brauche ich die erste Zeile in einem Skript, in allen Skripten, gar nicht, in Unterordnern (je nach Ebene) anders?

                            Adapter: Fritzbox, Unify Circuit
                            Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                            1 Antwort Letzte Antwort
                            0
                            • AlCalzoneA Offline
                              AlCalzoneA Offline
                              AlCalzone
                              Developer
                              schrieb am zuletzt editiert von
                              #36

                              @ruhr70:

                              Argh… brauche ich die erste Zeile in einem Skript, in allen Skripten, gar nicht, in Unterordnern (je nach Ebene) anders? `
                              Gerade mal probiert. Anscheinend muss nur eine Datei geöffnet sein, die die Referenz auf javascript.d.ts enthält, dann geht es in allen anderen auch.
                              1097_test1.png
                              1097_tst2.png

                              Damit es immer in allen dateien geht, brauchst du sowohl // @ts-check als auch ///

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

                              1 Antwort Letzte Antwort
                              0
                              • ruhr70R Offline
                                ruhr70R Offline
                                ruhr70
                                schrieb am zuletzt editiert von
                                #37

                                @AlCalzone:

                                @ruhr70:

                                Argh… brauche ich die erste Zeile in einem Skript, in allen Skripten, gar nicht, in Unterordnern (je nach Ebene) anders? `
                                Gerade mal probiert. Anscheinend muss nur eine Datei geöffnet sein, die die Referenz auf javascript.d.ts enthält, dann geht es in allen anderen auch.

                                Damit es immer in allen dateien geht, brauchst du sowohl // @ts-check als auch /// `

                                komischerweise funktioniert es gerade auch, ohne das "reference…" in irgendeiner Datei steht.

                                Vielleicht hat sich das VSCode ja gemerkt :lol:

                                Danke für die Rückmeldung.

                                Dann werde ich mir im Produktivsystem ein Skript anlegen, welches nur die beiden Zeilen enthält und in allen anderen Skripten // @ts-check ergänzen.

                                [EDIT]

                                Ups… das fette geöffnet überlesen.

                                Dann teste ich noch etwas. Eventuell muss nur die Datei selbst geöffnet sein.

                                [EDIT2]

                                ja. Wenn javascript.d.ts geöffnet ist, dann funktioniert es ohne den Referenzverweis.

                                Ist für mcih einfacher, als in allen Datein die richtigen ../../ zu pflegen.

                                Adapter: Fritzbox, Unify Circuit
                                Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                1 Antwort Letzte Antwort
                                0
                                • ruhr70R Offline
                                  ruhr70R Offline
                                  ruhr70
                                  schrieb am zuletzt editiert von
                                  #38

                                  @AlCalzone:

                                  Vor allem kann es mit https://github.com/ioBroker/ioBroker.javascript/blob/master/lib/javascript.d.ts Autovervollständigung und Typüberprüfung für die Funktionen der ioBroker-Schnittstelle, wenn du am Anfang deines Skripts diesen Kommentar einfügst:

                                  /// <reference path="javascript.d.ts">
                                  // @ts-check</reference>
                                  ```` `  
                                  

                                  ftp-sync funktioniert, Typcheck auch :-)

                                  Zur Typprüfung habe ich noch eine Frage.

                                  Was machst Du mit Zeilen, in denen Module nachgeladen werden?

                                  Wie:````
                                  const Co2Monitor = require('./co2-monitor');

                                  
                                  Hier bekomme ich einen Fehler. Kann man den verhindern?
                                   ![327_2018-02-10_typ-check.png](/assets/uploads/files/327_2018-02-10_typ-check.png) 
                                  
                                  Die globalen Funktionen, die bei mir verwendet werden, habe ich am Ende der Datei ****javascript.d.ts**** hinzugefügt:
                                  
                                  function sayit(text: string, vol: number?, instanz?: number): void;
                                  function isTimeInRange(strLower:string, strUpper:string): boolean;
                                  function arbeitstag(): boolean;
                                  function urlaubstag(): boolean;
                                  

                                  }

                                  
                                  Wahrscheinlicher ist es sinnvoll noch eine zweite Datei anzulegen?
                                  
                                  Hier muss ich mir dann noch ansehen, wie die aussehen muss und was ich aus der ****javascript.d.ts**** weglassen kann.
                                  
                                  Dann wird ein Fehler bemängelt, bei dem ich nicht nachvollziehen kann, warum:
                                   ![327_2018-02-10_false.png](/assets/uploads/files/327_2018-02-10_false.png) 
                                  
                                  Die beiden ****createState()**** sind doch inhaltlich gleich. Warum erfolgt bei dem letzten ****createState()**** die Fehlermeldung?

                                  Adapter: Fritzbox, Unify Circuit
                                  Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                  1 Antwort Letzte Antwort
                                  0
                                  • ruhr70R Offline
                                    ruhr70R Offline
                                    ruhr70
                                    schrieb am zuletzt editiert von
                                    #39

                                    @AlCalzone:

                                    Anscheinend vergibt ioBroker da noch etwas mehr als meine Definitionen :D `

                                    Bei der Typprüfung erhalte ich noch einen Fehler bei der Verarbeitung eines Objekts, welches die Funktion on() liefert:
                                    327_2018-02-10_id.png

                                    Mein Fehler?

                                    Oder muss die Datei zur Typprüfung noch angepasst werden?

                                    Adapter: Fritzbox, Unify Circuit
                                    Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                    1 Antwort Letzte Antwort
                                    0
                                    • AlCalzoneA Offline
                                      AlCalzoneA Offline
                                      AlCalzone
                                      Developer
                                      schrieb am zuletzt editiert von
                                      #40

                                      Schau ich mir später in Ruhe an. Die Module werden nicht bemängelt wenn du sie in deinem Entwicklungsordner per npm installierst. Wenn du zusätzlich „@types/modulname“ installierst, gibts dafür auch Hilfe.

                                      Gesendet von unterwegs

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

                                      1 Antwort Letzte Antwort
                                      0
                                      • AlCalzoneA Offline
                                        AlCalzoneA Offline
                                        AlCalzone
                                        Developer
                                        schrieb am zuletzt editiert von
                                        #41

                                        Ok hab doch noch ein bisschen Leerlauf.

                                        Deine eigenen Funktionen kannst du in einer eigenen .d.ts Datei deklarieren. Im einfachsten Fall reicht für jede Funktion ein „declare function(…): ...“

                                        Oder du machst es ähnlich wie ich mit declare global (aber dann musst du ein Modul wie „fs“ importieren)

                                        Dein zweites createState hat common.type state statt string. Das gibts glaube ich nicht, deswegen wird das Objekt nicht als Partial common erkannt.

                                        Das mit on() hat jemand anders nachgerüstet, das hab ich jetzt nicht im Kopf

                                        Gesendet von unterwegs

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

                                        1 Antwort Letzte Antwort
                                        0
                                        • R Offline
                                          R Offline
                                          robsdobs
                                          schrieb am zuletzt editiert von
                                          #42

                                          @ruhe70:Als was verwendest du den das in IOBroker. JavaScript oder Typescript?

                                          Bei Typescript brauchst du die Definition deiner globalen Funktion immer im Script. Oder, wenn es etwas anderes gibt: Ich suche auch noch nach einer besseren Methode.

                                          Das mit dem on hab ich zwar nachgerüstet, aber auch nicht im Kopf. Das sehe ich mir an.

                                          Das hatte ich anhand der verfügbaren Doku erstellt. Vielleicht fehlt noch was. - Bin hier auch nur Anfänger.

                                          Scripte: http://forum.iobroker.net/viewtopic.php?f=23&amp;t=2799&amp;p=119565#p119565,

                                          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

                                          360

                                          Online

                                          32.6k

                                          Benutzer

                                          82.0k

                                          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