Skip to content

Commit

Permalink
Handle additional indirection in Redtube playlists
Browse files Browse the repository at this point in the history
Fixes issue #29305
  • Loading branch information
dirkf committed Jun 20, 2021
1 parent c2350ca commit f79c7ec
Showing 1 changed file with 21 additions and 11 deletions.
32 changes: 21 additions & 11 deletions youtube_dl/extractor/redtube.py
Expand Up @@ -84,23 +84,33 @@ def _real_extract(self, url):
r'mediaDefinition["\']?\s*:\s*(\[.+?}\s*\])', webpage,
'media definitions', default='{}'),
video_id, fatal=False)
if medias and isinstance(medias, list):
for media in medias:
for media in medias if isinstance(medias, list) else []:
format_url = url_or_none(media.get('videoUrl'))
if not format_url:
continue
format_id = media.get('format')
quality = media.get('quality')
if format_id == 'hls' or (format_id == 'mp4' and not quality):
more_media = self._download_json(format_url, video_id, fatal=False)
else:
more_media = [media]
for media in more_media if isinstance(more_media, list) else []:
format_url = url_or_none(media.get('videoUrl'))
if not format_url:
continue
if media.get('format') == 'hls' or determine_ext(format_url) == 'm3u8':
format_id = media.get('format')
if format_id == 'hls' or determine_ext(format_url) == 'm3u8':
formats.extend(self._extract_m3u8_formats(
format_url, video_id, 'mp4',
entry_protocol='m3u8_native', m3u8_id='hls',
entry_protocol='m3u8_native', m3u8_id=format_id or 'hls',
fatal=False))
continue
format_id = media.get('quality')
formats.append({
'url': format_url,
'format_id': format_id,
'height': int_or_none(format_id),
})
else:
format_id = media.get('quality')
formats.append({
'url': format_url,
'format_id': format_id,
'height': int_or_none(format_id),
})
if not formats:
video_url = self._html_search_regex(
r'<source src="(.+?)" type="video/mp4">', webpage, 'video URL')
Expand Down

0 comments on commit f79c7ec

Please sign in to comment.