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. [Gelöst] Rauchmelder Alarm per NodeJS Socket

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    13
    1
    125

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    562

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.7k

[Gelöst] Rauchmelder Alarm per NodeJS Socket

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
11 Beiträge 3 Kommentatoren 864 Aufrufe
  • Ä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.
  • apollon77A Offline
    apollon77A Offline
    apollon77
    schrieb am zuletzt editiert von
    #2

    Was hast du denn für rauchender im Einsatz? Das schreibst du leider nicht ;-)

    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
    • U Offline
      U Offline
      uzulio
      schrieb am zuletzt editiert von
      #3

      @apollon77:

      Was hast du denn für rauchender im Einsatz? Das schreibst du leider nicht ;-) `

      Im Eifer des Gefechts ganz vergessen :oops:

      Habe aktuell 3 Homematic IP Rauchmelder HmIP-SWSD im Einsatz.

      1 Antwort Letzte Antwort
      0
      • paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #4

        @uzulio:

        Wenn ich direkt mit den Alarm-Variablen der Rauchmelder arbeite, bekomme ich beim ersten Alarm eine Nachricht, aber auch die Nachrichten der anderen Rauchmelder, die halt sagen, dass sie keinen Alarm haben. `
        Wie hast Du das angestellt ?

        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
        • U Offline
          U Offline
          uzulio
          schrieb am zuletzt editiert von
          #5

          @paul53:

          Wie hast Du das angestellt ? `

          Naja ich habe eine Variable, die den Status aller Rauchmelder beinhaltet und gehe die bei Änderung mit einer each-Funktion durch. Damit kann ich es ja nicht vermeiden, dass das passiert. Daher meine Frage.

          Natürlich könnte ich das jetzt für jeden einzeln machen, aber in Zukunft sollen noch mehr dazu kommen und dann wird das ein wenig lästig und ich hatte gehofft ich kann das irgendwie zusammenlegen.

          1 Antwort Letzte Antwort
          0
          • paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #6

            @uzulio:

            Naja ich habe eine Variable, die den Status aller Rauchmelder beinhaltet und gehe die bei Änderung mit einer each-Funktion durch. `
            Also eine https://github.com/ioBroker/ioBroker.javascript/blob/master/doc/en/javascript.md#–-selector ? Darauf kann man auch on() anwenden.

            const alleRM = $(...);
            
            alleRM.on(function(dp) {
               var msg = dp.deviceName + ': Alarm ';
               if(dp.state.val) msg = msg + 'kommend !';
               else msg = msg + 'gehend';
               // msg versenden
            });
            

            Mit on() wird nur der auslösende Datenpunkt ausgewertet.

            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
            • U Offline
              U Offline
              uzulio
              schrieb am zuletzt editiert von
              #7

              @paul53:

              const alleRM = $(...);
              alleRM.on(function(dp) {
                 var msg = dp.deviceName + ': Alarm ';
                 if(dp.state.val) msg = msg + 'kommend !';
                 else msg = msg + 'gehend';
                 // msg versenden
              });
              

              Mit on() wird nur der auslösende Datenpunkt ausgewertet. `

              Aber das hilft mir doch nicht, oder? Jeder Rauchmelder hat ja entweder 0 oder 1 als state. Wenn ich mich nicht täusche würde doch bei deinem Codebeispiel ein Alarm auf Rauchmelder 1 kommen und die Ausgabe wäre "Alarm kommend". Rauchmelder 2 und 3 würden doch jetzt aber gleichzeitig auch "Alarm gehend" ausgeben. Das ist doch genau das was ich vermeiden will.

              Oder verstehe ich etwas falsch?

              1 Antwort Letzte Antwort
              0
              • paul53P Offline
                paul53P Offline
                paul53
                schrieb am zuletzt editiert von
                #8

                @uzulio:

                Rauchmelder 2 und 3 würden doch jetzt aber gleichzeitig auch "Alarm gehend" ausgeben. `
                Nein. Es wird nur der gerade triggernde Datenpunkt in der Callback-Funktion ausgewertet. Probier es aus !

                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
                • U Offline
                  U Offline
                  uzulio
                  schrieb am zuletzt editiert von
                  #9

                  Tatsächlich :roll: Vielen Dank!

                  Also war der einzige Fehler die each-Funktion zu nutzen oder wie darf ich das verstehen? Bis auf das habe ich es quasi genauso probiert vorher.

                  Edit:

                  Für den Fall, dass man noch den Raum mit abfragen möchte:

                  var raum = getObject(dp.channelId, 'rooms').enumNames
                  
                  1 Antwort Letzte Antwort
                  0
                  • paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von
                    #10

                    @uzulio:

                    Also war der einzige Fehler die each-Funktion zu nutzen oder wie darf ich das verstehen? `
                    Ja, each() fragt alle Datenpunkte in einer Schleife ab.

                    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
                    • U Offline
                      U Offline
                      uzulio
                      schrieb am zuletzt editiert von
                      #11

                      Alles klar, dann bedanke ich mich für die schnelle Hilfe :D

                      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

                      887

                      Online

                      32.5k

                      Benutzer

                      81.8k

                      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