diff options
| -rw-r--r-- | youtube_dl/extractor/nova.py | 33 | 
1 files changed, 27 insertions, 6 deletions
| diff --git a/youtube_dl/extractor/nova.py b/youtube_dl/extractor/nova.py index 06cb8cb3f..edf8b82c6 100644 --- a/youtube_dl/extractor/nova.py +++ b/youtube_dl/extractor/nova.py @@ -6,7 +6,9 @@ import re  from .common import InfoExtractor  from ..utils import (      clean_html, +    js_to_json,      unified_strdate, +    url_or_none,  ) @@ -111,8 +113,21 @@ class NovaIE(InfoExtractor):              webpage, 'video id')          config_url = self._search_regex( -            r'src="(http://tn\.nova\.cz/bin/player/videojs/config\.php\?[^"]+)"', +            r'src="(https?://(?:tn|api)\.nova\.cz/bin/player/videojs/config\.php\?[^"]+)"',              webpage, 'config url', default=None) +        config_params = {} + +        if not config_url: +            player = self._parse_json( +                self._search_regex( +                    r'(?s)Player\s*\(.+?\s*,\s*({.+?\bmedia\b["\']?\s*:\s*["\']?\d+.+?})\s*\)', webpage, +                    'player', default='{}'), +                video_id, transform_source=js_to_json, fatal=False) +            if player: +                config_url = url_or_none(player.get('configUrl')) +                params = player.get('configParams') +                if isinstance(params, dict): +                    config_params = params          if not config_url:              DEFAULT_SITE_ID = '23000' @@ -127,14 +142,20 @@ class NovaIE(InfoExtractor):              }              site_id = self._search_regex( -                r'site=(\d+)', webpage, 'site id', default=None) or SITES.get(site, DEFAULT_SITE_ID) - -            config_url = ('http://tn.nova.cz/bin/player/videojs/config.php?site=%s&media=%s&jsVar=vjsconfig' -                          % (site_id, video_id)) +                r'site=(\d+)', webpage, 'site id', default=None) or SITES.get( +                site, DEFAULT_SITE_ID) + +            config_url = 'https://api.nova.cz/bin/player/videojs/config.php' +            config_params = { +                'site': site_id, +                'media': video_id, +                'quality': 3, +                'version': 1, +            }          config = self._download_json(              config_url, display_id, -            'Downloading config JSON', +            'Downloading config JSON', query=config_params,              transform_source=lambda s: s[s.index('{'):s.rindex('}') + 1])          mediafile = config['mediafile'] | 
