[brightcove] Extract more formats (#8862)

This commit is contained in:
Yen Chi Hsuan 2016-03-26 18:21:07 +08:00
parent 5964b598ff
commit d6c340cae5

View File

@ -297,7 +297,7 @@ def _extract_video_info(self, video_info):
'uploader': video_info.get('publisherName'), 'uploader': video_info.get('publisherName'),
} }
renditions = video_info.get('renditions') renditions = video_info.get('renditions', []) + video_info.get('IOSRenditions', [])
if renditions: if renditions:
formats = [] formats = []
for rend in renditions: for rend in renditions:
@ -319,13 +319,23 @@ def _extract_video_info(self, video_info):
if ext is None: if ext is None:
ext = determine_ext(url) ext = determine_ext(url)
size = rend.get('size') size = rend.get('size')
formats.append({ a_format = {
'url': url, 'url': url,
'ext': ext, 'ext': ext,
'height': rend.get('frameHeight'), 'height': rend.get('frameHeight'),
'width': rend.get('frameWidth'), 'width': rend.get('frameWidth'),
'filesize': size if size != 0 else None, 'filesize': size if size != 0 else None,
}) }
# m3u8 manifests with remote == false are media playlists
# Not calling _extract_m3u8_formats here to save network traffic
if ext == 'm3u8':
a_format.update({
'ext': 'mp4',
'protocol': 'm3u8',
})
formats.append(a_format)
self._sort_formats(formats) self._sort_formats(formats)
info['formats'] = formats info['formats'] = formats
elif video_info.get('FLVFullLengthURL') is not None: elif video_info.get('FLVFullLengthURL') is not None: