mirror of
https://github.com/ytdl-org/youtube-dl
synced 2024-11-17 02:52:38 +09:00
Revert to _VALID_URL to match video_id and integration
* Retrieve the last instance of said parameters that appears in the query string, rather than the first previously * Resolve the respective comment in #30212
This commit is contained in:
parent
abfc16a123
commit
4225c46d3b
@ -6,7 +6,6 @@ import re
|
||||
from .common import InfoExtractor
|
||||
from ..compat import (
|
||||
compat_str,
|
||||
compat_parse_qs,
|
||||
compat_urllib_parse_urlparse,
|
||||
compat_urllib_parse_urlencode,
|
||||
)
|
||||
@ -263,11 +262,13 @@ class GlomexEmbedIE(GlomexBaseIE):
|
||||
|
||||
def _real_extract(self, url):
|
||||
url, origin_url = self._unsmuggle_origin_url(url)
|
||||
embed_id = self._match_id(url)
|
||||
query = compat_parse_qs(compat_urllib_parse_urlparse(url).query)
|
||||
video_id = query['playlistId'][0]
|
||||
# perhaps redundant
|
||||
assert embed_id == video_id
|
||||
integration = query['integrationId'][0]
|
||||
# must return a valid match since it was already tested when selecting the IE
|
||||
try:
|
||||
matches = self._VALID_URL_RE.match(url).groupdict()
|
||||
except AttributeError:
|
||||
matches = re.match(self._VALID_URL, url).groupdict()
|
||||
# id is not enforced in the pattern, so do it now; ditto integration
|
||||
video_id = matches['id']
|
||||
integration = matches['integration']
|
||||
return self._download_and_extract_api_data(video_id, integration,
|
||||
origin_url)
|
||||
|
Loading…
Reference in New Issue
Block a user