diff options
| -rw-r--r-- | youtube_dl/extractor/once.py | 37 | 
1 files changed, 37 insertions, 0 deletions
| diff --git a/youtube_dl/extractor/once.py b/youtube_dl/extractor/once.py new file mode 100644 index 000000000..403f8c0af --- /dev/null +++ b/youtube_dl/extractor/once.py @@ -0,0 +1,37 @@ +# coding: utf-8 +from __future__ import unicode_literals + +import re + +from .common import InfoExtractor + + +class OnceIE(InfoExtractor): +    _VALID_URL = r'https?://once\.unicornmedia\.com/now/[^/]+/[^/]+/(?P<domain_id>[^/]+)/(?P<application_id>[^/]+)/(?:[^/]+/)?(?P<media_item_id>[^/]+)/content\.(?:once|m3u8|mp4)' +    ADAPTIVE_URL_TEMPLATE = 'http://once.unicornmedia.com/now/master/playlist/%s/%s/%s/content.m3u8' +    PROGRESSIVE_URL_TEMPLATE = 'http://once.unicornmedia.com/now/media/progressive/%s/%s/%s/%s/content.mp4' + +    def _extract_once_formats(self, url): +        domain_id, application_id, media_item_id = re.match( +            OnceIE._VALID_URL, url).groups() +        adaptive_formats = self._extract_m3u8_formats( +            self.ADAPTIVE_URL_TEMPLATE % ( +                domain_id, application_id, media_item_id), +            media_item_id, 'mp4', m3u8_id='hls', fatal=False) +        formats = [] +        formats.extend(adaptive_formats) +        for adaptive_format in adaptive_formats: +            rendition_id = self._search_regex( +                r'/now/media/playlist/[^/]+/[^/]+/([^/]+)', +                adaptive_format['url'], 'redition id', default=None) +            if rendition_id: +                progressive_format = adaptive_format.copy() +                progressive_format.update({ +                    'url': self.PROGRESSIVE_URL_TEMPLATE % ( +                        domain_id, application_id, rendition_id, media_item_id), +                    'format_id': adaptive_format['format_id'].replace( +                        'hls', 'http'), +                    'protocol': 'http', +                }) +                formats.append(progressive_format) +        return formats | 
