]> jfr.im git - yt-dlp.git/commitdiff
[curiositystream] Add more metadata
authorpukkandan <redacted>
Sat, 13 Nov 2021 18:19:14 +0000 (23:49 +0530)
committerpukkandan <redacted>
Sat, 13 Nov 2021 18:19:14 +0000 (23:49 +0530)
Closes #1568

yt_dlp/extractor/common.py
yt_dlp/extractor/curiositystream.py

index 5c6e599017397d5ce2df6ae164026329340ab156..6f0650296105c865449e1dedbf1d6639d6114847 100644 (file)
@@ -342,6 +342,7 @@ class InfoExtractor(object):
     series, programme or podcast:
 
     series:         Title of the series or programme the video episode belongs to.
+    series_id:      Id of the series or programme the video episode belongs to, as a unicode string.
     season:         Title of the season the video episode belongs to.
     season_number:  Number of the season the video episode belongs to, as an integer.
     season_id:      Id of the season the video episode belongs to, as a unicode string.
index 628c83631950a5e167ff36ee126bb500a0f70bdc..286a4c6af4e77ecebbe2ee29d43e424964105ad5 100644 (file)
@@ -50,19 +50,23 @@ def _real_initialize(self):
 class CuriosityStreamIE(CuriosityStreamBaseIE):
     IE_NAME = 'curiositystream'
     _VALID_URL = r'https?://(?:app\.)?curiositystream\.com/video/(?P<id>\d+)'
-    _TEST = {
+    _TESTS = [{
         'url': 'https://app.curiositystream.com/video/2',
         'info_dict': {
             'id': '2',
             'ext': 'mp4',
             'title': 'How Did You Develop The Internet?',
             'description': 'Vint Cerf, Google\'s Chief Internet Evangelist, describes how he and Bob Kahn created the internet.',
+            'channel': 'Curiosity Stream',
+            'categories': ['Technology', 'Interview'],
+            'average_rating': 96.79,
+            'series_id': '2',
         },
         'params': {
             # m3u8 download
             'skip_download': True,
         },
-    }
+    }]
 
     def _real_extract(self, url):
         video_id = self._match_id(url)
@@ -139,6 +143,10 @@ def _real_extract(self, url):
             'duration': int_or_none(media.get('duration')),
             'tags': media.get('tags'),
             'subtitles': subtitles,
+            'channel': media.get('producer'),
+            'categories': [media.get('primary_category'), media.get('type')],
+            'average_rating': media.get('rating_percentage'),
+            'series_id': str(media.get('collection_id') or '') or None,
         }