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.7k

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

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

Eigenen Adapter erstellen

Geplant Angeheftet Gesperrt Verschoben Entwicklung
176 Beiträge 9 Kommentatoren 15.0k 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

    @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 Offline
    Ben1983B Offline
    Ben1983
    schrieb am zuletzt editiert von
    #164

    @ben1983 Hier nochmal der Link zur aktuellen Version:
    Zisternensteuerung

    ich frage den State.val ab, aber leider (egal ob true oder false) wird irgendwie immer der Else zweig ausgeführt und damit immer (setToFrischwasser)
    Hier die Abfrage

    	async checkSchwimmerschalter()
    	{
    		this.log.info(this._schwimmerschalter.val);
    		if(this._schwimmerschalter.val == this.config.zisternenlogik)
    		{
    			this.log.info("Start set to Zisterne");
    			this.setToZisterne();
    		}
    		else
    		{
    			this.log.info("Start set to Frischwasser");
    			this.setToFrischwasser();
    		}
    	}
    

    Der log oben drüber liefert den korrekten Wert.

    Fällt jemand ein Fehler auf?

    apollon77A 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 Ben1983
      #165

      @apollon77 natürlich sollte der letzte Post an Dich gehen.

      1 Antwort Letzte Antwort
      0
      • Ben1983B Ben1983

        @ben1983 Hier nochmal der Link zur aktuellen Version:
        Zisternensteuerung

        ich frage den State.val ab, aber leider (egal ob true oder false) wird irgendwie immer der Else zweig ausgeführt und damit immer (setToFrischwasser)
        Hier die Abfrage

        	async checkSchwimmerschalter()
        	{
        		this.log.info(this._schwimmerschalter.val);
        		if(this._schwimmerschalter.val == this.config.zisternenlogik)
        		{
        			this.log.info("Start set to Zisterne");
        			this.setToZisterne();
        		}
        		else
        		{
        			this.log.info("Start set to Frischwasser");
        			this.setToFrischwasser();
        		}
        	}
        

        Der log oben drüber liefert den korrekten Wert.

        Fällt jemand ein Fehler auf?

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

        @ben1983 Naja wenn der Vergleich sagt es ist nicht gleich dann ists nicht gleich. Log mal beides und zeig mal log

        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 Offline
          Ben1983B Offline
          Ben1983
          schrieb am zuletzt editiert von
          #167

          @apollon77 laut log sollte es aber erfüllt sein.
          Ich habe auch schon die Bedingung dahingehend geändert, dass ich auf == false abgefragt habe und egal welcher Zustand der Parameter angenommen hat wurde trotzdem immer der else Zweig ausgeführt.
          Echt sehr sehr merkwürdig.
          Vielleicht kann jemand mal das Ding über github testen, ob es Bei euch auch so ist?

          apollon77A 1 Antwort Letzte Antwort
          0
          • Ben1983B Ben1983

            @apollon77 laut log sollte es aber erfüllt sein.
            Ich habe auch schon die Bedingung dahingehend geändert, dass ich auf == false abgefragt habe und egal welcher Zustand der Parameter angenommen hat wurde trotzdem immer der else Zweig ausgeführt.
            Echt sehr sehr merkwürdig.
            Vielleicht kann jemand mal das Ding über github testen, ob es Bei euch auch so ist?

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

            @ben1983 Logge doch bitte mal beide werte!!!! Am besten mit "JSON.stringify(wert)" weil wenn es ein boolean ist aber dein wert ggf ein string ist hast du "

            false == "false"

            und das stimmt natürlich nicht. beachte bitte datentypen!!

            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 Logge doch bitte mal beide werte!!!! Am besten mit "JSON.stringify(wert)" weil wenn es ein boolean ist aber dein wert ggf ein string ist hast du "

              false == "false"

              und das stimmt natürlich nicht. beachte bitte datentypen!!

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

              @apollon77 ah ok.
              Ich bin unterwegs. Am besten schaue ich noch mal, dass der Type wirklich boolean ist.
              In den Objekten musste ich bis jetzt true oder false eintragen.
              Nicht anhaken.

              1 Antwort Letzte Antwort
              0
              • Ben1983B Offline
                Ben1983B Offline
                Ben1983
                schrieb am zuletzt editiert von
                #170

                @apollon77 sagte in Eigenen Adapter erstellen:

                JSON.stringify(wert)

                Danke, das war es. Funktioniert jetzt.
                Nun habe ich nur noch die Funktion der Schrittkette zu lösen.
                Hat jemand eine Idee, wie man Wartezeiten innerhalb einer Schrittkette elegant löst?
                Also die Schrittkette muss natürlich auch abgebrochen werden können.
                dann wäre ich ja mit einem await nicht so gut bedient, oder?

                Und habe ich irgendwo eine Systemzeit, welche ich auf bspw. "22:30" vergleichen kann?

                1 Antwort Letzte Antwort
                0
                • apollon77A apollon77

                  @ben1983 Logge doch bitte mal beide werte!!!! Am besten mit "JSON.stringify(wert)" weil wenn es ein boolean ist aber dein wert ggf ein string ist hast du "

                  false == "false"

                  und das stimmt natürlich nicht. beachte bitte datentypen!!

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

                  @apollon77 Was bedeutet diese Meldung?
                  Warum wird er teminiert?

                  host.dev-zisternensteuerung-DESKTOP-JHNIDES
                  2022-02-06 14:14:01.768	error	instance system.adapter.zisternensteuerung.0 terminated with code 7 (ADAPTER_ALREADY_RUNNING)
                  
                  zisternensteuerung.0
                  2022-02-06 14:14:00.207	warn	Got terminate signal. Checking desired PID: 6452 vs own PID 7400
                  host.dev-zisternensteuerung-DESKTOP-JHNIDES
                  2022-02-06 14:14:00.183	info	instance system.adapter.zisternensteuerung.0 started with pid 6452
                  
                  zisternensteuerung.0
                  2022-02-06 14:14:00.178	warn	Got terminate signal. Checking desired PID: 0 vs own PID 7400
                  
                  1 Antwort Letzte Antwort
                  0
                  • apollon77A apollon77

                    @ben1983 Logge doch bitte mal beide werte!!!! Am besten mit "JSON.stringify(wert)" weil wenn es ein boolean ist aber dein wert ggf ein string ist hast du "

                    false == "false"

                    und das stimmt natürlich nicht. beachte bitte datentypen!!

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

                    @apollon77 Vielleicht kann sich mal eine meinen code ansehen.
                    Habe nun erste Versuche mit der Zeitsteuerung gemacht.
                    Habe einen intervall gesetzt, der jede sekunde die Zeit holt.
                    (Denke das geht bestimmt schönes und eleganter, oder?
                    Würde gerne eine Zeitvariable "abonieren", dass ich auch irgendwie auf die Änderung reagieren kann.
                    Geht so etwas?
                    Wie funktioniert denn jetzt eigentlich die getForeignState() funktion?

                    Hier der Link zu meinem Github Repository: ioBroker.zisternensteuerung

                    liv-in-skyL 1 Antwort Letzte Antwort
                    0
                    • apollon77A Offline
                      apollon77A Offline
                      apollon77
                      schrieb am zuletzt editiert von
                      #173

                      @Ben1983 Ich muss ehrlich sagen das mir persönlich mit all meinen Themen gerade die Zeit fehlt dich hier angemessen zu unterstützen. Bitte nicht falsch verstehen, aber bei Dir fehlen aktuell noch viele JavaScript und Programmierungs-Grundagen. Das kann ich gerade nicht Covern.

                      Beispiel:

                      • Nen user true/false als Text eigeben zu lassen ist nicht so sinnvoll ... ne Checkbox und mit einem Boolean arbeiten ist sinnvoll
                      • Ich kapiere grundsätzlich nicht was du mit Schrittkette meinst und auch das was du da mit der Zeit tust will mir nicht in den Kopf ... Man müsste jetzt starten das du erklärst was du wie tun willst und dann gemeinsam überlegt wie man das in Code umsetzt ...
                      • Wenn du eteas zu einer bestimmten Zeit ausführen willst nimm node_schedule wie bereits oben gesagt.

                      Die Logs wegen terminate bedeuten das sich dein Adapter nicht ordnungsgemäß beendet aktuell. Grund muss man schauen

                      Am besten meldest Du dich mal im Discord an und fragst ob einer der anderen Devs dir hier zur Seite stehen kann.

                      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 Vielleicht kann sich mal eine meinen code ansehen.
                        Habe nun erste Versuche mit der Zeitsteuerung gemacht.
                        Habe einen intervall gesetzt, der jede sekunde die Zeit holt.
                        (Denke das geht bestimmt schönes und eleganter, oder?
                        Würde gerne eine Zeitvariable "abonieren", dass ich auch irgendwie auf die Änderung reagieren kann.
                        Geht so etwas?
                        Wie funktioniert denn jetzt eigentlich die getForeignState() funktion?

                        Hier der Link zu meinem Github Repository: ioBroker.zisternensteuerung

                        liv-in-skyL Offline
                        liv-in-skyL Offline
                        liv-in-sky
                        schrieb am zuletzt editiert von
                        #174

                        @ben1983 falls du wieder eine session auf discord organisieren kannst, wäre ich sehr interessiert mitzuschauen - wenn das ginge - könntest du das hier dann posten ?

                        @apollon77
                        war schon verwundert :-)

                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                        1 Antwort Letzte Antwort
                        0
                        • apollon77A apollon77

                          @Ben1983 Ich muss ehrlich sagen das mir persönlich mit all meinen Themen gerade die Zeit fehlt dich hier angemessen zu unterstützen. Bitte nicht falsch verstehen, aber bei Dir fehlen aktuell noch viele JavaScript und Programmierungs-Grundagen. Das kann ich gerade nicht Covern.

                          Beispiel:

                          • Nen user true/false als Text eigeben zu lassen ist nicht so sinnvoll ... ne Checkbox und mit einem Boolean arbeiten ist sinnvoll
                          • Ich kapiere grundsätzlich nicht was du mit Schrittkette meinst und auch das was du da mit der Zeit tust will mir nicht in den Kopf ... Man müsste jetzt starten das du erklärst was du wie tun willst und dann gemeinsam überlegt wie man das in Code umsetzt ...
                          • Wenn du eteas zu einer bestimmten Zeit ausführen willst nimm node_schedule wie bereits oben gesagt.

                          Die Logs wegen terminate bedeuten das sich dein Adapter nicht ordnungsgemäß beendet aktuell. Grund muss man schauen

                          Am besten meldest Du dich mal im Discord an und fragst ob einer der anderen Devs dir hier zur Seite stehen kann.

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

                          @apollon77 danke für die Infos.
                          Ich möchte den User nichts eingeben lassen.
                          Ich hatte mir über den js adapter dummy States generiert.
                          Der User soll garnichts eintragen außer seine ids

                          Ich möchte eigentlich nur folgendes machen:
                          Bei einer Statusänderung was ausführen und bei einer bestimmten Zeit auch was ausführen.

                          Mit schrittkette meine ich einen definierten Ablauf:
                          Bsp. 1. schalten eines States.
                          2. x Sekunden warten
                          3. einen State schalten.
                          4. warten auf einen bestimmten Zustand eines States.
                          5. alle States zurück setzen.

                          Sowas bspw.

                          Ich komme aus der zyklischen Programmierung (SPS) und würde behaupten, dass ich in logiken recht fit bin.
                          Mir fehlt es derzeit einfach an der Vorgehensweise bei Javaskript.

                          1 Antwort Letzte Antwort
                          0
                          • OliverIOO OliverIO

                            @ben1983 said in Eigenen Adapter erstellen:

                            @oliverio ok.
                            Würde es halt gerne verstehen, wo das her kommt.
                            Aber zurück zu meiner anderen Frage,
                            Wie realisiert ihr denn zyklische Abläufe und Timer?

                            schau in meine adapter.

                            verwende setTimeout.
                            setInterval wird dann im Review angemeckert

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

                            @oliverio kannst Du mir eventuell weiter helfen?

                            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

                            979

                            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