|
|
@ -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 |