diff options
Diffstat (limited to 'youtube_dl/extractor/spiegeltv.py')
| -rw-r--r-- | youtube_dl/extractor/spiegeltv.py | 52 | 
1 files changed, 41 insertions, 11 deletions
| diff --git a/youtube_dl/extractor/spiegeltv.py b/youtube_dl/extractor/spiegeltv.py index 98cf92d89..27f4033c5 100644 --- a/youtube_dl/extractor/spiegeltv.py +++ b/youtube_dl/extractor/spiegeltv.py @@ -2,7 +2,11 @@  from __future__ import unicode_literals  from .common import InfoExtractor -from ..utils import float_or_none +from ..compat import compat_urllib_parse_urlparse +from ..utils import ( +    determine_ext, +    float_or_none, +)  class SpiegeltvIE(InfoExtractor): @@ -17,7 +21,7 @@ class SpiegeltvIE(InfoExtractor):              'thumbnail': 're:http://.*\.jpg$',          },          'params': { -            # rtmp download +            # m3u8 download              'skip_download': True,          }      }, { @@ -51,9 +55,39 @@ class SpiegeltvIE(InfoExtractor):          is_wide = media_json['is_wide']          server_json = self._download_json( -            'http://www.spiegel.tv/streaming_servers/', video_id, -            note='Downloading server information') -        server = server_json[0]['endpoint'] +            'http://spiegeltv-prod-static.s3.amazonaws.com/projectConfigs/projectConfig.json', +            video_id, note='Downloading server information') + +        format = '16x9' if is_wide else '4x3' + +        formats = [] +        for streamingserver in server_json['streamingserver']: +            endpoint = streamingserver.get('endpoint') +            if not endpoint: +                continue +            play_path = 'mp4:%s_spiegeltv_0500_%s.m4v' % (uuid, format) +            if endpoint.startswith('rtmp'): +                formats.append({ +                    'url': endpoint, +                    'format_id': 'rtmp', +                    'app': compat_urllib_parse_urlparse(endpoint).path[1:], +                    'play_path': play_path, +                    'player_path': 'http://prod-static.spiegel.tv/frontend-076.swf', +                    'ext': 'flv', +                    'rtmp_live': True, +                }) +            elif determine_ext(endpoint) == 'm3u8': +                m3u8_formats = self._extract_m3u8_formats( +                    endpoint.replace('[video]', play_path), +                    video_id, 'm4v', +                    preference=1,  # Prefer hls since it allows to workaround georestriction +                    m3u8_id='hls', fatal=False) +                if m3u8_formats is not False: +                    formats.extend(m3u8_formats) +            else: +                formats.append({ +                    'url': endpoint, +                })          thumbnails = []          for image in media_json['images']: @@ -65,16 +99,12 @@ class SpiegeltvIE(InfoExtractor):          description = media_json['subtitle']          duration = float_or_none(media_json.get('duration_in_ms'), scale=1000) -        format = '16x9' if is_wide else '4x3' - -        url = server + 'mp4:' + uuid + '_spiegeltv_0500_' + format + '.m4v'          return {              'id': video_id,              'title': title, -            'url': url, -            'ext': 'm4v',              'description': description,              'duration': duration, -            'thumbnails': thumbnails +            'thumbnails': thumbnails, +            'formats': formats,          } | 
