[orf:tvthek] Fix extraction (closes #17737)
authorSebastian Haas <sehaas@deebas.com>
Tue, 30 Oct 2018 22:44:50 +0000 (23:44 +0100)
committerSergey M․ <dstftw@gmail.com>
Fri, 2 Nov 2018 16:47:17 +0000 (23:47 +0700)
use _extract_m3u8_formats and _extract_f4m_formats helper functions
closes #17737

youtube_dl/extractor/orf.py

index c1fb580ca8d9a20d785d71194d2822e51b2ee1ae..da8031ad297455a764ae71a2d18fa8566e397bde 100644 (file)
@@ -80,14 +80,16 @@ class ORFTVthekIE(InfoExtractor):
             if not video_id or not title:
                 continue
             video_id = compat_str(video_id)
-            formats = [{
-                'preference': -10 if fd['delivery'] == 'hls' else None,
-                'format_id': '%s-%s-%s' % (
-                    fd['delivery'], fd['quality'], fd['quality_string']),
-                'url': fd['src'],
-                'protocol': fd['protocol'],
-                'quality': quality_to_int(fd['quality']),
-            } for fd in sd['sources']]
+            formats = []
+            for fd in sd['sources']:
+                format_id = '%s-%s-%s' % (
+                    fd['delivery'], fd['quality'], fd['quality_string'])
+                if determine_ext(fd['src']) == 'm3u8':
+                    formats.extend(self._extract_m3u8_formats(
+                        fd['src'], video_id, 'mp4', m3u8_id=format_id))
+                elif determine_ext(fd['src']) == 'f4m':
+                    formats.extend(self._extract_f4m_formats(
+                        fd['src'], video_id, f4m_id=format_id))
 
             # Check for geoblocking.
             # There is a property is_geoprotection, but that's always false