diff options
| author | sprhawk <465558+sprhawk@users.noreply.github.com> | 2017-12-26 22:27:26 +0800 | 
|---|---|---|
| committer | sprhawk <465558+sprhawk@users.noreply.github.com> | 2017-12-26 22:27:26 +0800 | 
| commit | c33de004e13da11f1ae3cad7310b36500cfb9d28 (patch) | |
| tree | c742e448af6c126eca4b259c85f83177aec54847 /youtube_dl/extractor/discoverygo.py | |
| parent | 42a1012c7767306626c5358a18ad3e86417bd7b7 (diff) | |
| parent | db145ee54a57f5ccc89639de8c589eb111a91b19 (diff) | |
Merge branch 'master' of github.com:rg3/youtube-dl into weibo
Diffstat (limited to 'youtube_dl/extractor/discoverygo.py')
| -rw-r--r-- | youtube_dl/extractor/discoverygo.py | 79 | 
1 files changed, 44 insertions, 35 deletions
| diff --git a/youtube_dl/extractor/discoverygo.py b/youtube_dl/extractor/discoverygo.py index 7cd5d4291..3368c4c07 100644 --- a/youtube_dl/extractor/discoverygo.py +++ b/youtube_dl/extractor/discoverygo.py @@ -5,6 +5,7 @@ import re  from .common import InfoExtractor  from ..compat import compat_str  from ..utils import ( +    determine_ext,      extract_attributes,      ExtractorError,      int_or_none, @@ -27,42 +28,9 @@ class DiscoveryGoBaseIE(InfoExtractor):              velocitychannel          )go\.com/%s(?P<id>[^/?#&]+)''' - -class DiscoveryGoIE(DiscoveryGoBaseIE): -    _VALID_URL = DiscoveryGoBaseIE._VALID_URL_TEMPLATE % r'(?:[^/]+/)+' -    _GEO_COUNTRIES = ['US'] -    _TEST = { -        'url': 'https://www.discoverygo.com/bering-sea-gold/reaper-madness/', -        'info_dict': { -            'id': '58c167d86b66d12f2addeb01', -            'ext': 'mp4', -            'title': 'Reaper Madness', -            'description': 'md5:09f2c625c99afb8946ed4fb7865f6e78', -            'duration': 2519, -            'series': 'Bering Sea Gold', -            'season_number': 8, -            'episode_number': 6, -            'age_limit': 14, -        }, -    } - -    def _real_extract(self, url): -        display_id = self._match_id(url) - -        webpage = self._download_webpage(url, display_id) - -        container = extract_attributes( -            self._search_regex( -                r'(<div[^>]+class=["\']video-player-container[^>]+>)', -                webpage, 'video container')) - -        video = self._parse_json( -            container.get('data-video') or container.get('data-json'), -            display_id) - +    def _extract_video_info(self, video, stream, display_id):          title = video['name'] -        stream = video.get('stream')          if not stream:              if video.get('authenticated') is True:                  raise ExtractorError( @@ -106,7 +74,11 @@ class DiscoveryGoIE(DiscoveryGoBaseIE):                          not subtitle_url.startswith('http')):                      continue                  lang = caption.get('fileLang', 'en') -                subtitles.setdefault(lang, []).append({'url': subtitle_url}) +                ext = determine_ext(subtitle_url) +                subtitles.setdefault(lang, []).append({ +                    'url': subtitle_url, +                    'ext': 'ttml' if ext == 'xml' else ext, +                })          return {              'id': video_id, @@ -124,6 +96,43 @@ class DiscoveryGoIE(DiscoveryGoBaseIE):          } +class DiscoveryGoIE(DiscoveryGoBaseIE): +    _VALID_URL = DiscoveryGoBaseIE._VALID_URL_TEMPLATE % r'(?:[^/]+/)+' +    _GEO_COUNTRIES = ['US'] +    _TEST = { +        'url': 'https://www.discoverygo.com/bering-sea-gold/reaper-madness/', +        'info_dict': { +            'id': '58c167d86b66d12f2addeb01', +            'ext': 'mp4', +            'title': 'Reaper Madness', +            'description': 'md5:09f2c625c99afb8946ed4fb7865f6e78', +            'duration': 2519, +            'series': 'Bering Sea Gold', +            'season_number': 8, +            'episode_number': 6, +            'age_limit': 14, +        }, +    } + +    def _real_extract(self, url): +        display_id = self._match_id(url) + +        webpage = self._download_webpage(url, display_id) + +        container = extract_attributes( +            self._search_regex( +                r'(<div[^>]+class=["\']video-player-container[^>]+>)', +                webpage, 'video container')) + +        video = self._parse_json( +            container.get('data-video') or container.get('data-json'), +            display_id) + +        stream = video.get('stream') + +        return self._extract_video_info(video, stream, display_id) + +  class DiscoveryGoPlaylistIE(DiscoveryGoBaseIE):      _VALID_URL = DiscoveryGoBaseIE._VALID_URL_TEMPLATE % ''      _TEST = { | 
