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. Skripten / Logik
  4. Ical-Einträge teilen?

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.2k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Ical-Einträge teilen?

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
35 Beiträge 5 Kommentatoren 3.7k Aufrufe
  • Ä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.
  • AlCalzoneA Offline
    AlCalzoneA Offline
    AlCalzone
    Developer
    schrieb am zuletzt editiert von
    #18

    Das ist korrekt, dazu muss das Regex und die Auswertung der Matches angepasst werden. Komme ich heute nicht mehr dazu, ich melde mich morgen.

    Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

    1 Antwort Letzte Antwort
    0
    • AlCalzoneA Offline
      AlCalzoneA Offline
      AlCalzone
      Developer
      schrieb am zuletzt editiert von
      #19

      Hier das vollständige Skript:

      var html = ...;
      
      var regex = /^.+color:\s?([#0-9A-Za-z]+).+(ical[a-zA-Z]+).\>([^\<]+).+color:(#[0-9a-zA-Z]+).+ical[a-zA-Z0-9]+.\>\s?([^\<]+).+$/gm
      
      // Alle Termine finden
      var results = [];
      var match;
      // und Details auslesen
      while (match = regex.exec(html)) {
          results.push({
              farbe: match[1],
              kalender: match[4],
              datum: match[3],
              name: match[5],
              stufe: match[2]
          });
      }
      
      var kalender = {};
      if (results.length)
        kalender = results.reduce(function (gruppiert, termin) {
            // Kalender dieser Farbe intialisieren, wenn nicht schon geschehen
            if (!gruppiert[termin.kalender]) gruppiert[termin.kalender] = [];
      
            // Termin hinzufügen
            gruppiert[termin.kalender].push({
                name: termin.name,
                stufe: termin.stufe,
                datum: termin.datum,
                farbe: termin.farbe
            });
      
            // Sammlerobjekt zurückgeben für den nächsten Aufruf
            return gruppiert;
        }, {});
      
      function toHtml(kalender) {
          if (! (kalender && kalender.length)) return "";
          return kalender.reduce(function(html, termin) {
              if (html != "") html += "
      \n";
              html += '' + termin.datum + '' + 
                  '' + termin.name + '';
              return html;
          }, "");
      }
      
      

      Beispielausgabe:

      toHtml(kalender["#00FF00"]);
      
      liefert:
      
      In 3 Tagen 16:15-17:45Test 3
      
      In 5 Tagen 16:15-17:45Test 4
      
      

      Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

      1 Antwort Letzte Antwort
      0
      • Lenny.CBL Offline
        Lenny.CBL Offline
        Lenny.CB
        Most Active
        schrieb am zuletzt editiert von
        #20

        Hallo zusammen,

        eben festgestellt, dass das Script keine Ergebnisse mehr bringt.

        Habe mal versucht mit den Daten von "ical.1.data.html" im online-regex-Tester zu spielen.

        Dabei ist mir aufgefallen, dass der Zeilenumbruch fehlt. Setze ich nach dem
        im Tester ein "Enter" werden auch wieder alle Einträge lt. Suche korrekt gefunden.

        Wurde hier was in die Richtung am ical-Adapter geändert. Habe versucht das auf GIT nachzuvollziehen, sehe da aber leider mit den vielen Versionen nicht durch.

        1 Antwort Letzte Antwort
        0
        • Lenny.CBL Offline
          Lenny.CBL Offline
          Lenny.CB
          Most Active
          schrieb am zuletzt editiert von
          #21

          @ Apollon77: kann das mit deinen Änderungen am Adapter zu tun haben?

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

            Das kann sehr gut sein. Das html war an einigen Stellen fehlerhaft und das wurde irgendwann gefixt.

            Die Idee das html zu parsen ist auch nicht wirklich ideal ;-)

            Jetzt exakt Forensik zu betreiben wann ich da was geändert habe was mit der regex kollidiert wäre mühsehlig ;-(

            Option A: passt die regex an. Ich verspreche aber nicht das eine künftige Optimierung der html Darstellung bzw für vis das wieder ändert!

            Option B: nehmt, wie sinnvoller, die Data.table als json Objekt als Grundlage für eine skriptuelle Verarbeitung ;-)

            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
            • Lenny.CBL Offline
              Lenny.CBL Offline
              Lenny.CB
              Most Active
              schrieb am zuletzt editiert von
              #23

              @apollon77:

              Option B: nehmt, wie sinnvoller, die Data.table als json Objekt als Grundlage für eine skriptuelle Verarbeitung ;-) `
              Habe befürchtet das sowas kommt. Das war der Zauber mit JSON.stringify….. richtig?

              Oder gibt es vielleicht schon was Fertiges? :-)

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

                In dem Fall

                var data = JSON.parse(getState(„ical.0.data.table“).val);

                Und dann hast du es schon.

                Ausgabe strukturiert danach:

                console.log(JSON.stringify(data,NULL,2));

                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
                • Lenny.CBL Offline
                  Lenny.CBL Offline
                  Lenny.CB
                  Most Active
                  schrieb am zuletzt editiert von
                  #25

                  so hatte ich auch angefangen. Da kamen dann schon die Fehler…

                  blöderweise steige ich bei javascript immer noch nicht durch... :oops:

                  var data = JSON.parse(getState("ical.1.data.table").val);
                  console.log(JSON.stringify(data,NULL,2));
                  
                  javascript.1	2018-05-24 07:09:03.755	error	at ContextifyScript.Script.runInContext (vm.js:35:29)
                  javascript.1	2018-05-24 07:09:03.755	error	at script.js.Skript1:11:17
                  javascript.1	2018-05-24 07:09:03.754	error	at Object.parse (native)
                  javascript.1	2018-05-24 07:09:03.754	error	SyntaxError: Unexpected token o in JSON at position 1
                  javascript.1	2018-05-24 07:09:03.754	error	^
                  javascript.1	2018-05-24 07:09:03.754	error	[object Object],[object Object],[object Object],[object Object]
                  javascript.1	2018-05-24 07:09:03.753	error	script.js.Skript1: undefined:1
                  
                  1 Antwort Letzte Antwort
                  0
                  • apollon77A Offline
                    apollon77A Offline
                    apollon77
                    schrieb am zuletzt editiert von
                    #26

                    Was ist denn in deinem Skript in Zeile 11?! Oder hast du globale Skripte noch? Scheinbar sieht das json komisch aus.

                    Gib den Wert doch mal vor dem json. Parse aus

                    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
                    • Lenny.CBL Offline
                      Lenny.CBL Offline
                      Lenny.CB
                      Most Active
                      schrieb am zuletzt editiert von
                      #27

                      @apollon77:

                      Was ist denn in deinem Skript in Zeile 11?! `
                      Zeile 11 gibt es nicht. Das ursprüngliche Script ist gestoppt. Ich hatte in einem "Testscript" nur deine beiden Zeilen drin. Wollte mal im Log schauen was dabei rum kommt und mir mit "copy & paste" im "try a& error"-Modus was zusammen frickeln.

                      var data = JSON.parse(getState("ical.1.data.table").val);
                      console.log(JSON.stringify(data,NULL,2));
                      

                      @apollon77:

                      Oder hast du globale Skripte noch? ` Nein, nichts unter common, nichts unter global.
                      @apollon77:

                      Scheinbar sieht das json komisch aus. ` Jupp, denke ich auch.
                      @apollon77:

                      Gib den Wert doch mal vor dem json. Parse aus ` Oh Gott ich hoffe du schlägst mich jetzt nicht… Wie mache ich das? :shock:

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

                        console.log(getState(„ical.1.data.table“).val);

                        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
                        • Lenny.CBL Offline
                          Lenny.CBL Offline
                          Lenny.CB
                          Most Active
                          schrieb am zuletzt editiert von
                          #29

                          @apollon77:

                          console.log(getState(„ical.1.data.table“).val); ` kommt das bei rum…````
                          javascript.1 2018-05-24 15:41:08.401 info script.js.Skript1: registered 0 subscriptions and 0 schedules
                          javascript.1 2018-05-24 15:41:08.400 info script.js.Skript1: [object Object],[object Object],[object Object],[object Object]
                          javascript.1 2018-05-24 15:41:08.391 info Start javascript script.js.Skript1
                          javascript.1 2018-05-24 15:41:08.361 info Stop script script.js.Skript1

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

                            Hm … mach mal

                            console.log(JSON.stringify(getState(...).val, NULL, 2);

                            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
                            • Lenny.CBL Offline
                              Lenny.CBL Offline
                              Lenny.CB
                              Most Active
                              schrieb am zuletzt editiert von
                              #31

                              @apollon77:

                              Hm … mach mal

                              console.log(JSON.stringify(getState(...).val, NULL, 2); ` hatte beim Einfügen einen Fehler. Habe dann vor dem ";" noch eine ")" gesetzt

                              console.log(JSON.stringify(getState('ical.1.data.table').val, NULL, 2));
                              

                              Ergebnis:````
                              javascript.1 2018-05-24 17:28:02.652 error at ContextifyScript.Script.runInContext (vm.js:35:29)
                              javascript.1 2018-05-24 17:28:02.652 error at script.js.Skript1:15:63
                              javascript.1 2018-05-24 17:28:02.651 error ReferenceError: NULL is not defined
                              javascript.1 2018-05-24 17:28:02.651 error ^
                              javascript.1 2018-05-24 17:28:02.650 error console.log(JSON.stringify(getState('ical.1.data.table').val, NULL, 2));
                              javascript.1 2018-05-24 17:28:02.650 error script.js.Skript1: script.js.Skript1:15
                              javascript.1 2018-05-24 17:28:02.620 info Start javascript script.js.Skript1

                              Achso, "Skript1:15:63" kommt desswegen, weil ich die anderen "Versuche" immer auskommentiere.
                              1 Antwort Letzte Antwort
                              0
                              • apollon77A Offline
                                apollon77A Offline
                                apollon77
                                schrieb am zuletzt editiert von
                                #32

                                Schreib null mal klein. Mist

                                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
                                • Lenny.CBL Offline
                                  Lenny.CBL Offline
                                  Lenny.CB
                                  Most Active
                                  schrieb am zuletzt editiert von
                                  #33

                                  @apollon77:

                                  Schreib null mal klein. Mist ` das schaut besser aus… (ich habe mal alles persönliche mit "xxxxx" ersetzt.

                                  ! javascript.1 2018-05-25 07:54:09.016 info script.js.Skript1: registered 0 subscriptions and 0 schedules
                                  ! javascript.1 2018-05-25 07:54:09.016 info ]
                                  ! javascript.1 2018-05-25 07:54:09.016 info }
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineC"
                                  ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-31T15:10:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-31T14:40:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineC ical_6days",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "date": "In 6 Tagen 16:40-17:10",
                                  ! javascript.1 2018-05-25 07:54:09.016 info {
                                  ! javascript.1 2018-05-25 07:54:09.016 info },
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineC"
                                  ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-29T16:00:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-29T15:30:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineC ical_4days",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "date": "In 4 Tagen 17:30-18:00",
                                  ! javascript.1 2018-05-25 07:54:09.016 info {
                                  ! javascript.1 2018-05-25 07:54:09.016 info },
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineS"
                                  ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-28T15:00:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-28T12:00:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineS ical_3days",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "date": "In 3 Tagen 14:00-17:00",
                                  ! javascript.1 2018-05-25 07:54:09.016 info {
                                  ! javascript.1 2018-05-25 07:54:09.016 info },
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineS"
                                  ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-28T07:00:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-28T06:00:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineS ical_3days",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "date": "In 3 Tagen 08:00-09:00",
                                  ! javascript.1 2018-05-25 07:54:09.016 info {
                                  ! javascript.1 2018-05-25 07:54:09.016 info },
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_calName": "TermineS"
                                  ! javascript.1 2018-05-25 07:54:09.016 info "location": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_rule": " ",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_allDay": false,
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_IDID": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.com",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_section": "",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_end": "2018-05-25T12:00:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_date": "2018-05-23T06:00:00.000Z",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "_class": "ical_TermineS ical_today",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "event": "xxxxxxxxxxxxxxx",
                                  ! javascript.1 2018-05-25 07:54:09.016 info "date": "Noch 6 Stunden",
                                  ! javascript.1 2018-05-25 07:54:09.016 info {
                                  ! javascript.1 2018-05-25 07:54:09.016 info script.js.Skript1: [
                                  ! javascript.1 2018-05-25 07:54:08.987 info Start javascript script.js.Skript1
                                  ! javascript.1 2018-05-25 07:54:08.961 info Stop script script.js.Skript1

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

                                    Dann kannst du es direkt nutzen. Brauchst kein parse. In de log Ausgabe siehst du was so drin 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
                                    • Lenny.CBL Offline
                                      Lenny.CBL Offline
                                      Lenny.CB
                                      Most Active
                                      schrieb am zuletzt editiert von
                                      #35

                                      @apollon77:

                                      Dann kannst du es direkt nutzen. Brauchst kein parse. In de log Ausgabe siehst du was so drin ist. ` Dank dir erst einmal… Mal schauen ob ich da was hinbekomme...

                                      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

                                      430

                                      Online

                                      32.7k

                                      Benutzer

                                      82.3k

                                      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