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.
    • Axel Koeneke
      Axel Koeneke last edited by

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

      npm ls serialport

      Jetzt wird es interessant:

      pi@iobroker-cl1:~ $ npm ls serialport
      /home/pi
      └── serialport@9.2.8
      
      
      pi@iobroker-cl1:/opt/iobroker $ npm ls serialport
      iobroker.inst@3.0.0 /opt/iobroker
      ├─┬ iobroker.discovery@2.7.5
      │ └── serialport@9.2.8
      ├─┬ iobroker.javascript@5.3.1
      │ └── %(#ff0000)[UNMET DEPENDENCY] serialport@^10.4.0
      ├─┬ iobroker.smartmeter@3.3.3
      │ ├── serialport@10.3.0
      │ └─┬ smartmeter-obis@3.0.2
      │   └── serialport@10.3.0
      └─┬ iobroker.zwave2@2.4.3
        └─┬ zwave-js@8.11.7
          ├─┬ @zwave-js/serial@8.11.7
          │ └── serialport@9.2.8  deduped
          └── serialport@9.2.8  deduped
      
      npm ERR! missing: serialport@^10.4.0, required by iobroker.javascript@5.3.1
      

      Wenn ich das richtig lese, dann verlangt der javascript@5.3.1, serialport@10

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

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

        Wenn ich das richtig lese, dann verlangt der javascript@5.3.1, serialport@10

        Ja, aber nur weil der bei dir händisch als zusätzliches Modul eingetragen ist. Generell ist serialport keine Abhängigkeit im javascript-Adapter.

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

          @thomas-braun Okay das Modul habe ich wieder entfernt. Reboot des Pi gemacht, die Ausgabe ist aber noch die Gleiche. Wie kann ich das gerade ziehen?

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

            @axel-koeneke

            Möglich das der jetzt manuell da rausgepflückt werden muss. Das hab ich aber noch nie gemacht.

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

              @thomas-braun Okay, dann werde ich mal suchen...
              Danke für die Geduld.

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

                @axel-koeneke

                Wäre vielleicht mal interessant zu sehen, warum der serialport nicht baut.
                Lass den mal drin und starte den javascript-Adapter neu. Im Log dürfte dann was entsprechendes drin stehen. Etwaige andere skripte am besten solange mal stoppen, dann spuken die nicht mit drin rum.

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

                  Ich habe noch JavaScript 5.2.21

                  Upgrade kann/will ich erst machen wenn ich wieder zu Hause bin. Kein Lust über VPN da rum zu fummeln wenn es nachher nicht mehr läuft. 🙂

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

                    @axel-koeneke

                    Hilft dir zwar nicht, aber bei mir baut der serialport auch als zusätzliches Paket im javascript-Adapter.

                    echad@chet:/opt/iobroker $ npm ls serialport
                    iobroker.inst@3.0.0 /opt/iobroker
                    ├─┬ iobroker.javascript@5.3.3
                    │ └── serialport@10.4.0
                    └─┬ iobroker.zigbee@1.6.16
                      ├─┬ zigbee-herdsman-converters@14.0.422
                      │ └─┬ zigbee-herdsman@0.14.14
                      │   └── serialport@9.2.8
                      └─┬ zigbee-herdsman@0.14.16
                        └── serialport@9.2.8
                    

                    Deinstallation geht übrigens aus dem richtigen Ordner heraus so:

                    echad@chet:/opt/iobroker/node_modules/iobroker.javascript $ npm uninstall serialport
                    
                    Axel Koeneke 1 Reply Last reply Reply Quote 0
                    • Axel Koeneke
                      Axel Koeneke @Thomas Braun last edited by

                      @thomas-braun sagte in Script Hilfe für Abfrage Serielle Kommunikation gesucht!:

                      @axel-koeneke

                      Hilft dir zwar nicht, aber bei mir baut der serialport auch als zusätzliches Paket im javascript-Adapter.

                      ├─┬ iobroker.javascript@5.3.3
                      │ └── serialport@10.4.0
                      

                      Und da isser wieder. Hmm, wenn der javascript den 10er Port mitbringt, frage ich mich wie ich den 9er manuell installieren kann.
                      Der 10er wird mit Wendy's Script nicht mehr funktionieren (s.O.).
                      VG

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

                        @axel-koeneke Kann keine schnelle Lösung anbieten da ich wie gesagt nicht zu Hause bin um vernünftig testen zu können aber ich denke das Script bekommen wir angepasst.

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

                          @axel-koeneke

                          Jetzt scheints ja sauber drin zu sein.
                          Zu dem skript kann ich nix sagen.

                          Trag den serialport im Adapter mal so ein:
                          serialport@9
                          oder
                          serialport@9.2.8
                          das installiert eine Version aus dem 9er-Zweig oder halt v 9.2.8
                          Was halt gebraucht wird.

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

                            @thomas-braun Danke, das war es:

                            pi@iobroker-cl1:/opt/iobroker/node_modules/iobroker.javascript $ npm install serialport@9.2.8
                            
                            pi@iobroker-cl1:/opt/iobroker $ npm ls serialport
                            iobroker.inst@3.0.0 /opt/iobroker
                            ├─┬ iobroker.discovery@2.7.5
                            │ └── serialport@9.2.8
                            ├─┬ iobroker.javascript@5.2.21
                            │ └── serialport@9.2.8  deduped
                            ├─┬ iobroker.smartmeter@3.2.1
                            │ ├── serialport@9.2.8  deduped
                            │ └─┬ smartmeter-obis@2.3.0
                            │   └── serialport@9.2.8  deduped
                            └─┬ iobroker.zwave2@2.4.3
                              └─┬ zwave-js@8.11.7
                                ├─┬ @zwave-js/serial@8.11.7
                                │ └── serialport@9.2.8  deduped
                                └── serialport@9.2.8  deduped
                            

                            Jetzt läuft das Script wieder.
                            Muss ich mir gleich ins kleine Buch schreiben (Tips & Tricks) 🙂
                            VG
                            Axel

                            1 Reply Last reply Reply Quote 0
                            • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            960
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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