Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [gelöst] Skript stoppt bei Zustandsänderung mit Fehler

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] Skript stoppt bei Zustandsänderung mit Fehler

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 @maloross last edited by paul53

      @maloross sagte: ich dachte, das ist ein Objekt.

      Nein, das ist nur ein Ordner ohne Objekt, der durch Punkte in der Datenpunkt-ID erzeugt wird.
      Das Objekt kann man von einem übergeordneten Ordner (mit Objekt) aus nachträglich erstellen, indem man den identischen Namen "schrankbeleuchtung" für das Objekt (Kanal) verwendet. Zeige bitte auch die übergeordnete Struktur von "schrankbeleuchtung.switch".

      maloross 1 Reply Last reply Reply Quote 0
      • maloross
        maloross @paul53 last edited by

        @paul53
        ich habe jetzt alle Funktionen entfernt, nur noch im Ursprungsordner das Schranklicht mit Raum und Funktion versehen - Fehler bleibt, Protokoll schreibt

        javascript.0
        2023-12-30 14:00:36.526	error	script.js.common.Testbereich.Statistikprojekte.licht_zaehlen: Fehler, Datenpunkt im Scriptverzeichnis als Trigger definiert
        

        Was mich irrtiert ist der Hinweis auf das Scriptverzeichnis, das in meinem Fall "javascript.0 ". Ich versuche es mal auf das Userverzeichnis umzuleiten.

        Ich hoffe, das Bild der Struktur ist ausreichend
        9fd8bc11-30be-4a6f-a5cd-c4df1ef3b663-image.png

        paul53 1 Reply Last reply Reply Quote 0
        • paul53
          paul53 @maloross last edited by

          @maloross sagte: Ich hoffe, das Bild der Struktur ist ausreichend

          Ja. Selektiere "homematic" und ändere in den Eigenschaften (Bleistift rechts) den Objekttyp von "Kanal" in "Gerät" oder "Verzeichnis". Dann erstelle unter "homematic" ein Objekt vom Typ "Kanal" mit dem Namen "schrankbeleuchtung" (genau so geschrieben).

          maloross 1 Reply Last reply Reply Quote 0
          • maloross
            maloross @paul53 last edited by maloross

            @paul53 danke für deine Unterstützung 🙂

            58a0d73b-0074-463d-814c-36f2fdc10d85-image.png
            erster Testlauf positiv, Skript läuft ohne Fehler durch.
            also sollte die Struktur auch im Alias-Verzeichnis "Gerät-Kanal-Datenpunkt" sein.

            EDIT: Es gibt Skripte, die auf ChannelID basieren - das würde dann ja super auch im Alias-Verzeichnis funktionieren.

            paul53 2 Replies Last reply Reply Quote 0
            • paul53
              paul53 @maloross last edited by

              @maloross sagte: sollte die Struktur auch im Alias-Verzeichnis "Gerät-Kanal-Datenpunkt" sein

              Ja, wenn man "channelId" und / oder "deviceId" verwenden will. Außerdem lassen sich weitere Datenpunkte unter dem Kanal leichter manuell erstellen.

              maloross 1 Reply Last reply Reply Quote 0
              • maloross
                maloross @paul53 last edited by

                @paul53 super, habe heute eine ganze Menge gelernt (habe noch ein Skripte, die ich dann ausprobieren kann).
                Da ich die Aliase mit dem Manager anlege, habe ich nicht auf die Ordnerstruktur geachtet. Bei der überschaubaren Anzahl kann ich das ganz schnell anpassen und für die Zukunft dann gleich richtig anlegen.

                1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @maloross last edited by

                  @maloross sagte: Skript läuft ohne Fehler durch

                  Dann ändere in der Überschrift im ersten Beitrag [Fehler] in [gelöst].

                  A 1 Reply Last reply Reply Quote 0
                  • A
                    Andersmacher @paul53 last edited by

                    @paul53 Ich habe hier interessiert mitgelesen und würde gern noch folgendes nachfragen:

                    Ich hatte die Struktur (Geräte, Kanäle, ...) bisher hauptsächlich/nur als Homematic-spezifisch angesehen.
                    Solange, wie man Aliasse einsetzt, um (HM-)Geräte ohne großen Aufwand 1:1 zu ersetzen (z. B. bei defekt), ist mir klar, daß es einen Sinn/Vorteil ergibt / ergeben kann, auch unter den Aliassen diese Struktur von HM beizubehalten (entsprechendes gilt dann auch für Strukturen anderer Hersteller).

                    Tatsächlich habe ich diese Nachbildung bisher nicht umgesetzt. Mein Gedanke dabei war, daß man sonst ja eigentlich immer darauf angewiesen ist, 1:1 Ersatz oder doch zumindest Ersatz mit der gleichen "Struktur" benutzen zu müssen.

                    Sollte ich Aliasse (zumindest künftig) aus Deiner Sicht doch immer an die Originalstruktur anpassen? Falls ja, wie wäre dann die empfohlene Vorgehensweise bei Hardwaretausch, wenn der Ersatz eine andere Struktur als das Original aufweist?

                    Oder ist die Struktur "genormt" und ich habe das einfach noch nicht bemerkt?

                    (Ich hatte bisher noch nie die Fragestellung / das Problem, das @maloross beschreibt bzw. habe es (falls es doch da war) offenbar irgendwie anders gelöst.

                    Freue mich über Erläuterungen/Empfehlungen.

                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @Andersmacher last edited by paul53

                      @andersmacher sagte: ist die Struktur "genormt"

                      Nein.

                      @andersmacher sagte in [gelöst] Skript stoppt bei Zustandsänderung mit Fehler:

                      Struktur (Geräte, Kanäle, ...) bisher hauptsächlich/nur als Homematic-spezifisch angesehen.

                      ioBroker ist aus einer Entwicklung für HomeMatic entstanden. Deshalb liefert "channelId" die ID des Parent-Objektes und "deviceID" die ID des Grandparent-Objektes.

                      @andersmacher sagte in [gelöst] Skript stoppt bei Zustandsänderung mit Fehler:

                      Aliasse (zumindest künftig) aus Deiner Sicht doch immer an die Originalstruktur anpassen?

                      Nein, besser eine einheitliche Struktur verwenden, wie z.B. "alias.0.folder.device.channel.state". Möglichst auch identisch für eigene Datenpunkte unter "0_userdata.0". Dabei sollte die Bezeichnung von z.B. "device" nicht wörtlich genommen werden.

                      A 1 Reply Last reply Reply Quote 1
                      • A
                        Andersmacher @paul53 last edited by

                        @paul53 Vielen Dank für die Erläuterungen!!!

                        Einen guten Rutsch nach 2024 für alle ioBrok(l)er.

                        1 Reply Last reply Reply Quote 0
                        • First post
                          Last post

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        824
                        Online

                        31.8k
                        Users

                        80.0k
                        Topics

                        1.3m
                        Posts

                        4
                        25
                        612
                        Loading More Posts
                        • Oldest to Newest
                        • Newest to Oldest
                        • Most Votes
                        Reply
                        • Reply as topic
                        Log in to reply
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                        The ioBroker Community 2014-2023
                        logo