Skip to content

Latest commit

 

History

History
60 lines (41 loc) · 5.97 KB

README.md

File metadata and controls

60 lines (41 loc) · 5.97 KB

This is in german, because the provided content is in german

tl;dr

Einführung

Auf https://livecenter.sportschau.de stellt die ARD für viele Sportarten Ergebnisse bereit. Für mindestens Bundesliga-Fussball gibt es ab der Saison 2021/22 auch Livestreams: die per Livestream übertragenen Spiele (oder auch Konferenzen) sind dann mit einem entsprechendem Audio-Symbol markiert. Ein Klick auf das Symbol führt zu einer Seite, auf der der Livestream im Browser abgespielt werden kann.

Motivation

Für die Nutzung per Browser (oder wohl auch per Sportschau App, aber nicht selber ausprobiert) ist die Webseite wohl praktisch - für eine Weiterverwendung der darin enthaltenen Livestream-Daten aber ein Graus:

  • Die Webseite ist (bzw. war mit Stand September 2021) nicht XHTML konform, so dass eine Transformation per XSLT nicht möglich war
  • Die HTML Struktur der Daten-Elemente, die die eigentlichen Spielinformationen ausmachen und die Links auf die Livestreams enthalten ist...sagen wir mal....ungewöhnlich (im Sinne von HTML oder XML oder auch genenrell programmiertechnischer Konstrukte);
  • Die auf der Webseite angebotenen RSS Feeds haben auch nicht auf die direkten Livestreams verwiesen, sondern wieder nur auf die Browser-Seiten

Kurzum: Eine Verwendung außerhalb von Web-Browser und Sportschau-App war nicht möglich.

Was sind Beispiele für solche andersartigen Verwendungsszenarien?

Lösung

Auf Google AppEngine läuft eine kleine Python-Anwendung (deren Quelltext in diesem Repository enthalten ist), die sowohl Podcast-Feeds als auch HTTP redirects auf die direkten MP3-Livestreams bereitstellt. Die Bereitstellung erfolgt durch Verarbeitung der von livecenter.sportschau.de bereitgestellten HTML-Seite in python.

HOWTO

Sowohl die Generierung der Podcast-Feeds als auch die der HTTP redirects kann über folgende HTTP GET Parameter gefiltert werden:

  • date: Für welches Datum, z.B. "2021-09-25"; wenn weggelassen, dann immer das tagesaktuelle Datum
  • comp: Welcher Wettbewerb, z.B. "Bundesliga" oder "2. Bundesliga" (ohne Anführungszeichen)
  • team: Welches Team, z.B. "Eintracht Frankfurt" oder "1. FC Köln" (ohne Anführungszeichen) - oder "Konferenz" für nur Konferenz-Übertragungen

Der Titel des generierten Podcast-Feeds kann auch per "title" Parameter mitgegeben werden. Ansonsten wird als Standardwert "Sportschau Livecenter" genommen.

WICHTIG: Sowohl für die Podcast-Generierung als auch dir HTTP-redirect Generierung wird die gleiche Filter-Logik angewendet, aber: in den Podcasts werden alle gefilterten Livestreams aufgeführt - beim HTTP-redirect führt aber der erstbeste Treffer direkt zum Livestream. Hier ist also eine konkrete Parametrisierung wichtig.

Beispiele Podcast:

Beispiele HTTP-Redirect:

FAQ

  • Wenn ich auf den Link ganz oben klicke, lande ich wieder auf dieser Seite - was mache ich falsch? Nun, ich wollte für meine Lösung keine UI implementieren, also werden nur die konkreten Podcast und Redirect Aufrufe implementiert. Alle anderen Aufrufe landen entweder hier auf Github oder münden in einem HTTP 404 (nicht gefunden).
  • Warum kriege ich keine Ergebnisse, auch ganz ohne "team" oder "comp" Filter? Vermutlich, weil heute gar keine Spiele mit Livestreams angesetzt sind. Leider ist die Sportschau-Seite tagesweise aufgebaut und man kann nicht (oder zumindest nicht einfach) "zeig mir das nächste Spiel" (auch wenn das erst in X Tagen ist) an umsetzen; vielleicht implementiere ich das aber noch. Mal sehen...
  • Warum funktioniert das überhaupt nicht mehr? Hmmm...drei Möglichkeiten:
    • Die Struktur der Webseite der Sportschau wurde geändert und passt nicht mehr zu der hier implementierten Verarbeitungslogik. Da müsste mal jemand das Programm hier anpassen...
    • Wenn das in naher Zukunft passiert (aus September 2021er Sicht), dann ist vielleicht mein kostenlos-Kontingent bei Google-App-Engine aufgebraucht; das würde bedeuten es nutzen SEHR VIELE Leute den Dienst...das wäre cool (ausser natürlich, dass das nicht mehr funktioniert...sorry dafür).
    • Wenn das in deutlicher Zukunft passiert (aus September 2021er Sicht), dann vermutlich weil Google-App-Engine kein Python 3.9 mehr unterstützt und ich das Programm (noch) nicht auf eine dann unterstützte Python Version migriert habe.