Browse Source

[ccc] Improve extraction (closes #14601, closes #20355)

master
Sergey M․ 6 years ago
parent
commit
f916abc0ac
No known key found for this signature in database GPG Key ID: 2C393E0F18A9236D
1 changed files with 13 additions and 17 deletions
  1. +13
    -17
      youtube_dl/extractor/ccc.py

+ 13
- 17
youtube_dl/extractor/ccc.py View File

@ -6,6 +6,7 @@ from ..utils import (
int_or_none, int_or_none,
parse_iso8601, parse_iso8601,
try_get, try_get,
url_or_none,
) )
@ -30,16 +31,7 @@ class CCCIE(InfoExtractor):
} }
}, { }, {
'url': 'https://media.ccc.de/v/32c3-7368-shopshifting#download', 'url': 'https://media.ccc.de/v/32c3-7368-shopshifting#download',
'info_dict': {
'id': '2835',
'ext': 'mp4',
'title': 'Shopshifting',
'creator': 'Karsten Nohl, Fabian Bräunlein, dexter',
'description': 'md5:0fade0535e9dc3076d0cbda4958a18eb',
'upload_date': '20151227',
'timestamp': 1451249100,
'tags': list,
}
'only_matching': True,
}] }]
def _real_extract(self, url): def _real_extract(self, url):
@ -104,12 +96,16 @@ class CCCPlaylistIE(InfoExtractor):
}] }]
def _real_extract(self, url): def _real_extract(self, url):
acronym = self._match_id(url).lower()
playlist_id = self._match_id(url).lower()
conf = self._download_json(
'https://media.ccc.de/public/conferences/' + playlist_id,
playlist_id)
conf = self._download_json('https://media.ccc.de/public/conferences/' + acronym, acronym)
entries = []
for e in conf['events']:
event_url = url_or_none(e.get('frontend_link'))
if event_url:
entries.append(self.url_result(event_url, ie=CCCIE.ie_key()))
return self.playlist_result(
[self.url_result(event['frontend_link']) for event in conf['events']],
acronym,
conf['title'],
)
return self.playlist_result(entries, playlist_id, conf.get('title'))

Loading…
Cancel
Save