| 
									
										
										
										
											2013-06-29 17:29:40 +02:00
										 |  |  | import base64 | 
					
						
							|  |  |  | import re | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from .common import InfoExtractor | 
					
						
							|  |  |  | from ..utils import ( | 
					
						
							|  |  |  |     compat_parse_qs, | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class TutvIE(InfoExtractor): | 
					
						
							|  |  |  |     _VALID_URL=r'https?://(?:www\.)?tu\.tv/videos/(?P<id>[^/?]+)' | 
					
						
							|  |  |  |     _TEST = { | 
					
						
							|  |  |  |         u'url': u'http://tu.tv/videos/noah-en-pabellon-cuahutemoc', | 
					
						
							|  |  |  |         u'file': u'2742556.flv', | 
					
						
							|  |  |  |         u'md5': u'5eb766671f69b82e528dc1e7769c5cb2', | 
					
						
							|  |  |  |         u'info_dict': { | 
					
						
							|  |  |  |             u"title": u"Noah en pabellon cuahutemoc" | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def _real_extract(self, url): | 
					
						
							|  |  |  |         mobj = re.match(self._VALID_URL, url) | 
					
						
							|  |  |  |         video_id = mobj.group('id') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         webpage = self._download_webpage(url, video_id) | 
					
						
							|  |  |  |         internal_id = self._search_regex(r'codVideo=([0-9]+)', webpage, u'internal video ID') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         data_url = u'http://tu.tv/flvurl.php?codVideo=' + str(internal_id) | 
					
						
							|  |  |  |         data_content = self._download_webpage(data_url, video_id, note=u'Downloading video info') | 
					
						
							|  |  |  |         data = compat_parse_qs(data_content) | 
					
						
							| 
									
										
										
										
											2013-06-29 17:42:15 +02:00
										 |  |  |         video_url = base64.b64decode(data['kpt'][0]).decode('utf-8') | 
					
						
							|  |  |  |         ext = video_url.partition(u'?')[0].rpartition(u'.')[2] | 
					
						
							| 
									
										
										
										
											2013-06-29 17:29:40 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         info = { | 
					
						
							|  |  |  |             'id': internal_id, | 
					
						
							|  |  |  |             'url': video_url, | 
					
						
							|  |  |  |             'ext': ext, | 
					
						
							| 
									
										
										
										
											2013-07-12 19:00:19 +02:00
										 |  |  |             'title': self._og_search_title(webpage), | 
					
						
							| 
									
										
										
										
											2013-06-29 17:29:40 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         return [info] |