Skip to content
  • 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
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Node-Red
  5. Hilfe bei debuggen einer übernommenen Funktion

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.2k

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

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

Hilfe bei debuggen einer übernommenen Funktion

Geplant Angeheftet Gesperrt Verschoben Node-Red
157 Beiträge 2 Kommentatoren 14.9k Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • B BF0911

    Egal, ob ich deine Change- und Switch-Node für die max. Laufzeit nutze oder auch meine, bei beiden wird kein True ausgegeben.

    Die Tageslaufzeit steht auf 0 Minuten und die max. Tages-Laufzeit auf 5 Min. Damit wäre ja eigentlich die Bedingung erfüllt.

    Screenshot 2024-05-16 100007.png

    mickymM Online
    mickymM Online
    mickym
    Most Active
    schrieb am zuletzt editiert von
    #113

    @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

    Egal, ob ich deine Change- und Switch-Node für die max. Laufzeit nutze oder auch meine, bei beiden wird kein True ausgegeben.

    Die Tageslaufzeit steht auf 0 Minuten und die max. Tages-Laufzeit auf 5 Min. Damit wäre ja eigentlich die Bedingung erfüllt.

    Screenshot 2024-05-16 100007.png

    Das geht aber musst ggf nochmal Deinen Kontext überprüfen:

    b72f7f27-fc0c-4f53-81c3-3f5d615df5e2-image.png

    Dann über switch Node direkt oder über Change Node.

    4f10e8ed-9feb-463f-8970-01ed0b897bc3-image.png

    [
       {
           "id": "325ebafbfc46c792",
           "type": "switch",
           "z": "d25606275138920f",
           "name": "< max.Laufzeit",
           "property": "PHPumpe_Laufzeit_Total.minutes",
           "propertyType": "flow",
           "rules": [
               {
                   "t": "lte",
                   "v": "PH_Parameter.MaxTagesLaufzeit_min",
                   "vt": "flow"
               },
               {
                   "t": "gt",
                   "v": "PH_Parameter.MaxTagesLaufzeit_min",
                   "vt": "flow"
               }
           ],
           "checkall": "true",
           "repair": false,
           "outputs": 2,
           "x": 1620,
           "y": 2580,
           "wires": [
               [
                   "b8645033761a6e42"
               ],
               [
                   "6cbb1e9c5751f30b"
               ]
           ]
       },
       {
           "id": "e84bf913f93cf73d",
           "type": "inject",
           "z": "d25606275138920f",
           "name": "",
           "props": [
               {
                   "p": "payload"
               }
           ],
           "repeat": "",
           "crontab": "",
           "once": false,
           "onceDelay": 0.1,
           "topic": "",
           "payload": "test",
           "payloadType": "str",
           "x": 1410,
           "y": 2580,
           "wires": [
               [
                   "325ebafbfc46c792",
                   "254b4143b3a8b7c7"
               ]
           ]
       },
       {
           "id": "b8645033761a6e42",
           "type": "debug",
           "z": "d25606275138920f",
           "name": "unter Laufzeit",
           "active": true,
           "tosidebar": true,
           "console": false,
           "tostatus": false,
           "complete": "payload",
           "targetType": "msg",
           "statusVal": "",
           "statusType": "auto",
           "x": 1840,
           "y": 2560,
           "wires": []
       },
       {
           "id": "6cbb1e9c5751f30b",
           "type": "debug",
           "z": "d25606275138920f",
           "name": "über Laufzeit",
           "active": true,
           "tosidebar": true,
           "console": false,
           "tostatus": false,
           "complete": "payload",
           "targetType": "msg",
           "statusVal": "",
           "statusType": "auto",
           "x": 1830,
           "y": 2600,
           "wires": []
       },
       {
           "id": "254b4143b3a8b7c7",
           "type": "change",
           "z": "d25606275138920f",
           "name": "max. Laufzeit nicht erreicht?",
           "rules": [
               {
                   "t": "set",
                   "p": "IST_Laufzeit",
                   "pt": "msg",
                   "to": "PHPumpe_Laufzeit_Total.minutes",
                   "tot": "flow"
               },
               {
                   "t": "set",
                   "p": "MAX_Laufzeit",
                   "pt": "msg",
                   "to": "PH_Parameter.MaxTagesLaufzeit_min",
                   "tot": "flow"
               },
               {
                   "t": "set",
                   "p": "payload",
                   "pt": "msg",
                   "to": "IST_Laufzeit <= MAX_Laufzeit",
                   "tot": "jsonata"
               }
           ],
           "action": "",
           "property": "",
           "from": "",
           "to": "",
           "reg": false,
           "x": 1640,
           "y": 2680,
           "wires": [
               [
                   "b9b1c02c155917fb"
               ]
           ]
       },
       {
           "id": "b9b1c02c155917fb",
           "type": "debug",
           "z": "d25606275138920f",
           "name": "mit Change Node",
           "active": true,
           "tosidebar": true,
           "console": false,
           "tostatus": false,
           "complete": "payload",
           "targetType": "msg",
           "statusVal": "",
           "statusType": "auto",
           "x": 1890,
           "y": 2680,
           "wires": []
       }
    ]
    

    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

    1 Antwort Letzte Antwort
    0
    • B BF0911

      Und dann (mutmaßlich zum Schluss) stehe ich noch vor der Herausforderung,

      die einstellbaren Parameter ohne Function-Node zu erstellen.

      So ist es im eigentlichen Skript:

      Screenshot 2024-05-16 105650.png Screenshot 2024-05-16 105625.png Screenshot 2024-05-16 100007.png

      Ich glaube auch verstanden zu haben, was dort gemacht wurde, erholt sich aus der Flow.Variable Ph-Parameter die einzelne Werte, schreib die in das jeweilige msg.payload, dieser payload wird über das Dashboard geändert und mit der zweiten Function-Node wieder ins Array geschrieben.

      Ich gehe davon aus, dass man fürs zurückschreiben wieder JSONata nutzen muss, da wäre mir aber die Syntax nicht klar.

      mickymM Online
      mickymM Online
      mickym
      Most Active
      schrieb am zuletzt editiert von mickym
      #114

      @bf0911 Um Dein Dashboard zu intialisieren brauchst Du das topic nicht. Dieser Mensch scheint irgendwie nicht begriffen zu haben, dass man in das topic auch Objekte schreiben kann.

      Du lädst Dir einmal den Kontext in eine payload und verteilst das dann über eine Change Node direkt an Dein Dashboard.
      Vorher solltest Du aber den Kontext über mqtt bereits eingelesen haben. Also in dem Fall musst Du wohl mit dem retain Flag arbeiten oder Du speicherst grundsätzlich nicht in mqtt sondern im iobroker.

      Du musst jedenfalls kein JSONATA verwenden, sondern geht alles direkt - so wie auch bei den switch Nodes, wie unten beschrieben.
      Wie gesagt Du musst Dir halt mal überlegen, ob Du für die Speicherung mal generell mqtt oder den iobroker verwendest.

      5325a6af-4d0c-4d8e-9eff-b53eb92d50e6-image.png

      Ich hab mal nur als Parameter für Dein Dashboard den Grenzwert und die max. Tageslaufzeit genommen.

      d614d7f6-1ba2-44ff-be14-78c00487111b-image.png

      Ist also sehr einfach, ohne JSONATA und alles.

      Du holst Dir also den ganzen Kontext in Dein Nachrichtenobjekt und initialisierst dann einfach die Inputfelder mit den Eigenschaften deines Objektes ph-Parameter. Du musst halt nach dem Neustart warten bis Dein Kontext initialisiert ist (bei mqtt durch das Retain oder bei Iobroker In durch das sofortige Auslesen).

      Ich habe deshalb mal den Init auf 10s gestellt. Eventuell brauchst noch länger:

      8922cc0c-7bf2-4d42-8823-73e06731f852-image.png

      Wie Du siehst kannst Du die Ausgabe des Dashboards direkt in die Parameter im Flowkontext schreiben,

      Eigentlich doch sehr easy und verständlich. Hier der Flow:

      [
         {
             "id": "625fb4eee509196a",
             "type": "inject",
             "z": "d25606275138920f",
             "name": "",
             "props": [
                 {
                     "p": "payload"
                 }
             ],
             "repeat": "",
             "crontab": "",
             "once": true,
             "onceDelay": "10",
             "topic": "",
             "payload": "init",
             "payloadType": "str",
             "x": 530,
             "y": 2940,
             "wires": [
                 [
                     "78b4132678634198"
                 ]
             ]
         },
         {
             "id": "78b4132678634198",
             "type": "change",
             "z": "d25606275138920f",
             "name": "",
             "rules": [
                 {
                     "t": "set",
                     "p": "payload",
                     "pt": "msg",
                     "to": "PH_Parameter",
                     "tot": "flow"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 710,
             "y": 2940,
             "wires": [
                 [
                     "c0ebbc8c64b7b0cd",
                     "4b28ddc52ba7ab15"
                 ]
             ]
         },
         {
             "id": "4e03066e4c048e62",
             "type": "ui_numeric",
             "z": "d25606275138920f",
             "name": "",
             "label": "PH Grenzwert",
             "tooltip": "",
             "group": "f173af108d4b6003",
             "order": 3,
             "width": 0,
             "height": 0,
             "wrap": false,
             "passthru": false,
             "topic": "topic",
             "topicType": "msg",
             "format": "{{value}}",
             "min": 0,
             "max": 10,
             "step": "0.1",
             "className": "",
             "x": 1160,
             "y": 2900,
             "wires": [
                 [
                     "f06b228b62354eb2"
                 ]
             ]
         },
         {
             "id": "2dc1917de1a4f96a",
             "type": "ui_numeric",
             "z": "d25606275138920f",
             "name": "",
             "label": "Maximale Tageslaufzeit",
             "tooltip": "",
             "group": "f173af108d4b6003",
             "order": 0,
             "width": 0,
             "height": 0,
             "wrap": false,
             "passthru": false,
             "topic": "topic",
             "topicType": "msg",
             "format": "{{value}} min",
             "min": 0,
             "max": 10,
             "step": 1,
             "className": "",
             "x": 1190,
             "y": 2960,
             "wires": [
                 [
                     "9b305980fa6f1fe0"
                 ]
             ]
         },
         {
             "id": "c0ebbc8c64b7b0cd",
             "type": "change",
             "z": "d25606275138920f",
             "name": "",
             "rules": [
                 {
                     "t": "set",
                     "p": "payload",
                     "pt": "msg",
                     "to": "payload.PH_Grenzwert",
                     "tot": "msg"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 950,
             "y": 2900,
             "wires": [
                 [
                     "4e03066e4c048e62"
                 ]
             ]
         },
         {
             "id": "4b28ddc52ba7ab15",
             "type": "change",
             "z": "d25606275138920f",
             "name": "",
             "rules": [
                 {
                     "t": "set",
                     "p": "payload",
                     "pt": "msg",
                     "to": "payload.MaxTagesLaufzeit_min",
                     "tot": "msg"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 950,
             "y": 2960,
             "wires": [
                 [
                     "2dc1917de1a4f96a"
                 ]
             ]
         },
         {
             "id": "f06b228b62354eb2",
             "type": "change",
             "z": "d25606275138920f",
             "name": "",
             "rules": [
                 {
                     "t": "set",
                     "p": "PH_Parameter.PH_Grenzwert",
                     "pt": "flow",
                     "to": "payload",
                     "tot": "msg"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 1500,
             "y": 2900,
             "wires": [
                 []
             ]
         },
         {
             "id": "9b305980fa6f1fe0",
             "type": "change",
             "z": "d25606275138920f",
             "name": "",
             "rules": [
                 {
                     "t": "set",
                     "p": "PH_Parameter.MaxTagesLaufzeit_min",
                     "pt": "flow",
                     "to": "payload",
                     "tot": "msg"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 1530,
             "y": 2960,
             "wires": [
                 []
             ]
         },
         {
             "id": "f173af108d4b6003",
             "type": "ui_group",
             "name": "Parameter",
             "tab": "5fb772105c6cc8b7",
             "order": 3,
             "disp": true,
             "width": "6",
             "collapse": false,
             "className": ""
         },
         {
             "id": "5fb772105c6cc8b7",
             "type": "ui_tab",
             "name": "Home",
             "icon": "dashboard",
             "disabled": false,
             "hidden": false
         }
      ]
      

      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

      B 1 Antwort Letzte Antwort
      0
      • mickymM mickym

        @bf0911 Um Dein Dashboard zu intialisieren brauchst Du das topic nicht. Dieser Mensch scheint irgendwie nicht begriffen zu haben, dass man in das topic auch Objekte schreiben kann.

        Du lädst Dir einmal den Kontext in eine payload und verteilst das dann über eine Change Node direkt an Dein Dashboard.
        Vorher solltest Du aber den Kontext über mqtt bereits eingelesen haben. Also in dem Fall musst Du wohl mit dem retain Flag arbeiten oder Du speicherst grundsätzlich nicht in mqtt sondern im iobroker.

        Du musst jedenfalls kein JSONATA verwenden, sondern geht alles direkt - so wie auch bei den switch Nodes, wie unten beschrieben.
        Wie gesagt Du musst Dir halt mal überlegen, ob Du für die Speicherung mal generell mqtt oder den iobroker verwendest.

        5325a6af-4d0c-4d8e-9eff-b53eb92d50e6-image.png

        Ich hab mal nur als Parameter für Dein Dashboard den Grenzwert und die max. Tageslaufzeit genommen.

        d614d7f6-1ba2-44ff-be14-78c00487111b-image.png

        Ist also sehr einfach, ohne JSONATA und alles.

        Du holst Dir also den ganzen Kontext in Dein Nachrichtenobjekt und initialisierst dann einfach die Inputfelder mit den Eigenschaften deines Objektes ph-Parameter. Du musst halt nach dem Neustart warten bis Dein Kontext initialisiert ist (bei mqtt durch das Retain oder bei Iobroker In durch das sofortige Auslesen).

        Ich habe deshalb mal den Init auf 10s gestellt. Eventuell brauchst noch länger:

        8922cc0c-7bf2-4d42-8823-73e06731f852-image.png

        Wie Du siehst kannst Du die Ausgabe des Dashboards direkt in die Parameter im Flowkontext schreiben,

        Eigentlich doch sehr easy und verständlich. Hier der Flow:

        [
           {
               "id": "625fb4eee509196a",
               "type": "inject",
               "z": "d25606275138920f",
               "name": "",
               "props": [
                   {
                       "p": "payload"
                   }
               ],
               "repeat": "",
               "crontab": "",
               "once": true,
               "onceDelay": "10",
               "topic": "",
               "payload": "init",
               "payloadType": "str",
               "x": 530,
               "y": 2940,
               "wires": [
                   [
                       "78b4132678634198"
                   ]
               ]
           },
           {
               "id": "78b4132678634198",
               "type": "change",
               "z": "d25606275138920f",
               "name": "",
               "rules": [
                   {
                       "t": "set",
                       "p": "payload",
                       "pt": "msg",
                       "to": "PH_Parameter",
                       "tot": "flow"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 710,
               "y": 2940,
               "wires": [
                   [
                       "c0ebbc8c64b7b0cd",
                       "4b28ddc52ba7ab15"
                   ]
               ]
           },
           {
               "id": "4e03066e4c048e62",
               "type": "ui_numeric",
               "z": "d25606275138920f",
               "name": "",
               "label": "PH Grenzwert",
               "tooltip": "",
               "group": "f173af108d4b6003",
               "order": 3,
               "width": 0,
               "height": 0,
               "wrap": false,
               "passthru": false,
               "topic": "topic",
               "topicType": "msg",
               "format": "{{value}}",
               "min": 0,
               "max": 10,
               "step": "0.1",
               "className": "",
               "x": 1160,
               "y": 2900,
               "wires": [
                   [
                       "f06b228b62354eb2"
                   ]
               ]
           },
           {
               "id": "2dc1917de1a4f96a",
               "type": "ui_numeric",
               "z": "d25606275138920f",
               "name": "",
               "label": "Maximale Tageslaufzeit",
               "tooltip": "",
               "group": "f173af108d4b6003",
               "order": 0,
               "width": 0,
               "height": 0,
               "wrap": false,
               "passthru": false,
               "topic": "topic",
               "topicType": "msg",
               "format": "{{value}} min",
               "min": 0,
               "max": 10,
               "step": 1,
               "className": "",
               "x": 1190,
               "y": 2960,
               "wires": [
                   [
                       "9b305980fa6f1fe0"
                   ]
               ]
           },
           {
               "id": "c0ebbc8c64b7b0cd",
               "type": "change",
               "z": "d25606275138920f",
               "name": "",
               "rules": [
                   {
                       "t": "set",
                       "p": "payload",
                       "pt": "msg",
                       "to": "payload.PH_Grenzwert",
                       "tot": "msg"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 950,
               "y": 2900,
               "wires": [
                   [
                       "4e03066e4c048e62"
                   ]
               ]
           },
           {
               "id": "4b28ddc52ba7ab15",
               "type": "change",
               "z": "d25606275138920f",
               "name": "",
               "rules": [
                   {
                       "t": "set",
                       "p": "payload",
                       "pt": "msg",
                       "to": "payload.MaxTagesLaufzeit_min",
                       "tot": "msg"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 950,
               "y": 2960,
               "wires": [
                   [
                       "2dc1917de1a4f96a"
                   ]
               ]
           },
           {
               "id": "f06b228b62354eb2",
               "type": "change",
               "z": "d25606275138920f",
               "name": "",
               "rules": [
                   {
                       "t": "set",
                       "p": "PH_Parameter.PH_Grenzwert",
                       "pt": "flow",
                       "to": "payload",
                       "tot": "msg"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 1500,
               "y": 2900,
               "wires": [
                   []
               ]
           },
           {
               "id": "9b305980fa6f1fe0",
               "type": "change",
               "z": "d25606275138920f",
               "name": "",
               "rules": [
                   {
                       "t": "set",
                       "p": "PH_Parameter.MaxTagesLaufzeit_min",
                       "pt": "flow",
                       "to": "payload",
                       "tot": "msg"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 1530,
               "y": 2960,
               "wires": [
                   []
               ]
           },
           {
               "id": "f173af108d4b6003",
               "type": "ui_group",
               "name": "Parameter",
               "tab": "5fb772105c6cc8b7",
               "order": 3,
               "disp": true,
               "width": "6",
               "collapse": false,
               "className": ""
           },
           {
               "id": "5fb772105c6cc8b7",
               "type": "ui_tab",
               "name": "Home",
               "icon": "dashboard",
               "disabled": false,
               "hidden": false
           }
        ]
        

        B Offline
        B Offline
        BF0911
        schrieb am zuletzt editiert von BF0911
        #115

        @mickym

        Danke für deine Ausführungen.

        Ich hatte es mit der Nachrichten-Eigenschaft so verstanden, dass ich dafür z. B. False oder True von den Pumpen abfragen kann.

        Deswegen msg.chlorpumpe.

        mickymM B 3 Antworten Letzte Antwort
        0
        • B BF0911

          @mickym

          Danke für deine Ausführungen.

          Ich hatte es mit der Nachrichten-Eigenschaft so verstanden, dass ich dafür z. B. False oder True von den Pumpen abfragen kann.

          Deswegen msg.chlorpumpe.

          mickymM Online
          mickymM Online
          mickym
          Most Active
          schrieb am zuletzt editiert von
          #116

          @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

          Ich hatte es mit der Nachrichten-Eigenschaft so verstanden, dass ich dafür z. B. False oder True von den Pumpen abfragen kann.

          Na wenn Du es vorher mit einer iobroker-get in Dein Nachrichtenobjekt geholt hast, dann schon. Alles gut. Wie gesagt, wenn du die Parameter nicht mehr brauchst oder die payload nicht mehr brauchst, dann kannst auch die direkt verwenden.

          Aber ich denke Du bist nun soweit - dass Du meine Hilfe nicht mehr brauchst, bei solchen Dingen.

          Wenn Du Dir nun Dein Gesamtwerk betrachtest, ist das nicht viel übersichtlicher geworden?

          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

          1 Antwort Letzte Antwort
          0
          • B BF0911

            @mickym

            Danke für deine Ausführungen.

            Ich hatte es mit der Nachrichten-Eigenschaft so verstanden, dass ich dafür z. B. False oder True von den Pumpen abfragen kann.

            Deswegen msg.chlorpumpe.

            mickymM Online
            mickymM Online
            mickym
            Most Active
            schrieb am zuletzt editiert von mickym
            #117

            @bf0911 Wie gesagt, ich würde mir in Deinem Fall überlegen, ob Du überhaupt mit mqtt arbeitest oder mqtt nicht nur dafür verwendest ggf. Deine Hardware zu steuern.

            Wie bist Du überhaupt darauf gekommen, mqtt zu verwenden? - Jetzt sag nicht, weil das Skript das gemacht hat. Ja wenn man kein iobroker hat, dann nimmt man in NOdeRed Standalone Konfigurationen mqtt - dann muss man ggf. mit retain Flags arbeiten oder mit einem Filekontext, der einen Neustart überlebt. In Deinem Fall würde ich aber alles in Datenpunkten speichern. Du musst nur die Objekte als JSON Strings abspeichern und wieder restaurieren.

            Im Endeffekt glaube ich, dass Dir die Zeit Dich in NodeRed einzuarbeiten weniger Zeit gekostet hat, als nach fertigen Skripten zu suchen.

            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

            1 Antwort Letzte Antwort
            0
            • B BF0911

              @mickym

              Danke für deine Ausführungen.

              Ich hatte es mit der Nachrichten-Eigenschaft so verstanden, dass ich dafür z. B. False oder True von den Pumpen abfragen kann.

              Deswegen msg.chlorpumpe.

              B Offline
              B Offline
              BF0911
              schrieb am zuletzt editiert von
              #118

              Ja, erstmal ganz lieben Dank für die Zeit und Mühe.

              Eine abschließende Frage hab ich noch, du setzt in dem Beispiel "Dashboard" die flow.Variablen. Die habe ich bzw. wir ja schon an einer anderen Stelle gesetzt. Fehlt da dann nicht noch das zurückschreiben per MQTT in das Array?

              Ja, mein Flow ist wirklich total übersichtlich geworden. Und dass ist für mich das wichtigste, ich weiß was wann wo passiert und kann dies alles nachvollziehen.

              Ja, doch richtig. Weil es so vorgeben war. Ich hatte ja die Hoffung, nur ein, zwei Nodes anpassen zu müssen, damit das Skript läuft.

              Ich nehme mal an, dass ich mit iobroker-out genau so Arrays schreiben kann wie per MQTT? Also natürlich, wenn der Datenpunkt vorhanden ist.

              mickymM 1 Antwort Letzte Antwort
              0
              • B BF0911

                Ja, erstmal ganz lieben Dank für die Zeit und Mühe.

                Eine abschließende Frage hab ich noch, du setzt in dem Beispiel "Dashboard" die flow.Variablen. Die habe ich bzw. wir ja schon an einer anderen Stelle gesetzt. Fehlt da dann nicht noch das zurückschreiben per MQTT in das Array?

                Ja, mein Flow ist wirklich total übersichtlich geworden. Und dass ist für mich das wichtigste, ich weiß was wann wo passiert und kann dies alles nachvollziehen.

                Ja, doch richtig. Weil es so vorgeben war. Ich hatte ja die Hoffung, nur ein, zwei Nodes anpassen zu müssen, damit das Skript läuft.

                Ich nehme mal an, dass ich mit iobroker-out genau so Arrays schreiben kann wie per MQTT? Also natürlich, wenn der Datenpunkt vorhanden ist.

                mickymM Online
                mickymM Online
                mickym
                Most Active
                schrieb am zuletzt editiert von mickym
                #119

                @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                Ja, erstmal ganz lieben Dank für die Zeit und Mühe.

                Eine abschließende Frage hab ich noch, du setzt in dem Beispiel "Dashboard" die flow.Variablen. Die habe ich bzw. wir ja schon an einer anderen Stelle gesetzt. Fehlt da dann nicht noch das zurückschreiben per MQTT in das Array?

                Ja da hast Du Recht, aber das würde ich nur ein einziges Mal machen im Flow. Wird natürlich bei jeder Änderung das ganze Objekt zurückgeschrieben. (aber du siehst wieviel einfacher das ist).

                b7ff1afd-56e4-4c04-aa3e-015cbd6623b7-image.png

                In dieser letzten Change Node holst Du Dir einfach das ganze Objekt nochmal als payload in das Nachrichtenobjekt.

                e644e1a7-bfb8-4b92-843d-2e2d1a2da34e-image.png

                Ja, mein Flow ist wirklich total übersichtlich geworden. Und dass ist für mich das wichtigste, ich weiß was wann wo passiert und kann dies alles nachvollziehen.

                Perfekt!
                Und bis auf wenige Regeln, in den Du JSONATA verwendet hast, hast Du doch so gut wie keinen Code geschrieben? -´Oder siehst Du das anders?

                Ja, doch richtig. Weil es so vorgeben war. Ich hatte ja die Hoffung, nur ein, zwei Nodes anpassen zu müssen, damit das Skript läuft.

                Ja aber Du hättest den Flow nicht verstanden, so wie jetzt und ausserdem kannst Du nun in Zukunft Flows alleine schreiben und suchst Dir nicht mehr was zusammen .

                Ich nehme mal an, dass ich mit iobroker-out genau so Arrays schreiben kann wie per MQTT? Also natürlich, wenn der Datenpunkt vorhanden ist.

                Ja das einzige was der iobroker Nodes nicht können, gleich die Objekte als JSON Strings zu schreiben bzw. zu verwandeln.
                Wenn Du also Dein PH_Parameter als Ganzen in einen iobroker-Datenpunkt schreiben willst, dann musst Du den vorher in einen JSON-String umwandeln.

                ce02ab0e-b88d-4996-a7fa-54e035911e1e-image.png

                Den Datenpunkt im iobroker gibst halt auch den Datentyp JSON

                572f7fbb-29f9-4c17-a0ed-dcdfa761077b-image.png

                Sollen die Daten dann automatisch eingelesen werden - kannst Du das in der iobroker-IN Node konfigurieren:

                40b03d47-13e6-48ab-b20b-ae9c9790afee-image.png
                3c259d8e-7eee-4e91-b476-80ca0b490aef-image.png

                Hier nochmal zum Import:

                [
                   {
                       "id": "22fe457b460d3214",
                       "type": "ioBroker out",
                       "z": "d25606275138920f",
                       "name": "",
                       "topic": "0_userdata.0.Poolsteuerung.Parameter",
                       "ack": "false",
                       "autoCreate": "false",
                       "stateName": "",
                       "role": "",
                       "payloadType": "",
                       "readonly": "",
                       "stateUnit": "",
                       "stateMin": "",
                       "stateMax": "",
                       "x": 2440,
                       "y": 3120,
                       "wires": []
                   },
                   {
                       "id": "d214d7290a5c77da",
                       "type": "inject",
                       "z": "d25606275138920f",
                       "name": "",
                       "props": [
                           {
                               "p": "payload"
                           }
                       ],
                       "repeat": "",
                       "crontab": "",
                       "once": false,
                       "onceDelay": "10",
                       "topic": "",
                       "payload": "init",
                       "payloadType": "str",
                       "x": 1690,
                       "y": 3120,
                       "wires": [
                           [
                               "ad84a2d856866648"
                           ]
                       ]
                   },
                   {
                       "id": "ad84a2d856866648",
                       "type": "change",
                       "z": "d25606275138920f",
                       "name": "",
                       "rules": [
                           {
                               "t": "set",
                               "p": "payload",
                               "pt": "msg",
                               "to": "PH_Parameter",
                               "tot": "flow"
                           }
                       ],
                       "action": "",
                       "property": "",
                       "from": "",
                       "to": "",
                       "reg": false,
                       "x": 1870,
                       "y": 3120,
                       "wires": [
                           [
                               "2e4e4e6ba2abab86",
                               "9f4b4cddf32c69fb"
                           ]
                       ]
                   },
                   {
                       "id": "2e4e4e6ba2abab86",
                       "type": "debug",
                       "z": "d25606275138920f",
                       "name": "Objekt",
                       "active": true,
                       "tosidebar": true,
                       "console": false,
                       "tostatus": false,
                       "complete": "payload",
                       "targetType": "msg",
                       "statusVal": "",
                       "statusType": "auto",
                       "x": 2050,
                       "y": 3200,
                       "wires": []
                   },
                   {
                       "id": "9f4b4cddf32c69fb",
                       "type": "json",
                       "z": "d25606275138920f",
                       "name": "",
                       "property": "payload",
                       "action": "",
                       "pretty": false,
                       "x": 2090,
                       "y": 3120,
                       "wires": [
                           [
                               "d5ce1c7985b2ebd1",
                               "22fe457b460d3214"
                           ]
                       ]
                   },
                   {
                       "id": "d5ce1c7985b2ebd1",
                       "type": "debug",
                       "z": "d25606275138920f",
                       "name": "JSON String",
                       "active": true,
                       "tosidebar": true,
                       "console": false,
                       "tostatus": false,
                       "complete": "payload",
                       "targetType": "msg",
                       "statusVal": "",
                       "statusType": "auto",
                       "x": 2250,
                       "y": 3200,
                       "wires": []
                   },
                   {
                       "id": "60e419b85a25e765",
                       "type": "ioBroker in",
                       "z": "d25606275138920f",
                       "name": "Parameter",
                       "attrname": "payload",
                       "topic": "0_userdata.0.Poolsteuerung.Parameter",
                       "payloadType": "value",
                       "onlyack": "",
                       "func": "all",
                       "gap": "",
                       "fireOnStart": "true",
                       "outFormat": "MQTT",
                       "x": 1720,
                       "y": 3360,
                       "wires": [
                           [
                               "59fd74cb38a3b63c"
                           ]
                       ]
                   },
                   {
                       "id": "59fd74cb38a3b63c",
                       "type": "json",
                       "z": "d25606275138920f",
                       "name": "",
                       "property": "payload",
                       "action": "",
                       "pretty": false,
                       "x": 1890,
                       "y": 3360,
                       "wires": [
                           [
                               "be854702f4a8b844"
                           ]
                       ]
                   },
                   {
                       "id": "be854702f4a8b844",
                       "type": "debug",
                       "z": "d25606275138920f",
                       "name": "Objekt geholt",
                       "active": true,
                       "tosidebar": true,
                       "console": false,
                       "tostatus": false,
                       "complete": "payload",
                       "targetType": "msg",
                       "statusVal": "",
                       "statusType": "auto",
                       "x": 2090,
                       "y": 3360,
                       "wires": []
                   }
                ]
                

                Achso ein Fehler habe ich noch in der iobroker-Out node gemacht.

                e2562df9-b00e-4ca1-b081-bbcf12e625d1-image.png

                Wenn Du unter 0_userdata.0 schreibst, dann gibts ja keine Hardware, die diesen Wert in Empfang nimmt. Hier als ein ACK=true schreiben (also einen value und KEIN command).
                Wenn Du hingegen Deine Pumpen steuerst und direkt in einen Adapterdatenpunkt schreibst, zum Steuern, dann Type command (ACK=false) verwenden.

                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                B 1 Antwort Letzte Antwort
                0
                • mickymM mickym

                  @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                  Ja, erstmal ganz lieben Dank für die Zeit und Mühe.

                  Eine abschließende Frage hab ich noch, du setzt in dem Beispiel "Dashboard" die flow.Variablen. Die habe ich bzw. wir ja schon an einer anderen Stelle gesetzt. Fehlt da dann nicht noch das zurückschreiben per MQTT in das Array?

                  Ja da hast Du Recht, aber das würde ich nur ein einziges Mal machen im Flow. Wird natürlich bei jeder Änderung das ganze Objekt zurückgeschrieben. (aber du siehst wieviel einfacher das ist).

                  b7ff1afd-56e4-4c04-aa3e-015cbd6623b7-image.png

                  In dieser letzten Change Node holst Du Dir einfach das ganze Objekt nochmal als payload in das Nachrichtenobjekt.

                  e644e1a7-bfb8-4b92-843d-2e2d1a2da34e-image.png

                  Ja, mein Flow ist wirklich total übersichtlich geworden. Und dass ist für mich das wichtigste, ich weiß was wann wo passiert und kann dies alles nachvollziehen.

                  Perfekt!
                  Und bis auf wenige Regeln, in den Du JSONATA verwendet hast, hast Du doch so gut wie keinen Code geschrieben? -´Oder siehst Du das anders?

                  Ja, doch richtig. Weil es so vorgeben war. Ich hatte ja die Hoffung, nur ein, zwei Nodes anpassen zu müssen, damit das Skript läuft.

                  Ja aber Du hättest den Flow nicht verstanden, so wie jetzt und ausserdem kannst Du nun in Zukunft Flows alleine schreiben und suchst Dir nicht mehr was zusammen .

                  Ich nehme mal an, dass ich mit iobroker-out genau so Arrays schreiben kann wie per MQTT? Also natürlich, wenn der Datenpunkt vorhanden ist.

                  Ja das einzige was der iobroker Nodes nicht können, gleich die Objekte als JSON Strings zu schreiben bzw. zu verwandeln.
                  Wenn Du also Dein PH_Parameter als Ganzen in einen iobroker-Datenpunkt schreiben willst, dann musst Du den vorher in einen JSON-String umwandeln.

                  ce02ab0e-b88d-4996-a7fa-54e035911e1e-image.png

                  Den Datenpunkt im iobroker gibst halt auch den Datentyp JSON

                  572f7fbb-29f9-4c17-a0ed-dcdfa761077b-image.png

                  Sollen die Daten dann automatisch eingelesen werden - kannst Du das in der iobroker-IN Node konfigurieren:

                  40b03d47-13e6-48ab-b20b-ae9c9790afee-image.png
                  3c259d8e-7eee-4e91-b476-80ca0b490aef-image.png

                  Hier nochmal zum Import:

                  [
                     {
                         "id": "22fe457b460d3214",
                         "type": "ioBroker out",
                         "z": "d25606275138920f",
                         "name": "",
                         "topic": "0_userdata.0.Poolsteuerung.Parameter",
                         "ack": "false",
                         "autoCreate": "false",
                         "stateName": "",
                         "role": "",
                         "payloadType": "",
                         "readonly": "",
                         "stateUnit": "",
                         "stateMin": "",
                         "stateMax": "",
                         "x": 2440,
                         "y": 3120,
                         "wires": []
                     },
                     {
                         "id": "d214d7290a5c77da",
                         "type": "inject",
                         "z": "d25606275138920f",
                         "name": "",
                         "props": [
                             {
                                 "p": "payload"
                             }
                         ],
                         "repeat": "",
                         "crontab": "",
                         "once": false,
                         "onceDelay": "10",
                         "topic": "",
                         "payload": "init",
                         "payloadType": "str",
                         "x": 1690,
                         "y": 3120,
                         "wires": [
                             [
                                 "ad84a2d856866648"
                             ]
                         ]
                     },
                     {
                         "id": "ad84a2d856866648",
                         "type": "change",
                         "z": "d25606275138920f",
                         "name": "",
                         "rules": [
                             {
                                 "t": "set",
                                 "p": "payload",
                                 "pt": "msg",
                                 "to": "PH_Parameter",
                                 "tot": "flow"
                             }
                         ],
                         "action": "",
                         "property": "",
                         "from": "",
                         "to": "",
                         "reg": false,
                         "x": 1870,
                         "y": 3120,
                         "wires": [
                             [
                                 "2e4e4e6ba2abab86",
                                 "9f4b4cddf32c69fb"
                             ]
                         ]
                     },
                     {
                         "id": "2e4e4e6ba2abab86",
                         "type": "debug",
                         "z": "d25606275138920f",
                         "name": "Objekt",
                         "active": true,
                         "tosidebar": true,
                         "console": false,
                         "tostatus": false,
                         "complete": "payload",
                         "targetType": "msg",
                         "statusVal": "",
                         "statusType": "auto",
                         "x": 2050,
                         "y": 3200,
                         "wires": []
                     },
                     {
                         "id": "9f4b4cddf32c69fb",
                         "type": "json",
                         "z": "d25606275138920f",
                         "name": "",
                         "property": "payload",
                         "action": "",
                         "pretty": false,
                         "x": 2090,
                         "y": 3120,
                         "wires": [
                             [
                                 "d5ce1c7985b2ebd1",
                                 "22fe457b460d3214"
                             ]
                         ]
                     },
                     {
                         "id": "d5ce1c7985b2ebd1",
                         "type": "debug",
                         "z": "d25606275138920f",
                         "name": "JSON String",
                         "active": true,
                         "tosidebar": true,
                         "console": false,
                         "tostatus": false,
                         "complete": "payload",
                         "targetType": "msg",
                         "statusVal": "",
                         "statusType": "auto",
                         "x": 2250,
                         "y": 3200,
                         "wires": []
                     },
                     {
                         "id": "60e419b85a25e765",
                         "type": "ioBroker in",
                         "z": "d25606275138920f",
                         "name": "Parameter",
                         "attrname": "payload",
                         "topic": "0_userdata.0.Poolsteuerung.Parameter",
                         "payloadType": "value",
                         "onlyack": "",
                         "func": "all",
                         "gap": "",
                         "fireOnStart": "true",
                         "outFormat": "MQTT",
                         "x": 1720,
                         "y": 3360,
                         "wires": [
                             [
                                 "59fd74cb38a3b63c"
                             ]
                         ]
                     },
                     {
                         "id": "59fd74cb38a3b63c",
                         "type": "json",
                         "z": "d25606275138920f",
                         "name": "",
                         "property": "payload",
                         "action": "",
                         "pretty": false,
                         "x": 1890,
                         "y": 3360,
                         "wires": [
                             [
                                 "be854702f4a8b844"
                             ]
                         ]
                     },
                     {
                         "id": "be854702f4a8b844",
                         "type": "debug",
                         "z": "d25606275138920f",
                         "name": "Objekt geholt",
                         "active": true,
                         "tosidebar": true,
                         "console": false,
                         "tostatus": false,
                         "complete": "payload",
                         "targetType": "msg",
                         "statusVal": "",
                         "statusType": "auto",
                         "x": 2090,
                         "y": 3360,
                         "wires": []
                     }
                  ]
                  

                  Achso ein Fehler habe ich noch in der iobroker-Out node gemacht.

                  e2562df9-b00e-4ca1-b081-bbcf12e625d1-image.png

                  Wenn Du unter 0_userdata.0 schreibst, dann gibts ja keine Hardware, die diesen Wert in Empfang nimmt. Hier als ein ACK=true schreiben (also einen value und KEIN command).
                  Wenn Du hingegen Deine Pumpen steuerst und direkt in einen Adapterdatenpunkt schreibst, zum Steuern, dann Type command (ACK=false) verwenden.

                  B Offline
                  B Offline
                  BF0911
                  schrieb am zuletzt editiert von
                  #120

                  @mickym

                  Ja, super. Vielen Dank. Ich habe jetzt alle MQTT-In und Out gegen Json und Iobroker-in und out getauscht.

                  Da werden auch schon die Daten in die Datenpunkte geschrieben. Das scheint zu klappen.

                  Nun muss ich das noch mit dem Dashboard verstehen und umsetzen.

                  mickymM 1 Antwort Letzte Antwort
                  0
                  • B BF0911

                    @mickym

                    Ja, super. Vielen Dank. Ich habe jetzt alle MQTT-In und Out gegen Json und Iobroker-in und out getauscht.

                    Da werden auch schon die Daten in die Datenpunkte geschrieben. Das scheint zu klappen.

                    Nun muss ich das noch mit dem Dashboard verstehen und umsetzen.

                    mickymM Online
                    mickymM Online
                    mickym
                    Most Active
                    schrieb am zuletzt editiert von
                    #121

                    @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                    Nun muss ich das noch mit dem Dashboard verstehen und umsetzen.

                    Na da brauchst dann die Init Node nicht mehr sondern konfigurierst Dir die iobroker-In Node so, dass die Parameter direkt eingelesen werden:

                    5c5a4b48-97d1-4dbd-9d95-79121434d4a1-image.png

                    [
                       {
                           "id": "4e03066e4c048e62",
                           "type": "ui_numeric",
                           "z": "d25606275138920f",
                           "name": "",
                           "label": "PH Grenzwert",
                           "tooltip": "",
                           "group": "f173af108d4b6003",
                           "order": 3,
                           "width": 0,
                           "height": 0,
                           "wrap": false,
                           "passthru": false,
                           "topic": "topic",
                           "topicType": "msg",
                           "format": "{{value}}",
                           "min": 0,
                           "max": 10,
                           "step": "0.1",
                           "className": "",
                           "x": 1160,
                           "y": 2900,
                           "wires": [
                               [
                                   "f06b228b62354eb2"
                               ]
                           ]
                       },
                       {
                           "id": "2dc1917de1a4f96a",
                           "type": "ui_numeric",
                           "z": "d25606275138920f",
                           "name": "",
                           "label": "Maximale Tageslaufzeit",
                           "tooltip": "",
                           "group": "f173af108d4b6003",
                           "order": 0,
                           "width": 0,
                           "height": 0,
                           "wrap": false,
                           "passthru": false,
                           "topic": "topic",
                           "topicType": "msg",
                           "format": "{{value}} min",
                           "min": 0,
                           "max": 10,
                           "step": 1,
                           "className": "",
                           "x": 1190,
                           "y": 2980,
                           "wires": [
                               [
                                   "9b305980fa6f1fe0"
                               ]
                           ]
                       },
                       {
                           "id": "c0ebbc8c64b7b0cd",
                           "type": "change",
                           "z": "d25606275138920f",
                           "name": "",
                           "rules": [
                               {
                                   "t": "set",
                                   "p": "payload",
                                   "pt": "msg",
                                   "to": "payload.PH_Grenzwert",
                                   "tot": "msg"
                               }
                           ],
                           "action": "",
                           "property": "",
                           "from": "",
                           "to": "",
                           "reg": false,
                           "x": 950,
                           "y": 2900,
                           "wires": [
                               [
                                   "4e03066e4c048e62"
                               ]
                           ]
                       },
                       {
                           "id": "4b28ddc52ba7ab15",
                           "type": "change",
                           "z": "d25606275138920f",
                           "name": "",
                           "rules": [
                               {
                                   "t": "set",
                                   "p": "payload",
                                   "pt": "msg",
                                   "to": "payload.MaxTagesLaufzeit_min",
                                   "tot": "msg"
                               }
                           ],
                           "action": "",
                           "property": "",
                           "from": "",
                           "to": "",
                           "reg": false,
                           "x": 950,
                           "y": 2980,
                           "wires": [
                               [
                                   "2dc1917de1a4f96a"
                               ]
                           ]
                       },
                       {
                           "id": "f06b228b62354eb2",
                           "type": "change",
                           "z": "d25606275138920f",
                           "name": "",
                           "rules": [
                               {
                                   "t": "set",
                                   "p": "PH_Parameter.PH_Grenzwert",
                                   "pt": "flow",
                                   "to": "payload",
                                   "tot": "msg"
                               }
                           ],
                           "action": "",
                           "property": "",
                           "from": "",
                           "to": "",
                           "reg": false,
                           "x": 1560,
                           "y": 2900,
                           "wires": [
                               [
                                   "d4c5239e5ff47822"
                               ]
                           ]
                       },
                       {
                           "id": "9b305980fa6f1fe0",
                           "type": "change",
                           "z": "d25606275138920f",
                           "name": "",
                           "rules": [
                               {
                                   "t": "set",
                                   "p": "PH_Parameter.MaxTagesLaufzeit_min",
                                   "pt": "flow",
                                   "to": "payload",
                                   "tot": "msg"
                               }
                           ],
                           "action": "",
                           "property": "",
                           "from": "",
                           "to": "",
                           "reg": false,
                           "x": 1530,
                           "y": 2980,
                           "wires": [
                               [
                                   "d4c5239e5ff47822"
                               ]
                           ]
                       },
                       {
                           "id": "d4c5239e5ff47822",
                           "type": "change",
                           "z": "d25606275138920f",
                           "name": "",
                           "rules": [
                               {
                                   "t": "set",
                                   "p": "payload",
                                   "pt": "msg",
                                   "to": "PH_Parameter",
                                   "tot": "flow"
                               }
                           ],
                           "action": "",
                           "property": "",
                           "from": "",
                           "to": "",
                           "reg": false,
                           "x": 1870,
                           "y": 2940,
                           "wires": [
                               [
                                   "9f4b4cddf32c69fb"
                               ]
                           ]
                       },
                       {
                           "id": "22fe457b460d3214",
                           "type": "ioBroker out",
                           "z": "d25606275138920f",
                           "name": "Parameter",
                           "topic": "0_userdata.0.Poolsteuerung.Parameter",
                           "ack": "true",
                           "autoCreate": "false",
                           "stateName": "",
                           "role": "",
                           "payloadType": "",
                           "readonly": "",
                           "stateUnit": "",
                           "stateMin": "",
                           "stateMax": "",
                           "x": 2210,
                           "y": 2940,
                           "wires": []
                       },
                       {
                           "id": "9f4b4cddf32c69fb",
                           "type": "json",
                           "z": "d25606275138920f",
                           "name": "",
                           "property": "payload",
                           "action": "",
                           "pretty": false,
                           "x": 2050,
                           "y": 2940,
                           "wires": [
                               [
                                   "22fe457b460d3214"
                               ]
                           ]
                       },
                       {
                           "id": "46f3c4494c51b112",
                           "type": "ioBroker in",
                           "z": "d25606275138920f",
                           "name": "Parameter",
                           "attrname": "payload",
                           "topic": "0_userdata.0.Poolsteuerung.Parameter",
                           "payloadType": "value",
                           "onlyack": "",
                           "func": "all",
                           "gap": "",
                           "fireOnStart": "true",
                           "outFormat": "MQTT",
                           "x": 560,
                           "y": 2940,
                           "wires": [
                               [
                                   "3f76567ff2d9ebf0"
                               ]
                           ]
                       },
                       {
                           "id": "3f76567ff2d9ebf0",
                           "type": "json",
                           "z": "d25606275138920f",
                           "name": "",
                           "property": "payload",
                           "action": "",
                           "pretty": false,
                           "x": 730,
                           "y": 2940,
                           "wires": [
                               [
                                   "c0ebbc8c64b7b0cd",
                                   "4b28ddc52ba7ab15"
                               ]
                           ]
                       },
                       {
                           "id": "f173af108d4b6003",
                           "type": "ui_group",
                           "name": "Parameter",
                           "tab": "5fb772105c6cc8b7",
                           "order": 3,
                           "disp": true,
                           "width": "6",
                           "collapse": false,
                           "className": ""
                       },
                       {
                           "id": "5fb772105c6cc8b7",
                           "type": "ui_tab",
                           "name": "Home",
                           "icon": "dashboard",
                           "disabled": false,
                           "hidden": false
                       }
                    ]
                    

                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                    B 1 Antwort Letzte Antwort
                    0
                    • mickymM mickym

                      @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                      Nun muss ich das noch mit dem Dashboard verstehen und umsetzen.

                      Na da brauchst dann die Init Node nicht mehr sondern konfigurierst Dir die iobroker-In Node so, dass die Parameter direkt eingelesen werden:

                      5c5a4b48-97d1-4dbd-9d95-79121434d4a1-image.png

                      [
                         {
                             "id": "4e03066e4c048e62",
                             "type": "ui_numeric",
                             "z": "d25606275138920f",
                             "name": "",
                             "label": "PH Grenzwert",
                             "tooltip": "",
                             "group": "f173af108d4b6003",
                             "order": 3,
                             "width": 0,
                             "height": 0,
                             "wrap": false,
                             "passthru": false,
                             "topic": "topic",
                             "topicType": "msg",
                             "format": "{{value}}",
                             "min": 0,
                             "max": 10,
                             "step": "0.1",
                             "className": "",
                             "x": 1160,
                             "y": 2900,
                             "wires": [
                                 [
                                     "f06b228b62354eb2"
                                 ]
                             ]
                         },
                         {
                             "id": "2dc1917de1a4f96a",
                             "type": "ui_numeric",
                             "z": "d25606275138920f",
                             "name": "",
                             "label": "Maximale Tageslaufzeit",
                             "tooltip": "",
                             "group": "f173af108d4b6003",
                             "order": 0,
                             "width": 0,
                             "height": 0,
                             "wrap": false,
                             "passthru": false,
                             "topic": "topic",
                             "topicType": "msg",
                             "format": "{{value}} min",
                             "min": 0,
                             "max": 10,
                             "step": 1,
                             "className": "",
                             "x": 1190,
                             "y": 2980,
                             "wires": [
                                 [
                                     "9b305980fa6f1fe0"
                                 ]
                             ]
                         },
                         {
                             "id": "c0ebbc8c64b7b0cd",
                             "type": "change",
                             "z": "d25606275138920f",
                             "name": "",
                             "rules": [
                                 {
                                     "t": "set",
                                     "p": "payload",
                                     "pt": "msg",
                                     "to": "payload.PH_Grenzwert",
                                     "tot": "msg"
                                 }
                             ],
                             "action": "",
                             "property": "",
                             "from": "",
                             "to": "",
                             "reg": false,
                             "x": 950,
                             "y": 2900,
                             "wires": [
                                 [
                                     "4e03066e4c048e62"
                                 ]
                             ]
                         },
                         {
                             "id": "4b28ddc52ba7ab15",
                             "type": "change",
                             "z": "d25606275138920f",
                             "name": "",
                             "rules": [
                                 {
                                     "t": "set",
                                     "p": "payload",
                                     "pt": "msg",
                                     "to": "payload.MaxTagesLaufzeit_min",
                                     "tot": "msg"
                                 }
                             ],
                             "action": "",
                             "property": "",
                             "from": "",
                             "to": "",
                             "reg": false,
                             "x": 950,
                             "y": 2980,
                             "wires": [
                                 [
                                     "2dc1917de1a4f96a"
                                 ]
                             ]
                         },
                         {
                             "id": "f06b228b62354eb2",
                             "type": "change",
                             "z": "d25606275138920f",
                             "name": "",
                             "rules": [
                                 {
                                     "t": "set",
                                     "p": "PH_Parameter.PH_Grenzwert",
                                     "pt": "flow",
                                     "to": "payload",
                                     "tot": "msg"
                                 }
                             ],
                             "action": "",
                             "property": "",
                             "from": "",
                             "to": "",
                             "reg": false,
                             "x": 1560,
                             "y": 2900,
                             "wires": [
                                 [
                                     "d4c5239e5ff47822"
                                 ]
                             ]
                         },
                         {
                             "id": "9b305980fa6f1fe0",
                             "type": "change",
                             "z": "d25606275138920f",
                             "name": "",
                             "rules": [
                                 {
                                     "t": "set",
                                     "p": "PH_Parameter.MaxTagesLaufzeit_min",
                                     "pt": "flow",
                                     "to": "payload",
                                     "tot": "msg"
                                 }
                             ],
                             "action": "",
                             "property": "",
                             "from": "",
                             "to": "",
                             "reg": false,
                             "x": 1530,
                             "y": 2980,
                             "wires": [
                                 [
                                     "d4c5239e5ff47822"
                                 ]
                             ]
                         },
                         {
                             "id": "d4c5239e5ff47822",
                             "type": "change",
                             "z": "d25606275138920f",
                             "name": "",
                             "rules": [
                                 {
                                     "t": "set",
                                     "p": "payload",
                                     "pt": "msg",
                                     "to": "PH_Parameter",
                                     "tot": "flow"
                                 }
                             ],
                             "action": "",
                             "property": "",
                             "from": "",
                             "to": "",
                             "reg": false,
                             "x": 1870,
                             "y": 2940,
                             "wires": [
                                 [
                                     "9f4b4cddf32c69fb"
                                 ]
                             ]
                         },
                         {
                             "id": "22fe457b460d3214",
                             "type": "ioBroker out",
                             "z": "d25606275138920f",
                             "name": "Parameter",
                             "topic": "0_userdata.0.Poolsteuerung.Parameter",
                             "ack": "true",
                             "autoCreate": "false",
                             "stateName": "",
                             "role": "",
                             "payloadType": "",
                             "readonly": "",
                             "stateUnit": "",
                             "stateMin": "",
                             "stateMax": "",
                             "x": 2210,
                             "y": 2940,
                             "wires": []
                         },
                         {
                             "id": "9f4b4cddf32c69fb",
                             "type": "json",
                             "z": "d25606275138920f",
                             "name": "",
                             "property": "payload",
                             "action": "",
                             "pretty": false,
                             "x": 2050,
                             "y": 2940,
                             "wires": [
                                 [
                                     "22fe457b460d3214"
                                 ]
                             ]
                         },
                         {
                             "id": "46f3c4494c51b112",
                             "type": "ioBroker in",
                             "z": "d25606275138920f",
                             "name": "Parameter",
                             "attrname": "payload",
                             "topic": "0_userdata.0.Poolsteuerung.Parameter",
                             "payloadType": "value",
                             "onlyack": "",
                             "func": "all",
                             "gap": "",
                             "fireOnStart": "true",
                             "outFormat": "MQTT",
                             "x": 560,
                             "y": 2940,
                             "wires": [
                                 [
                                     "3f76567ff2d9ebf0"
                                 ]
                             ]
                         },
                         {
                             "id": "3f76567ff2d9ebf0",
                             "type": "json",
                             "z": "d25606275138920f",
                             "name": "",
                             "property": "payload",
                             "action": "",
                             "pretty": false,
                             "x": 730,
                             "y": 2940,
                             "wires": [
                                 [
                                     "c0ebbc8c64b7b0cd",
                                     "4b28ddc52ba7ab15"
                                 ]
                             ]
                         },
                         {
                             "id": "f173af108d4b6003",
                             "type": "ui_group",
                             "name": "Parameter",
                             "tab": "5fb772105c6cc8b7",
                             "order": 3,
                             "disp": true,
                             "width": "6",
                             "collapse": false,
                             "className": ""
                         },
                         {
                             "id": "5fb772105c6cc8b7",
                             "type": "ui_tab",
                             "name": "Home",
                             "icon": "dashboard",
                             "disabled": false,
                             "hidden": false
                         }
                      ]
                      

                      B Offline
                      B Offline
                      BF0911
                      schrieb am zuletzt editiert von
                      #122

                      @mickym

                      Ahh, verstehe. Dann habe ich es verstanden.

                      Vielen, vielen Dank!

                      mickymM 1 Antwort Letzte Antwort
                      0
                      • B BF0911

                        @mickym

                        Ahh, verstehe. Dann habe ich es verstanden.

                        Vielen, vielen Dank!

                        mickymM Online
                        mickymM Online
                        mickym
                        Most Active
                        schrieb am zuletzt editiert von mickym
                        #123

                        @bf0911 Einmal musst natürlich auch das komplette Objekt nach dem Einlesen in deine Flowvariable einlesen, das hatte ich noch vergessen:

                        9d8089ab-208f-4623-b823-bcf01201b49d-image.png
                        a0ce0b39-4273-404b-983f-32d7cc5780d7-image.png

                        Ich frage mich nur im Nachhinein, warum Dein Skript alles mit globalen Variablen und x unterschiedlichen Flows gemacht hat. Wenn ich mir das bis jetzt so anschaue

                        48333882-a1dd-4395-bf49-c7ea1ab4c2ef-image.png

                        ist der Flow doch nicht so groß und komplex??

                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                        B 1 Antwort Letzte Antwort
                        0
                        • mickymM mickym

                          @bf0911 Einmal musst natürlich auch das komplette Objekt nach dem Einlesen in deine Flowvariable einlesen, das hatte ich noch vergessen:

                          9d8089ab-208f-4623-b823-bcf01201b49d-image.png
                          a0ce0b39-4273-404b-983f-32d7cc5780d7-image.png

                          Ich frage mich nur im Nachhinein, warum Dein Skript alles mit globalen Variablen und x unterschiedlichen Flows gemacht hat. Wenn ich mir das bis jetzt so anschaue

                          48333882-a1dd-4395-bf49-c7ea1ab4c2ef-image.png

                          ist der Flow doch nicht so groß und komplex??

                          B Offline
                          B Offline
                          BF0911
                          schrieb am zuletzt editiert von
                          #124

                          @mickym

                          Warum globale Variable etc benutzt wurden kann ich dir nicht sagen.

                          Mein Flow ist etwas größer als deiner bzw. wird noch größer wegen dem Dashboard usw

                          Ich hab den Flow mit dem Dashboard zu übernommen, aber es lassen sich keine Zahlen einstellen
                          Das springt immer

                          mickymM 2 Antworten Letzte Antwort
                          0
                          • B BF0911

                            @mickym

                            Warum globale Variable etc benutzt wurden kann ich dir nicht sagen.

                            Mein Flow ist etwas größer als deiner bzw. wird noch größer wegen dem Dashboard usw

                            Ich hab den Flow mit dem Dashboard zu übernommen, aber es lassen sich keine Zahlen einstellen
                            Das springt immer

                            mickymM Online
                            mickymM Online
                            mickym
                            Most Active
                            schrieb am zuletzt editiert von mickym
                            #125

                            @bf0911 Na wenn du es wirklich übernommen hast, dann sollte es nicht passieren.

                            Schau mal ob du die Nachrichten nicht durchreichst?

                            856825fa-dda0-4b1f-b5d4-1f92a99b394f-image.png

                            das muss natürlich deaktiviert sein.

                            Ggf. musst DU natürlich bei ALLEN Dashboard Feldern schauen, dass Du die Nachrichten nicht durchreichst!!! (Also auch nicht bei Schaltern(switches) etc.)

                            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                            B 1 Antwort Letzte Antwort
                            0
                            • B BF0911

                              @mickym

                              Warum globale Variable etc benutzt wurden kann ich dir nicht sagen.

                              Mein Flow ist etwas größer als deiner bzw. wird noch größer wegen dem Dashboard usw

                              Ich hab den Flow mit dem Dashboard zu übernommen, aber es lassen sich keine Zahlen einstellen
                              Das springt immer

                              mickymM Online
                              mickymM Online
                              mickym
                              Most Active
                              schrieb am zuletzt editiert von
                              #126

                              @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                              Ich hab den Flow mit dem Dashboard zu übernommen, aber es lassen sich keine Zahlen einstellen
                              Das springt immer

                              Und ggf. immer Debug Nodes an die letzte Node vorne und direkt dahinter machen. Prüfen, wenn Du das Kabel vorne trennst, ob es an ankommenden Nachrichten liegt oder nicht. Das ist ja nun das schöne, dass Du sowas gut debuggen kannst.

                              Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                              1 Antwort Letzte Antwort
                              0
                              • mickymM mickym

                                @bf0911 Na wenn du es wirklich übernommen hast, dann sollte es nicht passieren.

                                Schau mal ob du die Nachrichten nicht durchreichst?

                                856825fa-dda0-4b1f-b5d4-1f92a99b394f-image.png

                                das muss natürlich deaktiviert sein.

                                Ggf. musst DU natürlich bei ALLEN Dashboard Feldern schauen, dass Du die Nachrichten nicht durchreichst!!! (Also auch nicht bei Schaltern(switches) etc.)

                                B Offline
                                B Offline
                                BF0911
                                schrieb am zuletzt editiert von BF0911
                                #127

                                @mickym

                                Ist es bei mir!

                                Ich hab deinen Flow natürlich mit meinen Variablen angepasst.
                                Screenshot 2024-05-16 135642.png

                                Jetzt scheint es zu funktionieren, obwohl ich nichts geändert habe

                                mickymM 2 Antworten Letzte Antwort
                                0
                                • B BF0911

                                  @mickym

                                  Ist es bei mir!

                                  Ich hab deinen Flow natürlich mit meinen Variablen angepasst.
                                  Screenshot 2024-05-16 135642.png

                                  Jetzt scheint es zu funktionieren, obwohl ich nichts geändert habe

                                  mickymM Online
                                  mickymM Online
                                  mickym
                                  Most Active
                                  schrieb am zuletzt editiert von
                                  #128

                                  @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                                  Jetzt scheint es zu funktionieren, obwohl ich nichts geändert habe

                                  Na dann weiß ich auch nicht - und lässt sich ja auch nicht mehr nachvollziehen.

                                  Wenn ein undefined drin ist (wie bei der Pumpe ) oder was das für eine Node ist
                                  58e87989-3f4b-458e-9857-1cdf23803c70-image.png

                                  kann ich dir nicht sagen.

                                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                  1 Antwort Letzte Antwort
                                  0
                                  • B BF0911

                                    @mickym

                                    Ist es bei mir!

                                    Ich hab deinen Flow natürlich mit meinen Variablen angepasst.
                                    Screenshot 2024-05-16 135642.png

                                    Jetzt scheint es zu funktionieren, obwohl ich nichts geändert habe

                                    mickymM Online
                                    mickymM Online
                                    mickym
                                    Most Active
                                    schrieb am zuletzt editiert von
                                    #129

                                    @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                                    Jetzt scheint es zu funktionieren, obwohl ich nichts geändert habe

                                    Vielleicht war auch noch was von Deinem alten Flow aktiv - dass den Kontext gesetzt hat? - Ich würde Dir raten den alten Flow komplett zu deaktivieren - damit Du nur noch die Nodes ggf. hast, um die raus zu kopieren.

                                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                    B 1 Antwort Letzte Antwort
                                    0
                                    • mickymM mickym

                                      @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                                      Jetzt scheint es zu funktionieren, obwohl ich nichts geändert habe

                                      Vielleicht war auch noch was von Deinem alten Flow aktiv - dass den Kontext gesetzt hat? - Ich würde Dir raten den alten Flow komplett zu deaktivieren - damit Du nur noch die Nodes ggf. hast, um die raus zu kopieren.

                                      B Offline
                                      B Offline
                                      BF0911
                                      schrieb am zuletzt editiert von
                                      #130

                                      @mickym

                                      Danke, habe den Flow direkt deaktiviert.

                                      mickymM 1 Antwort Letzte Antwort
                                      0
                                      • B BF0911

                                        @mickym

                                        Danke, habe den Flow direkt deaktiviert.

                                        mickymM Online
                                        mickymM Online
                                        mickym
                                        Most Active
                                        schrieb am zuletzt editiert von
                                        #131

                                        @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                                        @mickym

                                        Danke, habe den Flow direkt deaktiviert.

                                        Wie gesagt auch für später ist es immer wichtig die Stellen, wo Du was ausgibst möglichst übersichtlich hälst. Im Idealfall einmal - manchmal auch an mehreren Stellen, um das Ganze übersichtlich zu halten.

                                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                        1 Antwort Letzte Antwort
                                        0
                                        • mickymM Online
                                          mickymM Online
                                          mickym
                                          Most Active
                                          schrieb am zuletzt editiert von
                                          #132

                                          Ich verabschiede mich dann mal, wenn Du noch was auf dem Herzen hast dann schreibs rein. Entweder bekommst dann eine Antwort direkt, aber ich geh ja mal davon aus, dass Du am Nachmittag dann wieder ins reale Leben abtauchst. 😉

                                          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                          B 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

                                          726

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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