| 
									
										
										
										
											2016-09-09 23:20:45 +07:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from .common import InfoExtractor | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class KetnetIE(InfoExtractor): | 
					
						
							|  |  |  |     _VALID_URL = r'https?://(?:www\.)?ketnet\.be/(?:[^/]+/)*(?P<id>[^/?#&]+)' | 
					
						
							|  |  |  |     _TESTS = [{ | 
					
						
							|  |  |  |         'url': 'https://www.ketnet.be/kijken/zomerse-filmpjes', | 
					
						
							|  |  |  |         'md5': 'd907f7b1814ef0fa285c0475d9994ed7', | 
					
						
							|  |  |  |         'info_dict': { | 
					
						
							|  |  |  |             'id': 'zomerse-filmpjes', | 
					
						
							|  |  |  |             'ext': 'mp4', | 
					
						
							|  |  |  |             'title': 'Gluur mee op de filmset en op Pennenzakkenrock', | 
					
						
							|  |  |  |             'description': 'Gluur mee met Ghost Rockers op de filmset', | 
					
						
							|  |  |  |             'thumbnail': 're:^https?://.*\.jpg$', | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }, { | 
					
						
							|  |  |  |         'url': 'https://www.ketnet.be/kijken/karrewiet/uitzending-8-september-2016', | 
					
						
							|  |  |  |         'only_matching': True, | 
					
						
							|  |  |  |     }, { | 
					
						
							|  |  |  |         'url': 'https://www.ketnet.be/achter-de-schermen/sien-repeteert-voor-stars-for-life', | 
					
						
							|  |  |  |         'only_matching': True, | 
					
						
							| 
									
										
										
										
											2016-09-28 22:58:25 +07:00
										 |  |  |     }, { | 
					
						
							|  |  |  |         # mzsource, geo restricted to Belgium | 
					
						
							|  |  |  |         'url': 'https://www.ketnet.be/kijken/nachtwacht/de-bermadoe', | 
					
						
							|  |  |  |         'only_matching': True, | 
					
						
							| 
									
										
										
										
											2016-09-09 23:20:45 +07:00
										 |  |  |     }] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def _real_extract(self, url): | 
					
						
							|  |  |  |         video_id = self._match_id(url) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         webpage = self._download_webpage(url, video_id) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         config = self._parse_json( | 
					
						
							|  |  |  |             self._search_regex( | 
					
						
							|  |  |  |                 r'(?s)playerConfig\s*=\s*({.+?})\s*;', webpage, | 
					
						
							|  |  |  |                 'player config'), | 
					
						
							|  |  |  |             video_id) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         title = config['title'] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-28 22:58:25 +07:00
										 |  |  |         formats = [] | 
					
						
							|  |  |  |         for source_key in ('', 'mz'): | 
					
						
							|  |  |  |             source = config.get('%ssource' % source_key) | 
					
						
							|  |  |  |             if not isinstance(source, dict): | 
					
						
							|  |  |  |                 continue | 
					
						
							|  |  |  |             for format_id, format_url in source.items(): | 
					
						
							|  |  |  |                 if format_id == 'hls': | 
					
						
							|  |  |  |                     formats.extend(self._extract_m3u8_formats( | 
					
						
							|  |  |  |                         format_url, video_id, 'mp4', | 
					
						
							|  |  |  |                         entry_protocol='m3u8_native', m3u8_id=format_id, | 
					
						
							|  |  |  |                         fatal=False)) | 
					
						
							|  |  |  |                 elif format_id == 'hds': | 
					
						
							|  |  |  |                     formats.extend(self._extract_f4m_formats( | 
					
						
							|  |  |  |                         format_url, video_id, f4m_id=format_id, fatal=False)) | 
					
						
							|  |  |  |                 else: | 
					
						
							|  |  |  |                     formats.append({ | 
					
						
							|  |  |  |                         'url': format_url, | 
					
						
							|  |  |  |                         'format_id': format_id, | 
					
						
							|  |  |  |                     }) | 
					
						
							| 
									
										
										
										
											2016-09-09 23:20:45 +07:00
										 |  |  |         self._sort_formats(formats) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return { | 
					
						
							|  |  |  |             'id': video_id, | 
					
						
							|  |  |  |             'title': title, | 
					
						
							|  |  |  |             'description': config.get('description'), | 
					
						
							|  |  |  |             'thumbnail': config.get('image'), | 
					
						
							|  |  |  |             'series': config.get('program'), | 
					
						
							|  |  |  |             'episode': config.get('episode'), | 
					
						
							|  |  |  |             'formats': formats, | 
					
						
							|  |  |  |         } |