29 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
		
		
			
		
	
	
			29 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|  | # coding: utf-8 | ||
|  | from __future__ import unicode_literals | ||
|  | 
 | ||
|  | from .common import InfoExtractor | ||
|  | from ..utils import smuggle_url | ||
|  | 
 | ||
|  | 
 | ||
|  | class BravoTVIE(InfoExtractor): | ||
|  |     _VALID_URL = r'https?://(?:www\.)?bravotv\.com/(?:[^/]+/)+videos/(?P<id>[^/?]+)' | ||
|  |     _TEST = { | ||
|  |         'url': 'http://www.bravotv.com/last-chance-kitchen/season-5/videos/lck-ep-12-fishy-finale', | ||
|  |         'md5': 'd60cdf68904e854fac669bd26cccf801', | ||
|  |         'info_dict': { | ||
|  |             'id': 'LitrBdX64qLn', | ||
|  |             'ext': 'mp4', | ||
|  |             'title': 'Last Chance Kitchen Returns', | ||
|  |             'description': 'S13: Last Chance Kitchen Returns for Top Chef Season 13', | ||
|  |         } | ||
|  |     } | ||
|  | 
 | ||
|  |     def _real_extract(self, url): | ||
|  |         video_id = self._match_id(url) | ||
|  |         webpage = self._download_webpage(url, video_id) | ||
|  |         account_pid = self._search_regex(r'"account_pid"\s*:\s*"([^"]+)"', webpage, 'account pid') | ||
|  |         release_pid = self._search_regex(r'"release_pid"\s*:\s*"([^"]+)"', webpage, 'release pid') | ||
|  |         return self.url_result(smuggle_url( | ||
|  |             'http://link.theplatform.com/s/%s/%s?format=SMIL&mbr=true&switch=progressive' % (account_pid, release_pid), | ||
|  |             {'force_smil_url': True}), 'ThePlatform', release_pid) |