]> jfr.im git - yt-dlp.git/blobdiff - yt_dlp/extractor/bigo.py
[extractor/reddit] Add subreddit as `channel_id` (#5685)
[yt-dlp.git] / yt_dlp / extractor / bigo.py
index f90bfcd8e34f94586171be6e5bdfd55ba10e5d7f..1cb6e58be68ceab1df2e588a2cfc2840175df417 100644 (file)
@@ -1,8 +1,5 @@
-# coding: utf-8
-from __future__ import unicode_literals
-
 from .common import InfoExtractor
-from ..utils import ExtractorError
+from ..utils import ExtractorError, urlencode_postdata
 
 
 class BigoIE(InfoExtractor):
@@ -31,25 +28,27 @@ def _real_extract(self, url):
         user_id = self._match_id(url)
 
         info_raw = self._download_json(
-            'https://bigo.tv/studio/getInternalStudioInfo',
-            user_id, form_params={'siteId': user_id})
+            'https://ta.bigo.tv/official_website/studio/getInternalStudioInfo',
+            user_id, data=urlencode_postdata({'siteId': user_id}))
 
+        if not isinstance(info_raw, dict):
+            raise ExtractorError('Received invalid JSON data')
         if info_raw.get('code'):
             raise ExtractorError(
-                f'{info_raw["msg"]} (code {info_raw["code"]})', expected=True)
+                'Bigo says: %s (code %s)' % (info_raw.get('msg'), info_raw.get('code')), expected=True)
         info = info_raw.get('data') or {}
 
         if not info.get('alive'):
             raise ExtractorError('This user is offline.', expected=True)
 
+        formats, subs = self._extract_m3u8_formats_and_subtitles(
+            info.get('hls_src'), user_id, 'mp4', 'm3u8')
+
         return {
             'id': info.get('roomId') or user_id,
-            'title': info.get('roomTopic'),
-            'formats': [{
-                'url': info.get('hls_src'),
-                'ext': 'mp4',
-                'protocol': 'm3u8',
-            }],
+            'title': info.get('roomTopic') or info.get('nick_name') or user_id,
+            'formats': formats,
+            'subtitles': subs,
             'thumbnail': info.get('snapshot'),
             'uploader': info.get('nick_name'),
             'uploader_id': user_id,