Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Grünbeck SC18 Daten mit JS auslesen

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    Grünbeck SC18 Daten mit JS auslesen

    This topic has been deleted. Only users with topic management privileges can see it.
    • A
      ArnoD last edited by

      hatte jetzt wieder etwas Zeit. ☺

      @smartboart wen der Regenerationsstart nicht gesendet wird rufe ich die Funktion "RegenerationStart" jede Sekunde neu auf, bis der Befehl gesendet werden kann. Die eine Sekunde Verzögerung verhindert nur, dass der Arbeitsspeicher durch die Schleife nicht lahmgelegt wird.
      Den Kopierfehler habe ich korrigiert. Danke.

      @schmid_no1 ich habe noch nicht ganz verstanden, was bei dir das Problem ist. Funktioniert nur die manuelle Regeneration nicht mehr oder hängt das Script ?
      Was steht den im Logfile ?

      1 Reply Last reply Reply Quote 0
      • A
        ArnoD last edited by

        Bei mir funktioniert soweit alles, bis auf den bekannten Fehler "send flag is true" der ein bis zweimal am Tag auftritt. Habe auch die manuelle Regeneration bis jetzt vier mal verwendet ohne Fehler.

        smartboart 1 Reply Last reply Reply Quote 0
        • smartboart
          smartboart @ArnoD last edited by smartboart

          @ArnoD
          Also ich denke das hier nur einmal nach einer Sekunde getriggert wird...
          Oder stehe ich auf dem Schlauch

          setTimeout(RegenerationStart, 1000);
          

          Wenn ich auf dem Schlauch stehe.. Wie beendest du dann den den trigger?

          1 Reply Last reply Reply Quote 0
          • A
            ArnoD last edited by

            on({id:idRegStart,val:true,change:'ne'}, function RegenerationStart (obj){
            

            RegenerationStart ist eine Funktion die sich selber jede sekunde triggert bis

            if(KeineRueckmeldung == true){
            	merker = true;
            	setTimeout(RegenerationStart, 1000);
            	if (debug) {console.log('Befehl zum Regeneratiosstart ging wegen fehlender Rückmeldung nicht durch')}
            } 
            

            die Variable KeineRueckmeldung false ist.

            smartboart 1 Reply Last reply Reply Quote 0
            • A
              ArnoD last edited by

              Wenn ich jetzt so nachdenke, sollte ich das Ganze mit einem Zähler noch auf maximal 60 Durchläufe begrenzen, falls die Anlage aus irgendeinem Grund keine Antwort schickt. Soll ja vorkommen 🙂

              1 Reply Last reply Reply Quote 0
              • S
                schmid_no1 last edited by

                @ArnoD vielleicht triggere ich das falsch.
                Also ich geh hin und sende mit einem butto true
                Wenn das Script schon ein paar Stunden gelaufen ist bleibt in den Objekten true stehen wenn ich das Script neu starte verschwindet das true sofort wieder und Sekunden später werden die Fehler ausgelesen das gleiche bei der Regeneration.
                Fehler bekomme ich keine.

                smartboart 1 Reply Last reply Reply Quote 0
                • smartboart
                  smartboart @schmid_no1 last edited by smartboart

                  @schmid_no1 //*** Ausseneingriff ******

                  createState(instanz + PfadEbene1 + PfadEbene2[7] + 'Regenerationsstart', {def:'false',name:'Regenerationsstart',type:'boolean',role:'State',desc: 'State zum starten der Regeneration'});
                  

                  Triggern solltest du mit dem ausseneingriff State Regenerationsstart über vis...eDen setzt du auf true mit nem button. Der State setzt sich nach einer Sekunde selbst zurück auf false...
                  habe da ein Button genommen und für true und false verschiedene Bilder hinterlegt..Dann kannst du gleich am Button sehen, wenn er wieder nach einer Sekunde zurück gesetzt wird.

                  Beim Fehlerspeicher wird sofort auf false gesetzt sobal der Trigeer durch ging...Da habe ich auch ein setStateDeayed 1*1000 zum false setzen eingebaut....
                  Auch hier wird mit dem Ausseneingriff State getriggert.

                  setStateDelayed(instanz + PfadEbene1 + PfadEbene2[7]+'Fehlerspeicher',false,1*1000);
                  

                  Vlt. übernimmt ArnoD das auch dort... Beim Fehlerspeicher gibt es aber keinen Merker..

                  1 Reply Last reply Reply Quote 0
                  • smartboart
                    smartboart @ArnoD last edited by smartboart

                    @ArnoD Ah jetzt vertsehe ich sorry, hab hier voll auf dem schlauch gestanden..Ganz simpel aber genial....ist ja ja klar die Funktion triggert sich immer wieder selbst bi der Befehl durchgeht...Das ist natürlich besser wie ständig zu triggern...So einfach gelöst dass ich es nicht gesehen habe...Prima..
                    Wenn du es möchtest kann ich meine views auch zur Verfügung stellen...
                    Habe noch eine mit historie charts..

                    Unbenannt.PNG

                    1 Reply Last reply Reply Quote 0
                    • A
                      ArnoD last edited by

                      @smartboart ja manchmal brauche ich auch etwas Zeit um zu verstehen was andere hier so programmieren 😀

                      @schmid_no1 Welche State setzt du auf true ? Bei der manuellen Regeneration bleibt der State Regenerationsstart solange auf true bis der Befehl gesendet wird, danach sollte er wieder false sein.

                      1 Reply Last reply Reply Quote 0
                      • S
                        schmid_no1 last edited by

                        @ArnoD ich setze die State s vom ausseneingriff auf true und der bleibt Wenn das Script schon länger läuft auf true stehen.
                        Fehler bringt er auch keinen.
                        Versuche noch einen anderen toggle vielleicht klappt es ja

                        1 Reply Last reply Reply Quote 0
                        • A
                          ArnoD last edited by

                          Kannst du mal die Variable debug auf true setzen und mir hier das Log einstellen. Ich kann den Fehler bei mir nicht nachvollziehen egal, was ich verwende.

                          1 Reply Last reply Reply Quote 0
                          • S
                            schmid_no1 last edited by

                            @ArnoD hab ich gemacht bleibt in den objekten auf true stehen (Fehlerspeicher)

                            javascript.0 2019-03-20 20:13:00.124 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:
                            javascript.0 2019-03-20 20:12:48.218 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:<data><code>ok</code><D_D_1>22.0</D_D_1><D_A_4_1>-</D_A_4_1><D_A_4_2>-</D_A_4_2><D_A_4_3>-</D_A_4_3><D_C_1_1>0</D_C_1_1><D_C_2_1>0</D_C_2_1><D_C_5_1>0<
                            javascript.0 2019-03-20 20:12:45.009 info script.js.Allgemein.Grünbeck: 570 Byte an Daten wurden gesendet :id=3369&code=245&show=D_D_1|D_A_4_1|D_A_4_2|D_A_4_3|D_C_1_1|D_C_2_1|D_C_5_1|D_C_4_1|D_C_4_2|D_C_4_3|D_C_6_1|D_C_7_1|D_A_2_2|D_C_3_6_1|
                            javascript.0 2019-03-20 20:12:33.218 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:<data><code>ok</code><D_D_1>22.0</D_D_1><D_A_4_1>-</D_A_4_1><D_A_4_2>-</D_A_4_2><D_A_4_3>-</D_A_4_3><D_C_1_1>0</D_C_1_1><D_C_2_1>0</D_C_2_1><D_C_5_1>0<
                            javascript.0 2019-03-20 20:12:30.008 info script.js.Allgemein.Grünbeck: 570 Byte an Daten wurden gesendet :id=3369&code=245&show=D_D_1|D_A_4_1|D_A_4_2|D_A_4_3|D_C_1_1|D_C_2_1|D_C_5_1|D_C_4_1|D_C_4_2|D_C_4_3|D_C_6_1|D_C_7_1|D_A_2_2|D_C_3_6_1|
                            javascript.0 2019-03-20 20:12:18.212 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:<data><code>ok</code><D_D_1>22.0</D_D_1><D_A_4_1>-</D_A_4_1><D_A_4_2>-</D_A_4_2><D_A_4_3>-</D_A_4_3><D_C_1_1>0</D_C_1_1><D_C_2_1>0</D_C_2_1><D_C_5_1>0<
                            javascript.0 2019-03-20 20:12:15.007 info script.js.Allgemein.Grünbeck: 570 Byte an Daten wurden gesendet :id=3369&code=245&show=D_D_1|D_A_4_1|D_A_4_2|D_A_4_3|D_C_1_1|D_C_2_1|D_C_5_1|D_C_4_1|D_C_4_2|D_C_4_3|D_C_6_1|D_C_7_1|D_A_2_2|D_C_3_6_1|
                            javascript.0 2019-03-20 20:12:00.123 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:
                            javascript.0 2019-03-20 20:12:00.006 info script.js.Allgemein.Grünbeck: 570 Byte an Daten wurden gesendet :id=3369&code=245&show=D_D_1|D_A_4_1|D_A_4_2|D_A_4_3|D_C_1_1|D_C_2_1|D_C_5_1|D_C_4_1|D_C_4_2|D_C_4_3|D_C_6_1|D_C_7_1|D_A_2_2|D_C_3_6_1|
                            javascript.0 2019-03-20 20:11:48.224 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:<data><code>ok</code><D_D_1>22.0</D_D_1><D_A_4_1>-</D_A_4_1><D_A_4_2>-</D_A_4_2><D_A_4_3>-</D_A_4_3><D_C_1_1>0</D_C_1_1><D_C_2_1>0</D_C_2_1><D_C_5_1>0<
                            javascript.0 2019-03-20 20:11:45.007 info script.js.Allgemein.Grünbeck: 570 Byte an Daten wurden gesendet :id=3369&code=245&show=D_D_1|D_A_4_1|D_A_4_2|D_A_4_3|D_C_1_1|D_C_2_1|D_C_5_1|D_C_4_1|D_C_4_2|D_C_4_3|D_C_6_1|D_C_7_1|D_A_2_2|D_C_3_6_1|
                            javascript.0 2019-03-20 20:11:33.218 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:<data><code>ok</code><D_D_1>22.0</D_D_1><D_A_4_1>-</D_A_4_1><D_A_4_2>-</D_A_4_2><D_A_4_3>-</D_A_4_3><D_C_1_1>0</D_C_1_1><D_C_2_1>0</D_C_2_1><D_C_5_1>0<
                            javascript.0 2019-03-20 20:11:30.006 info script.js.Allgemein.Grünbeck: 570 Byte an Daten wurden gesendet :id=3369&code=245&show=D_D_1|D_A_4_1|D_A_4_2|D_A_4_3|D_C_1_1|D_C_2_1|D_C_5_1|D_C_4_1|D_C_4_2|D_C_4_3|D_C_6_1|D_C_7_1|D_A_2_2|D_C_3_6_1|
                            web.0 2019-03-20 20:11:22.062 info ==>Connected system.user.admin from ::ffff:192.168.2.106

                            1 Reply Last reply Reply Quote 0
                            • A
                              ArnoD last edited by

                              Welchen State hast du hier auf true gesetzt, manuelle Regeneration oder Fehlerspeicher ?
                              Es wurde nämlich keiner von beiden an die Anlage gesendet.

                              1 Reply Last reply Reply Quote 0
                              • A
                                ArnoD last edited by

                                Verwende mal das neue Script 1.6.6 und setze wieder die Variable debug auf true.
                                Dann bitte aus Vis das Auslesen vom Fehlerspeicher starten und hier das log wieder einstellen.

                                1 Reply Last reply Reply Quote 0
                                • S
                                  schmid_no1 last edited by

                                  @ArnoD ich denke das Problem ist mein Button da ich mit ihm nicht auf false zurückstellen kann. Wenn ich in zu kurzen Abständen drücke bleibt true stehen und ich konnte es nicht zurückstellen.
                                  Ich werde das wie @smartboart weiter oben erklärt hat ändern. Danke für deine Hilfe

                                  • javascript.0 2019-03-20 21:50:45.006 info script.js.Allgemein.Grünbeck: 570 Byte an Daten wurden gesendet :id=3369&code=245&show=D_D_1|D_A_4_1|D_A_4_2|D_A_4_3|D_C_1_1|D_C_2_1|D_C_5_1|D_C_4_1|D_C_4_2|D_C_4_3|D_C_6_1|D_C_7_1|D_A_2_2|D_C_3_6_1|
                                  • javascript.0 2019-03-20 21:50:33.194 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:<data><code>ok</code><D_D_1>22.0</D_D_1><D_A_4_1>-</D_A_4_1><D_A_4_2>-</D_A_4_2><D_A_4_3>-</D_A_4_3><D_C_1_1>0</D_C_1_1><D_C_2_1>0</D_C_2_1><D_C_5_1>0<
                                  • javascript.0 2019-03-20 21:50:32.711 info script.js.Allgemein.Grünbeck: State Fehlerspeicher wurde geändert. Variable KeineRueckmeldung = true
                                  • javascript.0 2019-03-20 21:50:30.006 info script.js.Allgemein.Grünbeck: 570 Byte an Daten wurden gesendet :id=3369&code=245&show=D_D_1|D_A_4_1|D_A_4_2|D_A_4_3|D_C_1_1|D_C_2_1|D_C_5_1|D_C_4_1|D_C_4_2|D_C_4_3|D_C_6_1|D_C_7_1|D_A_2_2|D_C_3_6_1|
                                  • javascript.0 2019-03-20 21:50:25.263 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:<data><code>ok</code><D_K_10_1>E4_h2343</D_K_10_1><D_K_10_2>E4_h5894</D_K_10_2><D_K_10_3>E4_h6184</D_K_10_3><D_K_10_4>0</D_K_10_4><D_K_10_5>0</D_K_10_5
                                  • javascript.0 2019-03-20 21:50:22.890 info script.js.Allgemein.Grünbeck: State Fehlerspeicher wurde geändert. Variable KeineRueckmeldung = true
                                  • javascript.0 2019-03-20 21:50:22.882 info script.js.Allgemein.Grünbeck: 173 Byte an Daten wurden gesendet :id=3369&code=245&show=D_K_10_1|D_K_10_2|D_K_10_3|D_K_10_4|D_K_10_5|D_K_10_6|D_K_10_7|D_K_10_8|D_K_10_9|D_K_10_10|D_K_10_11|D_K_10_12|D
                                  • javascript.0 2019-03-20 21:50:22.879 info script.js.Allgemein.Grünbeck: State Fehlerspeicher wurde geändert. Neuer Wert= true
                                  • javascript.0 2019-03-20 21:50:22.879 info script.js.Allgemein.Grünbeck: State Fehlerspeicher wurde geändert. Variable KeineRueckmeldung = false
                                  • javascript.0 2019-03-20 21:50:18.193 info script.js.Allgemein.Grünbeck: Rueckmeldung SC18:<data><code>ok</code><D_D_1>22.0</D_D_1><D_A_4_1>-</D_A_4_1><D_A
                                  1 Reply Last reply Reply Quote 0
                                  • A
                                    ArnoD last edited by

                                    Ich habe jetzt in der Version 1.7.0 alle Werte die aus Vis geändert werden können eigene State angelegt.
                                    Die Funktion ist jetzt bei allen gleich wie bereits bei der manuellen Regeneration.

                                    @schmid_no1 dein Problem, dass die State's Fehlerspeicher und manuelle Regeneration auf true bleiben sollte auch gelöst sein.

                                    1 Reply Last reply Reply Quote 0
                                    • A
                                      ArnoD last edited by

                                      Der Fehler "Error in callback: Error: INVALID_STATE_ERR: send flag is true" wird jetzt abgefangen. Es wird nur noch eine Warnung ausgegeben, dass keine Netzwerkverbindung zur Grünbeck Anlage besteht. Neuen State LanStatus hinzugefügt um bei Verbindungsproblemen eine Anzeige in Vis zu ermöglichen. Mehrer kleine Fehler korrigiert und das Script etwas aufgeräumt. Bei Änderungen in Vis wird jetzt nicht nur die Änderung an die Anlage gesendet, sondern auch gleich abgefragt um sicher zu sein das die Änderung übernommen wurde.
                                      Konnte das Script nur als Datei hochladen, da es anscheinend die zulässige Zeichenlänge hier überschreitet.

                                      smartboart 1 Reply Last reply Reply Quote 1
                                      • S
                                        schmid_no1 last edited by

                                        @ArnoD voll cool pack ich morgen gleich drauf

                                        1 Reply Last reply Reply Quote 0
                                        • smartboart
                                          smartboart last edited by

                                          Echt klasse wie du die Liste abarbeitest und voran gehst...Macht Spass zu sehen wie sich das entwickelt..
                                          Pobier es gleich mal aus...

                                          1 Reply Last reply Reply Quote 0
                                          • smartboart
                                            smartboart @ArnoD last edited by smartboart

                                            @ArnoD so hab jetzt auch meine view umgebaut mit Eingabe und Rückmldung...Kann man schön sehen wann der Befehl durchgeht..Super wie es läuft...
                                            Sag mal fängt sich jetzt das Script wider wenn der Skript den Fehler abgefangen hat bzw. sobald die Verbindung wieder steht? Kein Neustart des Skripts mehr? So oder so super Arbeit...

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            423
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

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