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. Entwicklung
  4. Verbesserungsvorschläge ioBroker

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    17
    1
    524

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

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

Verbesserungsvorschläge ioBroker

Scheduled Pinned Locked Moved Entwicklung
verbesserungoptimierungiobrokeradmin adapterjavascript adapter
22 Posts 8 Posters 2.7k Views 7 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.
  • A Offline
    A Offline
    aleks-83
    wrote on last edited by aleks-83
    #7

    Github issues erstellt:

    Suggestion: Check syntax when datapoints are changed/moved/deleted. #416

    Exclude adapters from "upgrade all adapters" #452

    = Dell Optiplex Micro - 10GB RAM - 200GB SSD - Debian VM =
    = Node.js v20.19.6 = NPM 10.8.2 = JS Controller 7.0.7 =

    Ubiquiti UAP-AC-LR - UAP-AC-Lite - Synology DS716+II - Fritz!Box 7490
    Glasfaser 400

    1 Reply Last reply
    0
    • paul53P paul53

      @Jan1 sagte in:

      somit könnte man das eben ach grafisch aufhübschen.

      Im Log oder welche Vorstellungen existieren ?

      J Offline
      J Offline
      Jan1
      wrote on last edited by
      #8

      @paul53
      So wie es @aleks-83 geschrieben hat. Da er doch das selbe meint wie ich. Log auswerten und eine grafische Anzeige die die Farbe wechselt und eventuell auch gleich noch die Herkunft des Fehler meldet.

      1 Reply Last reply
      0
      • A aleks-83

        So war das nicht ganz gemeint.

        Wenn es im Log auftaucht sehe ich es ja auch irgendwann.
        Aber "irgendwann" ist eben das Problem.
        Ich wüsste es gerne sofort.

        Also sobald man einen Datenpunkt verschiebt/ändert/löscht, könnte der JS Adapter einen Trigger zur Syntaxprüfung bekommen und umgehend grafisch oder auch im Log mitteilen das ein DP vermisst wird.
        Im JS Adapter selbst könnte man dann das Skript farblich markieren.

        AlCalzoneA Offline
        AlCalzoneA Offline
        AlCalzone
        Developer
        wrote on last edited by
        #9

        @aleks-83 Wie ich auch auf Github geschrieben habe, eine Referenz auf einen nicht vorhandenen Datenpunkt zu erkennen ist alles andere als trivial. Der Code selbst hat nämlich noch valide Syntax (im Skript ist es einfach nur eine Zeichenkette") - ein nicht existenter DP wird erst bei der Ausführung erkannt.

        Was ggf. gehen würde: Im JS-Controller den Fehlern für "State/Object existiert nicht" einen bestimmten Fehler-Code zuweisen und im Skript-Adapter darauf reagieren, wenn dieser Code aufgetreten ist, z.B. durch Markieren des Skriptes als fehlerhaft. Aber auch das wird erst passieren, wenn der Fehler auftritt.

        /cc @apollon77 @Bluefox

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

        1 Reply Last reply
        0
        • sigi234S Online
          sigi234S Online
          sigi234
          Forum Testing Most Active
          wrote on last edited by
          #10

          https://forum.iobroker.net/topic/25846/script-info-über-datenpunkte-sammeln

          Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
          Immer Daten sichern!

          paul53P 1 Reply Last reply
          0
          • sigi234S sigi234

            https://forum.iobroker.net/topic/25846/script-info-über-datenpunkte-sammeln

            paul53P Offline
            paul53P Offline
            paul53
            wrote on last edited by
            #11

            @sigi234
            Dieses Skript findet keine gelöschten Datenpunkte.

            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

            sigi234S 1 Reply Last reply
            0
            • paul53P paul53

              @sigi234
              Dieses Skript findet keine gelöschten Datenpunkte.

              sigi234S Online
              sigi234S Online
              sigi234
              Forum Testing Most Active
              wrote on last edited by
              #12

              @paul53 sagte in Verbesserungsvorschläge ioBroker:

              Dieses Skript findet keine gelöschten Datenpunkte.

              Kann man das einbauen?

              Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
              Immer Daten sichern!

              paul53P liv-in-skyL 2 Replies Last reply
              0
              • sigi234S sigi234

                @paul53 sagte in Verbesserungsvorschläge ioBroker:

                Dieses Skript findet keine gelöschten Datenpunkte.

                Kann man das einbauen?

                paul53P Offline
                paul53P Offline
                paul53
                wrote on last edited by
                #13

                @sigi234 sagte:

                Kann man das einbauen?

                Nein, was weg ist, kann nachträglich nicht mehr (per $Selector) gefunden werden.

                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                1 Reply Last reply
                0
                • sigi234S sigi234

                  @paul53 sagte in Verbesserungsvorschläge ioBroker:

                  Dieses Skript findet keine gelöschten Datenpunkte.

                  Kann man das einbauen?

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

                  @aleks-83
                  dafür (fehlende datenpunkte in scripts) könnte man doch das script von mic verwenden und nur auf solche fehler filter - anschliessend in der vis ein widget mit diesen fehlern und eine mail oder telegram - dann ist 's erledigt

                  https://forum.iobroker.net/topic/13971/vorlage-js-log-datei-aufbereiten-für-vis/210

                  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

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

                    @aleks-83
                    dafür (fehlende datenpunkte in scripts) könnte man doch das script von mic verwenden und nur auf solche fehler filter - anschliessend in der vis ein widget mit diesen fehlern und eine mail oder telegram - dann ist 's erledigt

                    https://forum.iobroker.net/topic/13971/vorlage-js-log-datei-aufbereiten-für-vis/210

                    A Offline
                    A Offline
                    aleks-83
                    wrote on last edited by aleks-83
                    #15

                    @liv-in-sky
                    So erspart man sich den Blick ins log, aber der Fehler muss trotzdem erst auftreten um von der "Log-Analyse" gefunden zu werden.
                    Das ist ja genau das wo mein Gedanke ansetzt: Ein Skript was gerade nicht läuft oder auf den Datenpunkt zugreift, meldet keinen fehlenden Datenpunkt.

                    Das Skript nutze ich bereits um mein (bereinigtes) Log auf der vis zu zeigen.

                    = Dell Optiplex Micro - 10GB RAM - 200GB SSD - Debian VM =
                    = Node.js v20.19.6 = NPM 10.8.2 = JS Controller 7.0.7 =

                    Ubiquiti UAP-AC-LR - UAP-AC-Lite - Synology DS716+II - Fritz!Box 7490
                    Glasfaser 400

                    AlCalzoneA 1 Reply Last reply
                    0
                    • A aleks-83

                      @liv-in-sky
                      So erspart man sich den Blick ins log, aber der Fehler muss trotzdem erst auftreten um von der "Log-Analyse" gefunden zu werden.
                      Das ist ja genau das wo mein Gedanke ansetzt: Ein Skript was gerade nicht läuft oder auf den Datenpunkt zugreift, meldet keinen fehlenden Datenpunkt.

                      Das Skript nutze ich bereits um mein (bereinigtes) Log auf der vis zu zeigen.

                      AlCalzoneA Offline
                      AlCalzoneA Offline
                      AlCalzone
                      Developer
                      wrote on last edited by AlCalzone
                      #16

                      @aleks-83 Um fehlende Datenpunkt zu finden, müsste die Check-Logik den Skript-Code verstehen, d.h. sie müsste wissen, welche Variablen oder Literale einen Datenpunkt referenzieren. Das kann recht schnell beliebig kompliziert werden:

                      const wasistdas = "adapter.0.dpname";
                      
                      // irgendwo ganz anders z.B. in einem Callback:
                      const einwert = getState(wasistdas).val;
                      

                      Allein hier müsste die Logik schon verstehen, dass...
                      ... getState Datenpunkte liest
                      ... wasistdas die ID des Datenpunkts darstellt
                      ... wasistdas eine Konstante ist
                      ... wo diese definiert ist
                      ... welchen Wert diese hat
                      um überhaupt prüfen zu können, ob der DP existiert.

                      Noch ein paar kleine Änderungen und die Prüfung ist quasi unmöglich zu realisieren:

                      let namespace = "adapter.0";
                      const dpname = "wasistdas";
                      
                      setTimeout(() => namespace = "anderer-adapter.1", 1000);
                      
                      // wird irgendwann ausgeführt, z.B. als Reaktion auf einen anderen DP:
                      const einwert = getState(namespace + "." + "dpname").val;
                      

                      Jetzt ist nicht nur die Frage, welchen Wert namespace hat, sondern auch wann es welchen Wert hat.

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

                      1 Reply Last reply
                      1
                      • A Offline
                        A Offline
                        aleks-83
                        wrote on last edited by aleks-83
                        #17

                        OK.
                        Den Code verstehe ich nicht, aber ich weiß was du meinst.
                        Ich spreche aber auch erst mal nur von Datenpunkten die direkt abgesprochen werden.
                        Wenn sie erst mal in ne Variable verpackt sind, wird es schwierig, das glaube ich...

                        Im JavaScript Adapter gibt es aber doch die Möglichkeit, Datenpunkte auf Vorhandensein zu prüfen, richtig?
                        Ich arbeite nur mit Klicki-Bunti Blockly und da finde ich sowas nicht.

                        Der JS Adapter könnte ja dann, jedes Mal wenn ich ein Skript anlege, die darin verwendeten Datenpunkte in einem globalen Skript, was zyklisch ausgeführt wird, auf Vorhandensein prüfen.
                        Wenn das nicht automatisch geht, müsste man das von Hand machen.
                        Dann bleibe mein Vorschlag immer noch ein Vorschlag für ein gutes Skript!?

                        So mein "Nichtprogrammierer"-Gedanke :grimacing:

                        = Dell Optiplex Micro - 10GB RAM - 200GB SSD - Debian VM =
                        = Node.js v20.19.6 = NPM 10.8.2 = JS Controller 7.0.7 =

                        Ubiquiti UAP-AC-LR - UAP-AC-Lite - Synology DS716+II - Fritz!Box 7490
                        Glasfaser 400

                        AlCalzoneA 1 Reply Last reply
                        0
                        • A aleks-83

                          OK.
                          Den Code verstehe ich nicht, aber ich weiß was du meinst.
                          Ich spreche aber auch erst mal nur von Datenpunkten die direkt abgesprochen werden.
                          Wenn sie erst mal in ne Variable verpackt sind, wird es schwierig, das glaube ich...

                          Im JavaScript Adapter gibt es aber doch die Möglichkeit, Datenpunkte auf Vorhandensein zu prüfen, richtig?
                          Ich arbeite nur mit Klicki-Bunti Blockly und da finde ich sowas nicht.

                          Der JS Adapter könnte ja dann, jedes Mal wenn ich ein Skript anlege, die darin verwendeten Datenpunkte in einem globalen Skript, was zyklisch ausgeführt wird, auf Vorhandensein prüfen.
                          Wenn das nicht automatisch geht, müsste man das von Hand machen.
                          Dann bleibe mein Vorschlag immer noch ein Vorschlag für ein gutes Skript!?

                          So mein "Nichtprogrammierer"-Gedanke :grimacing:

                          AlCalzoneA Offline
                          AlCalzoneA Offline
                          AlCalzone
                          Developer
                          wrote on last edited by
                          #18

                          @aleks-83 sagte in Verbesserungsvorschläge ioBroker:

                          Im JavaScript Adapter gibt es aber doch die Möglichkeit, Datenpunkte auf Vorhandensein zu prüfen, richtig?

                          Nein.

                          Dann bleibe mein Vorschlag immer noch ein Vorschlag für ein gutes Skript!?

                          Wie ich schon schrieb (ich glaube im Issue), das wäre durchaus sinnvoll, aber dann musst du dem Skript immer noch sagen, welche Datenpunkte es prüfen soll. Daher ist IMO die sinnvollste (und am ehesten machbare) Variante:

                          1. Definiere alle Datenpunkt-IDs als erstes im Skript
                          2. Prüfe beim Skriptstart die Existenz aller nötigen Datenpunkte
                          3. Wenn alle existieren, führe die restliche Skriptlogik aus.

                          Punkt 2 könnte man auch in Form eines Prüfskripts tun, welches sich den Quellcode der übrigen Skripte holt, die zu Beginn definierten DPs ausliest und prüft, ob diese existieren. Das setzt aber eine gewisse Disziplin und Konsistenz beim Definieren der DPs in den übrigen Skripten voraus.
                          Dieses Prüfskript sollte unter keinen Umständen global sein, da es ja sonst in jedes andere Skript eingefügt wird.

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

                          1 Reply Last reply
                          0
                          • A Offline
                            A Offline
                            aleks-83
                            wrote on last edited by
                            #19

                            Hmmm. Irgendwie verzwickt...

                            = Dell Optiplex Micro - 10GB RAM - 200GB SSD - Debian VM =
                            = Node.js v20.19.6 = NPM 10.8.2 = JS Controller 7.0.7 =

                            Ubiquiti UAP-AC-LR - UAP-AC-Lite - Synology DS716+II - Fritz!Box 7490
                            Glasfaser 400

                            1 Reply Last reply
                            0
                            • OstfrieseUnterwegsO Offline
                              OstfrieseUnterwegsO Offline
                              OstfrieseUnterwegs
                              wrote on last edited by
                              #20

                              Ist das nicht ein bisschen zu kurz gesprungen. Wenn mir z.B. ein Tür/Fenster-Kontakt abraucht und ich ihn durch einen neuen ersetze, dann muss ich z.Zt endlost suchen: Scripte, Vis, Szenen, Diagramme, sogar im shuttercontrol Adapter... Mag ja sein, dass es irgendwelche Dokumentations Asse gibt, die das alles nachgehalten haben, aber für mich ist das eine extrem nervige Sache.
                              Was helfen würde, wäre eine 'where used' Funktion bei den Objekten. Vlt ein extra Reiter im 'Edit Fenster'.
                              Ich weiss nicht genau, was die neue Alias Funktion in dem Zusammenhang bietet, vlt ist das die Lösung?

                              AlCalzoneA 1 Reply Last reply
                              0
                              • OstfrieseUnterwegsO OstfrieseUnterwegs

                                Ist das nicht ein bisschen zu kurz gesprungen. Wenn mir z.B. ein Tür/Fenster-Kontakt abraucht und ich ihn durch einen neuen ersetze, dann muss ich z.Zt endlost suchen: Scripte, Vis, Szenen, Diagramme, sogar im shuttercontrol Adapter... Mag ja sein, dass es irgendwelche Dokumentations Asse gibt, die das alles nachgehalten haben, aber für mich ist das eine extrem nervige Sache.
                                Was helfen würde, wäre eine 'where used' Funktion bei den Objekten. Vlt ein extra Reiter im 'Edit Fenster'.
                                Ich weiss nicht genau, was die neue Alias Funktion in dem Zusammenhang bietet, vlt ist das die Lösung?

                                AlCalzoneA Offline
                                AlCalzoneA Offline
                                AlCalzone
                                Developer
                                wrote on last edited by
                                #21

                                @OstfrieseUnterwegs sagte in Verbesserungsvorschläge ioBroker:

                                Ich weiss nicht genau, was die neue Alias Funktion in dem Zusammenhang bietet, vlt ist das die Lösung?

                                Soweit ich weiß ist sie für genau sowas gedacht.

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

                                OstfrieseUnterwegsO 1 Reply Last reply
                                0
                                • AlCalzoneA AlCalzone

                                  @OstfrieseUnterwegs sagte in Verbesserungsvorschläge ioBroker:

                                  Ich weiss nicht genau, was die neue Alias Funktion in dem Zusammenhang bietet, vlt ist das die Lösung?

                                  Soweit ich weiß ist sie für genau sowas gedacht.

                                  OstfrieseUnterwegsO Offline
                                  OstfrieseUnterwegsO Offline
                                  OstfrieseUnterwegs
                                  wrote on last edited by
                                  #22

                                  @AlCalzone sagte in Verbesserungsvorschläge ioBroker:

                                  @OstfrieseUnterwegs sagte in Verbesserungsvorschläge ioBroker:

                                  Ich weiss nicht genau, was die neue Alias Funktion in dem Zusammenhang bietet, vlt ist das die Lösung?

                                  Soweit ich weiß ist sie für genau sowas gedacht.

                                  Das wäre super. Dann werd ich mich mal damit befassen. Danke.

                                  1 Reply Last reply
                                  1
                                  Reply
                                  • Reply as topic
                                  Log in to reply
                                  • Oldest to Newest
                                  • Newest to Oldest
                                  • Most Votes


                                  Support us

                                  ioBroker
                                  Community Adapters
                                  Donate

                                  600

                                  Online

                                  32.7k

                                  Users

                                  82.5k

                                  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