From 826fa9c0e5231152debe45363d3e0ed4ac489aa3 Mon Sep 17 00:00:00 2001 From: Tobias Kunze Date: Fri, 27 Oct 2017 13:22:13 +0200 Subject: [PATCH] [ccc] Support playlist download for media.ccc.de --- youtube_dl/extractor/ccc.py | 17 +++++++++++++++++ youtube_dl/extractor/extractors.py | 5 ++++- 2 files changed, 21 insertions(+), 1 deletion(-) diff --git a/youtube_dl/extractor/ccc.py b/youtube_dl/extractor/ccc.py index 734702144..7349c0535 100644 --- a/youtube_dl/extractor/ccc.py +++ b/youtube_dl/extractor/ccc.py @@ -75,3 +75,20 @@ class CCCIE(InfoExtractor): 'tags': event_data.get('tags'), 'formats': formats, } + + +class CCCPlaylistIE(InfoExtractor): + IE_NAME = 'media.ccc.de:lists' + _VALID_URL = r'https?://(?:www\.)?media\.ccc\.de/c/(?P[^/?#&]+)' + + def _real_extract(self, url): + display_id = self._match_id(url).lower() + + all_conferences = self._download_json('https://media.ccc.de/public/conferences', display_id) + event = next(filter(lambda x: x.get('acronym').lower() == display_id, all_conferences['conferences'])) + event_list = self._download_json(event['url'], display_id)['events'] + + return self.playlist_result( + [self.url_result(event['frontend_link']) for event in event_list], + display_id, + ) diff --git a/youtube_dl/extractor/extractors.py b/youtube_dl/extractor/extractors.py index 18350810b..f5774d2a6 100644 --- a/youtube_dl/extractor/extractors.py +++ b/youtube_dl/extractor/extractors.py @@ -171,7 +171,10 @@ from .cbsnews import ( CBSNewsLiveVideoIE, ) from .cbssports import CBSSportsIE -from .ccc import CCCIE +from .ccc import ( + CCCIE, + CCCPlaylistIE, +) from .ccma import CCMAIE from .cctv import CCTVIE from .cda import CDAIE