|
|
@ -1931,8 +1931,15 @@ class YoutubeIE(YoutubeBaseInfoExtractor): |
|
|
|
'http_chunk_size': 10485760, |
|
|
|
'http_chunk_size': 10485760, |
|
|
|
} |
|
|
|
} |
|
|
|
formats.append(dct) |
|
|
|
formats.append(dct) |
|
|
|
elif video_info.get('hlsvp'): |
|
|
|
else: |
|
|
|
manifest_url = video_info['hlsvp'][0] |
|
|
|
manifest_url = ( |
|
|
|
|
|
|
|
url_or_none(try_get( |
|
|
|
|
|
|
|
player_response, |
|
|
|
|
|
|
|
lambda x: x['streamingData']['hlsManifestUrl'], |
|
|
|
|
|
|
|
compat_str)) or |
|
|
|
|
|
|
|
url_or_none(try_get( |
|
|
|
|
|
|
|
video_info, lambda x: x['hlsvp'][0], compat_str))) |
|
|
|
|
|
|
|
if manifest_url: |
|
|
|
formats = [] |
|
|
|
formats = [] |
|
|
|
m3u8_formats = self._extract_m3u8_formats( |
|
|
|
m3u8_formats = self._extract_m3u8_formats( |
|
|
|
manifest_url, video_id, 'mp4', fatal=False) |
|
|
|
manifest_url, video_id, 'mp4', fatal=False) |
|
|
@ -1955,7 +1962,7 @@ class YoutubeIE(YoutubeBaseInfoExtractor): |
|
|
|
error_message = extract_unavailable_message() |
|
|
|
error_message = extract_unavailable_message() |
|
|
|
if error_message: |
|
|
|
if error_message: |
|
|
|
raise ExtractorError(error_message, expected=True) |
|
|
|
raise ExtractorError(error_message, expected=True) |
|
|
|
raise ExtractorError('no conn, hlsvp or url_encoded_fmt_stream_map information found in video info') |
|
|
|
raise ExtractorError('no conn, hlsvp, hlsManifestUrl or url_encoded_fmt_stream_map information found in video info') |
|
|
|
|
|
|
|
|
|
|
|
# uploader |
|
|
|
# uploader |
|
|
|
video_uploader = try_get( |
|
|
|
video_uploader = try_get( |
|
|
|