Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. ulistermclane

    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

    U
    • Profile
    • Following 0
    • Followers 0
    • Topics 8
    • Posts 39
    • Best 0
    • Groups 1

    ulistermclane

    @ulistermclane

    0
    Reputation
    29
    Profile views
    39
    Posts
    0
    Followers
    0
    Following
    Joined Last Online

    ulistermclane Follow
    Starter

    Latest posts made by ulistermclane

    • RE: [gelöst] js2fs Adapter nicht mehr vorhanden?

      aha das ist ja cool. Prima, Danke für den Hinweis.

      posted in ioBroker Allgemein
      U
      ulistermclane
    • RE: vis Lizenz: offline nicht mehr möglich?

      Ich habe das System auf den alten Stand downgegraded (insbesondere auch den js-controller), jetzt funzt es wieder. Aber wird das neue Verhalten so bleiben?

      posted in Visualisierung
      U
      ulistermclane
    • RE: vis Lizenz: offline nicht mehr möglich?

      1.1.x (x=10 glaube ich)

      posted in Visualisierung
      U
      ulistermclane
    • RE: vis Lizenz: offline nicht mehr möglich?

      Offenbar ist dem nicht (mehr) so. Bei jedem reboot wird wohl neu geprüft und dafür wird eine Internetverbindung benötigt. Das Prüfungsergebnis wird wohl nicht (mehr) persistent abgelegt?

      posted in Visualisierung
      U
      ulistermclane
    • vis Lizenz: offline nicht mehr möglich?

      Halo,

      ich habe meine Installation für unser Ferienhaus mal upgedatet; vis läuft nun auf Version 1.2.2. Die Installation soll dort aber offine laufen; dies hat bisher auch funktioniert. Nach dem update bekomme ich nun eine Fehlermeldung "Keine gültige Lizenz gefunden" obwohl ein gültiger Schlüssel vorhanden ist. Im Log findet sich dazu die Fehlermeldung:

      vis.0	2020-01-05 10:43:32.720	error	(597) Cannot check license: Error: getaddrinfo EAI_AGAIN iobroker.net iobroker.net:443
      

      Funktioniert vis also nur noch auf einem System mit Internet-Verbindung?

      posted in Visualisierung
      U
      ulistermclane
    • RE: [gelöst] js2fs Adapter nicht mehr vorhanden?

      js2fs erscheint nicht mehr in der Adapterliste und lässt sich auch manuell nicht installieren:```
      pi@raspberrypi:~ $ iobroker install js2fs
      host.raspberrypi Unknown packetName js2fs
      host.raspberrypi download js2fs
      File not found: js2fs
      pi@raspberrypi:~ $

      posted in ioBroker Allgemein
      U
      ulistermclane
    • [gelöst] js2fs Adapter nicht mehr vorhanden?

      Hallo,

      ich habe meine Scripte bisher gern mit vscode und js2fs entwickelt. Ich habe nun einen neuen Server aufgesetzt und das Backup eingespielt. Leider lässt sich der js2fs nicht mehr installieren. Gibt es den nicht mehr / oder ist er inzwischen inkompatibel?

      Danke für einen Hinweis!

      posted in ioBroker Allgemein
      U
      ulistermclane
    • RE: Mehrere Trigger auf das gleiche Objekt setzen?

      @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.

      posted in Skripten / Logik
      U
      ulistermclane
    • RE: Mehrere Trigger auf das gleiche Objekt setzen?

      @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!

      posted in Skripten / Logik
      U
      ulistermclane
    • RE: Mehrere Trigger auf das gleiche Objekt setzen?

      @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.

      posted in Skripten / Logik
      U
      ulistermclane
    Community
    Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
    The ioBroker Community 2014-2023
    logo