'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<id>[^/?#&]+)'
+ _TESTS = [{
+ 'url': 'https://media.ccc.de/c/30c3',
+ 'info_dict': {
+ 'title': '30C3',
+ 'id': '30c3',
+ },
+ 'playlist_count': 135,
+ }]
+
+ def _real_extract(self, url):
+ acronym = self._match_id(url).lower()
+
+ conf = self._download_json('https://media.ccc.de/public/conferences/' + acronym, acronym)
+
+ return self.playlist_result(
+ [self.url_result(event['frontend_link']) for event in conf['events']],
+ acronym,
+ conf['title'],
+ )