Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Tester
  4. Test js-controller v2.0.x (GitHub)

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.5k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.1k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    2.7k

Test js-controller v2.0.x (GitHub)

Geplant Angeheftet Gesperrt Verschoben Tester
js-controller
1.0k Beiträge 48 Kommentatoren 316.2k Aufrufe 35 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • apollon77A apollon77

    @crunchip Hm ... kannst Du aus den "Gefühlen" irgendwie Fakten machen? Also beispielsweise: Vergleiche Admin log mit Logfile auf Platte oder so. Ist was anders?

    Bei früheren controllern wurden zB immer die "info" Meldungen bei Adapterstarts an Admin weitergegeben und auch so teilweise obwhl ein anderrr Loglevel war. Das ist jetzt auch "gefixt". Also ja. Adapter mit nicht info sollten ruhiger sein als früher.

    Ich habe bei mir nochmal gecheckt und da passts.

    crunchipC Abwesend
    crunchipC Abwesend
    crunchip
    Forum Testing Most Active
    schrieb am zuletzt editiert von
    #759

    @apollon77 was heisst Fakten machen.
    Ich sehe nur den Vergleich zu vorher, sprich bei js-controller1.5.x
    was nun richtig oder falsch bzw zu wenig oder zuviel geloggt wird, kann ich schlecht beurteilen, denn das was geloggt wird, kommt ja vom controller.
    admin log und logfile stimmen fast überein, also kaum Unterschiede.
    als Beispiel
    schalte ich das Licht irgendwo ein/aus, war das im log sichtbar, bzw
    generell irgend eine aktion die per skript erfolgte wurde im log angezeigt.

    umgestiegen von Proxmox auf Unraid

    apollon77A 1 Antwort Letzte Antwort
    0
    • crunchipC crunchip

      @apollon77 was heisst Fakten machen.
      Ich sehe nur den Vergleich zu vorher, sprich bei js-controller1.5.x
      was nun richtig oder falsch bzw zu wenig oder zuviel geloggt wird, kann ich schlecht beurteilen, denn das was geloggt wird, kommt ja vom controller.
      admin log und logfile stimmen fast überein, also kaum Unterschiede.
      als Beispiel
      schalte ich das Licht irgendwo ein/aus, war das im log sichtbar, bzw
      generell irgend eine aktion die per skript erfolgte wurde im log angezeigt.

      apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #760

      @crunchip hhhaaaaaa. Skripte. Hast du ggf JavaScript 4.3.0 installiert die Tage und nutzt dort log(„Info“,...) oder so? Wenn ja istvder scheinbar was im JavaScript Adapter. Issue gibts schon. Kann das sein?

      Mit Fakten machen meinte ich genau das. Was fehlt denn was da sein sollte.

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      crunchipC 1 Antwort Letzte Antwort
      0
      • apollon77A apollon77

        @crunchip hhhaaaaaa. Skripte. Hast du ggf JavaScript 4.3.0 installiert die Tage und nutzt dort log(„Info“,...) oder so? Wenn ja istvder scheinbar was im JavaScript Adapter. Issue gibts schon. Kann das sein?

        Mit Fakten machen meinte ich genau das. Was fehlt denn was da sein sollte.

        crunchipC Abwesend
        crunchipC Abwesend
        crunchip
        Forum Testing Most Active
        schrieb am zuletzt editiert von crunchip
        #761

        @apollon77 ja habe 4.3.0
        ja daran hatte ich nicht gedacht, da z.b. das Anwesenheitsskript mir die Ausgabe im log anzeigt, das Lichterzählenskript wieder nicht mehr.
        sowas wird nicht mehr angezeigt
        75f51992-86c6-42a8-8577-aa6571ec9a11-image.png

        umgestiegen von Proxmox auf Unraid

        apollon77A 2 Antworten Letzte Antwort
        0
        • crunchipC crunchip

          @apollon77 ja habe 4.3.0
          ja daran hatte ich nicht gedacht, da z.b. das Anwesenheitsskript mir die Ausgabe im log anzeigt, das Lichterzählenskript wieder nicht mehr.
          sowas wird nicht mehr angezeigt
          75f51992-86c6-42a8-8577-aa6571ec9a11-image.png

          apollon77A Offline
          apollon77A Offline
          apollon77
          schrieb am zuletzt editiert von
          #762

          @crunchip siehe issue, scheinbar kommt’s drauf an wie du loggst ;-)

          Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

          • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
          • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
          1 Antwort Letzte Antwort
          0
          • apollon77A apollon77

            @crunchip Hm ... kannst Du aus den "Gefühlen" irgendwie Fakten machen? Also beispielsweise: Vergleiche Admin log mit Logfile auf Platte oder so. Ist was anders?

            Bei früheren controllern wurden zB immer die "info" Meldungen bei Adapterstarts an Admin weitergegeben und auch so teilweise obwhl ein anderrr Loglevel war. Das ist jetzt auch "gefixt". Also ja. Adapter mit nicht info sollten ruhiger sein als früher.

            Ich habe bei mir nochmal gecheckt und da passts.

            crunchipC Abwesend
            crunchipC Abwesend
            crunchip
            Forum Testing Most Active
            schrieb am zuletzt editiert von
            #763

            @apollon77 sagte in [Aufruf] js-controller 2.0 Beta Test:

            Bei früheren controllern wurden zB immer die "info" Meldungen bei Adapterstarts an Admin weitergegeben und auch so teilweise obwhl ein anderrr Loglevel war. Das ist jetzt auch "gefixt".

            verstehe ich jetzt so, das wenn z.b der Adapter daswetter per cron neu startet, es nicht mehr angezeigt werden soll im log, ist das richtig?
            habe alles Adapter mit cron auf logstufe warn, bekomme aber trotzdem die Meldungen
            2791edf8-c88d-475f-aefd-cbfb26574b0c-image.png

            umgestiegen von Proxmox auf Unraid

            apollon77A 1 Antwort Letzte Antwort
            0
            • crunchipC crunchip

              @apollon77 sagte in [Aufruf] js-controller 2.0 Beta Test:

              Bei früheren controllern wurden zB immer die "info" Meldungen bei Adapterstarts an Admin weitergegeben und auch so teilweise obwhl ein anderrr Loglevel war. Das ist jetzt auch "gefixt".

              verstehe ich jetzt so, das wenn z.b der Adapter daswetter per cron neu startet, es nicht mehr angezeigt werden soll im log, ist das richtig?
              habe alles Adapter mit cron auf logstufe warn, bekomme aber trotzdem die Meldungen
              2791edf8-c88d-475f-aefd-cbfb26574b0c-image.png

              apollon77A Offline
              apollon77A Offline
              apollon77
              schrieb am zuletzt editiert von
              #764

              @crunchip meldungen vom Host (wie da zu sehen) werden nach dem Loglevel des Hosts geloggt ... und das steht bei dir auf info also kommen die noch. Die Adapter geben selbst noch ein "starting" aus ... das wäre weg

              Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

              • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
              • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
              1 Antwort Letzte Antwort
              0
              • crunchipC crunchip

                @apollon77 ja habe 4.3.0
                ja daran hatte ich nicht gedacht, da z.b. das Anwesenheitsskript mir die Ausgabe im log anzeigt, das Lichterzählenskript wieder nicht mehr.
                sowas wird nicht mehr angezeigt
                75f51992-86c6-42a8-8577-aa6571ec9a11-image.png

                apollon77A Offline
                apollon77A Offline
                apollon77
                schrieb am zuletzt editiert von
                #765

                @crunchip Naja wie ist der Log Befehl im Skript wenns fehlt?

                Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                crunchipC 1 Antwort Letzte Antwort
                0
                • apollon77A apollon77

                  @crunchip Naja wie ist der Log Befehl im Skript wenns fehlt?

                  crunchipC Abwesend
                  crunchipC Abwesend
                  crunchip
                  Forum Testing Most Active
                  schrieb am zuletzt editiert von
                  #766

                  @apollon77

                  var logging = true;
                  
                  var idAnzahlEin = 'javascript.0.Status.Lichter.Anzahl_ein',
                  idAnzahl = 'javascript.0.Status.Lichter.Anzahl',
                  idText = 'javascript.0.Status.Lichter.Text',
                  idRaum = 'javascript.0.Status.Lichter.Raum', // <---- NEU
                  idAnsage = 'javascript.0.Status.Lichter.Ansage';
                  
                  // Ab hier nix mehr ändern
                  createState(idAnzahl, { // wenn benötigt: Anzahl der vorhandenen Lichter
                  type: 'number',
                  name: 'Anzahl aller Lichter',
                  min: 0,
                  def: 0,
                  role: 'value'
                  });
                  createState(idAnzahlEin, { // Anzahl der Lichter, die auf sind als Variable unter Javascript.0 anlegen
                  type: 'number',
                  name: 'Anzahl der eingeschalteten Lichter',
                  min: 0,
                  def: 0,
                  role: 'value'
                  });
                  createState(idText, { // Anzahl der brennenden Lichter und deren Namen als Variable unter Javascript.0 anlegen
                  type: 'string',
                  name: 'Eingeschaltete Lichter',
                  desc: 'Namen der eingeschalteten Lichter',
                  def: ' ',
                  role: 'value'
                  });
                  createState(idAnsage, {
                  type: 'string',
                  name: 'Eingeschaltete Lichter (Ansage)',
                  desc: 'Namen der eingeschalteten Lichter (für Ansage aufbereitet)',
                  def: ' ',
                  role: 'value'
                  });
                  createState(idRaum, { // Räume, in denen Lichter brennen // <---- NEU
                  type: 'string',
                  name: 'Räume mit eingeschalteten Lichter',
                  desc: 'Namen der Räume, in denen Lichter eingeschaltet sind',
                  def: ' ',
                  role: 'value'
                  });
                  
                  var cacheSelectorState = $('channel[state.id=*.STATE](functions="licht")'); // Gewerk licht
                  var cacheSelectorLevel = $('channel[state.id=*.level](functions="licht")');
                  var cacheSelectorPOWER = $('state[id=*.POWER](functions="licht")'); // Sonoff
                  var cacheSelectorSwitch = $('state[id=*.Switch](functions="licht")'); // Shelly
                  var cacheSelectorMi = $('state[id=*.state](functions=licht)'); //Mi-Light
                  
                  function checkDevices(obj) {
                  // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk licht auf 0
                  var anzahlLichterAn = 0;
                  var anzahlLichter = 0;
                  var textLichterAn = [];
                  var textRaum = [];
                  
                  if (logging) {
                  log('++++++ Lichter Anzahl ++++ ');
                  log('#### SCHALTER ##### ');
                  }
                  cacheSelectorState.each(function (id, i) { // Schleife für jedes gefundenen Element *.STATE im Gewerk Licht
                  var obj = getObject(id);
                  var name = getObject(id).common.name;
                  var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                  var devicename = name.substring(0, name.indexOf(".STATE")); //.state aus Text entfernen
                  var raumname = getObject(id, "rooms"); // <---- NEU
                  
                  
                  // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                  // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { 
                  /*
                  if (logging) {
                  log('-------');
                  log('Kanal: ' + name);
                  log('Status: ' + status); 
                  }
                  */
                  
                  if (status) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                  ++anzahlLichterAn; 
                  textLichterAn.push(devicename); // Zu Array hinzufügen
                  textRaum.push(raumname.enumNames); // <---- NEU
                  }
                  ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                  // } // ENDE VK-Abfrage
                  
                  });
                  
                  
                  if (logging) log('#### DIMMER ##### ');
                  cacheSelectorLevel.each(function (id, i) { // Schleife für jedes gefundenen Element *.LEVEL im Gewerk Licht
                  var obj = getObject(id);
                  var name = getObject(id).common.name;
                  var status = getState(id).val; // Zustand *.LEVEL abfragen (jedes Element)
                  var devicename = name.substring(0, name.indexOf(".LEVEL")); //.state aus Text entfernen
                  var raumname = getObject(id, "rooms"); // <---- NEU
                  
                  // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                  // if ( (devicename.search(/(CUX)|(K2)|(K3)|(V10)|(VK)|(:)/ig) == -1) ) { // Geräte mit diesen Strings im namen nicht beachten
                  /*
                  if (logging) {
                  log('-------');
                  log('Kanal: ' + name);
                  log('Status: ' + status + '%'); 
                  }
                  */
                  
                  if (parseFloat(status) > 0) { // Wenn Dimmwert über 0
                  ++anzahlLichterAn; 
                  textLichterAn.push(devicename); // Zu Array hinzufügen
                  textRaum.push(raumname.enumNames); // <---- NEU
                  }
                  ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                  // } // Ende Abfrage VK 
                  
                  }); 
                  
                  if (logging) {
                  log('++++++ Lichter Anzahl ++++ ');
                  log('#### SCHALTER ##### ');
                  }
                  cacheSelectorPOWER.each(function (id, i) { // Schleife für jedes gefundenen Element *.POWER im Gewerk Licht
                  var obj = getObject(id);
                  var name = getObject(id).common.name;
                  var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                  var devicename = name.substring(0, name.indexOf("POWER")); //.state aus Text entfernen
                  var raumname = getObject(id, "rooms"); // <---- NEU
                  
                  
                  // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                  // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { 
                  /*
                  if (logging) {
                  log('-------');
                  log('Kanal: ' + name);
                  log('Status: ' + status); 
                  }
                  */
                  
                  if (status) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                  ++anzahlLichterAn; 
                  textLichterAn.push(devicename); // Zu Array hinzufügen
                  textRaum.push(raumname.enumNames); // <---- NEU
                  }
                  ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                  // } // ENDE VK-Abfrage
                  
                  });
                  
                  if (logging) {
                  log('++++++ Lichter Anzahl ++++ ');
                  log('#### SCHALTER ##### ');
                  }
                  cacheSelectorSwitch.each(function (id, i) { // Schleife für jedes gefundenen Element *.POWER im Gewerk Licht
                  var obj = getObject(id);
                  var name = getObject(id).common.name;
                  var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                  var devicename = name;
                  var raumname = getObject(id, "rooms"); // <---- NEU
                  
                  // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                  // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { 
                  /*
                  if (logging) {
                  log('-------');
                  log('Kanal: ' + name);
                  log('Status: ' + status); 
                  }
                  */
                  
                  if (status) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                  ++anzahlLichterAn; 
                  textLichterAn.push(devicename); // Zu Array hinzufügen
                  textRaum.push(raumname.enumNames); // <---- NEU
                  }
                  ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                  // } // ENDE VK-Abfrage
                  });
                  
                  
                  
                  if (logging) {
                  log('++++++ Lichter Anzahl ++++ ');
                  log('#### SCHALTER ##### ');
                  }
                  cacheSelectorMi.each(function (id, i) { // Schleife für jedes gefundenen Element *.POWER im Gewerk Licht
                  var obj = getObject(id);
                  var name = getObject(id).common.name;
                  var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                  var devicename = name.substring(0, name.indexOf(" Switch ON/OFF")); //.state aus Text entfernen
                  var raumname = getObject(id, "rooms"); // <---- NEU
                  
                  // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                  // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { 
                  /*
                  if (logging) {
                  log('-------');
                  log('Kanal: ' + name);
                  log('Status: ' + status); 
                  }
                  */
                  
                  if (status) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                  ++anzahlLichterAn; 
                  textLichterAn.push(devicename); // Zu Array hinzufügen
                  textRaum.push(raumname.enumNames); // <---- NEU
                  }
                  ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                  // } // ENDE VK-Abfrage
                  });
                  
                  // Array mit Lichternamen sortieren
                  textLichterAn.sort();
                  textRaum.sort(); // <---- NEU
                  // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                  if (logging) log("Text: " + textLichterAn);
                  if (logging) log("Anzahl Lichter: " + anzahlLichter + " # davon Lichter an: " + anzahlLichterAn);
                  // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                  setState(idText, textLichterAn.join(', ')); // Schreibt die aktuelle Namen der eingeschalteten Lichter
                  setState(idAnzahlEin, textLichterAn.length); // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
                  setState(idAnzahl, anzahlLichter); // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
                  // setState(idRaum, textRaum.join(',<br>')); // Räume, in denen Licht brennt // <---- NEU
                  setState(idRaum, textRaum.join(', ')); // Räume, in denen Licht brennt // <---- NEU
                  }
                  
                  // Trigger
                  cacheSelectorState.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk licht
                  if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                  checkDevices();
                  });
                  cacheSelectorLevel.on(function(obj) { // bei Zustandänderung *.LEVEL im Gewerk licht
                  if (logging) log('Auslösender Dimmer: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                  checkDevices();
                  });
                  cacheSelectorPOWER.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk licht
                  if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                  checkDevices();
                  });
                  cacheSelectorSwitch.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk licht
                  if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                  checkDevices();
                  });
                  cacheSelectorMi.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk licht
                  if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                  checkDevices();
                  });
                  function main() {
                  setTimeout(function(){
                  if (logging) log('Auslöser Skriptstart');
                  checkDevices();
                  }, 2000);
                  }
                  
                  main(); // Skriptstart-Auslöser
                  
                  // Aufbereitung für Ansage
                  function strip_tags(data) {
                  var rueckgabe = data.replace(/(&nbsp;|<([^>]+)>)/ig, " ");
                  return(rueckgabe);
                  }
                  
                  on(idText, function (obj) {
                  var text = obj.state.val;
                  text = (getState(idAnzahl).val > 0 ) ? 'Lichter eingeschaltet: ' + strip_tags(text) : 'Alle Lichter ausgeschaltet';
                  setState(idAnsage, text);
                  });
                  

                  umgestiegen von Proxmox auf Unraid

                  apollon77A 1 Antwort Letzte Antwort
                  0
                  • crunchipC crunchip

                    @apollon77

                    var logging = true;
                    
                    var idAnzahlEin = 'javascript.0.Status.Lichter.Anzahl_ein',
                    idAnzahl = 'javascript.0.Status.Lichter.Anzahl',
                    idText = 'javascript.0.Status.Lichter.Text',
                    idRaum = 'javascript.0.Status.Lichter.Raum', // <---- NEU
                    idAnsage = 'javascript.0.Status.Lichter.Ansage';
                    
                    // Ab hier nix mehr ändern
                    createState(idAnzahl, { // wenn benötigt: Anzahl der vorhandenen Lichter
                    type: 'number',
                    name: 'Anzahl aller Lichter',
                    min: 0,
                    def: 0,
                    role: 'value'
                    });
                    createState(idAnzahlEin, { // Anzahl der Lichter, die auf sind als Variable unter Javascript.0 anlegen
                    type: 'number',
                    name: 'Anzahl der eingeschalteten Lichter',
                    min: 0,
                    def: 0,
                    role: 'value'
                    });
                    createState(idText, { // Anzahl der brennenden Lichter und deren Namen als Variable unter Javascript.0 anlegen
                    type: 'string',
                    name: 'Eingeschaltete Lichter',
                    desc: 'Namen der eingeschalteten Lichter',
                    def: ' ',
                    role: 'value'
                    });
                    createState(idAnsage, {
                    type: 'string',
                    name: 'Eingeschaltete Lichter (Ansage)',
                    desc: 'Namen der eingeschalteten Lichter (für Ansage aufbereitet)',
                    def: ' ',
                    role: 'value'
                    });
                    createState(idRaum, { // Räume, in denen Lichter brennen // <---- NEU
                    type: 'string',
                    name: 'Räume mit eingeschalteten Lichter',
                    desc: 'Namen der Räume, in denen Lichter eingeschaltet sind',
                    def: ' ',
                    role: 'value'
                    });
                    
                    var cacheSelectorState = $('channel[state.id=*.STATE](functions="licht")'); // Gewerk licht
                    var cacheSelectorLevel = $('channel[state.id=*.level](functions="licht")');
                    var cacheSelectorPOWER = $('state[id=*.POWER](functions="licht")'); // Sonoff
                    var cacheSelectorSwitch = $('state[id=*.Switch](functions="licht")'); // Shelly
                    var cacheSelectorMi = $('state[id=*.state](functions=licht)'); //Mi-Light
                    
                    function checkDevices(obj) {
                    // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk licht auf 0
                    var anzahlLichterAn = 0;
                    var anzahlLichter = 0;
                    var textLichterAn = [];
                    var textRaum = [];
                    
                    if (logging) {
                    log('++++++ Lichter Anzahl ++++ ');
                    log('#### SCHALTER ##### ');
                    }
                    cacheSelectorState.each(function (id, i) { // Schleife für jedes gefundenen Element *.STATE im Gewerk Licht
                    var obj = getObject(id);
                    var name = getObject(id).common.name;
                    var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                    var devicename = name.substring(0, name.indexOf(".STATE")); //.state aus Text entfernen
                    var raumname = getObject(id, "rooms"); // <---- NEU
                    
                    
                    // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                    // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { 
                    /*
                    if (logging) {
                    log('-------');
                    log('Kanal: ' + name);
                    log('Status: ' + status); 
                    }
                    */
                    
                    if (status) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                    ++anzahlLichterAn; 
                    textLichterAn.push(devicename); // Zu Array hinzufügen
                    textRaum.push(raumname.enumNames); // <---- NEU
                    }
                    ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                    // } // ENDE VK-Abfrage
                    
                    });
                    
                    
                    if (logging) log('#### DIMMER ##### ');
                    cacheSelectorLevel.each(function (id, i) { // Schleife für jedes gefundenen Element *.LEVEL im Gewerk Licht
                    var obj = getObject(id);
                    var name = getObject(id).common.name;
                    var status = getState(id).val; // Zustand *.LEVEL abfragen (jedes Element)
                    var devicename = name.substring(0, name.indexOf(".LEVEL")); //.state aus Text entfernen
                    var raumname = getObject(id, "rooms"); // <---- NEU
                    
                    // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                    // if ( (devicename.search(/(CUX)|(K2)|(K3)|(V10)|(VK)|(:)/ig) == -1) ) { // Geräte mit diesen Strings im namen nicht beachten
                    /*
                    if (logging) {
                    log('-------');
                    log('Kanal: ' + name);
                    log('Status: ' + status + '%'); 
                    }
                    */
                    
                    if (parseFloat(status) > 0) { // Wenn Dimmwert über 0
                    ++anzahlLichterAn; 
                    textLichterAn.push(devicename); // Zu Array hinzufügen
                    textRaum.push(raumname.enumNames); // <---- NEU
                    }
                    ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                    // } // Ende Abfrage VK 
                    
                    }); 
                    
                    if (logging) {
                    log('++++++ Lichter Anzahl ++++ ');
                    log('#### SCHALTER ##### ');
                    }
                    cacheSelectorPOWER.each(function (id, i) { // Schleife für jedes gefundenen Element *.POWER im Gewerk Licht
                    var obj = getObject(id);
                    var name = getObject(id).common.name;
                    var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                    var devicename = name.substring(0, name.indexOf("POWER")); //.state aus Text entfernen
                    var raumname = getObject(id, "rooms"); // <---- NEU
                    
                    
                    // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                    // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { 
                    /*
                    if (logging) {
                    log('-------');
                    log('Kanal: ' + name);
                    log('Status: ' + status); 
                    }
                    */
                    
                    if (status) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                    ++anzahlLichterAn; 
                    textLichterAn.push(devicename); // Zu Array hinzufügen
                    textRaum.push(raumname.enumNames); // <---- NEU
                    }
                    ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                    // } // ENDE VK-Abfrage
                    
                    });
                    
                    if (logging) {
                    log('++++++ Lichter Anzahl ++++ ');
                    log('#### SCHALTER ##### ');
                    }
                    cacheSelectorSwitch.each(function (id, i) { // Schleife für jedes gefundenen Element *.POWER im Gewerk Licht
                    var obj = getObject(id);
                    var name = getObject(id).common.name;
                    var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                    var devicename = name;
                    var raumname = getObject(id, "rooms"); // <---- NEU
                    
                    // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                    // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { 
                    /*
                    if (logging) {
                    log('-------');
                    log('Kanal: ' + name);
                    log('Status: ' + status); 
                    }
                    */
                    
                    if (status) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                    ++anzahlLichterAn; 
                    textLichterAn.push(devicename); // Zu Array hinzufügen
                    textRaum.push(raumname.enumNames); // <---- NEU
                    }
                    ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                    // } // ENDE VK-Abfrage
                    });
                    
                    
                    
                    if (logging) {
                    log('++++++ Lichter Anzahl ++++ ');
                    log('#### SCHALTER ##### ');
                    }
                    cacheSelectorMi.each(function (id, i) { // Schleife für jedes gefundenen Element *.POWER im Gewerk Licht
                    var obj = getObject(id);
                    var name = getObject(id).common.name;
                    var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                    var devicename = name.substring(0, name.indexOf(" Switch ON/OFF")); //.state aus Text entfernen
                    var raumname = getObject(id, "rooms"); // <---- NEU
                    
                    // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen)
                    // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { 
                    /*
                    if (logging) {
                    log('-------');
                    log('Kanal: ' + name);
                    log('Status: ' + status); 
                    }
                    */
                    
                    if (status) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                    ++anzahlLichterAn; 
                    textLichterAn.push(devicename); // Zu Array hinzufügen
                    textRaum.push(raumname.enumNames); // <---- NEU
                    }
                    ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                    // } // ENDE VK-Abfrage
                    });
                    
                    // Array mit Lichternamen sortieren
                    textLichterAn.sort();
                    textRaum.sort(); // <---- NEU
                    // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                    if (logging) log("Text: " + textLichterAn);
                    if (logging) log("Anzahl Lichter: " + anzahlLichter + " # davon Lichter an: " + anzahlLichterAn);
                    // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                    setState(idText, textLichterAn.join(', ')); // Schreibt die aktuelle Namen der eingeschalteten Lichter
                    setState(idAnzahlEin, textLichterAn.length); // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
                    setState(idAnzahl, anzahlLichter); // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
                    // setState(idRaum, textRaum.join(',<br>')); // Räume, in denen Licht brennt // <---- NEU
                    setState(idRaum, textRaum.join(', ')); // Räume, in denen Licht brennt // <---- NEU
                    }
                    
                    // Trigger
                    cacheSelectorState.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk licht
                    if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                    checkDevices();
                    });
                    cacheSelectorLevel.on(function(obj) { // bei Zustandänderung *.LEVEL im Gewerk licht
                    if (logging) log('Auslösender Dimmer: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                    checkDevices();
                    });
                    cacheSelectorPOWER.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk licht
                    if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                    checkDevices();
                    });
                    cacheSelectorSwitch.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk licht
                    if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                    checkDevices();
                    });
                    cacheSelectorMi.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk licht
                    if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                    checkDevices();
                    });
                    function main() {
                    setTimeout(function(){
                    if (logging) log('Auslöser Skriptstart');
                    checkDevices();
                    }, 2000);
                    }
                    
                    main(); // Skriptstart-Auslöser
                    
                    // Aufbereitung für Ansage
                    function strip_tags(data) {
                    var rueckgabe = data.replace(/(&nbsp;|<([^>]+)>)/ig, " ");
                    return(rueckgabe);
                    }
                    
                    on(idText, function (obj) {
                    var text = obj.state.val;
                    text = (getState(idAnzahl).val > 0 ) ? 'Lichter eingeschaltet: ' + strip_tags(text) : 'Alle Lichter ausgeschaltet';
                    setState(idAnsage, text);
                    });
                    
                    apollon77A Offline
                    apollon77A Offline
                    apollon77
                    schrieb am zuletzt editiert von
                    #767

                    @crunchip passt denke ich zum javascript issue ;-)

                    Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                    • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                    • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                    crunchipC 1 Antwort Letzte Antwort
                    0
                    • apollon77A Offline
                      apollon77A Offline
                      apollon77
                      schrieb am zuletzt editiert von
                      #768

                      2.0.29 kommt jetzt demnächst ins Latest ... geht dann wieder dort weiter sobald es draussen ist ...

                      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                      1 Antwort Letzte Antwort
                      0
                      • apollon77A apollon77

                        @crunchip passt denke ich zum javascript issue ;-)

                        crunchipC Abwesend
                        crunchipC Abwesend
                        crunchip
                        Forum Testing Most Active
                        schrieb am zuletzt editiert von
                        #769

                        @apollon77 alles klar, dann wart ich mal ab

                        ansonsten läuft nun alles zur vollen Zufriedenheit----bis jetzt:grin:

                        KLASSE ARBEIT:+1:

                        umgestiegen von Proxmox auf Unraid

                        1 Antwort Letzte Antwort
                        0
                        • smartboartS Offline
                          smartboartS Offline
                          smartboart
                          schrieb am zuletzt editiert von smartboart
                          #770

                          Hi, habe auch mal upgedatet. Alles sofort geklappt. Mir fällt nur auf, dass ich unter den Objekten welche mittels Historie oder statistics mitlogge nicht mehr deaktivieren kann. Also die Maulschlüssel öffnen ganz normal die Einstellungen.Der Haken aktiv lässt sich auch ohne weiteres deaktiviern nur beim Speichern werden Änderungen nicht übernommen.

                          Systemdaten:

                           ioBroker-Rock
                          
                              Typ: js-controller
                              Titel: JS controller
                              OS: linux
                              Verfügbar: 2.0.29
                              Eingerichtet: 2.0.29
                              Ereignisse: ⇥24 / ↦13
                          
                          
                          
                          ioBroker-Rock
                          
                          Betriebssystem
                              linux
                          Architektur
                              arm64
                          CPUs
                              4
                          Geschwindigkeit
                              1296 MHz
                          Modell
                              unknown
                          RAM
                              3.9 GB
                          System Betriebszeit
                              2 T. 18:38:11
                          Node.js
                              v10.16.3
                          NPM
                              6.9.0
                          Festplatte Größe
                              56.1 GB
                          Festplatte frei
                              47.85 GB
                          Anzahl der Adapter
                              293
                          Betriebszeit
                              00:11:12
                          Aktive Instanzen
                              22
                          Hostname
                              ioBroker-Rock
                          

                          das hier taucht auch im log auf.Nach neustart..
                          Error 2019-10-14 17:46:22.010 warn from InMemDB: Error: Unknown Script 47ca5e051ba19850d94c45a1fc8725ff04ae868f
                          Error 2019-10-14 17:46:22.007 warn from InMemDB: Error: Unknown Script 47ca5e051ba19850d94c45a1fc8725ff04ae868f

                          apollon77A 1 Antwort Letzte Antwort
                          0
                          • smartboartS smartboart

                            Hi, habe auch mal upgedatet. Alles sofort geklappt. Mir fällt nur auf, dass ich unter den Objekten welche mittels Historie oder statistics mitlogge nicht mehr deaktivieren kann. Also die Maulschlüssel öffnen ganz normal die Einstellungen.Der Haken aktiv lässt sich auch ohne weiteres deaktiviern nur beim Speichern werden Änderungen nicht übernommen.

                            Systemdaten:

                             ioBroker-Rock
                            
                                Typ: js-controller
                                Titel: JS controller
                                OS: linux
                                Verfügbar: 2.0.29
                                Eingerichtet: 2.0.29
                                Ereignisse: ⇥24 / ↦13
                            
                            
                            
                            ioBroker-Rock
                            
                            Betriebssystem
                                linux
                            Architektur
                                arm64
                            CPUs
                                4
                            Geschwindigkeit
                                1296 MHz
                            Modell
                                unknown
                            RAM
                                3.9 GB
                            System Betriebszeit
                                2 T. 18:38:11
                            Node.js
                                v10.16.3
                            NPM
                                6.9.0
                            Festplatte Größe
                                56.1 GB
                            Festplatte frei
                                47.85 GB
                            Anzahl der Adapter
                                293
                            Betriebszeit
                                00:11:12
                            Aktive Instanzen
                                22
                            Hostname
                                ioBroker-Rock
                            

                            das hier taucht auch im log auf.Nach neustart..
                            Error 2019-10-14 17:46:22.010 warn from InMemDB: Error: Unknown Script 47ca5e051ba19850d94c45a1fc8725ff04ae868f
                            Error 2019-10-14 17:46:22.007 warn from InMemDB: Error: Unknown Script 47ca5e051ba19850d94c45a1fc8725ff04ae868f

                            apollon77A Offline
                            apollon77A Offline
                            apollon77
                            schrieb am zuletzt editiert von
                            #771

                            @smartboart Die Scripts Fehler könnten kommen wenn Du verschiedene Versionen laufen hast (Master/Slave ode rso) . Kann dass sein? Ggf bitte nochmal neu starten. Ich arbeite noch an einer nächsten version die da Dinge noch fixt.

                            Das andere mit Custom ich ansehen. Ist aktuell nicht bekannt. Kann es noch jemand nachvollziehen?

                            Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                            • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                            • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                            smartboartS 2 Antworten Letzte Antwort
                            0
                            • apollon77A apollon77

                              @smartboart Die Scripts Fehler könnten kommen wenn Du verschiedene Versionen laufen hast (Master/Slave ode rso) . Kann dass sein? Ggf bitte nochmal neu starten. Ich arbeite noch an einer nächsten version die da Dinge noch fixt.

                              Das andere mit Custom ich ansehen. Ist aktuell nicht bekannt. Kann es noch jemand nachvollziehen?

                              smartboartS Offline
                              smartboartS Offline
                              smartboart
                              schrieb am zuletzt editiert von smartboart
                              #772

                              @apollon77
                              ja hab nen multihost system, aber beide hochgezogen...
                              Beides neu gestartet, der Skript Fehler ist aber immernoch im log..

                              Der tauchte auch im master bei iobroker upgrade self im Anschluss auf. Das Upgrade ging erst beim 2 mal durch.. Hatte vorher das vorletzte releas drauf 2.0.25, was ohne Probleme zu installieren war..
                              Unbenannt.JPG

                              1 Antwort Letzte Antwort
                              0
                              • apollon77A apollon77

                                @smartboart Die Scripts Fehler könnten kommen wenn Du verschiedene Versionen laufen hast (Master/Slave ode rso) . Kann dass sein? Ggf bitte nochmal neu starten. Ich arbeite noch an einer nächsten version die da Dinge noch fixt.

                                Das andere mit Custom ich ansehen. Ist aktuell nicht bekannt. Kann es noch jemand nachvollziehen?

                                smartboartS Offline
                                smartboartS Offline
                                smartboart
                                schrieb am zuletzt editiert von
                                #773

                                @apollon77
                                hallo, hatte vorher nur states auf redis..Hab jetzt auch file auf redis umgestellt. Im Anschluss waren meine oben beschriebenen Fehler beseitigt.. Falls die Info hilfreich ist. Danke für eure tolle Arbeit!

                                1 Antwort Letzte Antwort
                                0
                                • smartboartS Offline
                                  smartboartS Offline
                                  smartboart
                                  schrieb am zuletzt editiert von smartboart
                                  #774

                                  Bei Adapter Updates habe ich folgende Gyp Fehler im Log.. oben wurde beschrieben es hat hier mit dem js controller nix zu tun . Meine Python Installation meldet bei
                                  apt-get install python-dev allerdings dass alles aktuell ist und nichts upzudaten wäre.. Die fehler haben keine Auswirkungen. mich würde trotzdem interessieren was die Ursache dafür ist...


                                  host.ioBroker-Rock 2019-10-14 19:39:11.291 info iobroker ERR! not ok
                                  host.ioBroker-Rock 2019-10-14 19:39:11.289 info iobroker gyp
                                  host.ioBroker-Rock 2019-10-14 19:39:11.277 info iobroker v3.8.0
                                  host.ioBroker-Rock 2019-10-14 19:39:11.274 info iobroker node -v v10.16.3gyp ERR! node-gyp -v
                                  host.ioBroker-Rock 2019-10-14 19:39:11.271 info iobroker cwd /opt/iobroker/node_modules/utf-8-validategyp ERR!
                                  host.ioBroker-Rock 2019-10-14 19:39:11.269 info iobroker ERR!
                                  host.ioBroker-Rock 2019-10-14 19:39:11.266 info iobroker "/usr/bin/node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"gyp
                                  host.ioBroker-Rock 2019-10-14 19:39:11.264 info iobroker ERR! command
                                  host.ioBroker-Rock 2019-10-14 19:39:11.261 info iobroker gyp
                                  host.ioBroker-Rock 2019-10-14 19:39:11.258 info iobroker at ChildProcess.onExit (/usr/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23)gyp ERR! stack at ChildProcess.emit (events.js:198:13)gyp ERR! stack at Process.Child
                                  host.ioBroker-Rock 2019-10-14 19:39:11.256 info iobroker stack
                                  host.ioBroker-Rock 2019-10-14 19:39:11.253 info iobroker ERR!
                                  host.ioBroker-Rock 2019-10-14 19:39:11.251 info iobroker Error: make failed with exit code: 2gyp
                                  host.ioBroker-Rock 2019-10-14 19:39:11.248 info iobroker stack
                                  host.ioBroker-Rock 2019-10-14 19:39:11.246 info iobroker ERR!
                                  host.ioBroker-Rock 2019-10-14 19:39:11.243 info iobroker gyp
                                  host.ioBroker-Rock 2019-10-14 19:39:11.240 info iobroker build error
                                  host.ioBroker-Rock 2019-10-14 19:39:11.238 info iobroker ERR!
                                  host.ioBroker-Rock 2019-10-14 19:39:11.236 info iobroker
                                  host.ioBroker-Rock 2019-10-14 19:39:11.233 info iobroker gyp

                                  apollon77A 1 Antwort Letzte Antwort
                                  0
                                  • ChaotC Offline
                                    ChaotC Offline
                                    Chaot
                                    schrieb am zuletzt editiert von
                                    #775

                                    Den ersten Härtetest hat das System heute schon hinter sich.
                                    Stromausfall und die USV war abgeschaltet :dizzy_face: weil ich den Batteriepack mit zur Arbeit hatte zum Austausch.
                                    Nach 30 Minuten fährt das System wieder hoch als wäre nichts geschehen. :blush:

                                    ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

                                    1 Antwort Letzte Antwort
                                    0
                                    • smartboartS smartboart

                                      Bei Adapter Updates habe ich folgende Gyp Fehler im Log.. oben wurde beschrieben es hat hier mit dem js controller nix zu tun . Meine Python Installation meldet bei
                                      apt-get install python-dev allerdings dass alles aktuell ist und nichts upzudaten wäre.. Die fehler haben keine Auswirkungen. mich würde trotzdem interessieren was die Ursache dafür ist...


                                      host.ioBroker-Rock 2019-10-14 19:39:11.291 info iobroker ERR! not ok
                                      host.ioBroker-Rock 2019-10-14 19:39:11.289 info iobroker gyp
                                      host.ioBroker-Rock 2019-10-14 19:39:11.277 info iobroker v3.8.0
                                      host.ioBroker-Rock 2019-10-14 19:39:11.274 info iobroker node -v v10.16.3gyp ERR! node-gyp -v
                                      host.ioBroker-Rock 2019-10-14 19:39:11.271 info iobroker cwd /opt/iobroker/node_modules/utf-8-validategyp ERR!
                                      host.ioBroker-Rock 2019-10-14 19:39:11.269 info iobroker ERR!
                                      host.ioBroker-Rock 2019-10-14 19:39:11.266 info iobroker "/usr/bin/node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"gyp
                                      host.ioBroker-Rock 2019-10-14 19:39:11.264 info iobroker ERR! command
                                      host.ioBroker-Rock 2019-10-14 19:39:11.261 info iobroker gyp
                                      host.ioBroker-Rock 2019-10-14 19:39:11.258 info iobroker at ChildProcess.onExit (/usr/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23)gyp ERR! stack at ChildProcess.emit (events.js:198:13)gyp ERR! stack at Process.Child
                                      host.ioBroker-Rock 2019-10-14 19:39:11.256 info iobroker stack
                                      host.ioBroker-Rock 2019-10-14 19:39:11.253 info iobroker ERR!
                                      host.ioBroker-Rock 2019-10-14 19:39:11.251 info iobroker Error: make failed with exit code: 2gyp
                                      host.ioBroker-Rock 2019-10-14 19:39:11.248 info iobroker stack
                                      host.ioBroker-Rock 2019-10-14 19:39:11.246 info iobroker ERR!
                                      host.ioBroker-Rock 2019-10-14 19:39:11.243 info iobroker gyp
                                      host.ioBroker-Rock 2019-10-14 19:39:11.240 info iobroker build error
                                      host.ioBroker-Rock 2019-10-14 19:39:11.238 info iobroker ERR!
                                      host.ioBroker-Rock 2019-10-14 19:39:11.236 info iobroker
                                      host.ioBroker-Rock 2019-10-14 19:39:11.233 info iobroker gyp

                                      apollon77A Offline
                                      apollon77A Offline
                                      apollon77
                                      schrieb am zuletzt editiert von
                                      #776

                                      @smartboart mehr log bitte

                                      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                      smartboartS 1 Antwort Letzte Antwort
                                      0
                                      • apollon77A Offline
                                        apollon77A Offline
                                        apollon77
                                        schrieb am zuletzt editiert von
                                        #777

                                        Hallo nochmals ich,

                                        ich habe mit das Reconnection Handling nochmal angesehen, weil es anders war wie gewollt.
                                        Die 2.0.30 auf GitHub hat das umgebaut.

                                        Ich wäre hier nochmal froh wenn Ihr checken könntet. Vor allem interessant ist das Verhalten von Slaves wenn der Master weg ist bzw. das verhalten des Gesamtsystems bei Redis-Nutzung wenn Redis weg ist.
                                        Mit der 2.0.30 wird bis zu ca. 40s versucht die Verbindung wieder herzustellen. Wenn das gelingt kommt das ganze ohne Restarts aus und auch aufgelaufene Datenänderungen (zB setState oder Infos zu State-Änderungen) werden nachgespielt.
                                        Wenn es länger braucht beenden sich die Adapter wie bisher und alles wartet das die DB wieder da ist.

                                        Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                        • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                        • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                        1 Antwort Letzte Antwort
                                        0
                                        • D Offline
                                          D Offline
                                          darkiop
                                          Most Active
                                          schrieb am zuletzt editiert von
                                          #778

                                          Habe beide auf die 2.0.30 gezogen.

                                          Beim installieren gab es ungewöhnlich viele Warnungen, die hatte ich vorher nicht - siehe Log. Beide laufen aber ohne Auffälligkeiten.

                                          iobroker-switch.sh 
                                          type '1.5' (latest) or '2.0' (from github)
                                          switch js-controller to: 2.0
                                          ioBroker is terminated ...
                                          Install js-controller 2.0.x ...
                                          
                                          > iobroker.js-controller@2.0.30 preinstall /opt/iobroker/node_modules/iobroker.js-controller
                                          > node lib/preinstallCheck.js
                                          
                                          NPM version: 6.9.0
                                          
                                          > unix-dgram@2.0.2 install /opt/iobroker/node_modules/unix-dgram
                                          > node-gyp rebuild
                                          
                                          make: Verzeichnis „/opt/iobroker/node_modules/unix-dgram/build“ wird betreten
                                            CXX(target) Release/obj.target/unix_dgram/src/unix_dgram.o
                                          ../src/unix_dgram.cc: In function ‘void {anonymous}::OnRecv({anonymous}::SocketContext*)’:
                                          ../src/unix_dgram.cc:121:25: warning: ‘v8::Local<v8::Value> Nan::MakeCallback(v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*)’ is deprecated [-Wdeprecated-declarations]
                                                               argv);
                                                                   ^
                                          In file included from ../src/unix_dgram.cc:5:0:
                                          ../../nan/nan.h:1024:46: note: declared here
                                             NAN_DEPRECATED inline v8::Local<v8::Value> MakeCallback(
                                                                                        ^~~~~~~~~~~~
                                          ../src/unix_dgram.cc: In function ‘void {anonymous}::OnWritable({anonymous}::SocketContext*)’:
                                          ../src/unix_dgram.cc:129:28: warning: ‘v8::Local<v8::Value> Nan::MakeCallback(v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*)’ is deprecated [-Wdeprecated-declarations]
                                                               0, NULL);
                                                                      ^
                                          In file included from ../src/unix_dgram.cc:5:0:
                                          ../../nan/nan.h:1024:46: note: declared here
                                             NAN_DEPRECATED inline v8::Local<v8::Value> MakeCallback(
                                                                                        ^~~~~~~~~~~~
                                          ../src/unix_dgram.cc: In function ‘Nan::NAN_METHOD_RETURN_TYPE {anonymous}::Socket(Nan::NAN_METHOD_ARGS_TYPE)’:
                                          ../src/unix_dgram.cc:189:37: warning: ‘int32_t v8::Value::Int32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             domain      = info[0]->Int32Value();
                                                                               ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2478:46: note: declared here
                                             V8_DEPRECATED("Use maybe version", int32_t Int32Value() const);
                                                                                        ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc:190:37: warning: ‘int32_t v8::Value::Int32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             type        = info[1]->Int32Value();
                                                                               ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2478:46: note: declared here
                                             V8_DEPRECATED("Use maybe version", int32_t Int32Value() const);
                                                                                        ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc:191:37: warning: ‘int32_t v8::Value::Int32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             protocol    = info[2]->Int32Value();
                                                                               ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2478:46: note: declared here
                                             V8_DEPRECATED("Use maybe version", int32_t Int32Value() const);
                                                                                        ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc: In function ‘Nan::NAN_METHOD_RETURN_TYPE {anonymous}::Bind(Nan::NAN_METHOD_ARGS_TYPE)’:
                                          ../src/unix_dgram.cc:230:28: warning: ‘int32_t v8::Value::Int32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             fd = info[0]->Int32Value();
                                                                      ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2478:46: note: declared here
                                             V8_DEPRECATED("Use maybe version", int32_t Int32Value() const);
                                                                                        ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc:231:33: warning: ‘v8::String::Utf8Value::Utf8Value(v8::Local<v8::Value>)’ is deprecated: Use Isolate version [-Wdeprecated-declarations]
                                             String::Utf8Value path(info[1]);
                                                                           ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2892:28: note: declared here
                                                             explicit Utf8Value(Local<v8::Value> obj));
                                                                      ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc: In function ‘Nan::NAN_METHOD_RETURN_TYPE {anonymous}::SendTo(Nan::NAN_METHOD_ARGS_TYPE)’:
                                          ../src/unix_dgram.cc:258:28: warning: ‘int32_t v8::Value::Int32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             fd = info[0]->Int32Value();
                                                                      ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2478:46: note: declared here
                                             V8_DEPRECATED("Use maybe version", int32_t Int32Value() const);
                                                                                        ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc:259:27: warning: ‘v8::Local<v8::Object> v8::Value::ToObject() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             buf = info[1]->ToObject();
                                                                     ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63:0,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:10046:15: note: declared here
                                           Local<Object> Value::ToObject() const {
                                                         ^~~~~
                                          ../src/unix_dgram.cc:260:33: warning: ‘uint32_t v8::Value::Uint32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             offset = info[2]->Uint32Value();
                                                                           ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2477:47: note: declared here
                                             V8_DEPRECATED("Use maybe version", uint32_t Uint32Value() const);
                                                                                         ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc:261:33: warning: ‘uint32_t v8::Value::Uint32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             length = info[3]->Uint32Value();
                                                                           ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2477:47: note: declared here
                                             V8_DEPRECATED("Use maybe version", uint32_t Uint32Value() const);
                                                                                         ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc:262:33: warning: ‘v8::String::Utf8Value::Utf8Value(v8::Local<v8::Value>)’ is deprecated: Use Isolate version [-Wdeprecated-declarations]
                                             String::Utf8Value path(info[4]);
                                                                           ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2892:28: note: declared here
                                                             explicit Utf8Value(Local<v8::Value> obj));
                                                                      ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc: In function ‘Nan::NAN_METHOD_RETURN_TYPE {anonymous}::Send(Nan::NAN_METHOD_ARGS_TYPE)’:
                                          ../src/unix_dgram.cc:302:28: warning: ‘int32_t v8::Value::Int32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             fd = info[0]->Int32Value();
                                                                      ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2478:46: note: declared here
                                             V8_DEPRECATED("Use maybe version", int32_t Int32Value() const);
                                                                                        ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc:303:27: warning: ‘v8::Local<v8::Object> v8::Value::ToObject() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             buf = info[1]->ToObject();
                                                                     ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63:0,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:10046:15: note: declared here
                                           Local<Object> Value::ToObject() const {
                                                         ^~~~~
                                          ../src/unix_dgram.cc: In function ‘Nan::NAN_METHOD_RETURN_TYPE {anonymous}::Connect(Nan::NAN_METHOD_ARGS_TYPE)’:
                                          ../src/unix_dgram.cc:340:28: warning: ‘int32_t v8::Value::Int32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             fd = info[0]->Int32Value();
                                                                      ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2478:46: note: declared here
                                             V8_DEPRECATED("Use maybe version", int32_t Int32Value() const);
                                                                                        ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc:341:33: warning: ‘v8::String::Utf8Value::Utf8Value(v8::Local<v8::Value>)’ is deprecated: Use Isolate version [-Wdeprecated-declarations]
                                             String::Utf8Value path(info[1]);
                                                                           ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2892:28: note: declared here
                                                             explicit Utf8Value(Local<v8::Value> obj));
                                                                      ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                          ../src/unix_dgram.cc: In function ‘Nan::NAN_METHOD_RETURN_TYPE {anonymous}::Close(Nan::NAN_METHOD_ARGS_TYPE)’:
                                          ../src/unix_dgram.cc:361:28: warning: ‘int32_t v8::Value::Int32Value() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                                             fd = info[0]->Int32Value();
                                                                      ^
                                          In file included from /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:26:0,
                                                           from /home/iobroker/.node-gyp/10.16.3/include/node/node.h:63,
                                                           from ../../nan/nan.h:54,
                                                           from ../src/unix_dgram.cc:5:
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8.h:2478:46: note: declared here
                                             V8_DEPRECATED("Use maybe version", int32_t Int32Value() const);
                                                                                        ^
                                          /home/iobroker/.node-gyp/10.16.3/include/node/v8config.h:324:3: note: in definition of macro ‘V8_DEPRECATED’
                                             declarator __attribute__((deprecated(message)))
                                             ^~~~~~~~~~
                                            SOLINK_MODULE(target) Release/obj.target/unix_dgram.node
                                            COPY Release/unix_dgram.node
                                          make: Verzeichnis „/opt/iobroker/node_modules/unix-dgram/build“ wird verlassen
                                          
                                          > iobroker.js-controller@2.0.30 install /opt/iobroker/node_modules/iobroker.js-controller
                                          > node iobroker.js setup first
                                          
                                          npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@2.1.1 (node_modules/fsevents):
                                          npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.1.1: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
                                          npm WARN optional SKIPPING OPTIONAL DEPENDENCY: osx-temperature-sensor@1.0.4 (node_modules/osx-temperature-sensor):
                                          npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for osx-temperature-sensor@1.0.4: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
                                          
                                          + iobroker.js-controller@2.0.30
                                          updated 4 packages and audited 35156 packages in 96.546s
                                          found 52 vulnerabilities (40 low, 12 high)
                                            run `npm audit fix` to fix them, or `npm audit` for details
                                          ioBroker will be started ...
                                          Starting iobroker controller daemon...
                                          iobroker controller daemon started. PID: 20872
                                          ┬─[root@iobroker-master:/opt/iobroker]─[10:16:27]
                                          ╰─># 
                                          

                                          Proxmox-ioBroker-Redis-HA Doku: https://forum.iobroker.net/topic/47478/dokumentation-einer-proxmox-iobroker-redis-ha-umgebung

                                          apollon77A 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          755

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe