|
|
@ -217,6 +217,7 @@ class GoIE(AdobePassIE):
|
|
|
|
title = video_data['title']
|
|
|
|
title = video_data['title']
|
|
|
|
|
|
|
|
|
|
|
|
formats = []
|
|
|
|
formats = []
|
|
|
|
|
|
|
|
subtitles = {}
|
|
|
|
for asset in video_data.get('assets', {}).get('asset', []):
|
|
|
|
for asset in video_data.get('assets', {}).get('asset', []):
|
|
|
|
asset_url = asset.get('value')
|
|
|
|
asset_url = asset.get('value')
|
|
|
|
if not asset_url:
|
|
|
|
if not asset_url:
|
|
|
@ -256,8 +257,10 @@ class GoIE(AdobePassIE):
|
|
|
|
error_message = ', '.join([error['message'] for error in errors])
|
|
|
|
error_message = ', '.join([error['message'] for error in errors])
|
|
|
|
raise ExtractorError('%s said: %s' % (self.IE_NAME, error_message), expected=True)
|
|
|
|
raise ExtractorError('%s said: %s' % (self.IE_NAME, error_message), expected=True)
|
|
|
|
asset_url += '?' + entitlement['uplynkData']['sessionKey']
|
|
|
|
asset_url += '?' + entitlement['uplynkData']['sessionKey']
|
|
|
|
formats.extend(self._extract_m3u8_formats(
|
|
|
|
fmts, subs = self._extract_m3u8_formats_and_subtitles(
|
|
|
|
asset_url, video_id, 'mp4', m3u8_id=format_id or 'hls', fatal=False))
|
|
|
|
asset_url, video_id, 'mp4', m3u8_id=format_id or 'hls', fatal=False)
|
|
|
|
|
|
|
|
formats.extend(fmts)
|
|
|
|
|
|
|
|
self._merge_subtitles(subs, target=subtitles)
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
f = {
|
|
|
|
f = {
|
|
|
|
'format_id': format_id,
|
|
|
|
'format_id': format_id,
|
|
|
@ -281,7 +284,6 @@ class GoIE(AdobePassIE):
|
|
|
|
formats.append(f)
|
|
|
|
formats.append(f)
|
|
|
|
self._sort_formats(formats)
|
|
|
|
self._sort_formats(formats)
|
|
|
|
|
|
|
|
|
|
|
|
subtitles = {}
|
|
|
|
|
|
|
|
for cc in video_data.get('closedcaption', {}).get('src', []):
|
|
|
|
for cc in video_data.get('closedcaption', {}).get('src', []):
|
|
|
|
cc_url = cc.get('value')
|
|
|
|
cc_url = cc.get('value')
|
|
|
|
if not cc_url:
|
|
|
|
if not cc_url:
|
|
|
|