Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Rutenbeck TCR IP4 wie korrekt schalten

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Rutenbeck TCR IP4 wie korrekt schalten

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

      Hallo zusammen,

      ich bin recht neu bei ioBroker und bräucht mal etwas Unterstüzung.

      Ich habe einen TCR IP 4 von Rutenbeck rumliegen.
      Die Dinger sind recht teuer, können aber nur per physikalischem Taster
      oder per integrierter WEB Oberfläche gesteuert werden.

      Aus der Web Oberfläche habe ich zwei Links heraus kopiert.

      mit:

      http://192.168.10.3/leds.cgi?led=1 (1...4) kann ich einen Ausgang toggeln

      und mit:
      http://192.168.10.3/status.xml

      bekomme ich ein kleines Status XML zurück

      <response>
      <led1>0</led1>
      <led2>0</led2>
      <led3>1</led3>
      <led4>1</led4>
      <pot0>nicht angeschlossen</pot0>
      </response>
      

      mit einem Parser Adapter und RegEx frage ich die Ports jede Sekunde ab.
      70771158-f95c-4c6d-8efb-5073bc45bf8d-image.png
      Diese Objekte nehmen ich dann im VIS als Schalter
      edcfd592-9a6b-44f4-bf2d-aada626ce0d0-image.png

      Den eigentlichen Schaltvorgang steuere ich dann über einen Blockly Script das auf Status Änderungen am Parser Objekt wartet.

      c64452dc-72e0-44dc-a91e-0253a611351d-image.png

      Das funktioniert zwar so, ist aber meiner Meinung nach nicht korrekt. Weil die Status Änderung am Parser Objekt
      zwei verschiedene Ursachen haben könnte. Erstens ein Taster am Gerät, zweitens ein Klick im VIS.

      Ich wüsste gerne wie Ihr das lösen würdet.

      R B 2 Replies Last reply Reply Quote 0
      • R
        Rutenbeck @hobride last edited by

        Hallo @hobride,

        Du kannst statt des Togglebefehls auch als "Trick" einen Impulsbefehl an den TCR IP 4 versenden. Wenn die Zeit "0" beträgt, schaltet das Gerät dauerhaft ein bzw. aus. Die Befehle lauten:

        Einschaltbefehl:
        192.168.0.3/impl.cgi?aus100:00:00normal (IP anpassen ; ...ausg1... für Ausgang 1 des Geräts)

        Ausschaltbefehl:
        192.168.0.3/impl.cgi?aus100:00:00reset

        In Deiner letzten Anmerkung führst Du an, dass die Statusänderung zwei Gründe haben kann (Taster bzw. Klick im VIS). Das lässt sich nicht ändern. Genau genommen lässt sich das Gerät über drei Möglichkeiten schalten. Neben den von Dir erwähnten, lassen sich auch abgesetzte Taster an das Gerät anschließen (grüner Klemmsockel oben am Gerät).

        Wir hoffen Dir ein wenig weitergeholfen zu haben. Wenn Du weitere Fragen oder Anregungen hast, kontaktiere uns gerne persönlich. Die erfoderlichen Kontaktdaten findest Du unter www.rutenbeck.de.

        LG
        Technical Support

        H 1 Reply Last reply Reply Quote 1
        • H
          hobride @Rutenbeck last edited by

          @rutenbeck Hey Danke für die Info. Darauf wäre ich wohl alleine nie gekommen 👍

          und mit Taster dachte ich eigentlich sowieso an abgesetzte Taster. Die am Gerät hätte ich eigentlich vernachlässigt 😁

          1 Reply Last reply Reply Quote 0
          • B
            Bolli @hobride last edited by

            @hobride hast du es mittlerweile am laufen ?

            1 Reply Last reply Reply Quote 0
            • B
              Blackbeard last edited by

              Ich habe mir folgenden JS-Code mit Hilfe von ChatGPT erstellt:

              const dgram = require('dgram');
              const deviceIP = 'xxx.xxx.xxx.xxx'; // IP-Adresse der Zeitschaltuhr
              const port = 30303; // UDP-Port der Zeitschaltuhr
              const states = ['OUT1', 'OUT2', 'OUT3', 'OUT4']; // Zustände (ohne Temperatur)
              const warnCooldown = {}; // Warnungstimer für Statusabweichungen
              const retryAttempts = 3; // Anzahl der Wiederholungen bei Abfrageabweichungen
              const warnLimit = 2; // Anzahl maximaler Warnungen pro Abweichung
              
              // Datenpunkte im ioBroker erstellen
              states.forEach(state => {
                  createState(`javascript.0.Zeitschaltuhr.${state}`, false, { name: `${state} Schalter`, type: 'boolean', def: false, read: true, write: true });
              });
              // Spezieller Datenpunkt für Temperatur
              createState(`javascript.0.Zeitschaltuhr.Temperatur`, 0, { name: 'Temperatur Status', type: 'mixed', def: 0, read: true, write: false });
              
              // Funktion, um UDP-Befehl zu senden und Antwort abzurufen
              function sendUDPCommandAndReceive(command, callback) {
                  const message = Buffer.from(command);
                  const client = dgram.createSocket('udp4');
              
                  client.on('message', (msg, rinfo) => {
                      const response = msg.toString();
              
                      // Antwort analysieren und Datenpunkte aktualisieren
                      if (response.startsWith('T')) {
                          const parts = response.split('=');
                          if (parts.length > 1) {
                              const value = parseFloat(parts[1].trim());
              
                              if (!isNaN(value)) {
                                  const currentState = getState(`javascript.0.Zeitschaltuhr.Temperatur`).val;
                                  if (value === -27) {
                                      if (currentState !== 'nicht angeschlossen') {
                                          setState(`javascript.0.Zeitschaltuhr.Temperatur`, 'nicht angeschlossen', true);
                                      }
                                  } else {
                                      if (currentState !== value) {
                                          setState(`javascript.0.Zeitschaltuhr.Temperatur`, value, true);
                                      }
                                  }
                              }
                          }
                      } else {
                          states.forEach(state => {
                              if (response.startsWith(state)) {
                                  const parts = response.split('=');
                                  if (parts.length > 1) {
                                      const value = parseInt(parts[1].trim(), 10);
              
                                      if (value === 0 || value === 1) {
                                          const currentState = getState(`javascript.0.Zeitschaltuhr.${state}`).val;
                                          if (currentState !== (value === 1)) {
                                              setState(`javascript.0.Zeitschaltuhr.${state}`, value === 1, true);
                                          }
                                      }
                                  }
                              }
                          });
                      }
              
                      client.close();
                      if (callback) callback(response);
                  });
              
                  client.send(message, 0, message.length, port, deviceIP, (err) => {
                      if (err) {
                          console.error(`Fehler beim Senden: ${err.message}`);
                          client.close();
                      }
                  });
              }
              
              // Funktion zur Steuerung der Ports (ein- und ausschalten)
              function controlPort(portNumber, state) {
                  if (portNumber < 1 || portNumber > 4) {
                      console.error('Ungültige Portnummer. Bitte 1 bis 4 angeben.');
                      return;
                  }
                  if (state !== 0 && state !== 1) {
                      console.error('Ungültiger Zustand. Bitte 0 (aus) oder 1 (ein) angeben.');
                      return;
                  }
              
                  const command = `OUT${portNumber} ${state}`;
                  sendUDPCommandAndReceive(command, () => {
                      let attempts = 0;
                      let warnings = 0;
              
                      function checkStatus() {
                          const queryCommand = `OUT${portNumber} ?`;
                          sendUDPCommandAndReceive(queryCommand, (response) => {
                              const parts = response.split('=');
                              if (parts.length > 1) {
                                  const value = parseInt(parts[1].trim(), 10);
                                  if (value === state) {
                                      setState(`javascript.0.Zeitschaltuhr.OUT${portNumber}`, value === 1, true);
                                  } else {
                                      attempts++;
                                      if (attempts < retryAttempts) {
                                          setTimeout(checkStatus, 500); // Wiederholen nach 500ms
                                      } else {
                                          warnings++;
                                          if (warnings <= warnLimit) {
                                              console.warn(`Status von OUT${portNumber} stimmt nicht überein: Erwartet ${state}, erhalten ${value}`);
                                          }
                                      }
                                  }
                              }
                          });
                      }
              
                      // Erste Statusprüfung nach 1 Sekunde
                      setTimeout(checkStatus, 1000);
                  });
              }
              
              // Listener für Schalter in ioBroker
              states.forEach((state, index) => {
                  on({ id: `javascript.0.Zeitschaltuhr.${state}`, change: 'any' }, (obj) => {
                      const newState = obj.state.val ? 1 : 0;
                      controlPort(index + 1, newState);
                  });
              });
              
              // Funktion zur regelmäßigen Abfrage
              function queryStates() {
                  states.concat('T').forEach((state) => {
                      const command = `${state} ?`;
                      sendUDPCommandAndReceive(command);
                  });
              }
              
              // Intervall für regelmäßige Abfragen (alle 10 Sekunden)
              setInterval(queryStates, 10000);
              
              // Initialer Aufruf
              queryStates();
              
              

              Der Code ließt den aktuellen Zustand der Ports 1-4 sowie der Temperatur (Ich besitze keinen Sensor und kann die Ausgabe der Temp. nicht testen) per UDP-Protokoll und erstellt in ioBroker passende Datenpunkte. Diese können dann aus ioBroker oder VIS geschaltet werden.

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

              Support us

              ioBroker
              Community Adapters
              Donate

              949
              Online

              31.7k
              Users

              79.7k
              Topics

              1.3m
              Posts

              4
              5
              648
              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