NEWS
Test/Support für Adapter rssfeed und vis-2-widgets-rssfeed
-
@liv-in-sky
mach mal bitte einen kompletten reload von vis.
am besten vis schliessen und neu öffnen
und ggfs. auch nochmal
iobroker upload rssfeed@OliverIO hab ich gemacht . aber mach ich gerne nochmal
-
@liv-in-sky
mach mal bitte einen kompletten reload von vis.
am besten vis schliessen und neu öffnen
und ggfs. auch nochmal
iobroker upload rssfeed -
jetzt haben wir es
iobroker stop
upload ...vis
upload rssfeed
... startvielen dank, gute nacht - und schöne träume
-
jetzt haben wir es
iobroker stop
upload ...vis
upload rssfeed
... startvielen dank, gute nacht - und schöne träume
@liv-in-sky
danke gleichfalls
das mit dem upload ist etwas träge, das dauert auch nach ausführen immer noch zwischen 10 und 30 sekunden, bis es im browser beim nachladen sichtbar ist.
ich weiß nicht was vis da im hintergrund alles macht -
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.Bin gerade beim Feuerwehr Feed

Kein Einsatz, natürlich keine Daten. Wie bekomme ich das Bild angezeigt?
-
Bin gerade beim Feuerwehr Feed

Kein Einsatz, natürlich keine Daten. Wie bekomme ich das Bild angezeigt?
Durch Erweiterung des Templates, hier in der 2. Zeile das img-Tag.
Die url ist in meta.image.url gespeichert
Ich habe den titel in ein Paragraphen tag gepacktz, damit das Bild drunter erscheint.<p><%- meta.title %> </p> <img src="<%- meta.image.url %>"> <% 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;" /> <% }); %> -
Bin gerade beim Feuerwehr Feed

Kein Einsatz, natürlich keine Daten. Wie bekomme ich das Bild angezeigt?
-
@sigi234
Wenn im RSS dann mal daten sind, dann am besten die daten mal in einen anderen Datenpunkt speichern bevor sie wieder weg sind. Dann kann man in Ruhe testen.Wirklich Cooler Adapter. :+1:
Wünsche und Überlegungen:
Kategorien?
Eine View für alle Feeds , derzeit mache ich für jeden eine eigen ViewEdit:
Kann man über Sichtbarkeit machenIn den Einstellungen im Adapter ist es nicht möglich die Daten nachträglich zu ändern.
-
Wirklich Cooler Adapter. :+1:
Wünsche und Überlegungen:
Kategorien?
Eine View für alle Feeds , derzeit mache ich für jeden eine eigen ViewEdit:
Kann man über Sichtbarkeit machenIn den Einstellungen im Adapter ist es nicht möglich die Daten nachträglich zu ändern.
@sigi234
Das hatte ich auch schon überlegt.
so wie bei openligadb, wo man die nächsten spiele mehrerer Ligen in einem widget integrieren kann.
Die Herausforderung ist, dass man Abweichungen zwischen den Feeds im Template ausregeln muss. Aber so viele Attribute sind es ja nicht.
für Marquee geht das auf jeden Fall.Was meinst du mit Kategorieen?
-
da bastle ich die letzten Tage an ner Lösung und ZACK - nen Adapter.. :)
Ich habe eben 4 Newsfeed angelegt und unter Objekte tauchen diese auch auf, allerdings mit falschen Namen.


ich schaue mir den Adapter auch mal an
@mguenther
hm, in welcher reihenfolge hast du die daten eingegeben?
ich hab ja mittlerweile schon viele datensätze angelegt und auch wieder gelöscht,
aber das hatte ich noch nicht.
allerdings sehe ich nur eine Abweichung
Der Datenpunkt mit namen ntv heißt in der 2. spalte Spiegel
lösche den mal und leg ihn neu an.
oder sind alle anderen auch durcheinander?dann sag mir mal noch wlechen browser du benützt. es kann da immer wieder mal browserunterschiede geben
-
@mguenther
hm, in welcher reihenfolge hast du die daten eingegeben?
ich hab ja mittlerweile schon viele datensätze angelegt und auch wieder gelöscht,
aber das hatte ich noch nicht.
allerdings sehe ich nur eine Abweichung
Der Datenpunkt mit namen ntv heißt in der 2. spalte Spiegel
lösche den mal und leg ihn neu an.
oder sind alle anderen auch durcheinander?dann sag mir mal noch wlechen browser du benützt. es kann da immer wieder mal browserunterschiede geben
@OliverIO
Firefox - ich hatte zuerst n-tv angelegt, danach spiegel. In der Instanz hatter er aus n-tv gleich ntv gemacht. Ich kösche mal ntv, wird auch unter Objekte ntv gelöscht? Blieb eben bestehen. Ich teste nochmal, zur Not lösche ich ntv per Hand und lege ihn neu in der Instanz an. -
@mguenther
hm, in welcher reihenfolge hast du die daten eingegeben?
ich hab ja mittlerweile schon viele datensätze angelegt und auch wieder gelöscht,
aber das hatte ich noch nicht.
allerdings sehe ich nur eine Abweichung
Der Datenpunkt mit namen ntv heißt in der 2. spalte Spiegel
lösche den mal und leg ihn neu an.
oder sind alle anderen auch durcheinander?dann sag mir mal noch wlechen browser du benützt. es kann da immer wieder mal browserunterschiede geben
-
@OliverIO
Firefox - ich hatte zuerst n-tv angelegt, danach spiegel. In der Instanz hatter er aus n-tv gleich ntv gemacht. Ich kösche mal ntv, wird auch unter Objekte ntv gelöscht? Blieb eben bestehen. Ich teste nochmal, zur Not lösche ich ntv per Hand und lege ihn neu in der Instanz an.@mguenther
ja datenpunkte von hand löschen. der adapter kann das nicht -
da bastle ich die letzten Tage an ner Lösung und ZACK - nen Adapter.. :)
Ich habe eben 4 Newsfeed angelegt und unter Objekte tauchen diese auch auf, allerdings mit falschen Namen.


ich schaue mir den Adapter auch mal an
@mguenther
ok problem konnte ich nachvollziehen.
es ist allerdings nur rein visueller natur, das in der 2.spalte uU ein anderer Text steht.
Werd ich korrigieren. -
@mguenther
ok problem konnte ich nachvollziehen.
es ist allerdings nur rein visueller natur, das in der 2.spalte uU ein anderer Text steht.
Werd ich korrigieren. -
@mguenther
ja ist ja klar.
hab ja geschrieben, das ich da was gefunden habe
muss aber erst beheben und neue version verteilen.
ist ja kein kritischer fehler
wenn es dich sehr stört, dann kannst du den datenpunkt in der 2.spalte editieren -
@mguenther
ja ist ja klar.
hab ja geschrieben, das ich da was gefunden habe
muss aber erst beheben und neue version verteilen.
ist ja kein kritischer fehler
wenn es dich sehr stört, dann kannst du den datenpunkt in der 2.spalte editieren -
@OliverIO
alles gut, hatte sich zeitlich überschnitten. Die Formatierung könnte jetzt ggf. noch über css angepasst werden. Dazu müsste dein Template angepasst werden, wenn ich das richtig verstanden habe - richtig?@mguenther
Das Template kann jeder selber anpassen.
Deswegen habe ich ein Template Mechanismus gewählt und das nicht fix in den code reinprogrammiert.
Die Feeds und der enthaltene oder auch nicht enthaltene html code ist so vielfältig, das man da keine generelle Lösung vorgeben kann.
Wenn jemand möchte, dann könnte sich jemand sogar das laufschrift widget nur darin bauen.
Das könnte man auch so erweitern, wenn man auf einen artikel klickt, das sich ein dialog mit der detailansicht öffnet.
aber da gibt es vielfältige Lösungsmöglichkeiten. -
@mguenther
Das Template kann jeder selber anpassen.
Deswegen habe ich ein Template Mechanismus gewählt und das nicht fix in den code reinprogrammiert.
Die Feeds und der enthaltene oder auch nicht enthaltene html code ist so vielfältig, das man da keine generelle Lösung vorgeben kann.
Wenn jemand möchte, dann könnte sich jemand sogar das laufschrift widget nur darin bauen.
Das könnte man auch so erweitern, wenn man auf einen artikel klickt, das sich ein dialog mit der detailansicht öffnet.
aber da gibt es vielfältige Lösungsmöglichkeiten.
