mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-11-30 07:28:19 +01:00
simplify _call_api
This commit is contained in:
parent
4e649c6a28
commit
bb98db29a1
|
@ -52,17 +52,19 @@ def _real_initialize(self):
|
|||
}).encode())
|
||||
self._HEADERS['x-chili-device-id'] = device_info['id']
|
||||
|
||||
def _call_api(self, path, video_id, note=None, **kwargs):
|
||||
def _call_api(self, path, video_id, note=None, headers=None, query=None, data=None):
|
||||
return self._download_json(
|
||||
f'https://www.plus.fifa.com/flux-capacitor/api/v1//{path}', video_id, note, **kwargs)
|
||||
f'https://www.plus.fifa.com/flux-capacitor/api/v1//{path}', video_id, note, headers={
|
||||
**self._HEADERS,
|
||||
**(headers or {}),
|
||||
}, query=query, data=data)
|
||||
|
||||
def _real_extract(self, url):
|
||||
urlh = self._request_webpage(url, self._match_id(url))
|
||||
video_id, display_id, locale = self._match_valid_url(urlh.url).group('id', 'display_id', 'locale')
|
||||
|
||||
video_info = self._call_api(
|
||||
'videoasset', video_id, 'Downloading video asset',
|
||||
headers=self._HEADERS, query={'catalog': video_id})[0]
|
||||
'videoasset', video_id, 'Downloading video asset', query={'catalog': video_id})[0]
|
||||
|
||||
formats = []
|
||||
subtitles = {}
|
||||
|
@ -73,12 +75,12 @@ def _real_extract(self, url):
|
|||
]:
|
||||
session_info = self._call_api(
|
||||
'streaming/session', video_id, 'Getting streaming session',
|
||||
headers={**self._HEADERS, 'x-chili-accept-stream': stream_type},
|
||||
headers={'x-chili-accept-stream': stream_type},
|
||||
data=json.dumps({'videoAssetId': video_info['id'], 'autoPlay': False}).encode())
|
||||
|
||||
streams_info = self._call_api(
|
||||
'streaming/urls', video_id, 'Getting streaming urls',
|
||||
headers={**self._HEADERS, 'x-chili-streaming-session': session_info['id']})
|
||||
headers={'x-chili-streaming-session': session_info['id']})
|
||||
|
||||
for playlist_url in traverse_obj(streams_info, (..., 'url')):
|
||||
ext = determine_ext(playlist_url)
|
||||
|
@ -115,8 +117,9 @@ def _preconnect_link(self):
|
|||
r'<link\b[^>]+\brel\s*=\s*"preconnect"[^>]+href\s*=\s*"([^"]+)"',
|
||||
self._download_webpage('https://fifa.com/', None), 'Preconnect Link')
|
||||
|
||||
def _call_api(self, path, video_id, note=None, **kwargs):
|
||||
return self._download_json(f'{self._preconnect_link}/{path}', video_id, note, **kwargs)
|
||||
def _call_api(self, path, video_id, note=None, query=None):
|
||||
return self._download_json(
|
||||
f'{self._preconnect_link}/{path}', video_id, note, query=query)
|
||||
|
||||
|
||||
class FifaIE(FifaBaseIE):
|
||||
|
|
Loading…
Reference in New Issue
Block a user