[StreamCZ] Add support for stream.cz
This commit is contained in:
		| @@ -203,6 +203,7 @@ from .stanfordoc import StanfordOpenClassroomIE | |||||||
| from .statigram import StatigramIE | from .statigram import StatigramIE | ||||||
| from .steam import SteamIE | from .steam import SteamIE | ||||||
| from .streamcloud import StreamcloudIE | from .streamcloud import StreamcloudIE | ||||||
|  | from .streamcz import StreamCZIE | ||||||
| from .sztvhu import SztvHuIE | from .sztvhu import SztvHuIE | ||||||
| from .teamcoco import TeamcocoIE | from .teamcoco import TeamcocoIE | ||||||
| from .techtalks import TechTalksIE | from .techtalks import TechTalksIE | ||||||
|   | |||||||
							
								
								
									
										64
									
								
								youtube_dl/extractor/streamcz.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								youtube_dl/extractor/streamcz.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | |||||||
|  | # -*- coding: utf-8 -*- | ||||||
|  | from __future__ import unicode_literals | ||||||
|  |  | ||||||
|  | import re | ||||||
|  | import json | ||||||
|  |  | ||||||
|  | from .common import InfoExtractor | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class StreamCZIE(InfoExtractor): | ||||||
|  |     _VALID_URL = r'https?://www\.stream\.cz/((?P<category>.+)/)?(?P<videogroup>.+)/(?P<videoid>.+)' | ||||||
|  |  | ||||||
|  |     _TESTS = [{ | ||||||
|  |         'url': 'http://www.stream.cz/peklonataliri/765767-ecka-pro-deti', | ||||||
|  |         'md5': '6d3ca61a8d0633c9c542b92fcb936b0c', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': '765767', | ||||||
|  |             'ext': 'mp4', | ||||||
|  |             'title': 'Peklo na talíři: Éčka pro děti', | ||||||
|  |             'description': 'md5:49ace0df986e95e331d0fe239d421519', | ||||||
|  |             'thumbnail': 'http://im.stream.cz/episode/52961d7e19d423f8f06f0100', | ||||||
|  |         }, | ||||||
|  |     }, | ||||||
|  |     ] | ||||||
|  |  | ||||||
|  |     def _real_extract(self, url): | ||||||
|  |         mobj = re.match(self._VALID_URL, url) | ||||||
|  |         video_id = mobj.group('videoid') | ||||||
|  |  | ||||||
|  |         webpage = self._download_webpage(url, video_id) | ||||||
|  |  | ||||||
|  |         data = self._html_search_regex(r'Stream\.Data\.Episode\((.+?)\);', webpage, 'stream data') | ||||||
|  |  | ||||||
|  |         jsonData = json.loads(data) | ||||||
|  |  | ||||||
|  |         formats = [] | ||||||
|  |         for video in jsonData['instances']: | ||||||
|  |             format_id = video['instances'][0]['quality'] | ||||||
|  |  | ||||||
|  |             if format_id == '240p': | ||||||
|  |                 quality = 0 | ||||||
|  |             elif format_id == '360p': | ||||||
|  |                 quality = 1 | ||||||
|  |             elif format_id == '480p': | ||||||
|  |                 quality = 2 | ||||||
|  |             elif format_id == '720p': | ||||||
|  |                 quality = 3 | ||||||
|  |  | ||||||
|  |             formats.append({ | ||||||
|  |                 'format_id': format_id, | ||||||
|  |                 'url': video['instances'][0]['source'], | ||||||
|  |                 'quality': quality, | ||||||
|  |                 'ext': 'mp4', | ||||||
|  |             }) | ||||||
|  |  | ||||||
|  |         self._sort_formats(formats) | ||||||
|  |  | ||||||
|  |         return { | ||||||
|  |             'id': str(jsonData['id']), | ||||||
|  |             'title': self._og_search_title(webpage), | ||||||
|  |             'thumbnail': jsonData['episode_image_original_url'].replace('//', 'http://'), | ||||||
|  |             'formats': formats, | ||||||
|  |             'description': self._og_search_description(webpage), | ||||||
|  |         } | ||||||
		Reference in New Issue
	
	Block a user