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. Entwicklung
  4. Eigenen Adapter erstellen

NEWS

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

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

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

Eigenen Adapter erstellen

Geplant Angeheftet Gesperrt Verschoben Entwicklung
176 Beiträge 9 Kommentatoren 15.1k Aufrufe 7 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.
  • Ben1983B Ben1983

    @apollon77 ok,
    wie würdest DU denn dann eine Schrittkette aufbauen?
    asynch und await?
    das ist dann auch wieder blöd, wenn ich die schrittkette abbrechen möchte, wenn das await noch nicht fertig ist.

    Bin gespannt auf deinen Vorschlag?
    immer einen schritt und dann wieder setTimeout?
    wären möglich... nicht ganz symmetrisch, aber denkbar.
    Aber wie würdest Du innerhalb einer schrittkette bspw. 10s warten?
    Oder wie würde man einen ablauf machen, der entweder bei einem bestimmten wert eines datenpunkts oder nach 10s in den nächsten schritt springt?

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

    @ben1983 said in Eigenen Adapter erstellen:

    @apollon77 ok,
    wie würdest DU denn dann eine Schrittkette aufbauen?
    asynch und await?
    das ist dann auch wieder blöd, wenn ich die schrittkette abbrechen möchte, wenn das await noch nicht fertig ist.

    Bin gespannt auf deinen Vorschlag?
    immer einen schritt und dann wieder setTimeout?
    wären möglich... nicht ganz symmetrisch, aber denkbar.
    Aber wie würdest Du innerhalb einer schrittkette bspw. 10s warten?
    Oder wie würde man einen ablauf machen, der entweder bei einem bestimmten wert eines datenpunkts oder nach 10s in den nächsten schritt springt?

    erzähle mal genau was du in welcher reihenfolge du schalten möchtest und was das am anderen ende ist, was du da schalten willst und wie man mit denen kommunizieren kann.
    die genaue vorgehensweise hängt von diesen möglichkeiten ab.

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

    1 Antwort Letzte Antwort
    0
    • OliverIOO OliverIO

      @ben1983 said in Eigenen Adapter erstellen:

      this.log.info

      this.log.info
      muss heißen
      this.adapter.log.info

      this.setTimeout(this.checkSchwimmerschalter,1000);
      

      leider hast du die Fehlermeldung nicht mitgegeben.
      grundsätzlich muss das schon funktionieren. Wahrscheinlich ist nicht das Problem, das die Funktion this.checkSchwimmerschalter nicht aufgerufen wird, sondern
      das innerhalb der Funktion der scope nix mehr mit dem Adapter zu tun hat und du mit this nicht mehr auf die Adapterfunktionen zugreifen kannst.
      Um das zu können, musst du entweder die Funktion in ein ES6-Konstrukt einpacken oder den gewünschten Scope mit bind mitgeben.
      angewandt auf dein Beispiel mache ich das so:

      this.setTimeout(this.checkSchwimmerschalter.bind(this),1000);
      
      apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #145

      @oliverio sagte in Eigenen Adapter erstellen:

      this.log.info
      muss heißen
      this.adapter.log.info

      ääähhm .. neee?

      Je nachdem wie der gesamte Code ist (ob ES6 Class oder old style) ist es entweder this.log oder adapter.log ... aber am Ende sind wir jetzt an einer Stelle wo man mehr code sehen muss. am Ende ist die Frage wo Sdu deine methode hingepackt hast und wann das ausgefphrt wird. Wenn "thislog" nicht da ist dann läuft Dein Code ggf CVOR dem "on(ready)" und dann ist DAS der Fehler!

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      1 Antwort Letzte Antwort
      0
      • Ben1983B Ben1983

        @apollon77 weist DU was das hier bedeuten soll?

        ich habe diese zeile:

        this.log.info("Schwimmer = " + this.config.schwimmerschalter);
        

        und bekomme diesen Fehler:

        
        zisternensteuerung.0
        2022-02-02 22:59:34.398	error	Cannot read properties of undefined (reading 'log')
        zisternensteuerung.0
        2022-02-02 22:59:34.397	error	TypeError: Cannot read properties of undefined (reading 'log') at checkSchwimmerschalter (C:\vscode\iobroker adapter\ioBroker.zisternensteuerung\.dev-server\default\node_modules\iobroker.zisternensteuerung\main.js:61:8) at Timeout._onTimeout (C:\vscode\iobroker adapter\ioBroker.zisternensteuerung\.dev-server\default\node_modules\iobroker.js-controller\lib\adapter.js:1273:17) at listOnTimeout (node:internal/timers:557:17) at processTimers (node:internal/timers:500:7)
        zisternensteuerung.0
        2022-02-02 22:59:34.394	error	unhandled promise rejection: Cannot read properties of undefined (reading 'log')
        zisternensteuerung.0
        2022-02-02 22:59:34.393	error	Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch().
        

        Aufgerufen wird der log innerhalb einer function.
        diese wird bei wertänderung aufgerufen. (Ohne Timeout klappt es)

        this.setTimeout(this.checkSchwimmerschalter,1000);
        

        wenn ich es so aufrufe, dann geht es:

        this.setTimeout(() =>{
          this.checkSchwimmerschalter();
        },1000);
        

        warum geht es nicht wie oben, wenn ich die function direkt aufrufe?
        auch wenn man es so schreibt, geht es nicht:

        this.setTimeout(function(){
           this.checkSchwimmerschalter();
        },1000);
        
        apollon77A Offline
        apollon77A Offline
        apollon77
        schrieb am zuletzt editiert von
        #146

        @ben1983 Also das ist jetzt JavaScript Language Specifics :-)

        sobald Du eine "function() .." machst ist "this" auf diese function bezogen und die hat nun mal nicht diese Methode. Um das zu verhindern deklariert man funktionen über den Arrow operator () => ..., dann wird "this" nicht geändert.

        Ansonsten (und ich versuche es einfach auszudrücken): DersetTimeout Parameter ist eine "function". "this.xy" ist aber eine Funktion einer Instanz und damit keine "natürliche function" und deswegen geht das nicht. Das lässt sich auch ändern, aber würde jetzt hier zu weit führen. Ich denke die notation

        this.setTimeout(() => this.checkSchwimmerschalter(),1000);
        

        passt.

        (ja in dem Fall das deine Function genau ein Kommando ist kannst du die geschweiften Klammern weglassen)

        Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

        • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
        • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
        Ben1983B 1 Antwort Letzte Antwort
        0
        • Ben1983B Ben1983

          @apollon77 ok,
          wie würdest DU denn dann eine Schrittkette aufbauen?
          asynch und await?
          das ist dann auch wieder blöd, wenn ich die schrittkette abbrechen möchte, wenn das await noch nicht fertig ist.

          Bin gespannt auf deinen Vorschlag?
          immer einen schritt und dann wieder setTimeout?
          wären möglich... nicht ganz symmetrisch, aber denkbar.
          Aber wie würdest Du innerhalb einer schrittkette bspw. 10s warten?
          Oder wie würde man einen ablauf machen, der entweder bei einem bestimmten wert eines datenpunkts oder nach 10s in den nächsten schritt springt?

          apollon77A Offline
          apollon77A Offline
          apollon77
          schrieb am zuletzt editiert von
          #147

          @ben1983 ALso hier müsste man jetzt mal verstehen was du genau tun willst - und warum du 10s warten musst.

          Wenn Du sicher sein willst das eins nach dem anderen erfolgt dann ja async/await. Der js-controller 4 wird auch ein this.delay(ms) haben was man nutzen kann wo wir sicherstellen das das beim "Unload" auch abgebrochen wird.

          Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

          • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
          • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
          Ben1983B 1 Antwort Letzte Antwort
          0
          • apollon77A apollon77

            @ben1983 Also das ist jetzt JavaScript Language Specifics :-)

            sobald Du eine "function() .." machst ist "this" auf diese function bezogen und die hat nun mal nicht diese Methode. Um das zu verhindern deklariert man funktionen über den Arrow operator () => ..., dann wird "this" nicht geändert.

            Ansonsten (und ich versuche es einfach auszudrücken): DersetTimeout Parameter ist eine "function". "this.xy" ist aber eine Funktion einer Instanz und damit keine "natürliche function" und deswegen geht das nicht. Das lässt sich auch ändern, aber würde jetzt hier zu weit führen. Ich denke die notation

            this.setTimeout(() => this.checkSchwimmerschalter(),1000);
            

            passt.

            (ja in dem Fall das deine Function genau ein Kommando ist kannst du die geschweiften Klammern weglassen)

            Ben1983B Offline
            Ben1983B Offline
            Ben1983
            schrieb am zuletzt editiert von
            #148

            @apollon77 warum geht es aber nicht, wenn ich den Funktionsaufruf ohne arrow function übergebe? Da deklariere ich ja nichts neu.
            Rufe ja genau das gleiche je auf wie in der arrow Funktion???

            apollon77A 1 Antwort Letzte Antwort
            0
            • apollon77A apollon77

              @ben1983 ALso hier müsste man jetzt mal verstehen was du genau tun willst - und warum du 10s warten musst.

              Wenn Du sicher sein willst das eins nach dem anderen erfolgt dann ja async/await. Der js-controller 4 wird auch ein this.delay(ms) haben was man nutzen kann wo wir sicherstellen das das beim "Unload" auch abgebrochen wird.

              Ben1983B Offline
              Ben1983B Offline
              Ben1983
              schrieb am zuletzt editiert von
              #149

              @apollon77 ich möchte folgendes machen.
              Entweder wenn die systemzeit eine bestimmte Zeit erreicht hat, oder ein Eingang (sxhwimmerschalter) sich ändert, möchte ich eine schrittkette durchlaufen die folgendes macht:

              1. einen State auf True setzen.
                (Damit wird physikalisch ein Shelly aktiviert und ein Stellmotor läuft).
              2. dann eine einstellbare Zeit x warten (verfahrzeot des Stellmotors)
              3. nächsten State auf True setzen.
              4. wieder warten zeit y.
              5. fertig loggen.
              6. schrittkette beendet verlassen
              1 Antwort Letzte Antwort
              0
              • Ben1983B Ben1983

                @apollon77 warum geht es aber nicht, wenn ich den Funktionsaufruf ohne arrow function übergebe? Da deklariere ich ja nichts neu.
                Rufe ja genau das gleiche je auf wie in der arrow Funktion???

                apollon77A Offline
                apollon77A Offline
                apollon77
                schrieb am zuletzt editiert von
                #150

                @ben1983 Ja, am Ende ist eine "Funktion einer Instanz" intern keine "function" die man hier übergeben kann weil Sie an das Objekt gebunden ist und nicht an "global". Wenn setTimeout die funktion ausführt geht daher das Objekt-"binding" verloren - es sei denn du setzt es explizit

                Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                Ben1983B 1 Antwort Letzte Antwort
                0
                • apollon77A apollon77

                  @ben1983 Ja, am Ende ist eine "Funktion einer Instanz" intern keine "function" die man hier übergeben kann weil Sie an das Objekt gebunden ist und nicht an "global". Wenn setTimeout die funktion ausführt geht daher das Objekt-"binding" verloren - es sei denn du setzt es explizit

                  Ben1983B Offline
                  Ben1983B Offline
                  Ben1983
                  schrieb am zuletzt editiert von Ben1983
                  #151

                  @apollon77 das bedeutet, mit einem direkten Aufruf als callback, oder mit function(){This.myfunctiln()} geht es nicht,
                  Aber in einer arrow function geht es?

                  Das liegt also an dem callback der settimeout Funktion?
                  Denn wenn ich direkt aufrufe gehts ja.

                  Oder solltest dann anders auf bspw. Log zugreifen?

                  Ps. Jemand ne Idee zu meinem Vorhaben?

                  OliverIOO apollon77A 2 Antworten Letzte Antwort
                  0
                  • Ben1983B Ben1983

                    @apollon77 das bedeutet, mit einem direkten Aufruf als callback, oder mit function(){This.myfunctiln()} geht es nicht,
                    Aber in einer arrow function geht es?

                    Das liegt also an dem callback der settimeout Funktion?
                    Denn wenn ich direkt aufrufe gehts ja.

                    Oder solltest dann anders auf bspw. Log zugreifen?

                    Ps. Jemand ne Idee zu meinem Vorhaben?

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

                    @ben1983
                    ja, lese meinen post oben
                    den abschnitt mit bind
                    ist etwas anstrengend mit dir.
                    die liest die posts nicht richtig
                    du antwortest nicht auf die fragen
                    fragst die gleichen fragen dann wieder andere

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

                    Ben1983B 1 Antwort Letzte Antwort
                    1
                    • Ben1983B Ben1983

                      @apollon77 das bedeutet, mit einem direkten Aufruf als callback, oder mit function(){This.myfunctiln()} geht es nicht,
                      Aber in einer arrow function geht es?

                      Das liegt also an dem callback der settimeout Funktion?
                      Denn wenn ich direkt aufrufe gehts ja.

                      Oder solltest dann anders auf bspw. Log zugreifen?

                      Ps. Jemand ne Idee zu meinem Vorhaben?

                      apollon77A Offline
                      apollon77A Offline
                      apollon77
                      schrieb am zuletzt editiert von
                      #153

                      @ben1983 Ok, schick mal den GitHub lInk zu dem code bitte in Gänze. Wenn du eine Methiode aufrufst und dort this.log nicht da ist dann ist was anderes im argen. Ich vermute das du code ausführts ohne das vorher on(ready) aufgerufen wurde und damit ist es einfach zu früh

                      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                      Ben1983B 1 Antwort Letzte Antwort
                      0
                      • Ben1983B Offline
                        Ben1983B Offline
                        Ben1983
                        schrieb am zuletzt editiert von Ben1983
                        #154

                        @apollon77 muss ich die Tage mal hoch laden.
                        Bin unterwegs. Aber:
                        Onready wurde ausgeführt und this.log soll ja ausgeführt werden.
                        Es geht ja auch bei direktaufruf der Funktion, oder in der arrowfunktion.
                        Nur als callback nicht.

                        Vielleicht kann ich es später noch hochladen

                        1 Antwort Letzte Antwort
                        0
                        • OliverIOO OliverIO

                          @ben1983
                          ja, lese meinen post oben
                          den abschnitt mit bind
                          ist etwas anstrengend mit dir.
                          die liest die posts nicht richtig
                          du antwortest nicht auf die fragen
                          fragst die gleichen fragen dann wieder andere

                          Ben1983B Offline
                          Ben1983B Offline
                          Ben1983
                          schrieb am zuletzt editiert von Ben1983
                          #155

                          @oliverio Sorry. Ich stelle die Fragen ja auch nur, weil ich mit der Antwort nichts anfangen kann, oder eventuell was anderes gemeint war.

                          Sollte man eigentlich generell die interne Funktion zur Abonierung einer State Änderung nutzen, oder vielleicht auch die on Funktion?

                          1 Antwort Letzte Antwort
                          0
                          • apollon77A apollon77

                            @ben1983 Ok, schick mal den GitHub lInk zu dem code bitte in Gänze. Wenn du eine Methiode aufrufst und dort this.log nicht da ist dann ist was anderes im argen. Ich vermute das du code ausführts ohne das vorher on(ready) aufgerufen wurde und damit ist es einfach zu früh

                            Ben1983B Offline
                            Ben1983B Offline
                            Ben1983
                            schrieb am zuletzt editiert von
                            #156

                            @apollon77 Hir der link zu github:

                            ioBroker.zisternensteuerung

                            apollon77A 1 Antwort Letzte Antwort
                            0
                            • Ben1983B Ben1983

                              @apollon77 Hir der link zu github:

                              ioBroker.zisternensteuerung

                              apollon77A Offline
                              apollon77A Offline
                              apollon77
                              schrieb am zuletzt editiert von
                              #157

                              @ben1983 Ok, und mit setInterval(() => this.checkSchwimmerschalter()) kommt das "this log gibbet nicht" auch?

                              Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                              • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                              • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                              Ben1983B 1 Antwort Letzte Antwort
                              0
                              • apollon77A apollon77

                                @ben1983 Ok, und mit setInterval(() => this.checkSchwimmerschalter()) kommt das "this log gibbet nicht" auch?

                                Ben1983B Offline
                                Ben1983B Offline
                                Ben1983
                                schrieb am zuletzt editiert von
                                #158

                                @apollon77 sagte in Eigenen Adapter erstellen:

                                @ben1983 Ok, und mit setInterval(() => this.checkSchwimmerschalter()) kommt das "this log gibbet nicht" auch?

                                Nein damit geht es.
                                Wo hast Du das denn im Code gefunden? Ist doch gar nicht mehr da drin.

                                Der Fehler kommt hier:

                                this.activeInterval = this.setInterval(this.checkSchwimmerschalter,1000);
                                

                                Das liegt dann ja wahrscheinlich am Binding.
                                Sollte es mit

                                this.activeInterval = this.setInterval(this.checkSchwimmerschalter.Bind(this),1000);
                                

                                Gehen?

                                Da erscheint ein Fehler, dass kein Catch zum abfangen erzeugt wurde.
                                Aber warum brauche ich das?

                                Und warum liefert mir die getForeignState Funktion einen error?

                                Nächste Frage:
                                Am Anfang logge ich ja die config Daten mit.
                                Warum stehen die da noch auf undefined?

                                apollon77A 2 Antworten Letzte Antwort
                                0
                                • Ben1983B Ben1983

                                  @apollon77 sagte in Eigenen Adapter erstellen:

                                  @ben1983 Ok, und mit setInterval(() => this.checkSchwimmerschalter()) kommt das "this log gibbet nicht" auch?

                                  Nein damit geht es.
                                  Wo hast Du das denn im Code gefunden? Ist doch gar nicht mehr da drin.

                                  Der Fehler kommt hier:

                                  this.activeInterval = this.setInterval(this.checkSchwimmerschalter,1000);
                                  

                                  Das liegt dann ja wahrscheinlich am Binding.
                                  Sollte es mit

                                  this.activeInterval = this.setInterval(this.checkSchwimmerschalter.Bind(this),1000);
                                  

                                  Gehen?

                                  Da erscheint ein Fehler, dass kein Catch zum abfangen erzeugt wurde.
                                  Aber warum brauche ich das?

                                  Und warum liefert mir die getForeignState Funktion einen error?

                                  Nächste Frage:
                                  Am Anfang logge ich ja die config Daten mit.
                                  Warum stehen die da noch auf undefined?

                                  apollon77A Offline
                                  apollon77A Offline
                                  apollon77
                                  schrieb am zuletzt editiert von
                                  #159

                                  @ben1983 sagte in Eigenen Adapter erstellen:

                                  Das liegt dann ja wahrscheinlich am Binding.

                                  Exakt, es ist dann "this" nicht mehr auf das objekt gesetzt und damit geht this.log schieff

                                  Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                  • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                  • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                  1 Antwort Letzte Antwort
                                  0
                                  • Ben1983B Ben1983

                                    @apollon77 sagte in Eigenen Adapter erstellen:

                                    @ben1983 Ok, und mit setInterval(() => this.checkSchwimmerschalter()) kommt das "this log gibbet nicht" auch?

                                    Nein damit geht es.
                                    Wo hast Du das denn im Code gefunden? Ist doch gar nicht mehr da drin.

                                    Der Fehler kommt hier:

                                    this.activeInterval = this.setInterval(this.checkSchwimmerschalter,1000);
                                    

                                    Das liegt dann ja wahrscheinlich am Binding.
                                    Sollte es mit

                                    this.activeInterval = this.setInterval(this.checkSchwimmerschalter.Bind(this),1000);
                                    

                                    Gehen?

                                    Da erscheint ein Fehler, dass kein Catch zum abfangen erzeugt wurde.
                                    Aber warum brauche ich das?

                                    Und warum liefert mir die getForeignState Funktion einen error?

                                    Nächste Frage:
                                    Am Anfang logge ich ja die config Daten mit.
                                    Warum stehen die da noch auf undefined?

                                    apollon77A Offline
                                    apollon77A Offline
                                    apollon77
                                    schrieb am zuletzt editiert von
                                    #160

                                    @ben1983 sagte in Eigenen Adapter erstellen:

                                    Sollte es mit
                                    this.activeInterval = this.setInterval(this.checkSchwimmerschalter.Bind(this),1000);

                                    Gehen?

                                    wenn du bind klein schreibst ja.

                                    Da erscheint ein Fehler, dass kein Catch zum abfangen erzeugt wurde.
                                    Aber warum brauche ich das?
                                    Und warum liefert mir die getForeignState Funktion einen error?

                                    welcher fehler kommt denn?
                                    Was ist denn this.config.schwimmerschalter ?? Ist die Idee das der user eine State-ID angibt die du dann nutzt oder wie?

                                    Nächste Frage:
                                    Am Anfang logge ich ja die config Daten mit.
                                    Warum stehen die da noch auf undefined?

                                    naja du hast eine funktion definiert mit 2 Parametern und rufst iIe mit nur einem auf. Damit ist der zweite undefined

                                    Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                    • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                    • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                    Ben1983B 3 Antworten Letzte Antwort
                                    0
                                    • apollon77A apollon77

                                      @ben1983 sagte in Eigenen Adapter erstellen:

                                      Sollte es mit
                                      this.activeInterval = this.setInterval(this.checkSchwimmerschalter.Bind(this),1000);

                                      Gehen?

                                      wenn du bind klein schreibst ja.

                                      Da erscheint ein Fehler, dass kein Catch zum abfangen erzeugt wurde.
                                      Aber warum brauche ich das?
                                      Und warum liefert mir die getForeignState Funktion einen error?

                                      welcher fehler kommt denn?
                                      Was ist denn this.config.schwimmerschalter ?? Ist die Idee das der user eine State-ID angibt die du dann nutzt oder wie?

                                      Nächste Frage:
                                      Am Anfang logge ich ja die config Daten mit.
                                      Warum stehen die da noch auf undefined?

                                      naja du hast eine funktion definiert mit 2 Parametern und rufst iIe mit nur einem auf. Damit ist der zweite undefined

                                      Ben1983B Offline
                                      Ben1983B Offline
                                      Ben1983
                                      schrieb am zuletzt editiert von
                                      #161

                                      @apollon77 Das funktioniert schon mal so:

                                      this.activeInterval = this.setInterval(this.checkSchwimmerschalter.bind(this),1000);
                                      

                                      Ist nur die Frage, ob man das so machen sollte um eine Schrittkette zu starten.
                                      Würde ja auch gerne eine async funktion erstellen, welche dann mit await einzelne schritte verzögert, aber ein await kann man nicht mehr abbrechen, oder?

                                      Danke für den Tip mit den zwei Parametern.
                                      Geht jetzt auch

                                      1 Antwort Letzte Antwort
                                      0
                                      • apollon77A apollon77

                                        @ben1983 sagte in Eigenen Adapter erstellen:

                                        Sollte es mit
                                        this.activeInterval = this.setInterval(this.checkSchwimmerschalter.Bind(this),1000);

                                        Gehen?

                                        wenn du bind klein schreibst ja.

                                        Da erscheint ein Fehler, dass kein Catch zum abfangen erzeugt wurde.
                                        Aber warum brauche ich das?
                                        Und warum liefert mir die getForeignState Funktion einen error?

                                        welcher fehler kommt denn?
                                        Was ist denn this.config.schwimmerschalter ?? Ist die Idee das der user eine State-ID angibt die du dann nutzt oder wie?

                                        Nächste Frage:
                                        Am Anfang logge ich ja die config Daten mit.
                                        Warum stehen die da noch auf undefined?

                                        naja du hast eine funktion definiert mit 2 Parametern und rufst iIe mit nur einem auf. Damit ist der zweite undefined

                                        Ben1983B Offline
                                        Ben1983B Offline
                                        Ben1983
                                        schrieb am zuletzt editiert von
                                        #162

                                        @apollon77

                                        welcher fehler kommt denn?
                                        es erscheint der Fehler:

                                        zisternensteuerung.0.2022-02-03 22:29:01.789	error	[object Object]
                                        

                                        Was ist denn this.config.schwimmerschalter ?? Ist die Idee das der user eine State-ID angibt die du dann nutzt oder wie?

                                        Ja, genau das ist die Idee, oder kann man die irgendwie via Dropdown auswählen?
                                        Dachte so muss man die Datenpunkte nicht noch extra in irgend einem Skript zuweisen.
                                        Oder würdest Du es lieber nicht so machen?

                                        Ben1983B 1 Antwort Letzte Antwort
                                        0
                                        • Ben1983B Ben1983

                                          @apollon77

                                          welcher fehler kommt denn?
                                          es erscheint der Fehler:

                                          zisternensteuerung.0.2022-02-03 22:29:01.789	error	[object Object]
                                          

                                          Was ist denn this.config.schwimmerschalter ?? Ist die Idee das der user eine State-ID angibt die du dann nutzt oder wie?

                                          Ja, genau das ist die Idee, oder kann man die irgendwie via Dropdown auswählen?
                                          Dachte so muss man die Datenpunkte nicht noch extra in irgend einem Skript zuweisen.
                                          Oder würdest Du es lieber nicht so machen?

                                          Ben1983B Offline
                                          Ben1983B Offline
                                          Ben1983
                                          schrieb am zuletzt editiert von Ben1983
                                          #163

                                          @ben1983 habe das GetForeignState so umgangen:

                                          async checkSchwimmerschalter(){if(this._schwimmerschalter)
                                          {
                                          	this.setToZisterne();
                                          }
                                          }
                                          async setToZisterne()
                                          {		 
                                          this.setForeignStateAsync(this.config.ansteuerungFrischwasserStellmotor,false,true);	
                                          await new Promise(resolve =>this.setTimeout(resolve,this.config.verfahrzeitFrischwassermotor));
                                          this.setForeignStateAsync(this.config.ansteuerungZisternenstellmotor,false,true);	}
                                          
                                          
                                          	onStateChange(id, state) {
                                          		if (state) {
                                          			// The state was changed
                                          			this.log.info(`state ${id} changed: ${state.val} (ack = ${state.ack})`);
                                          			this.log.info(this.config.schwimmerschalter);
                                          			if(id == this.config.schwimmerschalter)
                                          			{
                                          			
                                          			//this.activeInterval = this.setInterval(this.checkSchwimmerschalter.bind(this),1000);
                                          			this._schwimmerschalter = state.val;
                                          			this.checkSchwimmerschalter();
                                          			}
                                          
                                          		} else {
                                          			// The state was deleted
                                          			this.log.info(`state ${id} deleted`);
                                          		}
                                          	}
                                          

                                          Also den Wert bei Wertänderung in eine lokale Variable geschrieben.
                                          Aber trotzdem müsste doch das getForeignState auch gehen, oder?

                                          Was ist denn der Unterschied, wenn man mit der on funktion oder der subscribe und dann der internen onchange methode arbeitet?

                                          Ben1983B 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

                                          800

                                          Online

                                          32.4k

                                          Benutzer

                                          81.6k

                                          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