|
|
@ -16,6 +16,7 @@ from ..utils import (
|
|
|
|
int_or_none,
|
|
|
|
int_or_none,
|
|
|
|
float_or_none,
|
|
|
|
float_or_none,
|
|
|
|
parse_duration,
|
|
|
|
parse_duration,
|
|
|
|
|
|
|
|
determine_ext,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -51,7 +52,8 @@ class FranceTVBaseInfoExtractor(InfoExtractor):
|
|
|
|
if not video_url:
|
|
|
|
if not video_url:
|
|
|
|
continue
|
|
|
|
continue
|
|
|
|
format_id = video['format']
|
|
|
|
format_id = video['format']
|
|
|
|
if video_url.endswith('.f4m'):
|
|
|
|
ext = determine_ext(video_url)
|
|
|
|
|
|
|
|
if ext == 'f4m':
|
|
|
|
if georestricted:
|
|
|
|
if georestricted:
|
|
|
|
# See https://github.com/rg3/youtube-dl/issues/3963
|
|
|
|
# See https://github.com/rg3/youtube-dl/issues/3963
|
|
|
|
# m3u8 urls work fine
|
|
|
|
# m3u8 urls work fine
|
|
|
@ -61,12 +63,9 @@ class FranceTVBaseInfoExtractor(InfoExtractor):
|
|
|
|
'http://hdfauth.francetv.fr/esi/urltokengen2.html?url=%s' % video_url_parsed.path,
|
|
|
|
'http://hdfauth.francetv.fr/esi/urltokengen2.html?url=%s' % video_url_parsed.path,
|
|
|
|
video_id, 'Downloading f4m manifest token', fatal=False)
|
|
|
|
video_id, 'Downloading f4m manifest token', fatal=False)
|
|
|
|
if f4m_url:
|
|
|
|
if f4m_url:
|
|
|
|
f4m_formats = self._extract_f4m_formats(f4m_url, video_id)
|
|
|
|
formats.extend(self._extract_f4m_formats(f4m_url, video_id, 1, format_id))
|
|
|
|
for f4m_format in f4m_formats:
|
|
|
|
elif ext == 'm3u8':
|
|
|
|
f4m_format['preference'] = 1
|
|
|
|
formats.extend(self._extract_m3u8_formats(video_url, video_id, 'mp4', m3u8_id=format_id))
|
|
|
|
formats.extend(f4m_formats)
|
|
|
|
|
|
|
|
elif video_url.endswith('.m3u8'):
|
|
|
|
|
|
|
|
formats.extend(self._extract_m3u8_formats(video_url, video_id, 'mp4'))
|
|
|
|
|
|
|
|
elif video_url.startswith('rtmp'):
|
|
|
|
elif video_url.startswith('rtmp'):
|
|
|
|
formats.append({
|
|
|
|
formats.append({
|
|
|
|
'url': video_url,
|
|
|
|
'url': video_url,
|
|
|
|