Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Script Hilfe für Abfrage Serielle Kommunikation gesucht!

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Script Hilfe für Abfrage Serielle Kommunikation gesucht!

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

      @axel-koeneke
      @thomas-braun

      Hallo, ich klinke mich hier mal ein, da das Skript bei mir leider auch nicht mehr läuft...

      Ich habe im Skripte Reiter beim Starten des Skripts folgende Fehlermeldungen...

      22:18:11.108	info	javascript.2 (3043) Start javascript script.js.Wärmepumpe.Abfrage_Wärmepumpe
      22:18:11.256	warn	javascript.2 (3043) at script.js.Wärmepumpe.Abfrage_Wärmepumpe:5:1
      22:18:11.257	warn	javascript.2 (3043) at script.js.Wärmepumpe.Abfrage_Wärmepumpe:146:3
      22:18:11.322	info	javascript.2 (3043) script.js.Wärmepumpe.Abfrage_Wärmepumpe: registered 0 subscriptions and 0 schedules
      22:18:11.338	error	javascript.2 (3043) script.js.Wärmepumpe.Abfrage_Wärmepumpe: ReferenceError: parsers is not defined
      22:18:11.339	error	javascript.2 (3043) at script.js.Wärmepumpe.Abfrage_Wärmepumpe:14:20
      22:18:11.340	error	javascript.2 (3043) at script.js.Wärmepumpe.Abfrage_Wärmepumpe:146:3
      

      wobei Zeile 14 folgender code ist:

      const ByteLength = parsers.ByteLength;
      

      und das"parser" kenn er nicht.

      Ich habe auch versucht die 10er Version des serialport modules zu deinstalieren mit folgendem Befehl...

      /opt/iobroker/node_modules/iobroker.javascript $ npm uninstall serialport 
      

      um danach mit

      /opt/iobroker/node_modules/iobroker.javascript $ npm install serialport@9.2.8
      

      die Version 9.2.8 zu installieren. Leider dürfte da was nicht funktioniert haben...

      hier die Ansicht von npm ls serialport....

      pi@raspberry3b1:/opt/iobroker $ npm ls serialport
      iobroker.inst@3.0.0 /opt/iobroker
      ├─┬ iobroker.discovery@2.7.3
      │ └── serialport@9.2.8 
      └─┬ iobroker.javascript@5.2.21
        └── UNMET DEPENDENCY serialport@10.4.0 
      
      npm ERR! missing: serialport@10.4.0, required by iobroker.javascript@5.2.21
      

      Hab versucht das aus den oberen Beiträgen zu übernehmen, hat bei mir leider nicht geholfen..l
      habt Ihr noch einen Tip?

      lg

      Thomas Braun Axel Koeneke 2 Replies Last reply Reply Quote 0
      • Thomas Braun
        Thomas Braun Most Active @etzeste13 last edited by

        @etzeste13
        Hast du den serialport im javascript-Adapter eingetragen?

        1eefca16-520e-4de8-a14c-db8936c73d05-image.png
        So sollte das dann aussehen.

        1 Reply Last reply Reply Quote 0
        • E
          etzeste13 last edited by

          @thomas-braun

          Hallo,

          ja das habe ich auch gemacht..., habe ich sogar schon vor den manuellen eingriffen so eingetragen... hatte aber auch keine Änderung gebracht....

          7b556928-1d72-41cd-a02a-c8cbcfa13220-grafik.png

          1 Reply Last reply Reply Quote 0
          • Axel Koeneke
            Axel Koeneke @etzeste13 last edited by

            hier die Ansicht von npm ls serialport....

            └─┬ iobroker.javascript@5.2.21
              └── UNMET DEPENDENCY serialport@10.4.0 
            
            npm ERR! missing: serialport@10.4.0, required by iobroker.javascript@5.2.21
            

            Hab versucht das aus den oberen Beiträgen zu übernehmen, hat bei mir leider nicht geholfen..l
            habt Ihr noch einen Tip?

            lg

            Hast du mal alles neu gestartet?
            Sieht deine Ausgabe immer noch so wie oben aus?

            E 1 Reply Last reply Reply Quote 0
            • E
              etzeste13 @Axel Koeneke last edited by

              @axel-koeneke said in Script Hilfe für Abfrage Serielle Kommunikation gesucht!:

              npm ls serialport

              Hallo Axel,

              ich habe gerade eben nochmals neu gestartet und noch wie vor folgende Ausgabe

              pi@raspberry3b1:/opt/iobroker $ npm ls serialport
              iobroker.inst@3.0.0 /opt/iobroker
              ├─┬ iobroker.discovery@2.7.3
              │ └── serialport@9.2.8 
              └─┬ iobroker.javascript@5.2.21
                └── UNMET DEPENDENCY serialport@10.4.0 
              
              npm ERR! missing: serialport@10.4.0, required by iobroker.javascript@5.2.21
              
              
              1 Reply Last reply Reply Quote 0
              • wendy2702
                wendy2702 last edited by

                @etzeste13 Konntest du dein Problem eigentlich lösen?

                Ich versuche gerade verzweifelt Serialport 10.4.0 zu installieren was mir nicht gelingen will.

                Frage mich wie ihr euch das eingefangen habt.

                1 Reply Last reply Reply Quote 0
                • wendy2702
                  wendy2702 @Axel Koeneke last edited by wendy2702

                  @axel-koeneke sagte in Script Hilfe für Abfrage Serielle Kommunikation gesucht!:

                  Hallo Wendy,
                  hast du das Script schon unter V10 zum laufen gebracht?

                  Ja, heute Zeit gehabt, getestet mit Serialport 10.4.0

                  pi@iob-test:/opt/iobroker/node_modules/iobroker.javascript $ npm ls serialport
                  iobroker.javascript@5.4.0 /opt/iobroker/node_modules/iobroker.javascript
                  └── serialport@10.4.0
                  

                  Vielleicht findet ja jemand Zeit und Lust das auch mal bei sich zu testen.

                  // Anpassungen durch USER:
                  // Zeile 8 Javascript.x <-- eigene verwendete JS Instanz angeben
                  // Zeile 29 Device anpassen
                  // Zeile 41 Javascript.x <-- eigene verwendete JS Instanz angeben
                  
                  createState('Waterkotte.Daten.Abfrage_Rohdaten');
                  //createState('Waterkotte.Daten.Abfrage_Error');
                  setState("javascript.0.Waterkotte.Daten.Abfrage_Error"/*Waterkotte.Daten.Abfrage_Error*/, false);
                  
                  // To use the `ByteLength` parser:
                  const { SerialPort } = require('serialport');
                  const { ByteLengthParser } = require('@serialport/parser-byte-length');
                  
                  
                  var buffer = Buffer.alloc(12);
                  buffer[0] = 0x10;
                  buffer[1] = 0x02;
                  buffer[2] = 0x01;
                  buffer[3] = 0x15;
                  buffer[4] = 0x00;
                  buffer[5] = 0x00;
                  buffer[6] = 0x00;
                  buffer[7] = 0xf3;
                  buffer[8] = 0x10;
                  buffer[9] = 0x03;
                  buffer[10] = 0x7c;
                  buffer[11] = 0x32;
                  const port = new SerialPort({
                      path: '/dev/ttyUSB0',
                      baudRate: 9600,
                      dataBits : 8,
                      parity : 'none',
                      stopBits: 1
                      //  flowControl : false
                  },
                  
                  function (err)
                      {if (err) {
                  //        port.close();
                          console.log('Error1: ', err.message);
                          setState("javascript.0.Waterkotte.Daten.Abfrage_Error"/*Waterkotte.Daten.Abfrage_Error*/, true);
                      };
                  
                      const parser = port.pipe(new ByteLengthParser({ length: 253 }));
                      parser.on('data', function (data) {
                          console.log('Data received: ' + data.toString('hex'));
                          var daten = data.toString('hex');
                          setState('Waterkotte.Daten.Abfrage_Rohdaten', daten, true);
                          //port.close();
                      });
                  
                       // Flush input
                       port.flush();
                  
                       // send Data
                       port.write(buffer, function(err) {
                           if (err) {
                               return console.log('Error on write: ', err.message);
                           }
                           
                           console.log('Daten send');
                  //       port.close();
                          });
                      });
                      
                  port.on('open', function() {
                      console.log('Connected');
                  });
                  
                  port.on('error', function(err) {
                      console.log('Error2: ', err.message);
                  //  port.close();
                  });
                  
                  // close port if the script stopped (to be able to open it again)
                  onStop(function (callback) {
                      if (port && port.isOpen) {
                          port.close();
                          console.log('port closed');
                      }
                  });
                  
                  

                  Geht bestimmt auch schöner aber mehr geben meine Rudimentären JS Kenntnisse aktuell nicht her 🙂

                  Axel Koeneke E 2 Replies Last reply Reply Quote 1
                  • wendy2702
                    wendy2702 last edited by

                    Hier noch zum Umschalten Warmwasser auf 45 Grad

                    createState('Waterkotte.Daten.WW_TEMP_Change_feedback');
                    
                    // To use the `ByteLength` parser:
                    const { SerialPort } = require('serialport');
                    const { ByteLengthParser } = require('@serialport/parser-byte-length');
                    
                    var buffer = Buffer.alloc(14);
                    buffer[0] = 0x10;
                    buffer[1] = 0x02;
                    buffer[2] = 0x01;
                    buffer[3] = 0x13;
                    buffer[4] = 0x01;
                    buffer[5] = 0x3b;
                    buffer[6] = 0x00;		// Fourth 2 Hex
                    buffer[7] = 0x00;		// Third 2 Hex
                    buffer[8] = 0x34;		//Second 2 Hex
                    buffer[9] = 0x42;		//First 2 Hex
                    buffer[10] = 0x10;
                    buffer[11] = 0x03;
                    buffer[12] = 0xc8;  	//CRC
                    buffer[13] = 0x72;		//CRC
                    const port = new SerialPort({
                       path: '/dev/ttyUSB1',
                       baudRate: 9600,
                       dataBits : 8,
                       parity : 'none',
                       stopBits: 1
                       //  flowControl : false
                    }, 
                    
                    function (err) {
                       if (err) {
                    //        port.close();
                           return console.log('Error1: ', err.message);
                       }
                    
                       const parser = port.pipe(new ByteLengthParser({ length: 11 }));
                       parser.on('data', function (data) {
                       	console.log('Data received: ' + data.toString('hex'));
                       	var daten = data.toString('hex');
                       	setState('Waterkotte.Daten.WW_TEMP_Change_feedback', daten, true);
                       	//port.close();
                       });
                    
                       // Flush input
                       port.flush();
                    
                       // send Data
                           port.write(buffer, function(err) {
                       	    if (err) {
                       		    return console.log('Error on write: ', err.message);
                       	    }
                       
                       	    console.log('Daten send');
                    // 		    port.close();
                           });
                       });
                       
                    port.on('open', function() {
                       console.log('Connected');
                    });
                    
                    port.on('error', function(err) {
                       console.log('Error2: ', err.message);
                    //	port.close();
                    });
                    
                    // close port if the script stopped (to be able to open it again)
                    onStop(function (callback) {
                       if (port && port.isOpen) {
                       	port.close();
                       	console.log('port closed');
                       }
                    });
                    
                    

                    Hier umschalten Warmwasser auf 60Grad

                    createState('Waterkotte.Daten.WW_TEMP_Change_feedback');
                    
                    // To use the `ByteLength` parser:
                    const { SerialPort } = require('serialport');
                    const { ByteLengthParser } = require('@serialport/parser-byte-length');
                    
                    var buffer = Buffer.alloc(14);
                    buffer[0] = 0x10;
                    buffer[1] = 0x02;
                    buffer[2] = 0x01;
                    buffer[3] = 0x13;
                    buffer[4] = 0x01;
                    buffer[5] = 0x3b;
                    buffer[6] = 0x00;
                    buffer[7] = 0x00;
                    buffer[8] = 0x70;
                    buffer[9] = 0x42;
                    buffer[10] = 0x10;
                    buffer[11] = 0x03;
                    buffer[12] = 0xd0;
                    buffer[13] = 0x77;
                    const port = new SerialPort({
                       path: '/dev/ttyUSB1',
                       baudRate: 9600,
                       dataBits : 8,
                       parity : 'none',
                       stopBits: 1
                       //  flowControl : false
                    }, 
                    
                    function (err) {
                       if (err) {
                    //        port.close();
                           return console.log('Error1: ', err.message);
                       }
                    
                       const parser = port.pipe(new ByteLengthParser({ length: 11 }));
                       parser.on('data', function (data) {
                       	console.log('Data received: ' + data.toString('hex'));
                       	var daten = data.toString('hex');
                       	setState('Waterkotte.Daten.WW_TEMP_Change_feedback', daten, true);
                       	//port.close();
                       });
                    
                       // Flush input
                       port.flush();
                    
                       // send Data
                           port.write(buffer, function(err) {
                       	    if (err) {
                       		    return console.log('Error on write: ', err.message);
                       	    }
                       
                       	    console.log('Daten send');
                    // 		    port.close();
                           });
                       });
                       
                    port.on('open', function() {
                       console.log('Connected');
                    });
                    
                    port.on('error', function(err) {
                       console.log('Error2: ', err.message);
                    //	port.close();
                    });
                    
                    // close port if the script stopped (to be able to open it again)
                    onStop(function (callback) {
                       if (port && port.isOpen) {
                       	port.close();
                       	console.log('port closed');
                       }
                    });
                    
                    

                    1 Reply Last reply Reply Quote 1
                    • Axel Koeneke
                      Axel Koeneke @wendy2702 last edited by

                      @wendy2702 sagte in Script Hilfe für Abfrage Serielle Kommunikation gesucht!:

                      @axel-koeneke sagte in Script Hilfe für Abfrage Serielle Kommunikation gesucht!:

                      Hallo Wendy,
                      hast du das Script schon unter V10 zum laufen gebracht?

                      Ja, heute Zeit gehabt, getestet mit Serialport 10.4.0

                      pi@iob-test:/opt/iobroker/node_modules/iobroker.javascript $ npm ls serialport
                      iobroker.javascript@5.4.0 /opt/iobroker/node_modules/iobroker.javascript
                      └── serialport@10.4.0
                      

                      Vielleicht findet ja jemand Zeit und Lust das auch mal bei sich zu testen.

                      // Anpassungen durch USER:
                      // Zeile 8 Javascript.x <-- eigene verwendete JS Instanz angeben
                      // Zeile 29 Device anpassen
                      // Zeile 41 Javascript.x <-- eigene verwendete JS Instanz angeben
                      
                      createState('Waterkotte.Daten.Abfrage_Rohdaten');
                      //createState('Waterkotte.Daten.Abfrage_Error');
                      setState("javascript.0.Waterkotte.Daten.Abfrage_Error"/*Waterkotte.Daten.Abfrage_Error*/, false);
                      
                      // To use the `ByteLength` parser:
                      const { SerialPort } = require('serialport');
                      const { ByteLengthParser } = require('@serialport/parser-byte-length');
                      
                      
                      var buffer = Buffer.alloc(12);
                      buffer[0] = 0x10;
                      buffer[1] = 0x02;
                      buffer[2] = 0x01;
                      buffer[3] = 0x15;
                      buffer[4] = 0x00;
                      buffer[5] = 0x00;
                      buffer[6] = 0x00;
                      buffer[7] = 0xf3;
                      buffer[8] = 0x10;
                      buffer[9] = 0x03;
                      buffer[10] = 0x7c;
                      buffer[11] = 0x32;
                      const port = new SerialPort({
                          path: '/dev/ttyUSB0',
                          baudRate: 9600,
                          dataBits : 8,
                          parity : 'none',
                          stopBits: 1
                          //  flowControl : false
                      },
                      
                      function (err)
                          {if (err) {
                      //        port.close();
                              console.log('Error1: ', err.message);
                              setState("javascript.0.Waterkotte.Daten.Abfrage_Error"/*Waterkotte.Daten.Abfrage_Error*/, true);
                          };
                      
                          const parser = port.pipe(new ByteLengthParser({ length: 253 }));
                          parser.on('data', function (data) {
                              console.log('Data received: ' + data.toString('hex'));
                              var daten = data.toString('hex');
                              setState('Waterkotte.Daten.Abfrage_Rohdaten', daten, true);
                              //port.close();
                          });
                      
                           // Flush input
                           port.flush();
                      
                           // send Data
                           port.write(buffer, function(err) {
                               if (err) {
                                   return console.log('Error on write: ', err.message);
                               }
                               
                               console.log('Daten send');
                      //       port.close();
                              });
                          });
                          
                      port.on('open', function() {
                          console.log('Connected');
                      });
                      
                      port.on('error', function(err) {
                          console.log('Error2: ', err.message);
                      //  port.close();
                      });
                      
                      // close port if the script stopped (to be able to open it again)
                      onStop(function (callback) {
                          if (port && port.isOpen) {
                              port.close();
                              console.log('port closed');
                          }
                      });
                      
                      

                      Geht bestimmt auch schöner aber mehr geben meine Rudimentären JS Kenntnisse aktuell nicht her 🙂

                      Moin, werde es heute Abend mal testen.
                      VG
                      Axel

                      1 Reply Last reply Reply Quote 0
                      • E
                        etzeste13 @wendy2702 last edited by

                        @wendy2702

                        ich habe dein Scrict nun getestet....
                        es funktioniert mit dem serialport 10.. mit dem 9.x hat es nicht funktioniert.

                        Vielen Dank für die Anpassung des Scripts!!

                        vG
                        Etze

                        wendy2702 1 Reply Last reply Reply Quote 0
                        • wendy2702
                          wendy2702 @etzeste13 last edited by

                          @etzeste13 Danke fürs testen!

                          Axel Koeneke 1 Reply Last reply Reply Quote 0
                          • Axel Koeneke
                            Axel Koeneke @wendy2702 last edited by

                            @wendy2702 Bin jetzt auch zum testen gezwungen worden.
                            Läuft prima!

                            Axel Koeneke 1 Reply Last reply Reply Quote 0
                            • Axel Koeneke
                              Axel Koeneke @Axel Koeneke last edited by

                              @wendy2702 Habe jetzt mal den Error Datenpunkt im Eventlogger mitgeschrieben und bin überrascht wie oft die Instanz zurückgesetzt wird. Ist das bei dir auch so?
                              ffcf754c-aef5-41e6-a526-e125b502366f-image.png
                              VG
                              Axel

                              wendy2702 1 Reply Last reply Reply Quote 0
                              • wendy2702
                                wendy2702 @Axel Koeneke last edited by

                                @axel-koeneke Was genau zeichnest du da auf und welche Instanz meinst du?

                                1 Reply Last reply Reply Quote 0
                                • Axel Koeneke
                                  Axel Koeneke last edited by

                                  @wendy2702 Ich starte die Javascript Instanz (nur die auf dem Slave(PI)) neu, wenn das Error Bit in der Abfrage gesetzt wird. So wie du es wohl auch machst.

                                  wendy2702 1 Reply Last reply Reply Quote 0
                                  • wendy2702
                                    wendy2702 @Axel Koeneke last edited by

                                    @axel-koeneke Hmmm,

                                    also meine JS Instanz wurde in den letzten 8 Tagen 2x neu gestartet. Da gab es laut log wohl eine Überschneidung und der Port wurde nicht sauber geschlossen.

                                    W 1 Reply Last reply Reply Quote 0
                                    • W
                                      worxweis @wendy2702 last edited by

                                      Hallo Leute!

                                      ich besitze auch eine Waterkotte WP mit WPCU Regler!
                                      Model: DS 9301, FW1.00.11d

                                      Hier ist der Standard Kommunikationsmodus "Line-Modbus". Schnittstelle hat der Regler eine RS232.
                                      Hat irgendjemand hier Erfahrung, ob man diesen Regler mit dem Modbus Adapter auslesen kann?
                                      RTU kann der ja, und Line-Modbus dürfte ja eine RTU Modbus Variante sein, oder?

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

                                        @worxweis sagte in Script Hilfe für Abfrage Serielle Kommunikation gesucht!:

                                        WPCU Regler

                                        Lese mal ab hier:

                                        https://forum.iobroker.net/post/221705

                                        1 Reply Last reply Reply Quote 0
                                        • W
                                          worxweis @wendy2702 last edited by

                                          @wendy2702 Hallo!

                                          bin nicht so der Linux Fuchs. Kann mir jemand erklären, wie ich das Watercontrol am Raspy oder auf einem Windows Rechner zum laufen bekomme?

                                          Danke!

                                          wendy2702 1 Reply Last reply Reply Quote 0
                                          • wendy2702
                                            wendy2702 @worxweis last edited by

                                            @worxweis sagte in Script Hilfe für Abfrage Serielle Kommunikation gesucht!:

                                            Watercontrol

                                            Was meinst du damit?

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            894
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            15
                                            192
                                            20120
                                            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