Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/juergenpabel/livecenter_sportschau_de
Podcast und HTTP-Redirects für ARD Sportschau Fussball Livestreams (basierend auf livecenter.sportschau.de)
https://github.com/juergenpabel/livecenter_sportschau_de
bundesliga livestreams podcast sportschau
Last synced: about 1 month ago
JSON representation
Podcast und HTTP-Redirects für ARD Sportschau Fussball Livestreams (basierend auf livecenter.sportschau.de)
- Host: GitHub
- URL: https://github.com/juergenpabel/livecenter_sportschau_de
- Owner: juergenpabel
- License: apache-2.0
- Created: 2021-09-23T10:44:13.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2023-02-04T15:22:07.000Z (almost 2 years ago)
- Last Synced: 2024-11-01T11:42:41.893Z (3 months ago)
- Topics: bundesliga, livestreams, podcast, sportschau
- Language: Python
- Homepage:
- Size: 50.8 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# https://livecenter-sportschau-de.appspot.com/
**This is in german, because the provided content is in german**
## tl;dr ##
* Auf https://livecenter-sportschau-de.appspot.com/livestreams/podcast gibt es die tagesaktuellen Livestreams als Podcast bereitgestellt.
* Auf https://livecenter-sportschau-de.appspot.com/livestreams/redirect gibt es HTTP redirects (HTTP 302) für einzelne tagesaktuelle Livestreams.
Wie das konkret genutzt werden kann wird im Abschnitt "HOWTO" weiter unten beschrieben.## 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?
* Immer die (tagesaktuelle) Bundesliga-Konferenz auf einem Sound-System abspielen: https://livecenter-sportschau-de.appspot.com/livestreams/redirect?comp=Bundesliga&team=Konferenz
* Immer das (tagesaktuelle) Spiel mit Eintracht Frankfurt auf einem Sound-System abspielen: https://livecenter-sportschau-de.appspot.com/livestreams/redirect?team=Eintracht+Frankfurt
* Ein (tagesaktuelles) Spiel aus der 2. Bundesliga per Podcast-Client auswählen/anhören: https://livecenter-sportschau-de.appspot.com/livestreams/podcast?comp=2.+Bundesliga## 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-ÜbertragungenDer 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:
* Nur 1. Bundesliga-Spiele im Podcast auflisten: https://livecenter-sportschau-de.appspot.com/livestreams/podcast?comp=Bundesliga&title=Sportschau:+Bundesliga
* Nur 2. Bundesliga-Spiele im Podcast auflisten: https://livecenter-sportschau-de.appspot.com/livestreams/podcast?comp=2.+Bundesliga&title=Sportschau:+2.+Bundesliga
* Nur Spiele mit Eintracht Frankfurt (egal in welchem Wettbewerb): https://livecenter-sportschau-de.appspot.com/livestreams/podcast?team=Eintracht+Frankfurt&title=Eintracht+FrankfurtBeispiele HTTP-Redirect:
* Das tagesaktuelle Spiel des 1. FC Köln: https://livecenter-sportschau-de.appspot.com/livestreams/redirect?team=1.+FC+Köln
* Die Bundesliga-Spiele für ein bestimmtes Datum als Konferenz: https://livecenter-sportschau-de.appspot.com/livestreams/redirect?date=2021-09-25&comp=Bundesliga&team=Konferenz## 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.