|
|
|
@ -119,7 +119,8 @@ class LivestreamIE(InfoExtractor):
|
|
|
|
|
m3u8_url = video_data.get('m3u8_url')
|
|
|
|
|
if m3u8_url:
|
|
|
|
|
formats.extend(self._extract_m3u8_formats(
|
|
|
|
|
m3u8_url, video_id, 'mp4', 'm3u8_native', m3u8_id='hls', fatal=False))
|
|
|
|
|
m3u8_url, video_id, 'mp4', 'm3u8_native',
|
|
|
|
|
m3u8_id='hls', fatal=False))
|
|
|
|
|
|
|
|
|
|
f4m_url = video_data.get('f4m_url')
|
|
|
|
|
if f4m_url:
|
|
|
|
@ -158,11 +159,11 @@ class LivestreamIE(InfoExtractor):
|
|
|
|
|
if smil_url:
|
|
|
|
|
formats.extend(self._extract_smil_formats(smil_url, broadcast_id))
|
|
|
|
|
|
|
|
|
|
entry_protocol = 'm3u8' if is_live else 'm3u8_native'
|
|
|
|
|
m3u8_url = stream_info.get('m3u8_url')
|
|
|
|
|
if m3u8_url:
|
|
|
|
|
formats.extend(self._extract_m3u8_formats(
|
|
|
|
|
m3u8_url, broadcast_id, 'mp4', entry_protocol, m3u8_id='hls', fatal=False))
|
|
|
|
|
m3u8_url, broadcast_id, 'mp4', 'm3u8_native',
|
|
|
|
|
m3u8_id='hls', fatal=False))
|
|
|
|
|
|
|
|
|
|
rtsp_url = stream_info.get('rtsp_url')
|
|
|
|
|
if rtsp_url:
|
|
|
|
@ -276,7 +277,7 @@ class LivestreamOriginalIE(InfoExtractor):
|
|
|
|
|
'view_count': view_count,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
def _extract_video_formats(self, video_data, video_id, entry_protocol):
|
|
|
|
|
def _extract_video_formats(self, video_data, video_id):
|
|
|
|
|
formats = []
|
|
|
|
|
|
|
|
|
|
progressive_url = video_data.get('progressiveUrl')
|
|
|
|
@ -289,7 +290,8 @@ class LivestreamOriginalIE(InfoExtractor):
|
|
|
|
|
m3u8_url = video_data.get('httpUrl')
|
|
|
|
|
if m3u8_url:
|
|
|
|
|
formats.extend(self._extract_m3u8_formats(
|
|
|
|
|
m3u8_url, video_id, 'mp4', entry_protocol, m3u8_id='hls', fatal=False))
|
|
|
|
|
m3u8_url, video_id, 'mp4', 'm3u8_native',
|
|
|
|
|
m3u8_id='hls', fatal=False))
|
|
|
|
|
|
|
|
|
|
rtsp_url = video_data.get('rtspUrl')
|
|
|
|
|
if rtsp_url:
|
|
|
|
@ -340,11 +342,10 @@ class LivestreamOriginalIE(InfoExtractor):
|
|
|
|
|
}
|
|
|
|
|
video_data = self._download_json(stream_url, content_id)
|
|
|
|
|
is_live = video_data.get('isLive')
|
|
|
|
|
entry_protocol = 'm3u8' if is_live else 'm3u8_native'
|
|
|
|
|
info.update({
|
|
|
|
|
'id': content_id,
|
|
|
|
|
'title': self._live_title(info['title']) if is_live else info['title'],
|
|
|
|
|
'formats': self._extract_video_formats(video_data, content_id, entry_protocol),
|
|
|
|
|
'formats': self._extract_video_formats(video_data, content_id),
|
|
|
|
|
'is_live': is_live,
|
|
|
|
|
})
|
|
|
|
|
return info
|
|
|
|
|