NEWS
Test/Support für Adapter rssfeed und vis-2-widgets-rssfeed
-
Unter Abteilung Tester konnte ich kein Topic anlegen. Bitte dort hin verschieben.
Nachdem ich immer weider lese, wie sich die Leute mit rss-Feeds abmühen,
habe ich einen Adapter dazu geschrieben.
Dieser hat aktuell minimale Fähigkeiten, man kann damit aber
schon annehmbare Ergebnisse erzielen.Verwendete Bausteine
Um die Flexibilität bei der Anzeige der Feeds bieten zu können, erfolgt die Formatierung der Ausgabe
über ein template-system.
Eine Vorlage werde ich hier weiter unten kopieren.
Beschreibung der Formatierung und Syntax finden sich auf den folgenden Seiten
https://ejs.co/ und https://github.com/mde/ejsEinlesen der Feeds.
Dazu verwende ich ein node modul namens feedparser.
Dieses Modul kann verschiedene RSS-Standards (RSS, Atom, and RDF).
Dazu ist er noch dazu in der Lage, die Attribute zu normalisieren, so das es in der Ausgabe egal ist,
wie der jeweilige Standard ein bestimmtes Feld nennt.
https://github.com/danmactough/node-feedparserInstallation und Einrichtung
Schritt 1 - Installation
Der Adapter ist aktuell nur auf github verfügbar.
Name des Repository ist https://github.com/oweitman/iobroker.rssfeedSchritt 2 - Instanz hinzufügen
Der Adapter müsste dann im Abschnitt adapter im iobroker angezeigt werden.
Manchmal kommt es vor, das insbesondere bei Webänderungen (Widgets/Konfigurationsdialog) die Änderungen nicht sichtbar sind, muss evtl. auf der Kommandozeile folgender Befehl ausgeführt werden:
iobroker upload rssfeed
Im rechten Bereich in der Zeile des Adapters kann über den Plus-Knopf eine Instanz hinzugefügt werdenSchritt 3 - Konfiguration
Die Konfiguration ist relativ simpel. Es gibt nur wenige Felder
Refresh: ist die generelle Vorgabe, wie oft in Minuten der Feed neu abgerufen werden soll. Voreinstellung ist 60
Maximale Artikel im Datenpunkt: Hier kann die Gesamtmenge der zu verarbeitenden Daten begrenz werden.Dann je neuen Feed:
Name: Ein eindeutiger Name, darf nicht doppelt vorkommen
Url: Die vollständige Adresse des Feed (mit http:// oder https://)
Refresh: Bei Erfassung kann ein abweichender Wert angegeben werden. Ansonsten wird die generelle Vorgabe genommenNach Neustart und Abruf der Daten ist der Feed als JSON-Datenpunkt im Objektbaum zu finden.
Schritt 4 - vis und widgets
Um die Feeds anzuzeigen gibt es ein widget. Dieses kann über den Suchfilter in vis mittels rssfeed gefunden werden.
Das widget hat folgende Einstellmöglichkeiten
rss_oid Hier wird der JSON-Datenpunkt des gewünschten feeds ausgewählt. Ich habe festgestellt, das der Objektbrowser hier nicht imnmer zufriedenstellend funktioniert, da er die im JSON enthaltenen HTML-Anteile versucht dazustellen.
Alternativ die Datenpunkt ID direkt aus vis kopieren.
template: Hier kann ein template erfasst werden, welches javascript und html gemischt enthalten kann.maxarticles: Hier kann widget individuell die Anzahl der Artikel begrenzt werden.
Alle anderen Einstellungen sind identisch zu den anderen widgets, Die Formatvorgaben gellten generell für alle widgetinhalte
Die widgets rssfeed Meta helper und rssfeed Article helper unterstützen bei der Erstellung eines Templates,
indem dort komfortabel die meta-Informationen und die Attribute eines Artikels angezeigt werden.
Im widget rssfeed Article Helper kann man den Artikel auswählen, dessen Attribute angezeigt werden soll, sowie das Präfix anpassen, so dass es einfacher ist dieses in das Template zu kopieren.Ein weiteres widget hat nichts direkt mir rssfeed zu tun und ist in diesem adapter voraussichtlich temporär zu Gast.
Template anhand von Beispielen
Ein Beispiel, welches ich mit den folgenden RSS Feeds getestet habe:<%= meta.title %> <% articles.forEach(function(item){ %> <p><small><%- vis.formatDate(item.pubdate, "TT.MM.JJJJ SS:mm") %></small></p> <h3><%- item.title %></h3> <p><%- item.description %></p> <div style="clear:both;" /> <% }); %>Das Templatesystem arbeitet mit bestimmten Tags.
Die verwendeten Tags bedeuten das folgenden
<%= Der Inhalt des enthaltenen Ausdrucks/Variable wird escaped ausgegenen.
<%- Der Inhalt des enthaltenen Ausdrucks/Variable wird unescaped ausgegenen.
<% Tag ohne Ausgabe, wird für javascriptanweisungen verwendet
%> ist generell ein schließender Tag um eines der vorherigen abzuschließen
Alles was außerhalb dieser Tags ist, wird genau so dann angezeigt bzw. wenn es HTML ist als HTML interpretiert ausgegeben. (siehe bspw das p-tag,div-tag,small-tagInnerhalb des Templates habt ihr 2 vorgegebene variablen zur Verfügung
meta: Hier sind alle Metainformationen zum Feed enthalten. Die folgenden Inhalte stehen zur Verfügung. Ich denke die Bezeichner sind selbst erklärend. In der Hilfe werde ich diese noch genauer Beschreiben. bzw den Inhalt spezifizieren (manche sind Arrays)
meta.title
meta.description
meta.link
meta.xmlurl
meta.date
meta.pubdate
meta.author
meta.language
meta.image
meta.favicon
meta.copyright
meta.generator
meta.categoriesarticles: Ist ein Array mit einzelnen Elementen (javascript array). Jedes Element hat die folgenden Eigenschaften.
Damit es zum Beispiel passt mache ich hier mal das Prefix item davor. Aber wenn ihr wollt könnt ihr das selbst wählen. Es muss dann nur in der Schleife (forEach) entsprechend benannt werden. Auch hjier sind die Bezeichner erst einmal selbst erklärend. Nicht in jedem Feed sind alle attribute auch gefüllt. Die wichtigsten sind im obigen Template bereits enthalten.item.title
item.description
item.summary
item.link
item.origlink
item.permalink
item.date
item.pubdate
item.author
item.guid
item.comments
item.image
item.categories
item.source
item.enclosures"<%= meta.title %> <% articles.forEach(function(item){ %> <p><small><%- vis.formatDate(item.pubdate, "TT.MM.JJJJ SS:mm") %></small></p> <h3><%- item.title %></h3> <p><%- item.description %></p> <div style="clear:both;" /> <% }); %>Kurze Beschreibung was in den einzelnen Zeilen passiert
Z1: Der Feed-titel wird ausgegeben
Z2: Ohne Ausgabe. Schleife über alle articles, bei jedem Durchgang wird das aktuelle Element der variable item zugewiesen.
Z3: Datum und Uhrzeit wird ausgegeben und wird in einem p/small-Tag eingeschlossen zur Formatierung. Zur Formatierung wird die vis-eigene Datumsformatfunktion verwendet. Beschreibung ist im adapter vis zu finden.
Z4: Der Titel des Artikels wird ausgegeben. Zur Formatierung wird der Tag für Überschrift 3 verwendet
Z5: Der Inhalt des Artikels wird ausgegeben und in einem p-Tag eingeschlossen. Hier ist, zumindest bei den beiden Beispielen, HTML-code enthalten, der meist ein Bild, sowie beschreibenden Text mitbringt
Z6: Ein div-Tag, das ausgegeben werden muss, um eine spezielle Formatierung im Feed wieder aufzuheben.
Z7: Ohne Ausgabe. Hier wird die Schleife geschlossen. Alles was zwischen Z2 und Z7 definiert wurde, wird für jeden einzelnen Artikel wiederholt.Ich freue mich über reges testen und Vorschlag von Erweiterungen.
Fehler können hier, aber auch auf github https://github.com/oweitman/ioBroker.rssfeed
gemeldet werden.Hallo, ist es möglich die Schriftfarbe bei item.title in Abhängigkeit vom Text zu ändern? bindings?
Also item.title = Das Wort Türöffnung kommt vor = dann Farbe GELB
= Das Wort Brand kommt vor = dann Farbe ROT
= Das Wort Technischer Einsatz kommt vor = dann Farbe BLAU
= Das Wort Sturm kommt vor = dann Farbe GRÜNDerzeitiges Template:
<h4><meta.title style="color:#a9a7a7"><%- meta.title %></h4> <img src="<%- meta.image.url %>"> <% articles.forEach(function(item){ %> <p><item.pubdate style="color:Orange">Veröffentlichungsdatum: <%- vis.formatDate(item.pubdate, "TT.MM.JJJJ SS:mm")%> Uhr</p> <h3><item.title style="color:lime"><%- item.title %></h3> <p><%- item.description %></p> <div style="clear:both;" /> <% }); %>
-
-
Wie macht ihr das mit der Laufschrift ?
Ich möchte nur den Einzeiler, und das als Laufschrift.
maxarticles
-
echt ein super Adapter, schade dass man das ganze nur einmal liken kann.
Hallo an alle.
die templates sind noch nicht ganz meine Freunde, vielleicht kann mir ja von euch jemand helfen.
Ich versuche mich gerade an folgenden rss-feed:
https://www.hoerzu.de/rss/tipp/spielfilm/
Nun möchte ich folgendes realisieren:
- Oben Anzeige der Sendezeit
- Ein Bild der Sendung anzeigen lassen
- Den eingefügten Link aktive schalten
Ist das möglich und wenn ja, wie?


-
Hallo,
super spannender Adapter, habe ich mir schon lange gewünscht :)
Ich möchte das gerne als Newsticker nutzen, daher dachte ich das Widget Marquee ist das Richtige für mich. Jedoch wenn ich die rss_oid auswähle passiert in der View anschließend nichts, es ist einfach nichts zu sehen.
Vermutlich hab ich nur irgendwas übersehen aber vielleicht kann mir jemand auf die Sprünge helfen?

-
Hallo,
super spannender Adapter, habe ich mir schon lange gewünscht :)
Ich möchte das gerne als Newsticker nutzen, daher dachte ich das Widget Marquee ist das Richtige für mich. Jedoch wenn ich die rss_oid auswähle passiert in der View anschließend nichts, es ist einfach nichts zu sehen.
Vermutlich hab ich nur irgendwas übersehen aber vielleicht kann mir jemand auf die Sprünge helfen?

-
Hallo,
super spannender Adapter, habe ich mir schon lange gewünscht :)
Ich möchte das gerne als Newsticker nutzen, daher dachte ich das Widget Marquee ist das Richtige für mich. Jedoch wenn ich die rss_oid auswähle passiert in der View anschließend nichts, es ist einfach nichts zu sehen.
Vermutlich hab ich nur irgendwas übersehen aber vielleicht kann mir jemand auf die Sprünge helfen?

-
@skokarl ja im "normalen" Feed Widget mit dem Template aus dem Eingangsbeitrag hier erscheint was.

-
ja, sieht bisschen anders aus aber ich hab keine idee warum...Adapter 0.0.15 gerade nochmal frisch installiert, Upload Vis gemacht und trotzdem sieht mein Widget immernoch so aus...keine Ahnung warum
-
@skokarl hab ich....unabhängig von dem anders aussehendem Widget funktioniert es jetzt...Umschaltdauer steht bei mir ja noch (ms) dahinter, da war die Zahl einfach zu groß...mit der 120 wie bei dir funktioniert es jetzt...allerdings ist mir nicht ganz klar was die genau macht...6000 sind ja 6 Sekunden, ich ging davon aus das es bedeutet das nach 6 Sekunden der Text von vorne beginnt...und da wären 120ms ein wenig kurz...aber vermutlich habe ich das oben irgendwo nicht richtig gelesen...jedenfalls bewegt sich die Schrift schonmal, immerhin ein Anfang ;-)
-
@skokarl hab ich....unabhängig von dem anders aussehendem Widget funktioniert es jetzt...Umschaltdauer steht bei mir ja noch (ms) dahinter, da war die Zahl einfach zu groß...mit der 120 wie bei dir funktioniert es jetzt...allerdings ist mir nicht ganz klar was die genau macht...6000 sind ja 6 Sekunden, ich ging davon aus das es bedeutet das nach 6 Sekunden der Text von vorne beginnt...und da wären 120ms ein wenig kurz...aber vermutlich habe ich das oben irgendwo nicht richtig gelesen...jedenfalls bewegt sich die Schrift schonmal, immerhin ein Anfang ;-)
-
echt ein super Adapter, schade dass man das ganze nur einmal liken kann.
Hallo an alle.
die templates sind noch nicht ganz meine Freunde, vielleicht kann mir ja von euch jemand helfen.
Ich versuche mich gerade an folgenden rss-feed:
https://www.hoerzu.de/rss/tipp/spielfilm/
Nun möchte ich folgendes realisieren:
- Oben Anzeige der Sendezeit
- Ein Bild der Sendung anzeigen lassen
- Den eingefügten Link aktive schalten
Ist das möglich und wenn ja, wie?


@Oli sagte in Test Adapter rssfeed v0.0.x:
https://www.hoerzu.de/rss/tipp/spielfilm/
Nun möchte ich folgendes realisieren:
- Oben Anzeige der Sendezeit
Das würde funktionieren - Ein Bild der Sendung anzeigen lassen
Im Feed ist kein Bild enthalten. Die Beschreibung ist auch nur sehr verkürzt enthalten - Den eingefügten Link aktive schalten
Das würde funktionieren
Schau mal ob du mit diesem Feed glücklicher bist
https://www.tvspielfilm.de/tv-programm/rss/filme.xml -
@skokarl hab ich....unabhängig von dem anders aussehendem Widget funktioniert es jetzt...Umschaltdauer steht bei mir ja noch (ms) dahinter, da war die Zahl einfach zu groß...mit der 120 wie bei dir funktioniert es jetzt...allerdings ist mir nicht ganz klar was die genau macht...6000 sind ja 6 Sekunden, ich ging davon aus das es bedeutet das nach 6 Sekunden der Text von vorne beginnt...und da wären 120ms ein wenig kurz...aber vermutlich habe ich das oben irgendwo nicht richtig gelesen...jedenfalls bewegt sich die Schrift schonmal, immerhin ein Anfang ;-)
@Ash2k sagte in Test Adapter rssfeed v0.0.x:
@skokarl hab ich....unabhängig von dem anders aussehendem Widget funktioniert es jetzt...Umschaltdauer steht bei mir ja noch (ms) dahinter, da war die Zahl einfach zu groß...mit der 120 wie bei dir funktioniert es jetzt...allerdings ist mir nicht ganz klar was die genau macht...6000 sind ja 6 Sekunden, ich ging davon aus das es bedeutet das nach 6 Sekunden der Text von vorne beginnt...und da wären 120ms ein wenig kurz...aber vermutlich habe ich das oben irgendwo nicht richtig gelesen...jedenfalls bewegt sich die Schrift schonmal, immerhin ein Anfang ;-)
Was meinst du mit Umschaltdauer, wenn du Duration im marquee widget meinst, dann
sind das keine Milisekunden.
Es sind die Anzahl Sekunden, die es braucht bis der ganze Text komplett durchgelaufen ist.
Wenn man nichts eingibt, dann werden die Anzahl an Zeichen durch 6 geteilt.
Wenn man 40 eingibt, dann dauert es 40 Sekunden, bis alles durchgelaufen ist.
Ich glaub da muss ich mal noch einen anderen Algorithmus überlegen, da das je nach Umfang schwer abschätzbar ist.Nachtrag, ach jetzt Umschaltdauer.
hm,Aktuell liefere ich noch keine Übersetzung mit. Jetzt ist in vis wohl bereits eine Übersetzung für duration vorhanden (mit dem Zusatz (ms). Das ist aber der falsche Text.
Da muss ich das attribut spezieller benennen, damit das nicht passiert. -
@Ash2k sagte in Test Adapter rssfeed v0.0.x:
@skokarl hab ich....unabhängig von dem anders aussehendem Widget funktioniert es jetzt...Umschaltdauer steht bei mir ja noch (ms) dahinter, da war die Zahl einfach zu groß...mit der 120 wie bei dir funktioniert es jetzt...allerdings ist mir nicht ganz klar was die genau macht...6000 sind ja 6 Sekunden, ich ging davon aus das es bedeutet das nach 6 Sekunden der Text von vorne beginnt...und da wären 120ms ein wenig kurz...aber vermutlich habe ich das oben irgendwo nicht richtig gelesen...jedenfalls bewegt sich die Schrift schonmal, immerhin ein Anfang ;-)
Was meinst du mit Umschaltdauer, wenn du Duration im marquee widget meinst, dann
sind das keine Milisekunden.
Es sind die Anzahl Sekunden, die es braucht bis der ganze Text komplett durchgelaufen ist.
Wenn man nichts eingibt, dann werden die Anzahl an Zeichen durch 6 geteilt.
Wenn man 40 eingibt, dann dauert es 40 Sekunden, bis alles durchgelaufen ist.
Ich glaub da muss ich mal noch einen anderen Algorithmus überlegen, da das je nach Umfang schwer abschätzbar ist.Nachtrag, ach jetzt Umschaltdauer.
hm,Aktuell liefere ich noch keine Übersetzung mit. Jetzt ist in vis wohl bereits eine Übersetzung für duration vorhanden (mit dem Zusatz (ms). Das ist aber der falsche Text.
Da muss ich das attribut spezieller benennen, damit das nicht passiert.




