Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [gelöst] Elegantere Programmierung?

NEWS

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

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

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

[gelöst] Elegantere Programmierung?

Geplant Angeheftet Gesperrt Verschoben JavaScript
325 Beiträge 10 Kommentatoren 64.6k Aufrufe 8 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.
  • S skorpil

    @paul53 waaaas!? Du ohne IT Ausbildung? Ich glaube es nicht 😂 Ich hätte meinen Kopf darauf verwettet, Du hättest Informatik studiert.

    Nun gut, dann probiere ich weiter eine Lösung für Tibber zu finden. Und wenn ich was habe, melde ich mich hier.

    OliverIOO Offline
    OliverIOO Offline
    OliverIO
    schrieb am zuletzt editiert von OliverIO
    #274

    @skorpil sagte in [gelöst] Elegantere Programmierung?:

    @paul53 waaaas!? Du ohne IT Ausbildung? Ich glaube es nicht 😂 Ich hätte meinen Kopf darauf verwettet, Du hättest Informatik studiert.

    Nun gut, dann probiere ich weiter eine Lösung für Tibber zu finden. Und wenn ich was habe, melde ich mich hier.

    sorry, hab leider auch keine IT-Ausbildung (und so wie ich manche kennen ist das auch nicht immer eine Auszeichnung :) )

    Wie so oft muss man hier mehrere Technologien kennen.
    1.) Javascript
    2) Eine Bibliothek mit der man http sprechen kann
    3) Eine Bibliothek, die OAuth kann
    4) und zum Schluss muss man graphQL können bzw. die Basiskonzepte verstehen.
    Du hast einen Link zum graphQL Explorer geschickt, der natürlich auch ein Token benötigt. Durch Druck auf den Knopf Demo-Token kann man damit erst mal grundsätzlich arbeiten. Wie das mit Load personal Token application token abgefragt wird und im Hintergrund dann ein AccessToken abgefragt wird, keine Ahnung. Das reagiert nicht so wie ich erwartet hätte

    Also zur groben Lösung

    1. Muss ich voraussetzen, sonst wird es zu schwierig
    2. Hier würde ich Axios empfehlen https://www.npmjs.com/package/axios
    3. Hier würde ich ein Aufsatz auf axios empfehlen https://www.npmjs.com/package/axios-oauth-client
      In deiner tibber oberfläche müsstest du dir irgendwo ein application token/client-secret erzeugen können. Das wird per request an den server übertragen und du erhälst ein oauth-token zurück, welches du dann bei jeder nachfolgenden Abfrage als http-header mit dem vorsatz BEARER mitschicken musst
      Hier unter Authorization ist es erklärt, wohl auch mit Link zur Seite wo du dir einen Token holen kannst.
      https://developer.tibber.com/docs/guides/calling-api
    4. Wie man dann Abfragen ausführt steht dann hier:
      https://developer.tibber.com/docs/guides/calling-api unter "Performing" Requests
      Als curl Befehl ist ein Beispiel aufgeführt, was du an Daten mitgeben musst (Authorization, ContentType und die eigentlichen Daten), das kannst du beim lesen der Axios-Doku fast direkt umsetzen, da sind auch Beispiele für javascript mit dabei.
      Als Daten musst du dann ein graphQL-Ausdruck mitschicken(in einem JSON eingepackt als Attribut query, siehe Beispiel), den du in dem Explorer vorher ausprobieren kannst (halt mit Demo-Daten oder du trägst da ein OAuth-token ein, den du mit 3 geholt hast, dann auch mit deinen Daten)
      Mit dem Explorer müsstest du sehr Detailliert angeben können welche Daten du zurückbekommen möchtest, leider funktioniert die Autovervollständigung und das laden des Schemas (rechte Seite) nicht richtig. Daher könnte es schwierig werden, die richtigen Angaben zu machen. Da musst mal dort nachfragen. Evtl muss man eingeloggt sein.

    Meine Adapter und Widgets
    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
    Links im Profil

    CodierknechtC S 2 Antworten Letzte Antwort
    1
    • OliverIOO OliverIO

      @skorpil sagte in [gelöst] Elegantere Programmierung?:

      @paul53 waaaas!? Du ohne IT Ausbildung? Ich glaube es nicht 😂 Ich hätte meinen Kopf darauf verwettet, Du hättest Informatik studiert.

      Nun gut, dann probiere ich weiter eine Lösung für Tibber zu finden. Und wenn ich was habe, melde ich mich hier.

      sorry, hab leider auch keine IT-Ausbildung (und so wie ich manche kennen ist das auch nicht immer eine Auszeichnung :) )

      Wie so oft muss man hier mehrere Technologien kennen.
      1.) Javascript
      2) Eine Bibliothek mit der man http sprechen kann
      3) Eine Bibliothek, die OAuth kann
      4) und zum Schluss muss man graphQL können bzw. die Basiskonzepte verstehen.
      Du hast einen Link zum graphQL Explorer geschickt, der natürlich auch ein Token benötigt. Durch Druck auf den Knopf Demo-Token kann man damit erst mal grundsätzlich arbeiten. Wie das mit Load personal Token application token abgefragt wird und im Hintergrund dann ein AccessToken abgefragt wird, keine Ahnung. Das reagiert nicht so wie ich erwartet hätte

      Also zur groben Lösung

      1. Muss ich voraussetzen, sonst wird es zu schwierig
      2. Hier würde ich Axios empfehlen https://www.npmjs.com/package/axios
      3. Hier würde ich ein Aufsatz auf axios empfehlen https://www.npmjs.com/package/axios-oauth-client
        In deiner tibber oberfläche müsstest du dir irgendwo ein application token/client-secret erzeugen können. Das wird per request an den server übertragen und du erhälst ein oauth-token zurück, welches du dann bei jeder nachfolgenden Abfrage als http-header mit dem vorsatz BEARER mitschicken musst
        Hier unter Authorization ist es erklärt, wohl auch mit Link zur Seite wo du dir einen Token holen kannst.
        https://developer.tibber.com/docs/guides/calling-api
      4. Wie man dann Abfragen ausführt steht dann hier:
        https://developer.tibber.com/docs/guides/calling-api unter "Performing" Requests
        Als curl Befehl ist ein Beispiel aufgeführt, was du an Daten mitgeben musst (Authorization, ContentType und die eigentlichen Daten), das kannst du beim lesen der Axios-Doku fast direkt umsetzen, da sind auch Beispiele für javascript mit dabei.
        Als Daten musst du dann ein graphQL-Ausdruck mitschicken(in einem JSON eingepackt als Attribut query, siehe Beispiel), den du in dem Explorer vorher ausprobieren kannst (halt mit Demo-Daten oder du trägst da ein OAuth-token ein, den du mit 3 geholt hast, dann auch mit deinen Daten)
        Mit dem Explorer müsstest du sehr Detailliert angeben können welche Daten du zurückbekommen möchtest, leider funktioniert die Autovervollständigung und das laden des Schemas (rechte Seite) nicht richtig. Daher könnte es schwierig werden, die richtigen Angaben zu machen. Da musst mal dort nachfragen. Evtl muss man eingeloggt sein.
      CodierknechtC Offline
      CodierknechtC Offline
      Codierknecht
      Developer Most Active
      schrieb am zuletzt editiert von
      #275

      @oliverio sagte in [gelöst] Elegantere Programmierung?:

      sorry, hab leider auch keine IT-Ausbildung

      Willkommen im Club :grin:

      und so wie ich manche kennen ist das auch nicht immer eine Auszeichnung

      Manchmal (oft) sogar kontraproduktiv.
      Ich habe jedenfalls die Erfahrung gemacht, dass es (in unserem Team) einfacher ist, einem IT-affinen Fachmann das Programmieren beizubringen als einem (studierten) Programmierer unsere Prozesse zu erklären.
      Der junge Kollege beißt sich daran seit 3 Jahren die Zähne aus :dizzy_face:

      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

      Proxmox 9.1.1 LXC|8 GB|Core i7-6700
      HmIP|ZigBee|Tasmota|Unifi
      Zabbix Certified Specialist
      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

      OliverIOO 1 Antwort Letzte Antwort
      2
      • CodierknechtC Codierknecht

        @oliverio sagte in [gelöst] Elegantere Programmierung?:

        sorry, hab leider auch keine IT-Ausbildung

        Willkommen im Club :grin:

        und so wie ich manche kennen ist das auch nicht immer eine Auszeichnung

        Manchmal (oft) sogar kontraproduktiv.
        Ich habe jedenfalls die Erfahrung gemacht, dass es (in unserem Team) einfacher ist, einem IT-affinen Fachmann das Programmieren beizubringen als einem (studierten) Programmierer unsere Prozesse zu erklären.
        Der junge Kollege beißt sich daran seit 3 Jahren die Zähne aus :dizzy_face:

        OliverIOO Offline
        OliverIOO Offline
        OliverIO
        schrieb am zuletzt editiert von OliverIO
        #276

        @codierknecht sagte in [gelöst] Elegantere Programmierung?:

        Prozesse zu erklären.
        Der junge Kollege beißt sich daran seit 3 Jahren die Zähne aus

        Da ich mich schon sehr umfangreich auch mit Prozessmanagement auskenne und schon viele Schulungen durchgeführt habe, kann ich sagen, das es Leute gibt, die es nie lernen werden, da sie nicht in der Lage sind komplexe Problemstellungen in kleinere aufzuteilen, zu abstrahieren und dann noch das richtige Maß der Granularität zu finden.

        Dann ist er aber auch kein guter Programmierer? Das ist für mich nämlich ein sehr verwandter Skill.
        Am besten mal 4 Wochen in den Fachbereich schicken und ihn dort mitarbeiten lassen

        Meine Adapter und Widgets
        TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
        Links im Profil

        CodierknechtC HomoranH 2 Antworten Letzte Antwort
        1
        • OliverIOO OliverIO

          @codierknecht sagte in [gelöst] Elegantere Programmierung?:

          Prozesse zu erklären.
          Der junge Kollege beißt sich daran seit 3 Jahren die Zähne aus

          Da ich mich schon sehr umfangreich auch mit Prozessmanagement auskenne und schon viele Schulungen durchgeführt habe, kann ich sagen, das es Leute gibt, die es nie lernen werden, da sie nicht in der Lage sind komplexe Problemstellungen in kleinere aufzuteilen, zu abstrahieren und dann noch das richtige Maß der Granularität zu finden.

          Dann ist er aber auch kein guter Programmierer? Das ist für mich nämlich ein sehr verwandter Skill.
          Am besten mal 4 Wochen in den Fachbereich schicken und ihn dort mitarbeiten lassen

          CodierknechtC Offline
          CodierknechtC Offline
          Codierknecht
          Developer Most Active
          schrieb am zuletzt editiert von
          #277

          [Smalltalk]

          @oliverio sagte in [gelöst] Elegantere Programmierung?:

          Dann ist er aber auch kein guter Programmierer?

          Sagen wir's mal so: Es hält sich in Grenzen ;-)
          Ich maße mir aber auch nicht an, das beurteilen zu können.
          DCOM / COM+ ist inzwischen aber auch reichlich exotisch und Delphi als Sprache leider auch etwas aus der Mode gekommen.

          Aber wie im SAP ein Materialstamm aufgebaut ist (A-, B-, C- und D-Segment) und wie daraus anhand von Primärbedarfen über die Stücklistenauflösung Fertigungsaufträge entstehen, sollte man nach 3 Jahren im Schlaf runterbeten können.

          Aber lassen wir das.
          Mühsam ernährt sich das Eichhörnchen - bis zu meinem Renteneintritt hat er's dann hoffentlich drauf.

          "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

          Proxmox 9.1.1 LXC|8 GB|Core i7-6700
          HmIP|ZigBee|Tasmota|Unifi
          Zabbix Certified Specialist
          Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

          S 1 Antwort Letzte Antwort
          1
          • OliverIOO OliverIO

            @skorpil sagte in [gelöst] Elegantere Programmierung?:

            @paul53 waaaas!? Du ohne IT Ausbildung? Ich glaube es nicht 😂 Ich hätte meinen Kopf darauf verwettet, Du hättest Informatik studiert.

            Nun gut, dann probiere ich weiter eine Lösung für Tibber zu finden. Und wenn ich was habe, melde ich mich hier.

            sorry, hab leider auch keine IT-Ausbildung (und so wie ich manche kennen ist das auch nicht immer eine Auszeichnung :) )

            Wie so oft muss man hier mehrere Technologien kennen.
            1.) Javascript
            2) Eine Bibliothek mit der man http sprechen kann
            3) Eine Bibliothek, die OAuth kann
            4) und zum Schluss muss man graphQL können bzw. die Basiskonzepte verstehen.
            Du hast einen Link zum graphQL Explorer geschickt, der natürlich auch ein Token benötigt. Durch Druck auf den Knopf Demo-Token kann man damit erst mal grundsätzlich arbeiten. Wie das mit Load personal Token application token abgefragt wird und im Hintergrund dann ein AccessToken abgefragt wird, keine Ahnung. Das reagiert nicht so wie ich erwartet hätte

            Also zur groben Lösung

            1. Muss ich voraussetzen, sonst wird es zu schwierig
            2. Hier würde ich Axios empfehlen https://www.npmjs.com/package/axios
            3. Hier würde ich ein Aufsatz auf axios empfehlen https://www.npmjs.com/package/axios-oauth-client
              In deiner tibber oberfläche müsstest du dir irgendwo ein application token/client-secret erzeugen können. Das wird per request an den server übertragen und du erhälst ein oauth-token zurück, welches du dann bei jeder nachfolgenden Abfrage als http-header mit dem vorsatz BEARER mitschicken musst
              Hier unter Authorization ist es erklärt, wohl auch mit Link zur Seite wo du dir einen Token holen kannst.
              https://developer.tibber.com/docs/guides/calling-api
            4. Wie man dann Abfragen ausführt steht dann hier:
              https://developer.tibber.com/docs/guides/calling-api unter "Performing" Requests
              Als curl Befehl ist ein Beispiel aufgeführt, was du an Daten mitgeben musst (Authorization, ContentType und die eigentlichen Daten), das kannst du beim lesen der Axios-Doku fast direkt umsetzen, da sind auch Beispiele für javascript mit dabei.
              Als Daten musst du dann ein graphQL-Ausdruck mitschicken(in einem JSON eingepackt als Attribut query, siehe Beispiel), den du in dem Explorer vorher ausprobieren kannst (halt mit Demo-Daten oder du trägst da ein OAuth-token ein, den du mit 3 geholt hast, dann auch mit deinen Daten)
              Mit dem Explorer müsstest du sehr Detailliert angeben können welche Daten du zurückbekommen möchtest, leider funktioniert die Autovervollständigung und das laden des Schemas (rechte Seite) nicht richtig. Daher könnte es schwierig werden, die richtigen Angaben zu machen. Da musst mal dort nachfragen. Evtl muss man eingeloggt sein.
            S Offline
            S Offline
            skorpil
            schrieb am zuletzt editiert von
            #278

            @oliverio toll Dankeschön. Ich werde mich daran versuchen.

            Im übrigen, unglaublich, ich hätte gedacht, dass ihr alle hier IT studiert habt

            1 Antwort Letzte Antwort
            0
            • OliverIOO OliverIO

              @codierknecht sagte in [gelöst] Elegantere Programmierung?:

              Prozesse zu erklären.
              Der junge Kollege beißt sich daran seit 3 Jahren die Zähne aus

              Da ich mich schon sehr umfangreich auch mit Prozessmanagement auskenne und schon viele Schulungen durchgeführt habe, kann ich sagen, das es Leute gibt, die es nie lernen werden, da sie nicht in der Lage sind komplexe Problemstellungen in kleinere aufzuteilen, zu abstrahieren und dann noch das richtige Maß der Granularität zu finden.

              Dann ist er aber auch kein guter Programmierer? Das ist für mich nämlich ein sehr verwandter Skill.
              Am besten mal 4 Wochen in den Fachbereich schicken und ihn dort mitarbeiten lassen

              HomoranH Nicht stören
              HomoranH Nicht stören
              Homoran
              Global Moderator Administrators
              schrieb am zuletzt editiert von
              #279

              @oliverio das ist aber auch hier im Forum oft der echte Haken!
              Es ist sehr oft nicht wirklich "Ich kann kein Java", meist hapert's schon am strukturierten Denken / Herangehensweise

              kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

              der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

              1 Antwort Letzte Antwort
              1
              • CodierknechtC Codierknecht

                [Smalltalk]

                @oliverio sagte in [gelöst] Elegantere Programmierung?:

                Dann ist er aber auch kein guter Programmierer?

                Sagen wir's mal so: Es hält sich in Grenzen ;-)
                Ich maße mir aber auch nicht an, das beurteilen zu können.
                DCOM / COM+ ist inzwischen aber auch reichlich exotisch und Delphi als Sprache leider auch etwas aus der Mode gekommen.

                Aber wie im SAP ein Materialstamm aufgebaut ist (A-, B-, C- und D-Segment) und wie daraus anhand von Primärbedarfen über die Stücklistenauflösung Fertigungsaufträge entstehen, sollte man nach 3 Jahren im Schlaf runterbeten können.

                Aber lassen wir das.
                Mühsam ernährt sich das Eichhörnchen - bis zu meinem Renteneintritt hat er's dann hoffentlich drauf.

                S Offline
                S Offline
                skorpil
                schrieb am zuletzt editiert von
                #280

                @codierknecht @paul53 @OliverIO @Homoran @haus-automatisierung [small talk] ihr seid klasse hier. Es macht auch abseits von konkreten Fragen große Freude, Euch zuzuhören. Danke für Eure Geduld mit mir. Ich lerne viel. So, Lobhudelei Ende!

                1 Antwort Letzte Antwort
                1
                • S Offline
                  S Offline
                  skorpil
                  schrieb am zuletzt editiert von
                  #281

                  Ich habe mir dieses Javascript auf dem Umweg über Blockly (weil ich nicht das auch noch lernen will) zusammengestrickt:

                  on({id: "javascript.0.BenutzerVariablen.tibber_DP"/*tibber_DP*/, change: "ne"}, async function (obj) {
                    var value = obj.state.val;
                    var oldValue = obj.oldState.val;
                    setState("javascript.0.BenutzerVariablen.tibber_power"/*tibber_power*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'power'), true);
                    setState("javascript.0.BenutzerVariablen.tibber_lastMeterConsumption"/*tibber_lastMeterConsumption*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'lastMeterConsumption'), true);
                    setState("javascript.0.BenutzerVariablen.tibber_accumulatedConsumption"/*tibber_accumulatedConsumption*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'accumulatedConsumption'), true);
                    setState("javascript.0.BenutzerVariablen.tibber_minPower"/*tibber_minPower*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'minPower'), true);
                    setState("javascript.0.BenutzerVariablen.tibber_averagePower"/*tibber_averagePower*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'averagePower'), true);
                    setState("javascript.0.BenutzerVariablen.tibber_maxPower"/*tibber_maxPower*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'maxPower'), true);
                  });
                  

                  Stichwort "elegante Programmierung": geht das nicht auch viel kürzer? Denn große Teile des Scripts mit Try und catch etc. wiederholen sich ja immer. Das müßte doch auch über eine Funktion gehen? Oder lieber so lassen?

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • S skorpil

                    Ich habe mir dieses Javascript auf dem Umweg über Blockly (weil ich nicht das auch noch lernen will) zusammengestrickt:

                    on({id: "javascript.0.BenutzerVariablen.tibber_DP"/*tibber_DP*/, change: "ne"}, async function (obj) {
                      var value = obj.state.val;
                      var oldValue = obj.oldState.val;
                      setState("javascript.0.BenutzerVariablen.tibber_power"/*tibber_power*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'power'), true);
                      setState("javascript.0.BenutzerVariablen.tibber_lastMeterConsumption"/*tibber_lastMeterConsumption*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'lastMeterConsumption'), true);
                      setState("javascript.0.BenutzerVariablen.tibber_accumulatedConsumption"/*tibber_accumulatedConsumption*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'accumulatedConsumption'), true);
                      setState("javascript.0.BenutzerVariablen.tibber_minPower"/*tibber_minPower*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'minPower'), true);
                      setState("javascript.0.BenutzerVariablen.tibber_averagePower"/*tibber_averagePower*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'averagePower'), true);
                      setState("javascript.0.BenutzerVariablen.tibber_maxPower"/*tibber_maxPower*/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'maxPower'), true);
                    });
                    

                    Stichwort "elegante Programmierung": geht das nicht auch viel kürzer? Denn große Teile des Scripts mit Try und catch etc. wiederholen sich ja immer. Das müßte doch auch über eine Funktion gehen? Oder lieber so lassen?

                    paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von paul53
                    #282

                    @skorpil sagte: Das müßte doch auch über eine Funktion gehen?

                    Über eine Zwischenvariable object:

                    Blockly_temp.JPG

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

                    1 Antwort Letzte Antwort
                    0
                    • S Offline
                      S Offline
                      skorpil
                      schrieb am zuletzt editiert von skorpil
                      #283

                      @paul53 ich bin schon wieder lost. Zwei Fragen:

                      1. wie setzte ich in Blockly den "WERT"? Wo versteckt sich dieses Blockly. Ich finde es nicht.
                        Unbenannt-2.jpg

                      2. Ich habe mir in der CCU eine SV "tibber-power" angelegt. Mit dem Script

                      setState('hm-rega.0.72161'/**/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'power'), true);
                      

                      wird die Variable auch ständig aktualisiert. In den Objekten im iobroker sieht man das gut. Das Script funktioniert also!
                      Unbenannt-1.jpg

                      Nur, in der CCU wird die SV nicht aktualisiert.
                      Unbenannt-0jpg.jpg

                      Wo ist mein Denkfehler?

                      paul53P 1 Antwort Letzte Antwort
                      0
                      • S skorpil

                        @paul53 ich bin schon wieder lost. Zwei Fragen:

                        1. wie setzte ich in Blockly den "WERT"? Wo versteckt sich dieses Blockly. Ich finde es nicht.
                          Unbenannt-2.jpg

                        2. Ich habe mir in der CCU eine SV "tibber-power" angelegt. Mit dem Script

                        setState('hm-rega.0.72161'/**/, jsonataExpression((function () { try {return JSON.parse(getState("javascript.0.BenutzerVariablen.tibber_DP").val);} catch(e) {return {};}})(),'power'), true);
                        

                        wird die Variable auch ständig aktualisiert. In den Objekten im iobroker sieht man das gut. Das Script funktioniert also!
                        Unbenannt-1.jpg

                        Nur, in der CCU wird die SV nicht aktualisiert.
                        Unbenannt-0jpg.jpg

                        Wo ist mein Denkfehler?

                        paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von
                        #284

                        @skorpil sagte: "WERT"? Wo versteckt sich dieses Blockly.

                        Unter "Trigger"

                        Blockly_DP_Props.JPG

                        @skorpil sagte in [gelöst] Elegantere Programmierung?:

                        Nur, in der CCU wird die SV nicht aktualisiert.

                        Für eine SV muss "steuere" anstelle von "aktualisiere" verwendet werden, sonst wird nicht gesendet.

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

                        S 1 Antwort Letzte Antwort
                        1
                        • paul53P paul53

                          @skorpil sagte: "WERT"? Wo versteckt sich dieses Blockly.

                          Unter "Trigger"

                          Blockly_DP_Props.JPG

                          @skorpil sagte in [gelöst] Elegantere Programmierung?:

                          Nur, in der CCU wird die SV nicht aktualisiert.

                          Für eine SV muss "steuere" anstelle von "aktualisiere" verwendet werden, sonst wird nicht gesendet.

                          S Offline
                          S Offline
                          skorpil
                          schrieb am zuletzt editiert von
                          #285

                          @paul53 danke, jetzt klappts

                          1 Antwort Letzte Antwort
                          0
                          • S Offline
                            S Offline
                            skorpil
                            schrieb am zuletzt editiert von
                            #286

                            @paul53
                            ich bin gerade dabei, mir ein Script zu bauen, in dem ich immer wieder eine bestimmte Funktion benötige. Und zwar diese hier:

                            function getDeviceID(expression) {
                              const parts = expression.split('.'); // Aufteilen des Ausdrucks in Teile
                              if (parts.length >= 3) {
                                return parts[2]; // Rückgabe des dritten Teils (Geräte-ID)
                                /* 1. Teil = Name Adapterinstanz
                                   2. Teil = Nummer Adapterinstanz
                                   3. Teil = Geraete ID
                                   4. Teil = Geraete Kanal
                                   5. Teil = Zustandsvariable
                                */   
                              } else {
                                return null; // Wenn der Ausdruck nicht die erwartete Form hat, wird null zurückgegeben
                              }
                            }
                            

                            Um es übersichtlicher zu gestalten, habe ich diese Function unter global als eigenes Script mit dem Namen "Funktion GeraeteID" abgelegt und rufe die Funktion aus einem anderen Script wiefolgt auf

                            const thermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
                            const deviceID = getDeviceID(thermKueche);
                            log(deviceID); // Ausgabe: "JEQ0553018"
                            

                            Wenn ich unter global die Funktion "Funktion GeraeteID" modifiziere, meldet das Protokoll "Instanz ist deaktiviert" und es dauert einige Zeit. Danach funktioniert alles.

                            Warum ist das so? Oder sollte ich die wiederholt benötigte Funktion doch besser im aufrufenden Script selber unterbringen? Was ist richtig und sinnvoll?

                            paul53P 2 Antworten Letzte Antwort
                            0
                            • S skorpil

                              @paul53
                              ich bin gerade dabei, mir ein Script zu bauen, in dem ich immer wieder eine bestimmte Funktion benötige. Und zwar diese hier:

                              function getDeviceID(expression) {
                                const parts = expression.split('.'); // Aufteilen des Ausdrucks in Teile
                                if (parts.length >= 3) {
                                  return parts[2]; // Rückgabe des dritten Teils (Geräte-ID)
                                  /* 1. Teil = Name Adapterinstanz
                                     2. Teil = Nummer Adapterinstanz
                                     3. Teil = Geraete ID
                                     4. Teil = Geraete Kanal
                                     5. Teil = Zustandsvariable
                                  */   
                                } else {
                                  return null; // Wenn der Ausdruck nicht die erwartete Form hat, wird null zurückgegeben
                                }
                              }
                              

                              Um es übersichtlicher zu gestalten, habe ich diese Function unter global als eigenes Script mit dem Namen "Funktion GeraeteID" abgelegt und rufe die Funktion aus einem anderen Script wiefolgt auf

                              const thermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
                              const deviceID = getDeviceID(thermKueche);
                              log(deviceID); // Ausgabe: "JEQ0553018"
                              

                              Wenn ich unter global die Funktion "Funktion GeraeteID" modifiziere, meldet das Protokoll "Instanz ist deaktiviert" und es dauert einige Zeit. Danach funktioniert alles.

                              Warum ist das so? Oder sollte ich die wiederholt benötigte Funktion doch besser im aufrufenden Script selber unterbringen? Was ist richtig und sinnvoll?

                              paul53P Offline
                              paul53P Offline
                              paul53
                              schrieb am zuletzt editiert von paul53
                              #287

                              @skorpil sagte: "Funktion GeraeteID" modifiziere, meldet das Protokoll "Instanz ist deaktiviert" und es dauert einige Zeit. Danach funktioniert alles.

                              Wenn globale Skripte modifiziert werden, müssen anschließend alle anderen Skripte kompiliert werden, da globale Skripte in alle anderen Skripte eingefügt werden. Das dauert etwas.

                              @skorpil sagte in [gelöst] Elegantere Programmierung?:

                              Was ist richtig und sinnvoll?

                              Genau für Deine Situation, dass eigene Funktionen häufig verwendet werden, sind globale Skripte gedacht.

                              Anmerkung:

                              else return null
                              

                              ist unnötig, da andernfalls undefined zurück gegeben wird, was genauso wie null geprüft wird.

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

                              S 1 Antwort Letzte Antwort
                              1
                              • paul53P paul53

                                @skorpil sagte: "Funktion GeraeteID" modifiziere, meldet das Protokoll "Instanz ist deaktiviert" und es dauert einige Zeit. Danach funktioniert alles.

                                Wenn globale Skripte modifiziert werden, müssen anschließend alle anderen Skripte kompiliert werden, da globale Skripte in alle anderen Skripte eingefügt werden. Das dauert etwas.

                                @skorpil sagte in [gelöst] Elegantere Programmierung?:

                                Was ist richtig und sinnvoll?

                                Genau für Deine Situation, dass eigene Funktionen häufig verwendet werden, sind globale Skripte gedacht.

                                Anmerkung:

                                else return null
                                

                                ist unnötig, da andernfalls undefined zurück gegeben wird, was genauso wie null geprüft wird.

                                S Offline
                                S Offline
                                skorpil
                                schrieb am zuletzt editiert von skorpil
                                #288

                                @paul53 super. Danke. Nun noch eine Fragezur Verwendung der ON Anweisung:

                                on({id: urlaub, change: 'ne', val: 0} && {id: sommer, change: 'ne', val: 0} , function () {
                                

                                Der weitere Teil des Scripts soll nur ausgeführt werden, wenn die (vorher definierten Variablen "sommer" und "urlaub" beide den Wert 0 haben. Ist das dann so richtig?

                                paul53P 1 Antwort Letzte Antwort
                                0
                                • S skorpil

                                  @paul53 super. Danke. Nun noch eine Fragezur Verwendung der ON Anweisung:

                                  on({id: urlaub, change: 'ne', val: 0} && {id: sommer, change: 'ne', val: 0} , function () {
                                  

                                  Der weitere Teil des Scripts soll nur ausgeführt werden, wenn die (vorher definierten Variablen "sommer" und "urlaub" beide den Wert 0 haben. Ist das dann so richtig?

                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  schrieb am zuletzt editiert von
                                  #289

                                  @skorpil sagte: beide den Wert 0 haben. Ist das dann so richtig?

                                  Nein, man kann im Trigger keine Werte unterschiedlicher Datenpunkte per UND verknüpfen.

                                  on([urlaub, sommer], function () { // triggert bei Wertänderung eines DP
                                     if(getState(urlaub).val == 0 && getstate(sommer).val == 0) {
                                     }
                                  });
                                  

                                  Die Variablen sommer und urlaub müssen Datenpunkt-IDs enthalten.

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

                                  S 1 Antwort Letzte Antwort
                                  1
                                  • paul53P paul53

                                    @skorpil sagte: beide den Wert 0 haben. Ist das dann so richtig?

                                    Nein, man kann im Trigger keine Werte unterschiedlicher Datenpunkte per UND verknüpfen.

                                    on([urlaub, sommer], function () { // triggert bei Wertänderung eines DP
                                       if(getState(urlaub).val == 0 && getstate(sommer).val == 0) {
                                       }
                                    });
                                    

                                    Die Variablen sommer und urlaub müssen Datenpunkt-IDs enthalten.

                                    S Offline
                                    S Offline
                                    skorpil
                                    schrieb am zuletzt editiert von
                                    #290

                                    @paul53 sagte in [gelöst] Elegantere Programmierung?:

                                    on([urlaub, sommer], function () { // triggert bei Wertänderung eines DP if(getState(urlaub).val == 0 && getstate(sommer).val == 0) {

                                    Danke. Ich tappe dummerweise immer wieder in die gleichen Fallen.

                                    1 Antwort Letzte Antwort
                                    0
                                    • S skorpil

                                      @paul53
                                      ich bin gerade dabei, mir ein Script zu bauen, in dem ich immer wieder eine bestimmte Funktion benötige. Und zwar diese hier:

                                      function getDeviceID(expression) {
                                        const parts = expression.split('.'); // Aufteilen des Ausdrucks in Teile
                                        if (parts.length >= 3) {
                                          return parts[2]; // Rückgabe des dritten Teils (Geräte-ID)
                                          /* 1. Teil = Name Adapterinstanz
                                             2. Teil = Nummer Adapterinstanz
                                             3. Teil = Geraete ID
                                             4. Teil = Geraete Kanal
                                             5. Teil = Zustandsvariable
                                          */   
                                        } else {
                                          return null; // Wenn der Ausdruck nicht die erwartete Form hat, wird null zurückgegeben
                                        }
                                      }
                                      

                                      Um es übersichtlicher zu gestalten, habe ich diese Function unter global als eigenes Script mit dem Namen "Funktion GeraeteID" abgelegt und rufe die Funktion aus einem anderen Script wiefolgt auf

                                      const thermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
                                      const deviceID = getDeviceID(thermKueche);
                                      log(deviceID); // Ausgabe: "JEQ0553018"
                                      

                                      Wenn ich unter global die Funktion "Funktion GeraeteID" modifiziere, meldet das Protokoll "Instanz ist deaktiviert" und es dauert einige Zeit. Danach funktioniert alles.

                                      Warum ist das so? Oder sollte ich die wiederholt benötigte Funktion doch besser im aufrufenden Script selber unterbringen? Was ist richtig und sinnvoll?

                                      paul53P Offline
                                      paul53P Offline
                                      paul53
                                      schrieb am zuletzt editiert von paul53
                                      #291

                                      @skorpil sagte: Funktion benötige. Und zwar diese hier:

                                      Das kann man stark verkürzen.

                                      function getDeviceID(expression) {
                                        return expression.split('.')[2]; // Rückgabe des dritten Teils (Geräte-ID)
                                      }
                                      

                                      Die Frage ist, ob es sich bei diesem Einzeiler lohnt, eine Funktion zu verwenden.

                                      const thermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
                                      const deviceID = thermKueche.split('.')[2];
                                      log(deviceID); // Ausgabe: "JEQ0553018"
                                      

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

                                      S 1 Antwort Letzte Antwort
                                      0
                                      • paul53P paul53

                                        @skorpil sagte: Funktion benötige. Und zwar diese hier:

                                        Das kann man stark verkürzen.

                                        function getDeviceID(expression) {
                                          return expression.split('.')[2]; // Rückgabe des dritten Teils (Geräte-ID)
                                        }
                                        

                                        Die Frage ist, ob es sich bei diesem Einzeiler lohnt, eine Funktion zu verwenden.

                                        const thermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
                                        const deviceID = thermKueche.split('.')[2];
                                        log(deviceID); // Ausgabe: "JEQ0553018"
                                        
                                        S Offline
                                        S Offline
                                        skorpil
                                        schrieb am zuletzt editiert von
                                        #292

                                        @paul53 da hast du sehr recht Paul, für eine einzige Zeile lohnt sich der Aufwand sicher nicht . Ich habe aber insgesamt 4 Einstellungen, die bearbeitet werden müssen. Ich bin noch nicht so weit Komma aber hier schon mal mein Programm:

                                        // ###########################################
                                        //            Deklarationen
                                        //     (An- UND ABwesenheit detektieren)
                                        // ###########################################
                                        
                                        const urlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
                                        const sommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
                                        
                                        
                                            // Variable zur Einstellung des Thermometers
                                            var modus = 1; // 1 = AUTO; 2 = CEN
                                        
                                        const thermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
                                        const thermDieleTreppenhaus = 'hm-rpc.0.JEQ0552520.2.SETPOINT'/*Thermostat Diele Treppenhaus 1 SETPOINT*/;
                                        const thermEsszimmer = 'hm-rpc.0.JEQ0553158.2.SETPOINT'/*Thermostat Esszimmer 1 SETPOINT*/;
                                        const thermWohnzimmer = 'hm-rpc.0.JEQ0552318.2.SETPOINT'/*Thermostat Wohnzimmer 1 SETPOINT*/;
                                        
                                        // ausführen nur, wenn Urlaub aus und Sommer aus
                                        on([urlaub, sommer], function () { // triggert bei Wertänderung eines DP
                                           if(getState(urlaub).val == 0 && getstate(sommer).val == 0) {
                                        
                                            // Kueche
                                            // Auslesen der GeraeteID via global function getDeviceID
                                            var deviceID = getDeviceID(thermKueche);
                                            // log(deviceID); // Ausgabe: "JEQ0553018"
                                            // Modus des Thermometers einstellen via global function thermometerSetzen
                                            thermometerSetzen(deviceID, modus);
                                            // Temperatur einstellen
                                            setState(thermKueche,22);
                                        
                                            // DieleTreppenhaus
                                            deviceID = getDeviceID(thermDieleTreppenhaus);
                                            thermometerSetzen(deviceID, modus);
                                            setState(thermDieleTreppenhaus,19);
                                        
                                            // Esszimmer
                                            deviceID = getDeviceID(thermEsszimmer);
                                            thermometerSetzen(deviceID, modus);
                                            setState(thermEsszimmer,22);
                                        
                                            // Wohnzimmer
                                            deviceID = getDeviceID(thermWohnzimmer);
                                            thermometerSetzen(deviceID, modus);
                                            setState(thermWohnzimmer,22);
                                           } // Ende IF
                                        }); //Ende ON
                                        
                                        

                                        die beiden zugehörigen Funktionen habe ich im global Bereich definiert.

                                        function getDeviceID(expression) {
                                          const parts = expression.split('.'); // Aufteilen des Ausdrucks in Teile
                                          if (parts.length >= 3) {
                                            return parts[2]; // Rückgabe des dritten Teils (Geräte-ID)
                                            /* 1. Teil = Name Adapterinstanz
                                               2. Teil = Nummer Adapterinstanz
                                               3. Teil = Geraete ID
                                               4. Teil = Geraete Kanal
                                               5. Teil = Zustandsvariable
                                            */   
                                          } else {
                                            return null; // Wenn der Ausdruck nicht die erwartete Form hat, wird null zurückgegeben
                                          }
                                        }
                                        
                                        

                                        und

                                        
                                        function thermometerSetzen(geraetKanal, modus) {
                                        sendTo('hm-rpc.0', 'putParamset', {ID: geraetKanal, paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': modus}}, res => {
                                                log(res);
                                            });
                                        };    
                                        

                                        Ziel der ganzen Programmierung ist es wieder, ein umfangreiches HM Programm in den iobroker zu transferieren. Und hierum geht es:
                                        Unbenannt-1.jpg

                                        paul53P 1 Antwort Letzte Antwort
                                        0
                                        • S skorpil

                                          @paul53 da hast du sehr recht Paul, für eine einzige Zeile lohnt sich der Aufwand sicher nicht . Ich habe aber insgesamt 4 Einstellungen, die bearbeitet werden müssen. Ich bin noch nicht so weit Komma aber hier schon mal mein Programm:

                                          // ###########################################
                                          //            Deklarationen
                                          //     (An- UND ABwesenheit detektieren)
                                          // ###########################################
                                          
                                          const urlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
                                          const sommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
                                          
                                          
                                              // Variable zur Einstellung des Thermometers
                                              var modus = 1; // 1 = AUTO; 2 = CEN
                                          
                                          const thermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
                                          const thermDieleTreppenhaus = 'hm-rpc.0.JEQ0552520.2.SETPOINT'/*Thermostat Diele Treppenhaus 1 SETPOINT*/;
                                          const thermEsszimmer = 'hm-rpc.0.JEQ0553158.2.SETPOINT'/*Thermostat Esszimmer 1 SETPOINT*/;
                                          const thermWohnzimmer = 'hm-rpc.0.JEQ0552318.2.SETPOINT'/*Thermostat Wohnzimmer 1 SETPOINT*/;
                                          
                                          // ausführen nur, wenn Urlaub aus und Sommer aus
                                          on([urlaub, sommer], function () { // triggert bei Wertänderung eines DP
                                             if(getState(urlaub).val == 0 && getstate(sommer).val == 0) {
                                          
                                              // Kueche
                                              // Auslesen der GeraeteID via global function getDeviceID
                                              var deviceID = getDeviceID(thermKueche);
                                              // log(deviceID); // Ausgabe: "JEQ0553018"
                                              // Modus des Thermometers einstellen via global function thermometerSetzen
                                              thermometerSetzen(deviceID, modus);
                                              // Temperatur einstellen
                                              setState(thermKueche,22);
                                          
                                              // DieleTreppenhaus
                                              deviceID = getDeviceID(thermDieleTreppenhaus);
                                              thermometerSetzen(deviceID, modus);
                                              setState(thermDieleTreppenhaus,19);
                                          
                                              // Esszimmer
                                              deviceID = getDeviceID(thermEsszimmer);
                                              thermometerSetzen(deviceID, modus);
                                              setState(thermEsszimmer,22);
                                          
                                              // Wohnzimmer
                                              deviceID = getDeviceID(thermWohnzimmer);
                                              thermometerSetzen(deviceID, modus);
                                              setState(thermWohnzimmer,22);
                                             } // Ende IF
                                          }); //Ende ON
                                          
                                          

                                          die beiden zugehörigen Funktionen habe ich im global Bereich definiert.

                                          function getDeviceID(expression) {
                                            const parts = expression.split('.'); // Aufteilen des Ausdrucks in Teile
                                            if (parts.length >= 3) {
                                              return parts[2]; // Rückgabe des dritten Teils (Geräte-ID)
                                              /* 1. Teil = Name Adapterinstanz
                                                 2. Teil = Nummer Adapterinstanz
                                                 3. Teil = Geraete ID
                                                 4. Teil = Geraete Kanal
                                                 5. Teil = Zustandsvariable
                                              */   
                                            } else {
                                              return null; // Wenn der Ausdruck nicht die erwartete Form hat, wird null zurückgegeben
                                            }
                                          }
                                          
                                          

                                          und

                                          
                                          function thermometerSetzen(geraetKanal, modus) {
                                          sendTo('hm-rpc.0', 'putParamset', {ID: geraetKanal, paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': modus}}, res => {
                                                  log(res);
                                              });
                                          };    
                                          

                                          Ziel der ganzen Programmierung ist es wieder, ein umfangreiches HM Programm in den iobroker zu transferieren. Und hierum geht es:
                                          Unbenannt-1.jpg

                                          paul53P Offline
                                          paul53P Offline
                                          paul53
                                          schrieb am zuletzt editiert von paul53
                                          #293

                                          @skorpil sagte:

                                          function thermometerSetzen(geraetKanal, modus) {                                                                                                                                                                            
                                              sendTo('hm-rpc.0', 'putParamset', {ID: geraetKanal, paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': modus}}, res => {                                                                                                                                                                                    
                                                  log(res);                                                                                                                                                                                
                                              }); 
                                          };
                                          

                                          Du hast auch noch die alten HM-CC-TC?
                                          Dann würde ich das Aufsplitten der ID auch in dieser Funktion machen.

                                          function thermometerSetzen(idKanal, modus) {
                                              let ID = idKanal.split('.');
                                              ID = ID[2] + ':' + ID[3];
                                              sendTo('hm-rpc.0', 'putParamset', {ID: ID, paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': modus}}, res => {
                                                  if(res.error) log(res.error, 'warn');
                                              }); 
                                          };
                                          

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

                                          S 1 Antwort Letzte Antwort
                                          1
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          882

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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