| 
									
										
										
										
											2014-11-23 20:41:03 +01:00
										 |  |  | # coding: utf-8 | 
					
						
							| 
									
										
										
										
											2014-08-22 01:44:35 +02:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  | from .common import InfoExtractor | 
					
						
							|  |  |  | from ..utils import ( | 
					
						
							| 
									
										
										
										
											2017-08-12 17:18:23 +07:00
										 |  |  |     int_or_none, | 
					
						
							|  |  |  |     mimetype2ext, | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class AparatIE(InfoExtractor): | 
					
						
							| 
									
										
										
										
											2017-08-12 17:18:23 +07:00
										 |  |  |     _VALID_URL = r'https?://(?:www\.)?aparat\.com/(?:v/|video/video/embed/videohash/)(?P<id>[a-zA-Z0-9]+)' | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     _TEST = { | 
					
						
							| 
									
										
										
										
											2014-08-22 01:44:35 +02:00
										 |  |  |         'url': 'http://www.aparat.com/v/wP8On', | 
					
						
							| 
									
										
										
										
											2016-08-08 12:59:07 +08:00
										 |  |  |         'md5': '131aca2e14fe7c4dcb3c4877ba300c89', | 
					
						
							| 
									
										
										
										
											2014-08-22 01:44:35 +02:00
										 |  |  |         'info_dict': { | 
					
						
							|  |  |  |             'id': 'wP8On', | 
					
						
							|  |  |  |             'ext': 'mp4', | 
					
						
							|  |  |  |             'title': 'تیم گلکسی 11 - زومیت', | 
					
						
							| 
									
										
										
										
											2015-02-08 17:45:38 +02:00
										 |  |  |             'age_limit': 0, | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2014-08-22 01:44:35 +02:00
										 |  |  |         # 'skip': 'Extremely unreliable', | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def _real_extract(self, url): | 
					
						
							| 
									
										
										
										
											2014-11-26 12:40:51 +01:00
										 |  |  |         video_id = self._match_id(url) | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # Note: There is an easier-to-parse configuration at | 
					
						
							|  |  |  |         # http://www.aparat.com/video/video/config/videohash/%video_id | 
					
						
							|  |  |  |         # but the URL in there does not work | 
					
						
							| 
									
										
										
										
											2017-08-12 17:18:23 +07:00
										 |  |  |         webpage = self._download_webpage( | 
					
						
							|  |  |  |             'http://www.aparat.com/video/video/embed/vt/frame/showvideo/yes/videohash/' + video_id, | 
					
						
							|  |  |  |             video_id) | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-26 12:40:51 +01:00
										 |  |  |         title = self._search_regex(r'\s+title:\s*"([^"]+)"', webpage, 'title') | 
					
						
							| 
									
										
										
										
											2017-08-12 17:18:23 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         file_list = self._parse_json( | 
					
						
							|  |  |  |             self._search_regex( | 
					
						
							|  |  |  |                 r'fileList\s*=\s*JSON\.parse\(\'([^\']+)\'\)', webpage, | 
					
						
							|  |  |  |                 'file list'), | 
					
						
							|  |  |  |             video_id) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         formats = [] | 
					
						
							|  |  |  |         for item in file_list[0]: | 
					
						
							|  |  |  |             file_url = item.get('file') | 
					
						
							|  |  |  |             if not file_url: | 
					
						
							|  |  |  |                 continue | 
					
						
							|  |  |  |             ext = mimetype2ext(item.get('type')) | 
					
						
							|  |  |  |             label = item.get('label') | 
					
						
							|  |  |  |             formats.append({ | 
					
						
							|  |  |  |                 'url': file_url, | 
					
						
							|  |  |  |                 'ext': ext, | 
					
						
							|  |  |  |                 'format_id': label or ext, | 
					
						
							|  |  |  |                 'height': int_or_none(self._search_regex( | 
					
						
							|  |  |  |                     r'(\d+)[pP]', label or '', 'height', default=None)), | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |         self._sort_formats(formats) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  |         thumbnail = self._search_regex( | 
					
						
							| 
									
										
										
										
											2015-02-08 17:30:29 +06:00
										 |  |  |             r'image:\s*"([^"]+)"', webpage, 'thumbnail', fatal=False) | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return { | 
					
						
							|  |  |  |             'id': video_id, | 
					
						
							|  |  |  |             'title': title, | 
					
						
							|  |  |  |             'thumbnail': thumbnail, | 
					
						
							| 
									
										
										
										
											2015-02-08 17:45:38 +02:00
										 |  |  |             'age_limit': self._family_friendly_search(webpage), | 
					
						
							| 
									
										
										
										
											2017-08-12 17:18:23 +07:00
										 |  |  |             'formats': formats, | 
					
						
							| 
									
										
										
										
											2013-12-20 17:05:28 +01:00
										 |  |  |         } |