1
0
mirror of https://github.com/ytdl-org/youtube-dl.git synced 2025-01-26 04:40:17 +00:00

[discovery] limit video data by show slug(closes #21980)

This commit is contained in:
Remita Amine 2019-08-02 18:08:26 +01:00
parent d9d3a5a816
commit 995f319b06

View File

@ -34,7 +34,7 @@ class DiscoveryIE(DiscoveryGoBaseIE):
cookingchanneltv| cookingchanneltv|
motortrend motortrend
) )
)\.com/tv-shows/[^/]+/(?:video|full-episode)s/(?P<id>[^./?#]+)''' )\.com/tv-shows/(?P<show_slug>[^/]+)/(?:video|full-episode)s/(?P<id>[^./?#]+)'''
_TESTS = [{ _TESTS = [{
'url': 'https://go.discovery.com/tv-shows/cash-cab/videos/riding-with-matthew-perry', 'url': 'https://go.discovery.com/tv-shows/cash-cab/videos/riding-with-matthew-perry',
'info_dict': { 'info_dict': {
@ -53,13 +53,17 @@ class DiscoveryIE(DiscoveryGoBaseIE):
}, { }, {
'url': 'https://go.discovery.com/tv-shows/alaskan-bush-people/videos/follow-your-own-road', 'url': 'https://go.discovery.com/tv-shows/alaskan-bush-people/videos/follow-your-own-road',
'only_matching': True, 'only_matching': True,
}, {
# using `show_slug` is important to get the correct video data
'url': 'https://www.sciencechannel.com/tv-shows/mythbusters-on-science/full-episodes/christmas-special',
'only_matching': True,
}] }]
_GEO_COUNTRIES = ['US'] _GEO_COUNTRIES = ['US']
_GEO_BYPASS = False _GEO_BYPASS = False
_API_BASE_URL = 'https://api.discovery.com/v1/' _API_BASE_URL = 'https://api.discovery.com/v1/'
def _real_extract(self, url): def _real_extract(self, url):
site, display_id = re.match(self._VALID_URL, url).groups() site, show_slug, display_id = re.match(self._VALID_URL, url).groups()
access_token = None access_token = None
cookies = self._get_cookies(url) cookies = self._get_cookies(url)
@ -91,6 +95,7 @@ class DiscoveryIE(DiscoveryGoBaseIE):
display_id, 'Downloading content JSON metadata', display_id, 'Downloading content JSON metadata',
headers=headers, query={ headers=headers, query={
'slug': display_id, 'slug': display_id,
'show_slug': show_slug,
})[0] })[0]
video_id = video['id'] video_id = video['id']
stream = self._download_json( stream = self._download_json(