mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-31 14:45:14 +00:00 
			
		
		
		
	[orf:iptv] Add extractor (Closes #5140)
This commit is contained in:
		| @@ -354,6 +354,7 @@ from .orf import ( | |||||||
|     ORFTVthekIE, |     ORFTVthekIE, | ||||||
|     ORFOE1IE, |     ORFOE1IE, | ||||||
|     ORFFM4IE, |     ORFFM4IE, | ||||||
|  |     ORFIPTVIE, | ||||||
| ) | ) | ||||||
| from .parliamentliveuk import ParliamentLiveUKIE | from .parliamentliveuk import ParliamentLiveUKIE | ||||||
| from .patreon import PatreonIE | from .patreon import PatreonIE | ||||||
|   | |||||||
| @@ -11,6 +11,11 @@ from ..utils import ( | |||||||
|     HEADRequest, |     HEADRequest, | ||||||
|     unified_strdate, |     unified_strdate, | ||||||
|     ExtractorError, |     ExtractorError, | ||||||
|  |     strip_jsonp, | ||||||
|  |     int_or_none, | ||||||
|  |     float_or_none, | ||||||
|  |     determine_ext, | ||||||
|  |     remove_end, | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -197,3 +202,92 @@ class ORFFM4IE(InfoExtractor): | |||||||
|             'description': data['subtitle'], |             'description': data['subtitle'], | ||||||
|             'entries': entries |             'entries': entries | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class ORFIPTVIE(InfoExtractor): | ||||||
|  |     IE_NAME = 'orf:iptv' | ||||||
|  |     IE_DESC = 'iptv.ORF.at' | ||||||
|  |     _VALID_URL = r'http://iptv\.orf\.at/(?:#/)?stories/(?P<id>\d+)' | ||||||
|  |  | ||||||
|  |     _TEST = { | ||||||
|  |         'url': 'http://iptv.orf.at/stories/2267952', | ||||||
|  |         'md5': '26ffa4bab6dbce1eee78bbc7021016cd', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': '339775', | ||||||
|  |             'ext': 'flv', | ||||||
|  |             'title': 'Kreml-Kritiker Nawalny wieder frei', | ||||||
|  |             'description': 'md5:6f24e7f546d364dacd0e616a9e409236', | ||||||
|  |             'duration': 84.729, | ||||||
|  |             'thumbnail': 're:^https?://.*\.jpg$', | ||||||
|  |             'upload_date': '20150306', | ||||||
|  |         }, | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     def _real_extract(self, url): | ||||||
|  |         story_id = self._match_id(url) | ||||||
|  |  | ||||||
|  |         webpage = self._download_webpage( | ||||||
|  |             'http://iptv.orf.at/stories/%s' % story_id, story_id) | ||||||
|  |  | ||||||
|  |         video_id = self._search_regex( | ||||||
|  |             r'data-video(?:id)?="(\d+)"', webpage, 'video id') | ||||||
|  |  | ||||||
|  |         data = self._download_json( | ||||||
|  |             'http://bits.orf.at/filehandler/static-api/json/current/data.json?file=%s' % video_id, | ||||||
|  |             video_id)[0] | ||||||
|  |  | ||||||
|  |         duration = float_or_none(data['duration'], 1000) | ||||||
|  |  | ||||||
|  |         video = data['sources']['default'] | ||||||
|  |         load_balancer_url = video['loadBalancerUrl'] | ||||||
|  |         abr = int_or_none(video.get('audioBitrate')) | ||||||
|  |         vbr = int_or_none(video.get('bitrate')) | ||||||
|  |         fps = int_or_none(video.get('videoFps')) | ||||||
|  |         width = int_or_none(video.get('videoWidth')) | ||||||
|  |         height = int_or_none(video.get('videoHeight')) | ||||||
|  |         thumbnail = video.get('preview') | ||||||
|  |  | ||||||
|  |         rendition = self._download_json( | ||||||
|  |             load_balancer_url, video_id, transform_source=strip_jsonp) | ||||||
|  |  | ||||||
|  |         f = { | ||||||
|  |             'abr': abr, | ||||||
|  |             'vbr': vbr, | ||||||
|  |             'fps': fps, | ||||||
|  |             'width': width, | ||||||
|  |             'height': height, | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         formats = [] | ||||||
|  |         for format_id, format_url in rendition['redirect'].items(): | ||||||
|  |             if format_id == 'rtmp': | ||||||
|  |                 ff = f.copy() | ||||||
|  |                 ff.update({ | ||||||
|  |                     'url': format_url, | ||||||
|  |                     'format_id': format_id, | ||||||
|  |                 }) | ||||||
|  |                 formats.append(ff) | ||||||
|  |             elif determine_ext(format_url) == 'f4m': | ||||||
|  |                 formats.extend(self._extract_f4m_formats( | ||||||
|  |                     format_url, video_id, f4m_id=format_id)) | ||||||
|  |             elif determine_ext(format_url) == 'm3u8': | ||||||
|  |                 formats.extend(self._extract_m3u8_formats( | ||||||
|  |                     format_url, video_id, 'mp4', m3u8_id=format_id)) | ||||||
|  |             else: | ||||||
|  |                 continue | ||||||
|  |         self._sort_formats(formats) | ||||||
|  |  | ||||||
|  |         title = remove_end(self._og_search_title(webpage), ' - iptv.ORF.at') | ||||||
|  |         description = self._og_search_description(webpage) | ||||||
|  |         upload_date = unified_strdate(self._html_search_meta( | ||||||
|  |             'dc.date', webpage, 'upload date')) | ||||||
|  |  | ||||||
|  |         return { | ||||||
|  |             'id': video_id, | ||||||
|  |             'title': title, | ||||||
|  |             'description': description, | ||||||
|  |             'duration': duration, | ||||||
|  |             'thumbnail': thumbnail, | ||||||
|  |             'upload_date': upload_date, | ||||||
|  |             'formats': formats, | ||||||
|  |         } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Sergey M․
					Sergey M․