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

  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.4k

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

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

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

Geplant Angeheftet Gesperrt Verschoben Tester
js-controller
1.0k Beiträge 48 Kommentatoren 315.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

    Hallo nochmals,

    Falls jemand noch Zeit und Lust hat. Auf Github ist die 2.0.26 mit den Kleinigkeiten die aufgefallen sind. Release im Latest geplant für heute abend/morgen.

    Installation wie bisher hier üblich direkt per npm.

    2.0.26 Release Bella

    • (Apollon77) Make sure Logs are only streamed to admin for selected loglevel
    • (Apollon77) Fix "iobroker file write"
    • (Apollon77) Make sure invalid ids are handled correctly without throwing errors
    • (bluefox) Add alias.0 as object to be added
    • (bluefox) Allow Arrays as state values
    • (bluefox) Translate object names
    sigi234S Online
    sigi234S Online
    sigi234
    Forum Testing Most Active
    schrieb am zuletzt editiert von
    #748

    @apollon77

    Screenshot (258).png :grinning:

    Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
    Immer Daten sichern!

    1 Antwort Letzte Antwort
    1
    • D Offline
      D Offline
      darkiop
      Most Active
      schrieb am zuletzt editiert von
      #749

      Habs eben installiert und check heut Abend wann wir wieder zuhause sind das Log :)

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

      1 Antwort Letzte Antwort
      0
      • liv-in-skyL Offline
        liv-in-skyL Offline
        liv-in-sky
        schrieb am zuletzt editiert von
        #750

        js-controller 2.0.25 startet - bisher keine fehler

        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

        1 Antwort Letzte Antwort
        0
        • BBTownB Offline
          BBTownB Offline
          BBTown
          schrieb am zuletzt editiert von
          #751

          @apollon77 hast Du gleich noch eine v2.0.27 nachgeschoben?

          ioBroker auf NUC (VM debian v13 (Trixie ), node v22.21.0 npm v10.9.4, js-controller v7.0.7 jsonl/jsonl / HomeMatic CCU-2 (Wired und Funk) / Philips HUE / echo.DOT / Broadlink RM pro / SONOS

          1 Antwort Letzte Antwort
          0
          • apollon77A Offline
            apollon77A Offline
            apollon77
            schrieb am zuletzt editiert von
            #752

            Ja und gerade noch 2.0.28. sind jetzt bei den echten Edge cases angelangt ;-)

            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
            L E 2 Antworten Letzte Antwort
            0
            • BBTownB Offline
              BBTownB Offline
              BBTown
              schrieb am zuletzt editiert von
              #753

              @apollon77
              Respekt ... Privatleben wird auch total überschätzt :sunglasses:

              ioBroker auf NUC (VM debian v13 (Trixie ), node v22.21.0 npm v10.9.4, js-controller v7.0.7 jsonl/jsonl / HomeMatic CCU-2 (Wired und Funk) / Philips HUE / echo.DOT / Broadlink RM pro / SONOS

              1 Antwort Letzte Antwort
              0
              • crunchipC Abwesend
                crunchipC Abwesend
                crunchip
                Forum Testing Most Active
                schrieb am zuletzt editiert von
                #754

                @apollon77 also dann hier nochmal wegen dem log
                da ja vorher diverse Adapter nicht mit der entsprechenden Logstufe funktionierten, habe ich nun mal bei sämtlichen Adaptern, die auf warn/error standen wieder auf Info gestellt.
                Betroffen waren der Web, Chromcast, virtualpowermeter, die das log "zugemüllt" hatten
                desweiteren, wurde z.b beim virtualpowermeter in der .25 Version trotz ändern der logstufe das log zugemüllt.
                in der .28 stehen nun bei mir alle Adapter auf Logstufe Info und log verhält sich sehr, sehr ruhig,
                fast nur noch Meldungen, wenn z.b. Adapter per cron aktualisieren

                umgestiegen von Proxmox auf Unraid

                apollon77A 1 Antwort Letzte Antwort
                0
                • apollon77A apollon77

                  Ja und gerade noch 2.0.28. sind jetzt bei den echten Edge cases angelangt ;-)

                  L Offline
                  L Offline
                  lonsimbt
                  schrieb am zuletzt editiert von
                  #755

                  @apollon77

                  2.0.28 konnte ich problemlos installieren. Ich musste allerdings anschließend den Installations-Fixer drüberlaufen lassen wegen einiger Berechtigungsprobleme. Danach startet das System ohne Auffälligkeiten im Log.

                  Gruß Marco

                  iobroker im Container (debian Bullseye) unter proxmox 7.1
                  debmatic in VM (debian Buster) unter proxmox 7.1 mit HB-RF-USB und RPI-RF-MOD
                  40 HomeMatic Geräte, Phillips Hue, Ikea Tradfri, Logitech Harmony Hub, Botvac Connected, Robonect

                  1 Antwort Letzte Antwort
                  0
                  • apollon77A apollon77

                    Ja und gerade noch 2.0.28. sind jetzt bei den echten Edge cases angelangt ;-)

                    E Offline
                    E Offline
                    e-s
                    schrieb am zuletzt editiert von e-s
                    #756

                    @apollon77
                    Ist zwar etwas offtopic, aber mir fällt in letzter Zeit extrem oft auf das User Nodejs und node nicht gleichzeitig schaffen zu updaten. Ich glaube viele User haben starke Probleme deswegen, weil eben noch node 6 genutzt wird. Deswegen laufen viele Sachen nicht mehr.
                    Könnte man dies irgendwie anfangen und eben die aptget Befehle für was update als Fehlermeldung anzeigen lassen?

                    Habe es bewusst aber hier geschrieben obwohl andere threads gemeint sind.

                    apollon77A 1 Antwort Letzte Antwort
                    0
                    • crunchipC crunchip

                      @apollon77 also dann hier nochmal wegen dem log
                      da ja vorher diverse Adapter nicht mit der entsprechenden Logstufe funktionierten, habe ich nun mal bei sämtlichen Adaptern, die auf warn/error standen wieder auf Info gestellt.
                      Betroffen waren der Web, Chromcast, virtualpowermeter, die das log "zugemüllt" hatten
                      desweiteren, wurde z.b beim virtualpowermeter in der .25 Version trotz ändern der logstufe das log zugemüllt.
                      in der .28 stehen nun bei mir alle Adapter auf Logstufe Info und log verhält sich sehr, sehr ruhig,
                      fast nur noch Meldungen, wenn z.b. Adapter per cron aktualisieren

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

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

                      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 2 Antworten Letzte Antwort
                      0
                      • E e-s

                        @apollon77
                        Ist zwar etwas offtopic, aber mir fällt in letzter Zeit extrem oft auf das User Nodejs und node nicht gleichzeitig schaffen zu updaten. Ich glaube viele User haben starke Probleme deswegen, weil eben noch node 6 genutzt wird. Deswegen laufen viele Sachen nicht mehr.
                        Könnte man dies irgendwie anfangen und eben die aptget Befehle für was update als Fehlermeldung anzeigen lassen?

                        Habe es bewusst aber hier geschrieben obwohl andere threads gemeint sind.

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

                        @e-s das ist nicht sei neuestem. Und auch keine Ahnung woher das kommt. Sollte an sich nie vorkommen. Aber ... naja

                        Ich hab gerade keine Idee wie man das absichern soll. Vor allem weil das keine Standard Dinge sein können. Irgendwas ist also bei denen vermurkst und das zu fixen ist ggf bei jedem anders

                        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
                          #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
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          639

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          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