[download/hls] Delegate downloading to ffmpeg for live streams
This commit is contained in:
		| @@ -31,7 +31,7 @@ class HlsFD(FragmentFD): | ||||
|     FD_NAME = 'hlsnative' | ||||
|  | ||||
|     @staticmethod | ||||
|     def can_download(manifest): | ||||
|     def can_download(manifest, info_dict): | ||||
|         UNSUPPORTED_FEATURES = ( | ||||
|             r'#EXT-X-KEY:METHOD=(?!NONE|AES-128)',  # encrypted streams [1] | ||||
|             r'#EXT-X-BYTERANGE',  # playlists composed of byte ranges of media files [2] | ||||
| @@ -53,6 +53,7 @@ class HlsFD(FragmentFD): | ||||
|         ) | ||||
|         check_results = [not re.search(feature, manifest) for feature in UNSUPPORTED_FEATURES] | ||||
|         check_results.append(can_decrypt_frag or '#EXT-X-KEY:METHOD=AES-128' not in manifest) | ||||
|         check_results.append(not info_dict.get('is_live')) | ||||
|         return all(check_results) | ||||
|  | ||||
|     def real_download(self, filename, info_dict): | ||||
| @@ -62,7 +63,7 @@ class HlsFD(FragmentFD): | ||||
|  | ||||
|         s = manifest.decode('utf-8', 'ignore') | ||||
|  | ||||
|         if not self.can_download(s): | ||||
|         if not self.can_download(s, info_dict): | ||||
|             self.report_warning( | ||||
|                 'hlsnative has detected features it does not support, ' | ||||
|                 'extraction will be delegated to ffmpeg') | ||||
|   | ||||
		Reference in New Issue
	
	Block a user