+ def _extract_common_video_info(self, content_id, asset_types, mpx_acc, extra_info):
+ tp_path = 'dJ5BDC/media/guid/%d/%s' % (mpx_acc, content_id)
+ tp_release_url = f'https://link.theplatform.com/s/{tp_path}'
+ info = self._extract_theplatform_metadata(tp_path, content_id)
+
+ formats, subtitles = [], {}
+ last_e = None
+ for asset_type, query in asset_types.items():
+ try:
+ tp_formats, tp_subtitles = self._extract_theplatform_smil(
+ update_url_query(tp_release_url, query), content_id,
+ 'Downloading %s SMIL data' % asset_type)
+ except ExtractorError as e:
+ last_e = e
+ if asset_type != 'fallback':
+ continue
+ query['formats'] = '' # blank query to check if expired
+ try:
+ tp_formats, tp_subtitles = self._extract_theplatform_smil(
+ update_url_query(tp_release_url, query), content_id,
+ 'Downloading %s SMIL data, trying again with another format' % asset_type)
+ except ExtractorError as e:
+ last_e = e
+ continue
+ formats.extend(tp_formats)
+ subtitles = self._merge_subtitles(subtitles, tp_subtitles)
+ if last_e and not formats:
+ self.raise_no_formats(last_e, True, content_id)
+
+ extra_info.update({
+ 'id': content_id,
+ 'formats': formats,
+ 'subtitles': subtitles,
+ })
+ info.update({k: v for k, v in extra_info.items() if v is not None})
+ return info
+
+ def _extract_video_info(self, *args, **kwargs):
+ # Extract assets + metadata and call _extract_common_video_info
+ raise NotImplementedError('This method must be implemented by subclasses')
+
+ def _real_extract(self, url):
+ return self._extract_video_info(self._match_id(url))
+