- video_data = self._download_json(
- 'http://metaframe.digitalsmiths.tv/v2/CWtv/assets/%s/partner/132?format=json' % video_id, video_id)
-
- formats = self._extract_m3u8_formats(
- video_data['videos']['variantplaylist']['uri'], video_id, 'mp4')
+ video_data = None
+ formats = []
+ for partner in (154, 213):
+ vdata = self._download_json(
+ 'http://metaframe.digitalsmiths.tv/v2/CWtv/assets/%s/partner/%d?format=json' % (video_id, partner), video_id, fatal=False)
+ if not vdata:
+ continue
+ video_data = vdata
+ for quality, quality_data in vdata.get('videos', {}).items():
+ quality_url = quality_data.get('uri')
+ if not quality_url:
+ continue
+ if quality == 'variantplaylist':
+ formats.extend(self._extract_m3u8_formats(
+ quality_url, video_id, 'mp4', m3u8_id='hls', fatal=False))
+ else:
+ tbr = int_or_none(quality_data.get('bitrate'))
+ format_id = 'http' + ('-%d' % tbr if tbr else '')
+ if self._is_valid_url(quality_url, video_id, format_id):
+ formats.append({
+ 'format_id': format_id,
+ 'url': quality_url,
+ 'tbr': tbr,
+ })
+ self._sort_formats(formats)