Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. (gelöst )C-Programm auf Slave mit Rückgabewert ausführen

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    (gelöst )C-Programm auf Slave mit Rückgabewert ausführen

    This topic has been deleted. Only users with topic management privileges can see it.
    • arteck
      arteck Developer Most Active @Ralf 6 last edited by arteck

      @ralf-6 viele Wege führen nach..na du weist schon

      du kannst den linux adapter dafür nutzen.. aber für 1 Befehl ist es bissel oversized

      blockly sich schon mal angeschaut ??

      oder javascript

      const abfrage         = 'hier kommt dein consolen befehl rein';
      exec(abfrage, function(err, stdout, stderr) {
              if (err) {
                  log(err,"error");
                  return;
              }
              console.warn('dein sensorwert ' + stdout);
      
      });
      

      der javascript adapter muss zwingend auf dem slave installiert sein da der nuc an den i2c nicht dran kommt

      R 1 Reply Last reply Reply Quote 0
      • MartinP
        MartinP @Ralf 6 last edited by MartinP

        @ralf-6 Das ist ein Fall für die Simple Api

        EDIT: Codeschnipsel korrigiert

        https://github.com/ioBroker/ioBroker.simple-api

        1. Userdata Datenpunkt von Hand anlegen

        2. Rückgabewert des Programms mit Curl in einen Simple Api Aufruf verwandeln

        Wenn es wirklich der Exit-Code ist:

        SimpleApiUrl="http://192.168.2.201:8087/set/0_userdata.0."
        meinprogramm
        curl $SimpleApiUrl"MeinUserdataWert?value="$?
        

        Wenn es die Text-Ausgabe des Programmes ist

        result = $(meinprogramm)
        curl $SimpleApiUrl"MeinUserdataWert?value="$result
        
        
        R 1 Reply Last reply Reply Quote 0
        • R
          Ralf 6 @arteck last edited by

          @arteck
          Hallo,
          vielen Dank für den Hinweis mit dem Javascript und vor allem mit der zusätzlichen Instanz auf dem Slave. Leider funktioniert es bei mir noch nicht. Das kompilierte Programm läßt sich über die Konsole starten und gibt einen Wert aus. Mit dem Script bekomme ich erstmal einen Fehler. Der Haken bei "exec erlauben" ist gesetzt.

          Das Script habe ich folgendermaßen angepasst:

          
          const abfrage         = '/home/ralf/ ./drtr06';
          exec(abfrage, function(err, stdout, stderr) {
                  if (err) {
                      log(err,"error");
                      return;
                  }
                  console.warn('dein sensorwert ' + stdout);
           
          });
          
          

          Wenn ich es ausführe erhalte ich folgende Fehlemeldung:

          28.10.2024, 16:56:01.275	[info ]: javascript.0 (42398) Stopping script script.js.common.zum_Testen.drtr06_01
          28.10.2024, 16:56:01.296	[info ]: javascript.1 (740) Stopping script script.js.common.zum_Testen.drtr06_01
          28.10.2024, 16:56:05.407	[info ]: javascript.1 (740) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js)
          28.10.2024, 16:56:05.611	[info ]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
          28.10.2024, 16:56:05.647	[error]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: Error: Command failed: /home/ralf/ ./drtr06
          /bin/sh: 1: /home/ralf/: Permission denied
          
              at genericNodeError (node:internal/errors:984:15)
              at wrappedFn (node:internal/errors:538:14)
              at ChildProcess.exithandler (node:child_process:422:12)
              at ChildProcess.emit (node:events:519:28)
              at ChildProcess.emit (node:domain:488:12)
              at maybeClose (node:internal/child_process:1105:16)
              at Socket.<anonymous> (node:internal/child_process:457:11)
              at Socket.emit (node:events:519:28)
              at Socket.emit (node:domain:488:12)
              at Pipe.<anonymous> (node:net:339:12) {
            code: 126,
            killed: false,
            signal: null,
            cmd: '/home/ralf/ ./drtr06'
          }
          28.10.2024, 16:56:57.817	[info ]: javascript.1 (740) Stopping script script.js.common.zum_Testen.drtr06_01
          

          Ich vermute irgendetwas mit den Berichtigungen. Was muss ich jetzt noch tun?

          Gruß Ralf

          Thomas Braun 1 Reply Last reply Reply Quote 0
          • Thomas Braun
            Thomas Braun Most Active @Ralf 6 last edited by Thomas Braun

            @ralf-6 sagte in C-Programm auf Slave mit Rückgabewert ausführen:

            Was muss ich jetzt noch tun?

            Welcher user führt das denn nun aus?
            Der user iobroker hat in /home/ralf nix zu melden.
            Leg das Skript in /home/iobroker ab.

            paul53 1 Reply Last reply Reply Quote 0
            • R
              Ralf 6 @MartinP last edited by

              @martinp
              Hallo,
              vielen Dank für diesen Hinweis. Hierzu habe ich noch verständnis Fragen:

              • Den Adapter "simple-api" muss ich auf dem Master oder dem Slave installieren?
              • Bei "meinprogramm" kommt dort der Pfad mit Befehl rein?
              • "MeinUserdataWert" ist der Datenpunkt, welchen ich unter 1. anlegen soll?

              Ich gehe davon aus, dass es sich um eine Text-Ausgabe handelt, da der Wert in der Konsole angezeigt wird.

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

                @thomas-braun sagte: Leg das Skript in /home/iobroker ab.

                ... das kompilierte C-Programm in /home/iobroker.

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

                  @paul53 sagte in C-Programm auf Slave mit Rückgabewert ausführen:

                  ... das kompilierte C-Programm in /home/iobroker.

                  Stimmt.
                  Ist der Pfad nicht auch ungünstig/falsch? Ich würde das immer mit vollem absoluten Pfad aufrufen und nicht mit
                  '/home/ralf/ ./drtr06' Oder macht man das so in JS?

                  paul53 R 2 Replies Last reply Reply Quote 0
                  • paul53
                    paul53 @Thomas Braun last edited by paul53

                    @thomas-braun sagte: macht man das so in JS?

                    Nein, der Aufruf ist sicher falsch. An "exec" wird die normale Kommandozeile übergeben.

                    Thomas Braun 1 Reply Last reply Reply Quote 0
                    • R
                      Ralf 6 @Thomas Braun last edited by

                      @thomas-braun
                      Ich habe keine Ahnung wo so ein Programm richtigerweise liegen sollte und wie ich es mit einem absoluten Pfad aufrufen kann.
                      Ich bin sonst nur im Blockly unterwegs und von Haus ein Mechaniker und mache dies zum ertsen Mal.
                      Bin jedoch lernwillig und gebe mir Mühe die Informationen in meine Mechanikersprache zu übersetzen.

                      Vielen Dank für die Hilfe

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

                        Solche Programme gehören auch ganz eigentlich nach /usr/local/bin
                        Und da /usr/local/bin üblicherweise im $PATH liegt kannst du das dann auch direkt in der Kommandozeile aufrufen. Entsprechende Rechte natürlich vorausgesetzt.

                        R 1 Reply Last reply Reply Quote 0
                        • R
                          Ralf 6 @Thomas Braun last edited by

                          @thomas-braun
                          So das Programm liegt nun auf /usr/local/bin . Ich kann es auch aus der Konsole aufrufen und es gibt mir den Wert zurück.
                          Über das Script bekomme ich jedoch wieder eine Fehlermeldung.

                          28.10.2024, 17:46:30.509	[info ]: javascript.1 (740) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js)
                          28.10.2024, 17:46:30.547	[info ]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                          28.10.2024, 17:46:30.558	[error]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: Error: Command failed: /usr/local/bin/ ./drtr06
                          /bin/sh: 1: /usr/local/bin/: Permission denied
                          
                              at genericNodeError (node:internal/errors:984:15)
                              at wrappedFn (node:internal/errors:538:14)
                              at ChildProcess.exithandler (node:child_process:422:12)
                              at ChildProcess.emit (node:events:519:28)
                              at ChildProcess.emit (node:domain:488:12)
                              at maybeClose (node:internal/child_process:1105:16)
                              at Socket.<anonymous> (node:internal/child_process:457:11)
                              at Socket.emit (node:events:519:28)
                              at Socket.emit (node:domain:488:12)
                              at Pipe.<anonymous> (node:net:339:12) {
                            code: 126,
                            killed: false,
                            signal: null,
                            cmd: '/usr/local/bin/ ./drtr06'
                          }
                          28.10.2024, 17:46:39.047	[info ]: javascript.1 (740) Stopping script script.js.common.zum_Testen.drtr06_01
                          

                          Was ist der nächste Schritt?

                          Thomas Braun paul53 MartinP 3 Replies Last reply Reply Quote 0
                          • Thomas Braun
                            Thomas Braun Most Active @Ralf 6 last edited by

                            @ralf-6 sagte in C-Programm auf Slave mit Rückgabewert ausführen:

                            Command failed: /usr/local/bin/ ./drtr06

                            Das ist falsch. Das muss als absoluter Pfad dann

                            /usr/local/bin/drtr06
                            lauten.

                            1 Reply Last reply Reply Quote 0
                            • paul53
                              paul53 @Ralf 6 last edited by paul53

                              @ralf-6 sagte: cmd: '/usr/local/bin/ ./drtr06'

                              Das Kommando ist falsch. Ich nehme an, das Programm hat den Namen "drtr06"? Dann rufe es so auf, wenn es ausführbar unter /usr/local/bin liegt:

                              const abfrage         = 'drtr06';
                              
                              R 1 Reply Last reply Reply Quote 0
                              • R
                                Ralf 6 @paul53 last edited by

                                @paul53
                                Das Javascript lautet jetzt:

                                
                                const abfrage         = 'drtr06';
                                exec(abfrage, function(err, stdout, stderr) {
                                        if (err) {
                                            log(err,"error");
                                            return;
                                        }
                                        console.warn('dein sensorwert ' + stdout);
                                 
                                });
                                
                                

                                Die Fehlermeldung dazu:

                                28.10.2024, 17:52:57.159	[info ]: javascript.1 (740) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js)
                                28.10.2024, 17:52:57.201	[info ]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                                28.10.2024, 17:52:57.214	[error]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: Error: Command failed: drtr06
                                
                                    at genericNodeError (node:internal/errors:984:15)
                                    at wrappedFn (node:internal/errors:538:14)
                                    at ChildProcess.exithandler (node:child_process:422:12)
                                    at ChildProcess.emit (node:events:519:28)
                                    at ChildProcess.emit (node:domain:488:12)
                                    at maybeClose (node:internal/child_process:1105:16)
                                    at Socket.<anonymous> (node:internal/child_process:457:11)
                                    at Socket.emit (node:events:519:28)
                                    at Socket.emit (node:domain:488:12)
                                    at Pipe.<anonymous> (node:net:339:12) {
                                  code: 120,
                                  killed: false,
                                  signal: null,
                                  cmd: 'drtr06'
                                }
                                

                                Und Ja, es liegt unter /usr/local/bin . Läßt sich mit drtr06 ansonsten von der Konsole ausführen

                                paul53 1 Reply Last reply Reply Quote 0
                                • paul53
                                  paul53 @Ralf 6 last edited by

                                  @ralf-6 sagte: Läßt sich mit drtr06 ansonsten von der Konsole ausführen

                                  Zeige bitte

                                  ls -l /usr/local/bin/drtr06
                                  
                                  R 1 Reply Last reply Reply Quote 0
                                  • R
                                    Ralf 6 @paul53 last edited by

                                    @paul53

                                    ralf@raspberrypi13:/ $ ls -l /usr/local/bin/drtr06
                                    -rwxr-xr-x 1 root root 70936 Oct 28 17:43 /usr/local/bin/drtr06
                                    ralf@raspberrypi13:/ $
                                    
                                    
                                    paul53 1 Reply Last reply Reply Quote 0
                                    • MartinP
                                      MartinP @Ralf 6 last edited by

                                      @ralf-6 Ich habe jetzt erst gesehen, dass Du schon ein Python-Script hast - wieso den Simple-Api-Aufruf aus meinem obigem Script nicht mit dem vorhandenen Python statt mit bash auslösen?

                                      Hängt natürlich ein wenig von den Skills in den verschiedenen Programmiersprachen ab - wenn Du Python besser beherrscht, als Javascript, wieso nicht dabei bleiben in diesem Fall?

                                      R 1 Reply Last reply Reply Quote 0
                                      • paul53
                                        paul53 @Ralf 6 last edited by paul53

                                        @ralf-6
                                        Das Programm sollte so von jedem User ausführbar sein. Ich kann deshalb die Fehlermeldung aus dem Skript nicht interpretieren.

                                        1 Reply Last reply Reply Quote 0
                                        • R
                                          Ralf 6 @MartinP last edited by

                                          @martinp
                                          Na ja, ich habe keine bis wenig Kenntnisse in Programmiersprachen. Das Python Skript ruft das C-Programm auf. Das wurde mir schon so eingerichtet. Und welche Optionen ich habe, um es in den IoBroker einzubinden, weiß ich nicht. Was ich schon hinbekommen habe, ich kann seit kurzem über das erweiterte Python Skript den Wert über MQTT in den IoBroker senden. Ist natürlich ein umständlicher Weg und ob es auf Dauer Stabil läuft muss ich erst Testen. Der Sensor ist ein Sensibelchen.

                                          Thomas Braun MartinP 2 Replies Last reply Reply Quote 0
                                          • Thomas Braun
                                            Thomas Braun Most Active @Ralf 6 last edited by Thomas Braun

                                            @ralf-6

                                            Probier mal diese beiden Varianten im Terminal.

                                            sudo -H -u iobroker drtr06
                                            sudo -H -u iobroker /usr/local/bin/drtr06
                                            

                                            Und geh aus / heraus. Da hat der ralf nix verloren.
                                            Geht per

                                            cd
                                            

                                            (hoffentlich).

                                            R 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            662
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            36
                                            1229
                                            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