Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Mehrere Trigger auf das gleiche Objekt setzen?

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Mehrere Trigger auf das gleiche Objekt setzen?

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

      Hallo,

      ich habe in unterschiedlichen Skripten jeweils einen Trigger auf das gleiche Objekt (modbus.1.holdingRegisters.40084_PV_Leistung) gesetzt:

      Skript1: soll den Ladevorgang meines E-Mobils starten, wenn genug PV Leistung vorhanden ist

       // Trigger für switchon
        on({id: 'modbus.1.holdingRegisters.40084_PV_Leistung', valGt: pvLimit}, () => {
          fsm.switchon();
        });
      

      Skript2: berechnet die aktuelle Leistung des PV Wandlers (diese wird in 2 Registern abgelegt , Mantisse / Exponent) und legt das Ergebnis in einem neuen state ab:

      on("modbus.1.holdingRegisters.40084_PV_Leistung", function(obj) {
          
          var iPVpwr = getState("modbus.1.holdingRegisters.40084_PV_Leistung").val;
          var iPVpwrP = getState("modbus.1.holdingRegisters.40085_PV_Leistung_pot").val;
      
          var fPVpower = iPVpwr * Math.pow(10, iPVpwrP);
      
          setState("javascript.0.PV_Power"/*PV_Power*/, fPVpower, true); 
          
      });
      

      Wenn beide Skripte laufen, bekomme ich einen Fehler:

      javascript.0	2019-04-04 11:43:31.546	error	message modbus.1.holdingRegisters.40084_PV_Leistung [object Object] Cannot read property 'split' of undefined
      

      Dieser verschwindet, wenn ich eines der beiden Skripte abschalte. Deshalb vermute ich, dass zwei / mehrere Trigger auf das gleiche Objekt nicht funktionieren. Liege ich da richtig?
      Die naheliegende Lösung, die Funktionen in einem Skript / Trigger zusammenzufassen, finde ich nicht schön, da ich nicht zusammengehörige Funktionen in einem Skript zusammenführen müsste. Gibt es da vielleicht eine elegantere Lösung?
      Danke für einen kurzen Hinweis!

      paul53 1 Reply Last reply Reply Quote 0
      • liv-in-sky
        liv-in-sky last edited by liv-in-sky

        setze doch eine setTimeout-function von ein oder 2 secunden in eines der scripts ein

        1 Reply Last reply Reply Quote 0
        • U
          ulistermclane last edited by

          was soll das bringen? Das Event wird ja von aussen ausgelöst.

          1 Reply Last reply Reply Quote 0
          • liv-in-sky
            liv-in-sky last edited by

            aber die scripte laufen dann nicht gleichzeitig - ich habe keine probleme, wenn mit einem datenpunkt mehrere scripte getriggert werden

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

              @ulistermclane sagte:

              dass zwei / mehrere Trigger auf das gleiche Objekt nicht funktionieren. Liege ich da richtig?

              Nein, mehrereTrigger auf einen Datenpunkt sind möglich.

              @ulistermclane sagte in Mehrere Trigger auf das gleiche Objekt setzen?:

              Cannot read property 'split' of undefined

              In welchem Skript befindet sich ein .split('irgendwas') ?

              1 Reply Last reply Reply Quote 0
              • U
                ulistermclane last edited by

                das weis ich nicht; geht aus dem log nicht hervor

                1 Reply Last reply Reply Quote 0
                • U
                  ulistermclane last edited by ulistermclane

                  Das Ganze wird immer mysteriöser. Ich habe nun alle Aktionen in eine einzige Callback Funktion zusammengefasst:

                  on('modbus.1.holdingRegisters.40084_PV_Leistung', (obj) => {
                    // update pvpower state
                    var pvpowerMant = obj.state.val;
                    var pvpowerExp = getState('modbus.1.holdingRegisters.40085_PV_Leistung_pot').val;
                    var pvpower = pvpowerMant * Math.pow(10, pvpowerExp); 
                    console.log(pvpower);
                    setState('javascript.0.PV.Power', pvpower, true);
                    // wenn genügend PV-Leistung -> laden
                    if(pvpower > pvLimit) {
                      swon();
                    }
                    // wenn nicht genügend PV Leistung -> Ladung stoppen
                    if(pvpower <= (pvLimit - hyst)) {
                      console.log('zu wenig PV Power');
                      // ...aber nur wenn kein e manuelle Ladeanforderung
                      var pb = getState('knx.0.Sensoren_Heizung.Garage.EV_Ladeanforderung_Status').val;
                      if(!pb) {
                        fsm.switchoff();
                      }    
                    }
                  });
                  

                  und das andere Skript dann stillgelegt. Somit gibt es nur noch einen Trigger auf den modbus state. Der Fehler tritt immer noch auf. Außerdem sehe ich folgendes:

                  console.log(pvpower); (Zeile 6) gibt den richtigen Wert aus;
                  setState('javascript.0.PV.Power', pvpower, true); (Zeile7) setzt den entsprechenden state aber nicht

                  Der Zeitstempel des Fehlers ist derselbe(+1 ms) wie der des console.log Befehls. Sehr merkwürdig.

                  Homoran 1 Reply Last reply Reply Quote 0
                  • Homoran
                    Homoran Global Moderator Administrators @ulistermclane last edited by

                    @ulistermclane
                    Hast du Skripte unter global abgespeichert?

                    U 1 Reply Last reply Reply Quote 0
                    • U
                      ulistermclane @Homoran last edited by

                      @Homoran nein

                      1 Reply Last reply Reply Quote 0
                      • liv-in-sky
                        liv-in-sky last edited by liv-in-sky

                        ich dachte dieser split befehl ist vielleicht in der funktion oder im adapter und wenn sie einzeln laufen kam mir die idee der zeitverzögerung

                        sorry - hatte keinen refresh und nicht gesehen, dass ihr schon weiter seid !

                        1 Reply Last reply Reply Quote 0
                        • AlCalzone
                          AlCalzone Developer last edited by

                          @ulistermclane Du könntest mal probieren, den Adapter zu beenden und über die Konsole manuell auszuführen, in der Hoffnung dass man dort mehr sieht:

                          cd /opt/iobroker/node_modules/iobroker.javascript
                          node main.js --force --logs
                          
                          U 2 Replies Last reply Reply Quote 0
                          • U
                            ulistermclane @AlCalzone last edited by

                            @AlCalzone Danke für den Hinweis, probier ich morgen aus

                            1 Reply Last reply Reply Quote 0
                            • U
                              ulistermclane @AlCalzone last edited by

                              @AlCalzone habs probiert, in dem Directory gibt es kein main.js:

                              uli@KNX-Kiste:/opt/iobroker/node_modules/iobroker.javascript$ ls -l
                              insgesamt 300
                              drwxr-xr-x+  6 iobroker iobroker   4096 Mär  1 12:33 admin
                              -rw-r--r--+  1 iobroker iobroker   8284 Okt 26  1985 io-package.json
                              -rw-r--r--+  1 iobroker iobroker 160194 Okt 26  1985 javascript.js
                              drwxr-xr-x+  2 iobroker iobroker   4096 Mär  1 12:33 lib
                              -rw-r--r--+  1 iobroker iobroker   1137 Okt 26  1985 LICENSE
                              drwxr-xr-x+ 70 iobroker iobroker   4096 Apr  3 10:08 node_modules
                              -rw-r--r--+  1 iobroker iobroker   2292 Apr  3 10:08 package.json
                              -rw-rw-r--+  1 iobroker iobroker 101976 Apr  3 10:08 package-lock.json
                              -rw-r--r--+  1 iobroker iobroker   4497 Okt 26  1985 README.md
                              uli@KNX-Kiste:/opt/iobroker/node_modules/iobroker.javascript$ 
                              
                              
                              1 Reply Last reply Reply Quote 0
                              • AlCalzone
                                AlCalzone Developer last edited by

                                Welche Version hast du denn installiert? In neueren heißt die Datei main.js - bei dir javascript.js.

                                U 3 Replies Last reply Reply Quote 0
                                • U
                                  ulistermclane @AlCalzone last edited by

                                  @AlCalzone ich habe (hatte) 3.6.5. Ich habe nun mal auf 4.1.12 upgedatet. Dies führt dann zu einem Totalcrash der javascript engine wenn ich das Script starte. Ich habe inzwischen den Verdacht, dass der Auslöser ein importiertes Modul ist (javascript-state-machine). - Ich war zu faul, eine state machine selber zu programmieren ; mal sehen, was ich nun mache.

                                  1 Reply Last reply Reply Quote 0
                                  • U
                                    ulistermclane @AlCalzone last edited by

                                    @AlCalzone hier noch ein vollständiger log des Fehlers:

                                    javascript.0	2019-04-06 13:45:44.353	error	at TCP.onread (net.js:601:20)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket.Readable.push (_stream_readable.js:208:10)
                                    javascript.0	2019-04-06 13:45:44.353	error	at readableAddChunk (_stream_readable.js:250:11)
                                    javascript.0	2019-04-06 13:45:44.353	error	at addChunk (_stream_readable.js:263:12)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket.emit (events.js:211:7)
                                    javascript.0	2019-04-06 13:45:44.353	error	at emitOne (events.js:116:13)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket._ultron.on (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/ws/lib/WebSocket.js:138:22)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Receiver.add (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/ws/lib/Receiver.js:139:10)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Receiver.startLoop (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/ws/lib/Receiver.js:165:16)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Receiver.getData (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/ws/lib/Receiver.js:330:12)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Receiver.dataMessage (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/ws/lib/Receiver.js:389:14)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Receiver._receiver.onmessage (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/ws/lib/WebSocket.js:141:47)
                                    javascript.0	2019-04-06 13:45:44.353	error	at WebSocket.emit (events.js:211:7)
                                    javascript.0	2019-04-06 13:45:44.353	error	at emitOne (events.js:116:13)
                                    javascript.0	2019-04-06 13:45:44.353	error	at WebSocket.onMessage (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/ws/lib/EventTarget.js:99:16)
                                    javascript.0	2019-04-06 13:45:44.353	error	at WebSocket.ws.onmessage (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/engine.io-client/lib/transports/websocket.js:147:10)
                                    javascript.0	2019-04-06 13:45:44.353	error	at WS.Transport.onData (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/engine.io-client/lib/transport.js:137:8)
                                    javascript.0	2019-04-06 13:45:44.353	error	at WS.Transport.onPacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/engine.io-client/lib/transport.js:145:8)
                                    javascript.0	2019-04-06 13:45:44.353	error	at WS.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/component-emitter/index.js:133:20)
                                    javascript.0	2019-04-06 13:45:44.353	error	at WS.<anonymous> (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/engine.io-client/lib/socket.js:273:10)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket.onPacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/engine.io-client/lib/socket.js:456:14)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/component-emitter/index.js:133:20)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Manager.ondata (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/manager.js:335:16)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Decoder.add (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-parser/index.js:251:12)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Decoder.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/component-emitter/index.js:133:20)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Decoder.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Manager.ondecoded (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/manager.js:345:8)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Manager.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/component-emitter/index.js:133:20)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Manager.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket.onpacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:244:12)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket.onack (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:319:9)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Socket.adapter.getForeignState (/opt/iobroker/node_modules/iobroker.javascript/main.js:745:17)
                                    javascript.0	2019-04-06 13:45:44.353	error	at createProblemObject (/opt/iobroker/node_modules/iobroker.javascript/main.js:1123:17)
                                    javascript.0	2019-04-06 13:45:44.353	error	at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1101:42)
                                    javascript.0	2019-04-06 13:45:44.353	error	at execute (/opt/iobroker/node_modules/iobroker.javascript/main.js:925:21)
                                    javascript.0	2019-04-06 13:45:44.353	error	at Object.context.logError (/opt/iobroker/node_modules/iobroker.javascript/main.js:661:27)
                                    javascript.0	2019-04-06 13:45:44.353	error	TypeError: Cannot read property 'split' of undefined
                                    javascript.0	2019-04-06 13:45:44.352	error	uncaught exception: Cannot read property 'split' of undefined
                                    

                                    Anbei noch das vollständige Skript, das den Fehler erzeugt:

                                    /**
                                     * EV Ladesteuerung
                                     * 
                                     * schöpft überschüssige PV Energie ab um EV zu laden
                                     * 
                                     * Uli 04/2019
                                     * 
                                     * Version 0.1
                                     * Da die aktuelle Einspeiseleistung noch nicht bekannt ist,
                                     * wird geladen, sobald mehr als 1 kW PV Leistung verfügbar ist (const pvLimit)
                                     * 
                                     * Ladefreigabe via Modbus/TCP an EVCC Controller: Coil adresse 400
                                     * Sofortladetaste an der Wallbox wird über KNX eingelesen
                                     * 
                                     * Zusätzlich werden auch die PV Daten für die Visualisierung aufbereitet
                                     */
                                    
                                    /// <reference path="javascript.d.ts" />
                                    // @ts-check
                                    /*jshint -W117 */
                                    
                                    const pvLimit = 1000;
                                    const hyst = 100;
                                    
                                    // Ladezustand
                                    createState('EVCC.CarChargeStatus', '', {
                                      name: 'EV_CarChargeStatus',
                                      type: 'string',
                                      desc: 'Ladezustand'
                                    });
                                    // State Machine Zustand
                                    createState('EVCC.FSMStatus', 'undefined', {
                                      name: 'EV_FSMStatus',
                                      type: 'string',
                                      desc: 'Zustamd der State Machine'
                                    });
                                    // erzwungene Ladung
                                    createState('EVCC.forcedCharge', false, {
                                      name: 'EV_forcedCharge',
                                      type: 'boolean',
                                      desc: 'Ladung erzwingen'
                                    });
                                    
                                    // PV Werte
                                    createState('PV.PVPower', 0, {
                                      name: 'PV Power',
                                      type: 'number',
                                      desc: 'PV Leistung'
                                    });
                                    
                                    createState('PV.EnergyTotal', 0, {
                                      name: 'PV EnergyTotal',
                                      type: 'number',
                                      desc: 'PV kWh Total'
                                    });
                                    
                                    createState('PV.EnergyHeute', 0, {
                                      name: 'PV EnergyHeute',
                                      type: 'number',
                                      desc: 'PV kWh heute'
                                    });
                                    
                                    createState('PV.EnergyTotalBasis', 0, {
                                      name: 'PV EnergyTotalBasis',
                                      type: 'number',
                                      desc: 'PV kWh total Basiswert'
                                    });
                                    
                                    var StateMachine = require('javascript-state-machine');
                                    
                                    function switchCoil(wert) {
                                      setState('modbus.0.coils.400_ChargeEnable', wert);
                                      if(wert) {
                                        console.log('Ladeflag gesetzt');
                                      } else {
                                        console.log('Ladeflag gelöscht');
                                      }
                                    }
                                    
                                    var fsm = new StateMachine({
                                        init: 'standby',
                                        transitions: [
                                          {name: 'connect',     from: 'standby',   to: 'waiting'},
                                          {name: 'release',     from: 'waiting',   to: 'released'},
                                          {name: 'switchon',    from: 'released' , to: 'charging'},
                                          {name: 'pause',       from: 'charging',  to: 'waiting'},
                                          {name: 'switchoff',   from: 'charging',  to: 'finihed'},
                                          {name: 'disconnect',  from: ['waiting', 'finished'], to: 'standby'}
                                        ],
                                        methods: {
                                          onConnect: function() { 
                                            console.log('angeschlossen'); 
                                          },
                                          onRelease: function() { 
                                            console.log('Laden freigegeben');
                                          },
                                          onSwitchon: function() { 
                                            console.log('Laden gestartet'); 
                                          },
                                          onPause: function() { 
                                            console.log('Laden gestoppt'); 
                                          },
                                          onSwitchoff: function() {
                                            console.log('Laden beendet');
                                          },
                                          onDisconnect: function() { 
                                            console.log('abgesteckt'); 
                                          },
                                          onEnterStandby: function() { 
                                            console.log(this.state);
                                            setState('javascript.0.EVCC.FSMStatus', this.state); 
                                          },
                                          onEnterWaiting: function() { 
                                            setState('knx.0.Sensoren_Heizung.Garage.Zählerstand_SY_resetten', true);
                                            setState('javascript.0.EVCC.FSMStatus', this.state); 
                                            var pvp = getState('javascript.0.PV.PVPower').val;
                                            if (pvp >= pvLimit) {
                                              this.release();
                                            }
                                          },
                                          onEnterReleased: function() { 
                                            setState('javascript.0.EVCC.FSMStatus', this.state);
                                            switchCoil(true);
                                          },
                                          onEnterCharging: function() {
                                            setState('javascript.0.EVCC.FSMStatus', this.state); 
                                          },
                                          onLeaveCharging: function() {
                                            switchCoil(false);
                                          },
                                          onEnterFinished: function() {
                                            setState('javascript.0.EVCC.FSMStatus', this.state); 
                                            setState('javascript.0.EVCC.forcedCharge', false);
                                          }
                                        }
                                      });
                                    
                                    // Event EV_Status changing
                                    on({id: 'modbus.0.inputRegisters.100_EV_Status'}, (obj) => {
                                      var newstat = obj.state.val;
                                      var oldstat = obj.oldState.val;
                                      const sstrings = [
                                        'nicht angeschlossen',
                                        'angeschlossen',
                                        'Ladung läuft'
                                      ];
                                      console.log('old: ' + oldstat + ' new: ' + newstat);
                                      // Fahrzeug wird angesteckt
                                      if(oldstat === 65 && newstat === 66) { 
                                        fsm.connect();
                                      }
                                      if(oldstat === 66 && newstat === 67) { 
                                        fsm.switchon();
                                      }
                                      // Fahrzeug wird abgesteckt
                                      if(oldstat === 66 && newstat === 65) {
                                        fsm.disconnect();
                                      }
                                      // Ladung ist abgeschlossen
                                      if(oldstat === 67 && newstat === 66) {
                                        if (fsm.state !== 'waiting') {
                                          fsm.switchoff();
                                        }
                                      } 
                                      // Ladung ist abgebrochen
                                      if(oldstat === 67 && newstat === 65) {
                                        fsm.switchoff();
                                        fsm.disconnect();
                                      } 
                                      // dann noch String für Vis bereitstellen
                                      var sStatus = sstrings[newstat - 65];
                                      console.log("Fahrzeugstatus: " + sStatus);    
                                      setState("javascript.0.EVCC.CarChargeStatus", sStatus, true);  
                                    });
                                    
                                    // Event PVPower changing
                                    on('modbus.1.holdingRegisters.40084_PV_Leistung', (obj) => {
                                      // update pvpower state
                                      var pvpowerMant = obj.state.val;
                                      var pvpowerExp = getState('modbus.1.holdingRegisters.40085_PV_Leistung_pot').val;
                                      var pvpower = pvpowerMant * Math.pow(10, pvpowerExp); 
                                      //console.log(pvpower);
                                      setState('javascript.0.PV.PVPower', pvpower, true);
                                      // wenn genügend PV-Leistung -> laden freigeben
                                      if(pvpower > pvLimit) {
                                        fsm.release();
                                      }
                                      // wenn nicht genügend PV Leistung -> Ladung stoppen
                                      if(pvpower <= (pvLimit - hyst)) {    
                                        // ...aber nur wenn keine manuelle Ladeanforderung
                                        var pb = getState('javascript.0.EVCC.forcedCharge').val;
                                        if(!pb) {
                                          fsm.pause();
                                          console.log('zu wenig PV Power');
                                        }    
                                      }
                                    });
                                    
                                    // Event Ladeanforderung pressed
                                    on({id: 'knx.0.Sensoren_Heizung.Garage.EV_Ladeanforderung', change: 'gt'}, () => {
                                      fsm.release();
                                      setState('javascript.0.EVCC.forcedCharge', true);
                                      console.log('Laden erzwungen');
                                    });
                                    
                                    // Update PV Daten
                                    on("modbus.1.holdingRegisters.40094_PV_Energie", (obj) => {    
                                      var iPVWh = obj.state.val;
                                      var iPVWhP = getState("modbus.1.holdingRegisters.40096_PV_Energie_pot").val;
                                      // aktuelle Gesamtenergie
                                      var fPVkWhraw = iPVWh * Math.pow(10, (iPVWhP-3));
                                      setState('javascript.0.PV.EnergyTotal', fPVkWhraw, true); 
                                      // Energiegewinnung heute
                                      var fPkWhgestern = 1.0 * getState('javascript.0.PV.EnergyTotalBasis').val;
                                      var fPkWhheute = fPVkWhraw - fPkWhgestern;
                                      setState('javascript.0.PV.EnergyHeute', fPkWhheute, true);
                                    });
                                    
                                    // um Mitternacht neuen Basiswert speichern
                                    schedule("0 0 * * *", () => {
                                      var iEkWhgestern = getState('javascript.0.PV.EnergyTotal').val;
                                      setState('javascript.0.PV.EnergyTotalBasis', parseInt(iEkWhgestern), true);
                                      setState('javascript.0.PV.EnergyTotal', 0.0, true); // reset daily energy
                                    });
                                    
                                    // init
                                    function EVCCinit() {
                                      // Coil abschalten
                                      setState('modbus.0.coils.400_ChargeEnable', false);
                                      // forcedCharge auf false
                                      setState('javascript.0.EVCC.forcedCharge', false);
                                      // sync state machine
                                      var evstat = getState('modbus.0.inputRegisters.100_EV_Status').val;
                                      if(evstat === 66) {
                                        fsm.connect();
                                      }
                                    }
                                    
                                    EVCCinit();
                                    

                                    Es handelt sich um eine Ladesteuerung für mein E-Auto. Es soll nur geladen werden, wenn genügend PV Leistung zur Verfügung steht. Außerdem kann über einen Schalter die Ladung erzwungen werden. Ich möchte das gern mit einer FSM abbilden. Eigntlich müsste im iobroker Code doch auch eine FSM engine stecken, wenn ja, welche ist das und wie komme ich daran?

                                    Danke für Hinweise!

                                    1 Reply Last reply Reply Quote 0
                                    • U
                                      ulistermclane @AlCalzone last edited by

                                      @AlCalzone Ok, ich hab mich mal etwas tiefer in die Materie reingekniet und eine kleine FSM selbst geschrieben; damit läuft's nun. Keine Fehler mehr; obwohl ich wieder mehrere Trigger auf ein Objekt gesetzt habe.

                                      1 Reply Last reply Reply Quote 0
                                      • AlCalzone
                                        AlCalzone Developer last edited by

                                        Anscheined wurde von deinem Skript irgendwie ein Fehler ausgelöst, der keine Stack-Information enthält.
                                        Das sollte der Adapter richtig handlen, tut es aber nicht. Ich habe mal ein Issue aufgemacht.

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

                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        862
                                        Online

                                        31.8k
                                        Users

                                        79.9k
                                        Topics

                                        1.3m
                                        Posts

                                        javascript
                                        5
                                        18
                                        1397
                                        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