Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Error/Bug
    4. Nach Scriptausführung nur noch Fehler und keine Funkion

    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

    UNSOLVED Nach Scriptausführung nur noch Fehler und keine Funkion

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

      Ich hab Folgende Fehlermeldungen

      Ich hab folgendes script gestern installiert:
      homematic_verbrauchszaehler von GitHub.

      Ich hab das script auf beiden System am laufen gehabt weil sie unterschiedliche dinge aufzeichnen sollten. Es werden beide Adapter nacht neugestartet, da wir schon öfters ins Blockly-Scripte abgestürzt sind und es sich nur mit einem Neustart beheben läßt. deswegen wird der Adapter jede nacht neu gestartet. Seid dem Neustart heute nacht bekomme ich dir Folgende Fehlermeldung bei beides ioBroker Installationen. Der Adapter wird auch nicht mehr grün. Alle anderen Script funktionieren entsprechend auch nicht mehr.

      2020-06-08 15:20:54.446 - error: host.iobroker Caught by controller[0]: internal/modules/cjs/loader.js:969
      2020-06-08 15:20:54.447 - error: host.iobroker Caught by controller[0]: throw err;
      2020-06-08 15:20:54.447 - error: host.iobroker Caught by controller[0]: ^
      2020-06-08 15:20:54.447 - error: host.iobroker Caught by controller[0]: Error: Cannot find module 'typescript'
      2020-06-08 15:20:54.448 - error: host.iobroker Caught by controller[0]: Require stack:
      2020-06-08 15:20:54.448 - error: host.iobroker Caught by controller[0]: - /opt/iobroker/node_modules/virtual-tsc/build/compiler.js
      2020-06-08 15:20:54.449 - error: host.iobroker Caught by controller[0]: - /opt/iobroker/node_modules/virtual-tsc/build/index.js
      2020-06-08 15:20:54.449 - error: host.iobroker Caught by controller[0]: - /opt/iobroker/node_modules/iobroker.javascript/main.js
      2020-06-08 15:20:54.449 - error: host.iobroker Caught by controller[0]: at Function.Module._resolveFilename (internal/modules/cjs/loader.js:966:15)
      2020-06-08 15:20:54.449 - error: host.iobroker Caught by controller[0]: at Function.Module._load (internal/modules/cjs/loader.js:842:27)
      2020-06-08 15:20:54.450 - error: host.iobroker Caught by controller[0]: at Module.require (internal/modules/cjs/loader.js:1026:19)
      2020-06-08 15:20:54.450 - error: host.iobroker Caught by controller[0]: at require (internal/modules/cjs/helpers.js:72:18)
      2020-06-08 15:20:54.450 - error: host.iobroker Caught by controller[0]: at Object. (/opt/iobroker/node_modules/virtual-tsc/build/compiler.js:3:10)
      2020-06-08 15:20:54.450 - error: host.iobroker Caught by controller[0]: at Module._compile (internal/modules/cjs/loader.js:1138:30)
      2020-06-08 15:20:54.451 - error: host.iobroker Caught by controller[0]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:1158:10)
      2020-06-08 15:20:54.451 - error: host.iobroker Caught by controller[0]: at Module.load (internal/modules/cjs/loader.js:986:32)
      2020-06-08 15:20:54.451 - error: host.iobroker Caught by controller[0]: at Function.Module._load (internal/modules/cjs/loader.js:879:14)
      2020-06-08 15:20:54.451 - error: host.iobroker Caught by controller[0]: at Module.require (internal/modules/cjs/loader.js:1026:19)
      2020-06-08 15:20:54.451 - error: host.iobroker Caught by controller[0]: at require (internal/modules/cjs/helpers.js:72:18)
      2020-06-08 15:20:54.452 - error: host.iobroker Caught by controller[0]: at Object. (/opt/iobroker/node_modules/virtual-tsc/build/index.js:3:18)
      2020-06-08 15:20:54.452 - error: host.iobroker Caught by controller[0]: at Module._compile (internal/modules/cjs/loader.js:1138:30)
      2020-06-08 15:20:54.452 - error: host.iobroker Caught by controller[0]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:1158:10)
      2020-06-08 15:20:54.452 - error: host.iobroker Caught by controller[0]: at Module.load (internal/modules/cjs/loader.js:986:32)
      2020-06-08 15:20:54.452 - error: host.iobroker Caught by controller[0]: at Function.Module._load (internal/modules/cjs/loader.js:879:14)
      2020-06-08 15:20:54.453 - error: host.iobroker Caught by controller[0]: at Module.require (internal/modules/cjs/loader.js:1026:19)
      2020-06-08 15:20:54.453 - error: host.iobroker Caught by controller[0]: at require (internal/modules/cjs/helpers.js:72:18)
      2020-06-08 15:20:54.453 - error: host.iobroker Caught by controller[0]: at Object. (/opt/iobroker/node_modules/iobroker.javascript/main.js:35:24)
      2020-06-08 15:20:54.453 - error: host.iobroker Caught by controller[0]: at Module._compile (internal/modules/cjs/loader.js:1138:30)
      2020-06-08 15:20:54.453 - error: host.iobroker Caught by controller[0]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:1158:10)
      2020-06-08 15:20:54.453 - error: host.iobroker Caught by controller[0]: at Module.load (internal/modules/cjs/loader.js:986:32)
      2020-06-08 15:20:54.454 - error: host.iobroker Caught by controller[0]: at Function.Module._load (internal/modules/cjs/loader.js:879:14)
      2020-06-08 15:20:54.454 - error: host.iobroker Caught by controller[0]: at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:71:12)
      2020-06-08 15:20:54.454 - error: host.iobroker Caught by controller[0]: at internal/main/run_main_module.js:17:47
      2020-06-08 15:20:54.454 - error: host.iobroker Caught by controller[0]: {
      2020-06-08 15:20:54.454 - error: host.iobroker Caught by controller[0]: code: 'MODULE_NOT_FOUND',
      2020-06-08 15:20:54.455 - error: host.iobroker Caught by controller[0]: requireStack: [
      2020-06-08 15:20:54.455 - error: host.iobroker Caught by controller[0]: '/opt/iobroker/node_modules/virtual-tsc/build/compiler.js',
      2020-06-08 15:20:54.455 - error: host.iobroker Caught by controller[0]: '/opt/iobroker/node_modules/virtual-tsc/build/index.js',
      2020-06-08 15:20:54.455 - error: host.iobroker Caught by controller[0]: '/opt/iobroker/node_modules/iobroker.javascript/main.js'
      2020-06-08 15:20:54.455 - error: host.iobroker Caught by controller[0]: ]
      2020-06-08 15:20:54.456 - error: host.iobroker Caught by controller[0]: }
      2020-06-08 15:20:54.456 - error: host.iobroker instance system.adapter.javascript.0 terminated with code 1 (JS_CONTROLLER_STOPPED)
      

      😞
      Vielleicht kann mir ja jemand von euch weiter helfen. Löschen und neuinstallierten des Adapters hat leider kein erfolg gebracht.

      Ich hoffe das ich hier überhaupt richitg bin.

      Systemdata Bitte Ausfüllen
      Hardwaresystem: Pi3 -- DS415+ im Docker
      Arbeitsspeicher: 1GB -- 8GB
      Festplattenart: SD-Karte -- HDD
      Betriebssystem: Linux
      Node-Version: 12.18.0
      Nodejs-Version: 12.18.0
      NPM-Version: 6.14.4
      Thomas Braun Homoran 2 Replies Last reply Reply Quote 0
      • Thomas Braun
        Thomas Braun Most Active @Sunshinemaker last edited by

        @Sören

        which nodejs && nodejs -v && which node && node -v && which npm && npm -v && apt policy nodejs
        
        1 Reply Last reply Reply Quote 0
        • Sunshinemaker
          Sunshinemaker last edited by

          auf dem Pi3 bekommen ich

          /usr/bin/nodejs
          v12.18.0
          /usr/bin/node
          v12.18.0
          /usr/bin/npm
          6.14.4
          nodejs:
            Installiert:           12.18.0-1nodesource1
            Installationskandidat: 12.18.0-1nodesource1
            Versionstabelle:
           *** 12.18.0-1nodesource1 500
                  500 https://deb.nodesource.com/node_12.x buster/main armhf Packages
                  100 /var/lib/dpkg/status
               10.21.0~dfsg-1~deb10u1+rpi1 500
                  500 http://raspbian.raspberrypi.org/raspbian buster/main armhf Packages
          pi@raspberrypi:/opt/iobroker $ 
          

          Und der DS415 im Docker

          /usr/bin/nodejs                                                                                                                                                                                                                 
          v12.18.0                                                                                                                                                                                                                        
          /usr/bin/node                                                                                                                                                                                                                   
          v12.18.0                                                                                                                                                                                                                        
          /usr/bin/npm                                                                                                                                                                                                                    
          sudo: Hostname iobroker kann nicht aufgelöst werden                                                                                                                                                                            
          sudo: Die Audit-Nachricht kann nicht gesendet werden: Unbekannter Fehler -1                                                                                                                                                     
          sudo: pam_open_session: Systemfehler                                                                                                                                                                                            
          sudo: Regelwerks-Plugin konnte Sitzung nicht initialisieren 
          
          Thomas Braun 1 Reply Last reply Reply Quote 0
          • Thomas Braun
            Thomas Braun Most Active @Sunshinemaker last edited by

            @Sören
            Ach, Docker...
            Dann bin ich raus.

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

              @Thomas-Braun Aber auf dem Pi hab ich ja das selbe Problem...kannst du mir da evtl helfen?

              Ich halte eigentlich beide Systeme immer Parallel auf dem neusten stand. vielleicht klappt das, was auf dem Pi funktioniert, ja auch unter Docker.

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

                @Sören

                cd /opt/iobroker 
                npm i typescript 
                

                vielleicht.

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

                  @Thomas-Braun 👍 😀

                  Also unter dem Pi3 läuft der Adapter schon mal wieder, wird zumindest grün, gibt keine Fehler mehr aus und startet die Script alle wieder.

                  Es muß ich nur noch mal gucken wie den unter Docker wieder zu laufen bekommen, aber ich bin ja schon mal einen Schritt weiter dank dir 🙂

                  Und dann werd ich wohl nochmal testen müssen und as Ursprünge script wegen dem nichts mehr geht irgend wie geändert werden kann damit ich es nutzen kann. Vielleicht magst da ja mal einen Blick drüber werden, ich hab da leider nicht so die Ahnung von. Copy&Paste ist da ehr mehr meine Stärke 🤕

                  //jshint maxerr:1000
                  // https://github.com/hdering/homematic_stromverbrauch_protokollieren
                  
                  //----------------------------------------------------------------------------//
                  
                  // Version: 1.3.3
                  
                  //----------------------------------------------------------------------------//
                  // +++++++++  USER ANPASSUNGEN ++++++++++++++++++++++++
                  
                  // debug logging
                  var logging = true;
                  
                  // Aktivieren der History Instanz
                  var enable_history = false;
                  
                  // history Instanz
                  var instance_history = 'history.0';
                  
                  // Geräte können unterschiedliche Preise haben
                  var enable_unterschiedlichePreise = false;
                  
                  // Speichern der Werte in zusätzlichen Objekten.
                  // Wenn 0, dann deaktiviert
                  var Tag_Anzahl_Werte_in_der_Vergangenheit       = 7;
                  var Woche_Anzahl_Werte_in_der_Vergangenheit     = 4;
                  var Monat_Anzahl_Werte_in_der_Vergangenheit     = 12;
                  var Quartal_Anzahl_Werte_in_der_Vergangenheit   = 4;
                  var Jahr_Anzahl_Werte_in_der_Vergangenheit      = 2;
                  
                  // Grundpreis einberechnen
                  var enable_Grundpreis_einberechnen = false;
                  
                  var instance    = '0';
                  var instanz     = 'javascript.' + instance + '.';
                  
                  // Pfad innerhalb der Instanz
                  var pfad        = 'Verbrauchszaehler.';
                  
                  var default_unit = 'Wh';
                  var default_unit_kilo = 'kWh';
                  
                  // Diese Teile werden aus den Gerätenamen entfernt
                  var blacklist   = [':1', ':2', ':3', ':4', ':5', ':6', ':7', ':8'];
                  
                  var AnzahlKommastellenKosten = 2;
                  var AnzahlKommastellenVerbrauch = 3;
                  var AnzahlKommastellenZaehlerstand = 3;
                  
                  var KumulierterWertIstBereitsInKilo = false;
                  
                  var eigeneDatenpunkte = [
                      
                      // Beispiel:
                      // ['Datenpunkt', 'Aliasname', 'Einheit kumulierter Wert', 'Einheit berechnete Werte (kilo/1000)' ],
                      
                      // [ 'hm-rpc.2.NEQ0861663.1.ENERGY_COUNTER', 'Stromzaehler:1.ENERGY_COUNTER', 'Wh', 'kWh' ],
                      // [ 'javascript.1.MeinSonoffGeraet1', 'Strom.Sonoff.MeinSonoffGeraet1', 'Wh', 'kWh' ],
                      // [ 'javascript.1.MeinSonoffGeraet2', 'Strom.Sonoff.MeinSonoffGeraet2', 'kWh', 'kWh' ],
                      // [ 'javascript.1.MeineGas1', 'Gas.MeinGaszaehler1', 'm3', 'm3' ],
                      // [ 'javascript.1.MeineGas2', 'Gas.MeinGaszaehler2', 'm3', 'm3' ],
                  ];
                  
                  // Pushmeldung
                  function send_message(text) {
                      
                      // Hier können die Pushmeldung über alle möglichen Wege verschickt werden.
                      
                      //console.log(text);
                      
                      //sendTelegram(text);
                  }
                  
                  // ++++ ENDE USER ANPASSUNGEN ++++++++++++++++++++++++
                  //----------------------------------------------------------------------------//
                  
                  createState(pfad + 'Preis.aktuell.Arbeitspreis', {
                      name: 'Strompreis - aktueller Arbeitspreis (brutto)',
                      unit: '€/' + default_unit_kilo,
                      type: 'number',
                      def:  0,
                      min:  0
                  });
                  
                  createState(pfad + 'Preis.aktuell.Grundpreis',  {                           
                      name: 'Strompreis - aktueller Grundpreis (brutto)',
                      unit: '€/Monat',
                      type: 'number',
                      def:  0,
                      min: 0
                  });
                  
                  //----------------------------------
                  
                  createState(pfad + 'Preis.neu.Arbeitspreis', {
                      name: 'Strompreis - neuer Arbeitspreis ab Datum (brutto)',
                      unit: '€/' + default_unit_kilo,
                      type: 'number',
                      def:  0,
                      min:  0
                  });
                  
                  createState(pfad + 'Preis.neu.Grundpreis',  {                           
                      name: 'Strompreis - neuer Grundpreis ab Datum (brutto)',
                      unit: '€/Monat',
                      type: 'number',
                      def:  0,
                      min: 0
                  });
                  
                  createState(pfad + 'Preis.neu.Datum',  {                           
                      name: 'Strompreis und Grundpreis ab folgendem Datum zur Berechnung heranziehen (Beispiel 01.01.2019)',
                      type: 'string',
                      def: "01.01.1970",
                  });
                  
                  createState(pfad + 'Preis.neu.PreisaenderungDurchgefuehrt', false, {
                    read: true, 
                    write: true, 
                    type: "boolean", 
                    def: false
                  });
                  
                  //----------------------------------------------------------------------------//
                  
                  var cacheSelectorStateMeter  = $('channel[state.id=*.METER]');
                  var cacheSelectorStateEnergyCounter  = $('channel[state.id=*.ENERGY_COUNTER$]');
                  
                  //----------------------------------------------------------------------------//
                  
                  function parseObjects(id) {
                      var obj = getObject(id);
                  
                      return entferneDatenpunkt(obj.common.name);
                  }
                  
                  function setRecognizedChange(type, anzahl) {
                      
                      cacheSelectorStateMeter.each(function (id, i) {
                          var geraetename = parseObjects(id);
                  
                          rotateVerbrauchUndKosten(geraetename, type, anzahl);
                          
                          resetVerbrauchUndKosten(geraetename, type);
                          
                          schreibeZaehlerstand(geraetename, type);
                      });
                  
                      cacheSelectorStateEnergyCounter.each(function (id, i) {
                          var geraetename = parseObjects(id);
                  
                          rotateVerbrauchUndKosten(geraetename, type, anzahl);
                          
                          resetVerbrauchUndKosten(geraetename, type);
                          
                          schreibeZaehlerstand(geraetename, type);
                      });
                      
                      if (eigeneDatenpunkte.length > 0) {
                  
                          for(var i = 0; i < eigeneDatenpunkte.length; i++) {
                              var alias = eigeneDatenpunkte[i][1];
                              
                              rotateVerbrauchUndKosten(alias, type, anzahl);
                              
                              resetVerbrauchUndKosten(alias, type);
                              
                              schreibeZaehlerstand(alias, type);
                          }
                      }
                  }
                  
                  //----------------------------------------------------------------------------//
                  
                  // Tageswechsel
                  schedule("0 0 * * *", function() {
                      setRecognizedChange('Tag', Tag_Anzahl_Werte_in_der_Vergangenheit);
                  });
                  
                  // Wochenwechsel
                  schedule("0 0 * * 1", function() {
                      setRecognizedChange('Woche', Woche_Anzahl_Werte_in_der_Vergangenheit);
                  });
                  
                  // Monatswechsel
                  schedule("0 0 1 * *", function() {
                      setRecognizedChange('Monat', Monat_Anzahl_Werte_in_der_Vergangenheit);
                  });
                  
                  // Quartalswechsel
                  schedule("0 0 1 */3 *", function() {
                      setRecognizedChange('Quartal', Quartal_Anzahl_Werte_in_der_Vergangenheit);
                  });
                  
                  // Jahreswechsel
                  schedule("0 0 1 1 *", function() {
                      setRecognizedChange('Jahr', Jahr_Anzahl_Werte_in_der_Vergangenheit);
                  });
                  
                  //----------------------------------------------------------------------------//
                  
                  // Eigene Datenpunkte
                  function pruefeEigeneDatenpunkte() {
                      
                      if (eigeneDatenpunkte.length > 0) {
                      
                          for(var i = 0; i < eigeneDatenpunkte.length; i++) {
                              
                              var datenpunkt = eigeneDatenpunkte[i][0];
                              var alias = eigeneDatenpunkte[i][1];
                              var einheit = eigeneDatenpunkte[i][2];
                              var einheit_kilo = eigeneDatenpunkte[i][3];
                              
                              if(logging) console.log("Alias:" + alias + " Datenpunkt:" + datenpunkt + " Einheit:" + einheit + " Einheit_kilo:" + einheit_kilo);
                  
                              on(datenpunkt, function(obj) {
                  
                                  for(var i = 0; i < eigeneDatenpunkte.length; i++) {
                                      
                                      if(eigeneDatenpunkte[i][0] === obj.id)    
                                          run(obj, eigeneDatenpunkte[i][1], eigeneDatenpunkte[i][2], eigeneDatenpunkte[i][3]);
                                  }
                              });
                          }
                      }
                  }
                  
                  pruefeEigeneDatenpunkte();
                  
                  //----------------------------------------------------------------------------//
                  
                  // Einlesen der aktuellen Daten vom Zähler
                  function run(obj, alias, unit, unit_kilo) {
                      
                      if (logging) {   
                          log('-------- Strommesser ---------');
                          log('RegExp-Funktion ausgelöst');
                          log('id:           ' + obj.id);
                          log('Name:         ' + obj.common.name);   // Waschmaschine Küche:2.ENERGY_COUNTER
                          log('channel ID:   ' + obj.channelId);     // hm-rpc.0.MEQ0170864.2
                          log('channel Name: ' + obj.channelName);   // Waschmaschine Küche:2
                          log('device ID:    ' + obj.deviceId);      // hm-rpc.0.MEQ0170864
                          log('device name:  ' + obj.deviceName);    // Küche Waschmaschine
                          log('neuer Wert:   ' + obj.newState.val);  // 16499.699982
                          log('alter Wert:   ' + obj.oldState.val);  // 16499.699982
                      }
                  
                      // Gerätenamen erstellen
                      if (logging) log('vor der Aufbereitung: ' + obj.common.name); 
                      
                      var geraetename = entferneDatenpunkt(obj.common.name);
                  
                      if(typeof alias !== "undefined")  {
                          if(logging) console.log("Es wird der Aliasname gesetzt:" + alias);
                          
                          geraetename = alias;
                      }
                      
                      if (logging) log('Nach der Aufbereitung: ' + geraetename); 
                      
                      if(typeof geraetename !== "undefined") {
                          
                          //------------------------------------------------------------------------//
                          
                          _unit = default_unit;
                          _unit_kilo = default_unit_kilo;
                          
                          // States erstellen (CreateStates für dieses Gerät)
                          if(typeof unit !== "undefined")  {
                              _unit = unit;
                          }
                          
                          if(typeof unit_kilo !== "undefined")  {
                              _unit_kilo = unit_kilo;
                          }
                          
                          erstelleStates(geraetename, _unit, _unit_kilo);
                          
                          //------------------------------------------------------------------------//
                          
                          // Schreiben der neuen Werte
                      
                          var idKumuliert =  instanz + pfad + geraetename + '.Zaehlerstand.kumuliert';
                          
                          var NeustartEventuellErkannt = false;
                          var NeustartSicherErkannt = false;
                          
                          var oldState = obj.oldState.val;
                          var newState = obj.newState.val;
                          var difference = newState - oldState;
                      
                          if(difference > 0) {
                              
                              if(oldState !== 0) {
                      
                                  // Kumulierten Wert mit Ist-Wert (inkl. Backup) synchronisieren
                                  var newValueKumuliert = getState(idKumuliert).val + difference;
                                  
                                  newValueKumuliert = parseFloat(newValueKumuliert);
                      
                                  setState(idKumuliert, newValueKumuliert);
                                  
                              } else {
                                  
                                  if(newState < getState(pfad + geraetename + '.config.NeustartErkanntAlterWert').val) {
                      
                                      NeustartSicherErkannt = true;
                                  }
                              }
                              
                          } else {
                              
                              // Fall 2 oder 3
                              // Irgendetwas läuft außerplanmäßig. Wert wird sicherheitshalber gespeichert und nächster Lauf abgewartet
                              NeustartEventuellErkannt = true;
                              
                              setState(pfad + geraetename + '.config.NeustartErkanntAlterWert', obj.oldState.val);
                          }
                          
                          if(NeustartEventuellErkannt) {
                              
                              if(logging) {
                                  var message =  geraetename + '\n'
                                                  + 'Entweder die CCU oder Stromzähler wurden neugestartet/zurückgesetzt.\n'
                                                  + 'Dieser Wert wird einmal ignoriert und auf den nächsten Wert gewartet.';
                              
                                  send_message(message);
                              }
                          }
                          
                          if(NeustartSicherErkannt) {
                      
                              // zurücksetzen der Variable
                              setState(pfad + geraetename + '.config.NeustartErkanntAlterWert', 0);
                              
                              //----------------------------------------------------------------//
                      
                              var message2 = geraetename + '\n'
                                          + 'Der Stromzähler (' + geraetename + ') ist übergelaufen, gelöscht oder neugestartet worden (ggf. Stromausfall).\n'
                                          + 'newState:' + obj.newState.val + '\n' 
                                          + 'oldState:' + obj.oldState.val + '\n'
                                          + 'differenz:' + difference + '\n'
                                          + 'idKumuliert:' + getState(idKumuliert).val;
                      
                              send_message(message2);
                          }
                          
                          //--------------------------------------------------------------------//
                  
                          pruefePreisaenderung();
                          
                          if(enable_unterschiedlichePreise)
                              pruefePreisaenderung(geraetename);
                          
                          var idStrompreis = instanz + pfad + 'Preis.aktuell.Arbeitspreis';
                          var idGrundpreis = instanz + pfad + 'Preis.aktuell.Grundpreis';
                          
                          // aktualisiere den Verbrauch und die Kosten
                          if(KumulierterWertIstBereitsInKilo)
                              _zaehler    = (getState(idKumuliert).val).toFixed(AnzahlKommastellenZaehlerstand);
                          else
                              _zaehler    = (getState(idKumuliert).val / 1000).toFixed(AnzahlKommastellenZaehlerstand);
                          
                          _preis      = getState(idStrompreis).val;
                          _grundpreis = getState(idGrundpreis).val;
                          
                          // Wenn das Gerät einen eigenen Strompreis / Grundpreis hat
                          if(enable_unterschiedlichePreise) {
                              
                              if(getState(instanz + pfad + geraetename + '.eigenerPreis.aktuell.Arbeitspreis').val > 0) {
                                  _preis = getState(instanz + pfad + geraetename + '.eigenerPreis.aktuell.Arbeitspreis').val;
                  
                                  if (logging) console.log("Das Gerät:" + geraetename + " hat eigenen Strompreis: " + _preis);
                              }
                              
                              if(getState(instanz + pfad + geraetename + '.eigenerPreis.aktuell.Grundpreis').val > 0) {
                                  _grundpreis = getState(instanz + pfad + geraetename + '.eigenerPreis.aktuell.Grundpreis').val;
                                  
                                  if (logging) console.log("Das Gerät:" + geraetename + " hat eigenen Grundpreis: " + _grundpreis);
                              }
                          }
                  
                          berechneVerbrauchUndKosten(geraetename, _zaehler, _preis, _grundpreis); // in kWh
                  
                          if (logging) log('------------ ENDE ------------');
                          
                      } else {
                          
                          var message3 = 'Fehler beim Erstellen des Gerätenamens:\n'
                                      + 'obj.common.name: ' + obj.common.name;
                          
                          send_message(message3);
                      }
                  }
                  
                  cacheSelectorStateMeter.on(function(obj) {
                     run(obj);
                  });
                  
                  cacheSelectorStateEnergyCounter.on(function(obj) {
                     run(obj);
                  });
                  
                  //----------------------------------------------------------------------------//
                  
                  function entferneDatenpunkt(geraet) {
                      
                      var rueckgabe = geraet;
                      
                      // ":2.ENERGY_COUNTER" --> ".ENERGY_COUNTER"
                      if (geraet.indexOf(".ENERGY_COUNTER") != -1) {
                          
                          rueckgabe = geraet.substring(0, geraet.indexOf(".ENERGY_COUNTER"));
                          
                      } else if (geraet.indexOf(".METER") != -1) {
                          
                          rueckgabe = geraet.substring(0, geraet.indexOf(".METER"));
                      }
                      
                      if (logging) log('entferneDatenpunkt - rueckgabe1:' + rueckgabe);
                  
                      // Rückgabe sollte keine Sonderzeichen oder Leerzeichen enthalten. Wenn doch, werden die entfernt oder ersetzt
                  
                      try {
                          rueckgabe = checkBlacklist(rueckgabe);
                      }
                      catch(err) {
                          if (logging) log('entferneDatenpunkt - rueckgabe2:' + rueckgabe + ' error:' + err);
                      }
                      finally {
                          if (logging) log('entferneDatenpunkt - rueckgabe2:' + rueckgabe);
                      }
                  
                      try {
                          if (rueckgabe.charAt(rueckgabe.length - 1) == "-") rueckgabe = rueckgabe.substr(0, rueckgabe.length - 1);
                          if (rueckgabe.charAt(rueckgabe.length - 1) == "\\") rueckgabe = rueckgabe.substr(0, rueckgabe.length - 1);
                          if (rueckgabe.charAt(rueckgabe.length - 1) == ":") rueckgabe = rueckgabe.substr(0, rueckgabe.length - 1);
                      }
                      catch(err) {
                          if (logging) log('entferneDatenpunkt - rueckgabe3:' + rueckgabe + ' error:' + err);
                      }
                      finally {
                          if (logging) log('entferneDatenpunkt - rueckgabe3:' + rueckgabe);
                      }
                      
                      // per Regexp Leerzeichen entfernen
                      try {
                          rueckgabe = rueckgabe.replace(/\s/g, "");
                      }
                      catch(err) {
                          if (logging) log('entferneDatenpunkt - rueckgabe4:' + rueckgabe + ' error:' + err);
                      }
                      finally {
                          if (logging) log('entferneDatenpunkt - rueckgabe4:' + rueckgabe);
                      }
                  
                      return rueckgabe;
                  }
                  
                  function checkBlacklist(name) {
                      
                      var _name = "";
                      
                      if (blacklist.length > 0) {
                  
                          for(var i = 0; i < blacklist.length; i++) {
                            
                              if (name.indexOf(blacklist[i]) != -1) {
                  
                                  // Zeichenketten, die in der Blacklist stehen, aus dem Namen löschen
                                  _name = name.substring(0, name.indexOf(blacklist[i]));
                              }
                          }
                  
                          if(_name === "") {
                              return name;
                          } else {
                              return _name;
                          }
                      
                      } else return (name);
                  }
                  
                  function schreibeZaehlerstand(geraet, zeitraum) { 
                      
                      var idKumuliert =    instanz + pfad + geraet + '.Zaehlerstand.kumuliert',
                          idZaehlerstand = instanz + pfad + geraet + '.Zaehlerstand.' + zeitraum;
                      
                      // Zählerstand für übergebene Zeitraum und das Gerät in Wh auslesen und in kWh speichern (also durch 1000)
                      
                      if(KumulierterWertIstBereitsInKilo)
                          setState(idZaehlerstand, parseFloat( (getState(idKumuliert).val).toFixed(AnzahlKommastellenZaehlerstand)) );  
                      else
                          setState(idZaehlerstand, parseFloat( (getState(idKumuliert).val / 1000).toFixed(AnzahlKommastellenZaehlerstand)) ); 
                  
                      if (logging) log('Zählerstände für das Gerät ' + geraet + ' (' + zeitraum + ') in Objekten gespeichert');
                  }
                  
                  function rotateVerbrauchUndKosten(geraet, zeitraum, anzahl) {
                  
                      // Verbrauch
                      if(anzahl > 0) {
                          
                          for(var i = anzahl; i >= 0; i--) {
                              
                              var j = i;
                              
                              j++;
                              
                              if(getObject(instanz + pfad + geraet + '.Verbrauch._' + zeitraum + '.' + zeitraum + '_' + j)) {
                                  
                                  if(i === 0)
                                      setState(instanz + pfad + geraet + '.Verbrauch._' + zeitraum + '.' + zeitraum + '_' + j, getState(instanz + pfad + geraet + '.Verbrauch.' + zeitraum).val);
                                  else
                                      setState(instanz + pfad + geraet + '.Verbrauch._' + zeitraum + '.' + zeitraum + '_' + j, getState(instanz + pfad + geraet + '.Verbrauch._' + zeitraum + '.' + zeitraum + '_' + i).val);
                              }
                          }
                      }
                      
                      // Kosten
                      if(anzahl > 0) {
                          
                          for(var i = anzahl; i >= 0; i--) {
                              
                              var j = i;
                              
                              j++;
                              
                              if(getObject(instanz + pfad + geraet + '.Kosten._' + zeitraum + '.' + zeitraum + '_' + j)) {
                                  
                                  if(i === 0)
                                      setState(instanz + pfad + geraet + '.Kosten._' + zeitraum + '.' + zeitraum + '_' + j, getState(instanz + pfad + geraet + '.Kosten.' + zeitraum).val);
                                  else
                                      setState(instanz + pfad + geraet + '.Kosten._' + zeitraum + '.' + zeitraum + '_' + j, getState(instanz + pfad + geraet + '.Kosten._' + zeitraum + '.' + zeitraum + '_' + i).val);
                              }
                          }
                      }
                  }
                  
                  function resetVerbrauchUndKosten(geraet, zeitraum) {
                      
                      // Reset der Stromkosten für den übergebenen Zeitraum
                      // Reset des Stromverbrauchs für den übergebenen Zeitraum 
                      setState(instanz + pfad + geraet + '.Kosten.' + zeitraum, 0);     
                      setState(instanz + pfad + geraet + '.Verbrauch.' + zeitraum, 0);
                      
                      if (logging) log('Stromkosten und Stromverbrauch für das Gerät ' + geraet + ' (' + zeitraum + ') zurückgesetzt');
                  } 
                  
                  function berechneVerbrauchUndKosten(geraet, zaehler, preis, grundpreis) {                      
                      
                      // bei jedem eingehenden Wert pro Gerät
                  
                      if(preis === 0) {
                      
                          var message0 = 'Achtung!' + '.\n'
                                      + 'Es wurde noch kein Arbeitspreis angegeben.' + '\n' 
                                      + 'Ohne Arbeitspreis kann das Skript keine Berechnungen durchführen.' + '\n'
                                      + 'Diese Information ist zwingend notwendig!';
                          
                          log(message0, 'error');
                          
                      } else {
                      
                          var _grundpreis = 0;
                          
                          if(enable_Grundpreis_einberechnen) {
                      
                              _grundpreis = grundpreis * 12 / 365;
                              
                              _grundpreis = parseFloat(_grundpreis.toFixed(3));
                          }
                          
                          grundpreis_tag      = _grundpreis;
                          grundpreis_woche    = _grundpreis * 7;
                          grundpreis_monat    = _grundpreis * 30; 
                          grundpreis_quartal  = _grundpreis * 90;
                          grundpreis_jahr     = _grundpreis * 365;
                      
                          // Tag [Verbrauchskosten = (Zähler_ist - Zähler_Tagesbeginn) * Preis ] --- zaehler muss immer größer sein als Tages, Wochen, etc.-Wert
                          setState(instanz + pfad + geraet + '.Kosten.Tag',        parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Tag').val) * preis) + grundpreis_tag).toFixed(AnzahlKommastellenKosten) ) );  // Kosten an diesem Tag in €
                          
                          // Woche
                          setState(instanz + pfad + geraet + '.Kosten.Woche',      parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Woche').val) * preis) + grundpreis_woche).toFixed(AnzahlKommastellenKosten) ) );
                          
                          // Monat
                          setState(instanz + pfad + geraet + '.Kosten.Monat',      parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Monat').val) * preis) + grundpreis_monat).toFixed(AnzahlKommastellenKosten) ) );
                          
                          // Quartal
                          setState(instanz + pfad + geraet + '.Kosten.Quartal',    parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Quartal').val) * preis) + grundpreis_quartal).toFixed(AnzahlKommastellenKosten) ) );
                          
                          // Jahr
                          setState(instanz + pfad + geraet + '.Kosten.Jahr',       parseFloat( (((zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Jahr').val) * preis) + grundpreis_jahr).toFixed(AnzahlKommastellenKosten) ) );  
                          
                          if (logging) log('Stromkosten (' + geraet + ') aktualisiert');
                      }
                      
                      // Verbrauch berechnen
                      
                      // Tag [Verbrauchskosten = (Zähler_ist - Zähler_Tagesbeginn) * Preis ] --- zaehler muss immer größer sein als Tages, Wochen, etc.-Wert
                      setState(instanz + pfad + geraet + '.Verbrauch.Tag',     parseFloat(   (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Tag').val).toFixed(AnzahlKommastellenVerbrauch) ) );           // Verbrauch an diesem Tag in kWh
                  
                      // Woche
                      setState(instanz + pfad + geraet + '.Verbrauch.Woche',   parseFloat(   (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Woche').val).toFixed(AnzahlKommastellenVerbrauch) ) );
                  
                      // Monat
                      setState(instanz + pfad + geraet + '.Verbrauch.Monat',   parseFloat(   (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Monat').val).toFixed(AnzahlKommastellenVerbrauch) ) );
                  
                      // Quartal
                      setState(instanz + pfad + geraet + '.Verbrauch.Quartal', parseFloat(   (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Quartal').val).toFixed(AnzahlKommastellenVerbrauch) ) );
                  
                      // Jahr
                      setState(instanz + pfad + geraet + '.Verbrauch.Jahr',    parseFloat(   (zaehler - getState(instanz + pfad + geraet + '.Zaehlerstand.Jahr').val).toFixed(AnzahlKommastellenVerbrauch) ) );
                      
                      if (logging) log('Stromverbrauch (' + geraet + ') aktualisiert');
                  }
                  
                  function erstelleStates (geraet, _unit, _unit_kilo) {
                      
                      // Kumulierter Zählerstand (wird nie kleiner)
                      createState(pfad + geraet + '.Zaehlerstand.kumuliert', 0, {name: 'Kumulierter Zählerstand (' + geraet + ')', type: 'number', unit: _unit });
                              
                      // Zählerstand
                      createState(pfad + geraet + '.Zaehlerstand.Tag',     0, {name: 'Zählerstand Tagesbeginn ('       + geraet + ')', type: 'number', unit: _unit_kilo });
                      createState(pfad + geraet + '.Zaehlerstand.Woche',   0, {name: 'Zählerstand Wochenbeginn ('      + geraet + ')', type: 'number', unit: _unit_kilo });
                      createState(pfad + geraet + '.Zaehlerstand.Monat',   0, {name: 'Zählerstand Monatsbeginn ('      + geraet + ')', type: 'number', unit: _unit_kilo });
                      createState(pfad + geraet + '.Zaehlerstand.Quartal', 0, {name: 'Zählerstand Quartalsbeginn ('    + geraet + ')', type: 'number', unit: _unit_kilo });
                      createState(pfad + geraet + '.Zaehlerstand.Jahr',    0, {name: 'Zählerstand Jahresbeginn ('      + geraet + ')', type: 'number', unit: _unit_kilo });
                      
                      // Verbrauch 
                      createState(pfad + geraet + '.Verbrauch.Tag',        0, {name: 'Verbrauch seit Tagesbeginn ('    + geraet + ')', type: 'number', unit: _unit_kilo });
                      createState(pfad + geraet + '.Verbrauch.Woche',      0, {name: 'Verbrauch seit Wochenbeginn ('   + geraet + ')', type: 'number', unit: _unit_kilo });
                      createState(pfad + geraet + '.Verbrauch.Monat',      0, {name: 'Verbrauch seit Monatsbeginn ('   + geraet + ')', type: 'number', unit: _unit_kilo });
                      createState(pfad + geraet + '.Verbrauch.Quartal',    0, {name: 'Verbrauch seit Quartalsbeginn (' + geraet + ')', type: 'number', unit: _unit_kilo });
                      createState(pfad + geraet + '.Verbrauch.Jahr',       0, {name: 'Verbrauch seit Jahresbeginn ('   + geraet + ')', type: 'number', unit: _unit_kilo });
                              
                      // Stromkosten
                      createState(pfad + geraet + '.Kosten.Tag',           0, {name: 'Stromkosten heute ('             + geraet + ')', type: 'number', unit: '€' });
                      createState(pfad + geraet + '.Kosten.Woche',         0, {name: 'Stromkosten Woche ('             + geraet + ')', type: 'number', unit: '€' });
                      createState(pfad + geraet + '.Kosten.Monat',         0, {name: 'Stromkosten Monat ('             + geraet + ')', type: 'number', unit: '€' });
                      createState(pfad + geraet + '.Kosten.Quartal',       0, {name: 'Stromkosten Quartal ('           + geraet + ')', type: 'number', unit: '€' });
                      createState(pfad + geraet + '.Kosten.Jahr',          0, {name: 'Stromkosten Jahr ('              + geraet + ')', type: 'number', unit: '€' });
                      
                      // Speichern der Werte in zusätzlichen Variablen
                      if(Tag_Anzahl_Werte_in_der_Vergangenheit > 0) {
                          
                          for(var i = 1; i <= Tag_Anzahl_Werte_in_der_Vergangenheit; i++) {
                              createState(pfad + geraet + '.Verbrauch._Tag.Tag_' + i,             0, {name: 'Verbrauch vor ' + i + ' Tag(en) ('    + geraet + ')', type: 'number', unit: _unit_kilo });
                              createState(pfad + geraet + '.Kosten._Tag.Tag_' + i,                0, {name: 'Stromkosten vor ' + i + ' Tag(en) ('  + geraet + ')', type: 'number', unit:'€'  });
                          }
                      }
                      
                      if(Woche_Anzahl_Werte_in_der_Vergangenheit > 0) {
                          
                          for(var i = 1; i <= Woche_Anzahl_Werte_in_der_Vergangenheit; i++) {
                              createState(pfad + geraet + '.Verbrauch._Woche.Woche_' + i,         0, {name: 'Verbrauch vor ' + i + ' Woche(n) ('    + geraet + ')', type: 'number', unit: _unit_kilo });
                              createState(pfad + geraet + '.Kosten._Woche.Woche_' + i,            0, {name: 'Stromkosten vor ' + i + ' Woche(n) ('  + geraet + ')', type: 'number', unit:'€'  });
                          }
                      }
                      
                      if(Monat_Anzahl_Werte_in_der_Vergangenheit > 0) {
                  
                          for(var i = 1; i <= Monat_Anzahl_Werte_in_der_Vergangenheit; i++) {
                              createState(pfad + geraet + '.Verbrauch._Monat.Monat_' + i,         0, {name: 'Verbrauch vor ' + i + ' Monat(en) ('    + geraet + ')', type: 'number', unit: _unit_kilo });
                              createState(pfad + geraet + '.Kosten._Monat.Monat_' + i,            0, {name: 'Stromkosten vor ' + i + ' Monat(en) ('  + geraet + ')', type: 'number', unit:'€'  });
                          }
                      }
                      
                      if(Quartal_Anzahl_Werte_in_der_Vergangenheit > 0) {
                          
                          for(var i = 1; i <= Quartal_Anzahl_Werte_in_der_Vergangenheit; i++) {
                              createState(pfad + geraet + '.Verbrauch._Quartal.Quartal_' + i,     0, {name: 'Verbrauch vor ' + i + ' Quartal(en) ('    + geraet + ')', type: 'number', unit: _unit_kilo });
                              createState(pfad + geraet + '.Kosten._Quartal.Quartal_' + i,        0, {name: 'Stromkosten vor ' + i + ' Quartal(en) ('  + geraet + ')', type: 'number', unit:'€'  });
                          }
                      }
                      
                      if(Jahr_Anzahl_Werte_in_der_Vergangenheit > 0) {
                  
                          for(var i = 1; i <= Jahr_Anzahl_Werte_in_der_Vergangenheit; i++) {
                              createState(pfad + geraet + '.Verbrauch._Jahr.Jahr_' + i,           0, {name: 'Verbrauch vor ' + i + ' Jahr(en) ('    + geraet + ')', type: 'number', unit: _unit_kilo });
                              createState(pfad + geraet + '.Kosten._Jahr.Jahr_' + i,              0, {name: 'Stromkosten vor ' + i + ' Jahr(en) ('  + geraet + ')', type: 'number', unit:'€'  });
                          }
                      }
                  
                      // Neustart von CCU oder Gerät erkannt
                      createState(pfad + geraet + '.config.NeustartErkanntAlterWert', 0);
                      
                      // Gerät hat eigenen Strompreis
                      if(enable_unterschiedlichePreise) {
                          createState(pfad + geraet + '.eigenerPreis.aktuell.Arbeitspreis'            , { name: 'Strompreis - aktueller Arbeitspreis ab Datum (brutto)' ,     unit: '€/' + _unit_kilo,      type: 'number', def: 0 });
                          createState(pfad + geraet + '.eigenerPreis.aktuell.Grundpreis'              , { name: 'Strompreis - aktueller Grundpreis ab Datum (brutto)'   ,     unit: '€/Monat',    type: 'number', def: 0 });
                          createState(pfad + geraet + '.eigenerPreis.neu.Arbeitspreis'                , { name: 'Strompreis - neuer Arbeitspreis ab Datum (brutto)' ,         unit: '€/' + _unit_kilo,      type: 'number', def: 0 });
                          createState(pfad + geraet + '.eigenerPreis.neu.Grundpreis'                  , { name: 'Strompreis - neuer Grundpreis ab Datum (brutto)'   ,         unit: '€/Monat',    type: 'number', def: 0 });
                          createState(pfad + geraet + '.eigenerPreis.neu.Datum'                       , { name: 'Strompreis und Grundpreis ab folgendem Datum zur Berechnung heranziehen (Beispiel 01.01.2019)', def: "01.01.1970", type: 'string' });
                          
                          createState(pfad + geraet + '.eigenerPreis.neu.PreisaenderungDurchgefuehrt' ,     false, { read: true, write: true, type: "boolean", def: false });
                      }
                      
                      // history bei allen Datenpunkten aktivieren
                      if(enable_history) {
                          enableHistory(geraet, 'Tag');
                          enableHistory(geraet, 'Woche');
                          enableHistory(geraet, 'Monat');
                          enableHistory(geraet, 'Quartal');
                          enableHistory(geraet, 'Jahr');
                      }
                  
                      if (logging) log('States in der Instanz ' + instanz + pfad + ' erstellt');   
                  }
                  
                  function enableHistory(geraet, zeitraum) {
                  
                      if(instance_history !== '') {
                          
                          sendTo(instance_history, 'enableHistory', {
                              id: instanz + pfad + geraet + '.Kosten.' + zeitraum,
                              options: {
                                  changesOnly:  true,
                                  debounce:     0,
                                  retention:    31536000,
                                  maxLength:    3,
                                  changesMinDelta: 0.5
                              }
                          }, function (result) {
                              if (result.error) {
                                  if (logging) log("Fehler beim Aktivieren von History: " + result.error);
                              }
                          });
                          
                          sendTo(instance_history, 'enableHistory', {
                              id: instanz + pfad + geraet + '.Verbrauch.' + zeitraum,
                              options: {
                                  changesOnly:  true,
                                  debounce:     0,
                                  retention:    31536000,
                                  maxLength:    3,
                                  changesMinDelta: 0.5
                              }
                          }, function (result) {
                              if (result.error) {
                                  if (logging) log("Fehler beim Aktivieren von History: " + result.error);
                              }
                          });
                          
                          sendTo(instance_history, 'enableHistory', {
                              id: instanz + pfad + geraet + '.Zaehlerstand.' + zeitraum,
                              options: {
                                  changesOnly:  true,
                                  debounce:     0,
                                  retention:    31536000,
                                  maxLength:    3,
                                  changesMinDelta: 0.5
                              }
                          }, function (result) {
                              if (result.error) {
                                  if (logging) log("Fehler beim Aktivieren von History: " + result.error);
                              }
                          });
                      }
                  }
                  
                  function pruefePreisaenderung(geraet) {
                      
                      var _Datum = "";
                      var _PreisaenderungDurchgefuehrt = "";
                      var _Arbeitspreis = "";
                      var _Grundpreis = "";
                      var _ArbeitspreisNeu = "";
                      var _GrundpreisNeu = "";
                      
                      if(typeof geraet === "undefined") {
                          
                           // Default Arbeitspreis ändern
                  
                          _Datum                          = instanz + pfad + 'Preis.neu.Datum';
                          _PreisaenderungDurchgefuehrt    = instanz + pfad + 'Preis.neu.PreisaenderungDurchgefuehrt';
                          
                          _Arbeitspreis       = instanz + pfad + 'Preis.aktuell.Arbeitspreis';
                          _Grundpreis         = instanz + pfad + 'Preis.aktuell.Grundpreis';
                          _ArbeitspreisNeu    = instanz + pfad + 'Preis.neu.Arbeitspreis';
                          _GrundpreisNeu      = instanz + pfad + 'Preis.neu.Grundpreis';
                          
                      } else {
                  
                          // Arbeitspreis für Gerät ändern
                          
                          _Datum                          = instanz + pfad + geraet + '.eigenerPreis.neu.Datum';
                          _PreisaenderungDurchgefuehrt    = instanz + pfad + geraet + '.eigenerPreis.neu.PreisaenderungDurchgefuehrt';
                          
                          _Arbeitspreis       = instanz + pfad + geraet + '.eigenerPreis.aktuell.Arbeitspreis';
                          _Grundpreis         = instanz + pfad + geraet + '.eigenerPreis.aktuell.Grundpreis';
                          _ArbeitspreisNeu    = instanz + pfad + geraet + '.eigenerPreis.neu.Arbeitspreis';
                          _GrundpreisNeu      = instanz + pfad + geraet + '.eigenerPreis.neu.Grundpreis';
                      }
                  
                      if(getObject(_Datum)) {
                          
                          var date = getState(_Datum).val;
                          
                          var Datum_Tag;
                          var Datum_Monat;
                          var Datum_Jahr;
                  
                          try {
                              var Datum = date.match(/\d{2}(\.|-)\d{2}(\.|-)\d{4}/g).toString();
                              
                              Datum_Tag = Datum.split(".")[0];
                              Datum_Monat = Datum.split(".")[1];
                              Datum_Jahr = Datum.split(".")[2];
                              
                          } catch (err) {
                              console.log("Fehler beim Auslesen des Datums. Eventuell falsche Syntax? " + date + " (Error:" + err + ")");
                          }
                          
                          newdate = new Date(Datum_Monat + " " + Datum_Tag + " " + Datum_Jahr);
                  
                          var today = new Date();
                          today.setHours(0,0,0,0);
                  
                          if(today.getTime() === newdate.getTime()) {
                              
                              if(!getState(_PreisaenderungDurchgefuehrt).val) {
                  
                                  setState(_PreisaenderungDurchgefuehrt, true);
                                  
                                  var alterArbeitspreis = getState(_Arbeitspreis).val;
                                  var alterGrundpreis = getState(_Grundpreis).val;
                                  
                                  var neuerArbeitspreis = getState(_ArbeitspreisNeu).val;
                                  var neuerGrundpreis = getState(_GrundpreisNeu).val;
                                  
                                  setState(_Arbeitspreis, neuerArbeitspreis);
                                  setState(_Grundpreis, neuerGrundpreis);
                                  
                                  var message =  'Preisänderung für ' + geraet + ' wurde durchgeführt:' + '\n'
                                              + 'alter Arbeitspreis:' + alterArbeitspreis + '.\n'
                                              + 'alter Grundpeis:' + alterGrundpreis + '.\n'
                                              + 'neuer Arbeitspreis:' + neuerArbeitspreis + '.\n'
                                              + 'neuer Grundpreis:' + neuerGrundpreis;
                                  
                                  send_message(message);
                              }
                              
                          } else if(today.getTime() > newdate.getTime()) {
                  
                              // Variable zurücksetzen
                              setState(_PreisaenderungDurchgefuehrt, false);
                          }
                      }
                  }
                  
                  //----------------------------------------------------------------------------//
                  
                  Thomas Braun 1 Reply Last reply Reply Quote 0
                  • Thomas Braun
                    Thomas Braun Most Active @Sunshinemaker last edited by

                    @Sören
                    Von Skripten hab ich keine Ahnung.

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

                      @Thomas-Braun

                      Schade, aber ich Danke dir Trotzdem für deine Hilfe 🙂

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

                        @Sören sagte in Nach Scriptausführung nur noch Fehler und keine Funkion:

                        Error: Cannot find module 'typescript'

                        kannst du bitte die Dateien:
                        package-lock.json (in /opt/iobroker) und package.json (/opt/iobroker/node_modules/iobroker.javascript) hier posten?

                        der korrekte fix wäre:

                        cd /opt/iobroker/node_modules/iobroker.javascript
                        npm install --production
                        
                        Sunshinemaker 1 Reply Last reply Reply Quote 0
                        • Sunshinemaker
                          Sunshinemaker @Homoran last edited by Sunshinemaker

                          @Homoran
                          Beide Dateien von der Dockerinstallatioen.

                          package.json
                          package-lock.json

                          so, nach einigem hin und her Funktioniert jetzt auch

                          npm install --production
                          

                          in Docker
                          das Ergebnis:

                          root@iobroker2:/opt/iobroker/node_modules/iobroker.javascript# npm install --production                                                                                                                                         
                          npm WARN deprecated coffee-script@1.12.7: CoffeeScript on NPM has moved to "coffeescript" (no hyphen)                                                                                                                           
                          npm WARN deprecated chokidar@2.1.8: Chokidar 2 will break on node v14+. Upgrade to chokidar 3 with 15x less dependencies.                                                                                                       
                          npm WARN deprecated fsevents@1.2.13: fsevents 1 will break on node v14+ and could be using insecure binaries. Upgrade to fsevents 2.                                                                                            
                          npm WARN deprecated resolve-url@0.2.1: https://github.com/lydell/resolve-url#deprecated                                                                                                                                         
                          npm WARN deprecated urix@0.1.0: Please see https://github.com/lydell/urix#deprecated                                                                                                                                            
                          npm WARN checkPermissions Missing write access to /opt/iobroker/node_modules/iobroker.javascript/node_modules/@types                                                                                                            
                          npm WARN checkPermissions Missing write access to /opt/iobroker/node_modules/iobroker.javascript/node_modules                                                                                                                   
                          npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@^1.2.7 (node_modules/chokidar/node_modules/fsevents):                                                                                                                  
                          npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@1.2.13: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})                                                              
                          npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@~2.1.1 (node_modules/mocha/node_modules/chokidar/node_modules/fsevents):                                                                                               
                          npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.1.3: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})                                                               
                                                                                                                                                                                                                                                          
                          npm ERR! code EACCES                                                                                                                                                                                                            
                          npm ERR! syscall access                                                                                                                                                                                                         
                          npm ERR! path /opt/iobroker/node_modules/iobroker.javascript/node_modules/@types                                                                                                                                                
                          npm ERR! errno -13                                                                                                                                                                                                              
                          npm ERR! Error: EACCES: permission denied, access '/opt/iobroker/node_modules/iobroker.javascript/node_modules/@types'                                                                                                          
                          npm ERR!  { [Error: EACCES: permission denied, access '/opt/iobroker/node_modules/iobroker.javascript/node_modules/@types']                                                                                                     
                          npm ERR!   stack:                                                                                                                                                                                                               
                          npm ERR!    'Error: EACCES: permission denied, access \'/opt/iobroker/node_modules/iobroker.javascript/node_modules/@types\'',                                                                                                  
                          npm ERR!   errno: -13,                                                                                                                                                                                                          
                          npm ERR!   code: 'EACCES',                                                                                                                                                                                                      
                          npm ERR!   syscall: 'access',                                                                                                                                                                                                   
                          npm ERR!   path:                                                                                                                                                                                                                
                          npm ERR!    '/opt/iobroker/node_modules/iobroker.javascript/node_modules/@types' }                                                                                                                                              
                          npm ERR!                                                                                                                                                                                                                        
                          npm ERR! The operation was rejected by your operating system.                                                                                                                                                                   
                          npm ERR! It is likely you do not have the permissions to access this file as the current user                                                                                                                                   
                          npm ERR!                                                                                                                                                                                                                        
                          npm ERR! If you believe this might be a permissions issue, please double-check the                                                                                                                                              
                          npm ERR! permissions of the file and its containing directories, or try running                                                                                                                                                 
                          npm ERR! the command again as root/Administrator.                                                                                                                                                                               
                                                                                                                                                                                                                                                          
                          npm ERR! A complete log of this run can be found in:                                                                                                                                                                            
                          npm ERR!     /opt/iobroker/.npm/_logs/2020-06-08T17_54_10_994Z-debug.log 
                          
                          AlCalzone 1 Reply Last reply Reply Quote 0
                          • AlCalzone
                            AlCalzone Developer @Sunshinemaker last edited by AlCalzone

                            @Sören Mal den Fixer ausgeführt? EACCES ist meist ein deutlicher Hinweis, dass es mal Zeit ist.

                            Beide Dateien von der Dockerinstallatioen.

                            package.json
                            package-lock.json

                            War das vor oder nach npm install --production?

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

                              @AlCalzone

                              cd /opt/iobroker/node_modules/iobroker.javascript
                              npm install --production
                              

                              oder was Meinst du?

                              So jetzt mal ganz von vorne. Ich hab JETZT eben ein Backup erstellt, ioBroker neu aufgesetzt. Geupdatet, den fixer drüber laufen lassen. Backup wieder hergestellt. Und hab jetzt das Problem das ich gerade nicht mehr auf die oberfläche komme. 😠

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

                                @Sören sagte in Nach Scriptausführung nur noch Fehler und keine Funkion:

                                oder was Meinst du?

                                Stellen die geposteten Dateien den Zustand vor oder nach diesen Befehlen dar? Mich würde interessieren, was vorher war.

                                Und hab jetzt das Problem das ich gerade nicht mehr auf die oberfläche komme.

                                Was steht im Log? Kannst du mit iobroker logs ausgeben lassen.

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

                                  @AlCalzone said in Nach Scriptausführung nur noch Fehler und keine Funkion:

                                  Stellen die geposteten Dateien den Zustand vor oder nach diesen Befehlen dar? Mich würde interessieren, was vorher war.
                                  die Zeilen sind nach

                                  npm install --production
                                  

                                  vor ging kein nem befehl, das gib erst nachdem ich das Netzwerk von Host auf Bridge geändert hab.

                                  Was steht im Log? Kannst du mit iobroker logs ausgeben lassen.

                                  Terminal geht zum glück.

                                  iobroker.2020-06-08.log

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

                                    Ich hab einiges hin und her Probiert. Aber es hat nicht funktioniert. ich weiß nicht was ich verstellt hab. aber ich bin gerade an dem Punkt das ich nicht mal eine komplett Neue Docker Instanz vom ioBroker zum laufen bekommen.

                                    Ich hab aktuell wieder originale Instanz am Laufen in der keine npm befehle funktionieren. Dafür kann ich kann alles andere erstmal wieder nutzen.

                                    Vielleicht hat ja noch jemand eine Idee wie ich typescriptim Docker wieder zum laufen kommen.

                                    Ich danke euch allen aber schon mal jetzt für eure mühe und eure zeit 👏 👏 👏 👍

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

                                      @Sören sagte in Nach Scriptausführung nur noch Fehler und keine Funkion:

                                      vor ging kein npm befehl

                                      Hä? Bevor du npm ausgeführt hast ging npm nicht? Versteh ich nicht

                                      In deinem Log sehe ich eigentlich nur Fehler, die mit Netzwerk zu tun haben (falsche IP, Port schon belegt, ...)

                                      @Sören sagte in Nach Scriptausführung nur noch Fehler und keine Funkion:

                                      Vielleicht hat ja noch jemand eine Idee wie ich typescriptim Docker wieder zum laufen kommen.

                                      Nur mit npm. Suche virtual-tsc (entweder in /opt/iobroker/node_modules oder /opt/iobroker/node_modules/iobroker.javascript/node_modules), geh in den Ordner und installiere TypeScript: npm i typescript

                                      Anscheinend laufen wir derzeit (warum auch immer so plötzlich) in einen npm-Bug, der seit >1 Jahr bekannt und nicht gefixt ist.

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

                                        @AlCalzone said in Nach Scriptausführung nur noch Fehler und keine Funkion:

                                        Hä? Bevor du npm ausgeführt hast ging npm nicht? Versteh ich nicht

                                        Das Problem ist das iobroker in einer Dockerumgebung läuft. Und anscheinend gibt es ja Probleme mit den Rechten wenn als Netzwerk host gewählt ist. Ich bin aber in solchen dingen nicht wirklich der große Experte. Es gibt noch die Möglichkeit das ganze mit einem VLAN zu umgehen. Das hab ich ja versucht. Dann Funktionieren die befehle in Konsole, aber ich hab kein zugriff auf die Oberfläche. Zumindest was ich so alles im Internet irgendwo zusammen suchen konnte.

                                        Ich hatte vorhin eine neue iobrocker Umgebung in Docker angelegt, bei der npmfunktioniert hat, aber ich hab eben keine zugriff auf die Oberfläche gehabt habe, sondern nur auf die Konsole.

                                        jetzt bin ich wieder zurück zu meiner ausgangsitusation, das ich Zugriff auf die Grafische Oberfläche hab aber npmnicht mehr funktioniert. Und somit auch immer noch der fahler vorhanden ist. Da ich eine Multihost Umgebung habe, kann ich mir im moment damit behelfen das Javascript auf dem Pi3 läuft. Aber da der schon an seiner grenze ist, ist das keine dauerhafte Lösung, sondern nur ein Notbehelf. Aber so kann ich wenigstens alles andere vom Samrthome usw in betrieb halten und steh nciht ganz im Dunklen.

                                        Wenn ich aktuell in der Konsole npm i typescripteingebe passiert das:

                                        root@iobroker:/opt/iobroker# cd /opt/iobroker/node_modules/iobroker.javascrip
                                        bash: cd: /opt/iobroker/node_modules/iobroker.javascrip: Datei oder Verzeichnis nicht gefunden
                                        root@iobroker:/opt/iobroker# cd  /opt/iobroker/node_modules/iobroker.javascript/node_modules
                                        root@iobroker:/opt/iobroker/node_modules/iobroker.javascript/node_modules# npm i typescript
                                        sudo: Hostname iobroker kann nicht aufgelöst werden
                                        sudo: Die Audit-Nachricht kann nicht gesendet werden: Unbekannter Fehler -1
                                        sudo: pam_open_session: Systemfehler
                                        sudo: Regelwerks-Plugin konnte Sitzung nicht initialisieren
                                        root@iobroker:/opt/iobroker/node_modules/iobroker.javascript/node_modules#
                                        root@iobroker:/opt/iobroker/node_modules/iobroker.javascript/node_modules#
                                        root@iobroker:/opt/iobroker/node_modules/iobroker.javascript/node_modules# npm -v
                                        sudo: Hostname iobroker kann nicht aufgelöst werden
                                        sudo: Die Audit-Nachricht kann nicht gesendet werden: Unbekannter Fehler -1
                                        sudo: pam_open_session: Systemfehler
                                        sudo: Regelwerks-Plugin konnte Sitzung nicht initialisieren
                                        root@iobroker:/opt/iobroker/node_modules/iobroker.javascript/node_modules#
                                        
                                        

                                        Ich hoffe ich konnte mein Chaos etwas auflösen.

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

                                          Ich hab jetzt nochmal einen neuen iobroker aufgesetzt und zwar nach dieser Anleitung buanet iobroker V3 und jetzt bin ich wieder an dem Punkt das ich keine zugriff auf die Oberfläche bekomme. Per Terminal kein Problem. Allerdings vermute ich den Fehler dieses mal irgendwo im Netzwerk bzw den Einstellungen.

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

                                            @Sören sagte in Nach Scriptausführung nur noch Fehler und keine Funkion:

                                            sudo: Hostname iobroker kann nicht aufgelöst werden

                                            Hast du irgendwie (unvollständig) den Hostnamen geändert?
                                            Suche nach dem Fehler liefert Hinweise, dass man den manuell korrigieren kann:
                                            https://linuxhandbook.com/sudo-unable-resolve-host/

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            428
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            adapter fehler javascript adapter rot javascript.0 terminated
                                            4
                                            23
                                            783
                                            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