once.py 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. # coding: utf-8
  2. from __future__ import unicode_literals
  3. import re
  4. from .common import InfoExtractor
  5. class OnceIE(InfoExtractor):
  6. _VALID_URL = r'https?://once\.unicornmedia\.com/now/[^/]+/[^/]+/(?P<domain_id>[^/]+)/(?P<application_id>[^/]+)/(?:[^/]+/)?(?P<media_item_id>[^/]+)/content\.(?:once|m3u8|mp4)'
  7. ADAPTIVE_URL_TEMPLATE = 'http://once.unicornmedia.com/now/master/playlist/%s/%s/%s/content.m3u8'
  8. PROGRESSIVE_URL_TEMPLATE = 'http://once.unicornmedia.com/now/media/progressive/%s/%s/%s/%s/content.mp4'
  9. def _extract_once_formats(self, url):
  10. domain_id, application_id, media_item_id = re.match(
  11. OnceIE._VALID_URL, url).groups()
  12. adaptive_formats = self._extract_m3u8_formats(
  13. self.ADAPTIVE_URL_TEMPLATE % (
  14. domain_id, application_id, media_item_id),
  15. media_item_id, 'mp4', m3u8_id='hls', fatal=False)
  16. formats = []
  17. formats.extend(adaptive_formats)
  18. for adaptive_format in adaptive_formats:
  19. rendition_id = self._search_regex(
  20. r'/now/media/playlist/[^/]+/[^/]+/([^/]+)',
  21. adaptive_format['url'], 'redition id', default=None)
  22. if rendition_id:
  23. progressive_format = adaptive_format.copy()
  24. progressive_format.update({
  25. 'url': self.PROGRESSIVE_URL_TEMPLATE % (
  26. domain_id, application_id, rendition_id, media_item_id),
  27. 'format_id': adaptive_format['format_id'].replace(
  28. 'hls', 'http'),
  29. 'protocol': 'http',
  30. })
  31. formats.append(progressive_format)
  32. return formats