mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-11-23 02:25:11 +00:00
[youtube] Try embedded client variants before agegate
agegate variants appears to be broken, but don't remove them for the time-being
This commit is contained in:
parent
ae6a1b9585
commit
ae72962643
1 changed files with 10 additions and 5 deletions
|
@ -2940,13 +2940,18 @@ def _extract_player_responses(self, clients, video_id, webpage, master_ytcfg):
|
||||||
webpage, self._YT_INITIAL_PLAYER_RESPONSE_RE,
|
webpage, self._YT_INITIAL_PLAYER_RESPONSE_RE,
|
||||||
video_id, 'initial player response')
|
video_id, 'initial player response')
|
||||||
|
|
||||||
original_clients = clients
|
all_clients = set(clients)
|
||||||
clients = clients[::-1]
|
clients = clients[::-1]
|
||||||
prs = []
|
prs = []
|
||||||
|
|
||||||
def append_client(client_name):
|
def append_client(*client_names):
|
||||||
if client_name in INNERTUBE_CLIENTS and client_name not in original_clients:
|
""" Append the first client name that exists """
|
||||||
|
for client_name in client_names:
|
||||||
|
if client_name in INNERTUBE_CLIENTS:
|
||||||
|
if client_name not in all_clients:
|
||||||
clients.append(client_name)
|
clients.append(client_name)
|
||||||
|
all_clients.add(client_name)
|
||||||
|
return
|
||||||
|
|
||||||
# Android player_response does not have microFormats which are needed for
|
# Android player_response does not have microFormats which are needed for
|
||||||
# extraction of some data. So we return the initial_pr with formats
|
# extraction of some data. So we return the initial_pr with formats
|
||||||
|
@ -2992,7 +2997,7 @@ def append_client(client_name):
|
||||||
if client.endswith('_agegate') and self._is_unplayable(pr) and self.is_authenticated:
|
if client.endswith('_agegate') and self._is_unplayable(pr) and self.is_authenticated:
|
||||||
append_client(client.replace('_agegate', '_creator'))
|
append_client(client.replace('_agegate', '_creator'))
|
||||||
elif self._is_agegated(pr):
|
elif self._is_agegated(pr):
|
||||||
append_client(f'{client}_agegate')
|
append_client(f'{client}_embedded', f'{client.replace("_embedded", "")}_agegate')
|
||||||
|
|
||||||
if last_error:
|
if last_error:
|
||||||
if not len(prs):
|
if not len(prs):
|
||||||
|
|
Loading…
Reference in a new issue