pull/14430/merge
sepro 2 days ago committed by GitHub
commit 7379b19322
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -2026,6 +2026,9 @@ class YoutubeIE(YoutubeBaseInfoExtractor):
return None, None return None, None
return player_js_version.split('@') return player_js_version.split('@')
def _construct_player_url(self, player_id, variant):
return f'/s/player/{player_id}/{self._PLAYER_JS_VARIANT_MAP[variant]}'
def _extract_player_url(self, *ytcfgs, webpage=None): def _extract_player_url(self, *ytcfgs, webpage=None):
player_url = traverse_obj( player_url = traverse_obj(
ytcfgs, (..., 'PLAYER_JS_URL'), (..., 'WEB_PLAYER_CONTEXT_CONFIGS', ..., 'jsUrl'), ytcfgs, (..., 'PLAYER_JS_URL'), (..., 'WEB_PLAYER_CONTEXT_CONFIGS', ..., 'jsUrl'),
@ -2038,7 +2041,7 @@ class YoutubeIE(YoutubeBaseInfoExtractor):
if requested_js_variant in self._PLAYER_JS_VARIANT_MAP: if requested_js_variant in self._PLAYER_JS_VARIANT_MAP:
player_id = player_id_override or self._extract_player_info(player_url) player_id = player_id_override or self._extract_player_info(player_url)
original_url = player_url original_url = player_url
player_url = f'/s/player/{player_id}/{self._PLAYER_JS_VARIANT_MAP[requested_js_variant]}' player_url = self._construct_player_url(player_id, requested_js_variant)
if original_url != player_url: if original_url != player_url:
self.write_debug( self.write_debug(
f'Forcing "{requested_js_variant}" player JS variant for player {player_id}\n' f'Forcing "{requested_js_variant}" player JS variant for player {player_id}\n'
@ -2051,6 +2054,18 @@ class YoutubeIE(YoutubeBaseInfoExtractor):
return urljoin('https://www.youtube.com', player_url) return urljoin('https://www.youtube.com', player_url)
def _download_player_url(self, video_id, fatal=False): def _download_player_url(self, video_id, fatal=False):
requested_js_variant = self._configuration_arg('player_js_variant', [''])[0] or 'main'
if requested_js_variant == 'actual':
requested_js_variant = 'main'
if requested_js_variant not in self._PLAYER_JS_VARIANT_MAP:
self.report_warning(
f'Invalid player JS variant name "{requested_js_variant}" requested. '
f'Valid choices are: {", ".join(self._PLAYER_JS_VARIANT_MAP)}', only_once=True)
requested_js_variant = 'main'
player_id_override = self._get_player_js_version()[1]
if player_id_override:
self.write_debug(f'Forcing player {player_id_override}')
return urljoin('https://www.youtube.com', self._construct_player_url(player_id_override, requested_js_variant))
iframe_webpage = self._download_webpage_with_retries( iframe_webpage = self._download_webpage_with_retries(
'https://www.youtube.com/iframe_api', 'https://www.youtube.com/iframe_api',
note='Downloading iframe API JS', note='Downloading iframe API JS',
@ -2060,7 +2075,7 @@ class YoutubeIE(YoutubeBaseInfoExtractor):
player_version = self._search_regex( player_version = self._search_regex(
r'player\\?/([0-9a-fA-F]{8})\\?/', iframe_webpage, 'player version', fatal=fatal) r'player\\?/([0-9a-fA-F]{8})\\?/', iframe_webpage, 'player version', fatal=fatal)
if player_version: if player_version:
return f'https://www.youtube.com/s/player/{player_version}/player_ias.vflset/en_US/base.js' return urljoin('https://www.youtube.com', self._construct_player_url(player_version, requested_js_variant))
def _player_js_cache_key(self, player_url): def _player_js_cache_key(self, player_url):
player_id = self._extract_player_info(player_url) player_id = self._extract_player_info(player_url)

Loading…
Cancel
Save