about summary refs log tree commit diff
diff options
context:
space:
mode:
authorRemita Amine <remitamine@gmail.com>2020-11-24 22:54:08 +0100
committerRemita Amine <remitamine@gmail.com>2020-11-24 22:54:08 +0100
commita7ea88537a8bc8843636f21eb9bd9fa04d5060c5 (patch)
tree406ba141a7fc4060e13e3bcbcc607f238d25ddf9
parent6c35de4c6bc13c307215cd2f8977b7ac09de28fb (diff)
downloadyoutube-dl-a7ea88537a8bc8843636f21eb9bd9fa04d5060c5.tar.gz
youtube-dl-a7ea88537a8bc8843636f21eb9bd9fa04d5060c5.tar.xz
youtube-dl-a7ea88537a8bc8843636f21eb9bd9fa04d5060c5.zip
[bbc] fix BBC Three clip extraction
-rw-r--r--youtube_dl/extractor/bbc.py22
1 files changed, 19 insertions, 3 deletions
diff --git a/youtube_dl/extractor/bbc.py b/youtube_dl/extractor/bbc.py
index ca93b7be5..54cbcdc8e 100644
--- a/youtube_dl/extractor/bbc.py
+++ b/youtube_dl/extractor/bbc.py
@@ -1092,10 +1092,26 @@ class BBCIE(BBCCoUkIE):
             self._search_regex(
                 r'(?s)bbcthreeConfig\s*=\s*({.+?})\s*;\s*<', webpage,
                 'bbcthree config', default='{}'),
-            playlist_id, transform_source=js_to_json, fatal=False)
-        if bbc3_config:
+            playlist_id, transform_source=js_to_json, fatal=False) or {}
+        payload = bbc3_config.get('payload') or {}
+        if payload:
+            clip = payload.get('currentClip') or {}
+            clip_vpid = clip.get('vpid')
+            clip_title = clip.get('title')
+            if clip_vpid and clip_title:
+                formats, subtitles = self._download_media_selector(clip_vpid)
+                self._sort_formats(formats)
+                return {
+                    'id': clip_vpid,
+                    'title': clip_title,
+                    'thumbnail': dict_get(clip, ('poster', 'imageUrl')),
+                    'description': clip.get('description'),
+                    'duration': parse_duration(clip.get('duration')),
+                    'formats': formats,
+                    'subtitles': subtitles,
+                }
             bbc3_playlist = try_get(
-                bbc3_config, lambda x: x['payload']['content']['bbcMedia']['playlist'],
+                payload, lambda x: x['content']['bbcMedia']['playlist'],
                 dict)
             if bbc3_playlist:
                 playlist_title = bbc3_playlist.get('title') or playlist_title