82 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
		
		
			
		
	
	
			82 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|  | # coding: utf-8 | ||
|  | from __future__ import unicode_literals | ||
|  | 
 | ||
|  | import re | ||
|  | 
 | ||
|  | from .common import InfoExtractor | ||
|  | from ..utils import ( | ||
|  |     int_or_none, | ||
|  |     parse_duration, | ||
|  | ) | ||
|  | 
 | ||
|  | 
 | ||
|  | class ToonGogglesIE(InfoExtractor): | ||
|  |     _VALID_URL = r'https?://(?:www\.)?toongoggles\.com/shows/(?P<show_id>\d+)(?:/[^/]+/episodes/(?P<episode_id>\d+))?' | ||
|  |     _TESTS = [{ | ||
|  |         'url': 'http://www.toongoggles.com/shows/217143/bernard-season-2/episodes/217147/football', | ||
|  |         'md5': '18289fc2b951eff6b953a9d8f01e6831', | ||
|  |         'info_dict': { | ||
|  |             'id': '217147', | ||
|  |             'ext': 'mp4', | ||
|  |             'title': 'Football', | ||
|  |             'uploader_id': '1', | ||
|  |             'description': 'Bernard decides to play football in order to be better than Lloyd and tries to beat him no matter how, he even cheats.', | ||
|  |             'upload_date': '20160718', | ||
|  |             'timestamp': 1468879330, | ||
|  |         } | ||
|  |     }, { | ||
|  |         'url': 'http://www.toongoggles.com/shows/227759/om-nom-stories-around-the-world', | ||
|  |         'info_dict': { | ||
|  |             'id': '227759', | ||
|  |             'title': 'Om Nom Stories Around The World', | ||
|  |         }, | ||
|  |         'playlist_mincount': 11, | ||
|  |     }] | ||
|  | 
 | ||
|  |     def _call_api(self, action, page_id, query): | ||
|  |         query.update({ | ||
|  |             'for_ng': 1, | ||
|  |             'for_web': 1, | ||
|  |             'show_meta': 1, | ||
|  |             'version': 7.0, | ||
|  |         }) | ||
|  |         return self._download_json('http://api.toongoggles.com/' + action, page_id, query=query) | ||
|  | 
 | ||
|  |     def _parse_episode_data(self, episode_data): | ||
|  |         title = episode_data['episode_name'] | ||
|  | 
 | ||
|  |         return { | ||
|  |             '_type': 'url_transparent', | ||
|  |             'id': episode_data['episode_id'], | ||
|  |             'title': title, | ||
|  |             'url': 'kaltura:513551:' + episode_data['entry_id'], | ||
|  |             'thumbnail': episode_data.get('thumbnail_url'), | ||
|  |             'description': episode_data.get('description'), | ||
|  |             'duration': parse_duration(episode_data.get('hms')), | ||
|  |             'series': episode_data.get('show_name'), | ||
|  |             'season_number': int_or_none(episode_data.get('season_num')), | ||
|  |             'episode_id': episode_data.get('episode_id'), | ||
|  |             'episode': title, | ||
|  |             'episode_number': int_or_none(episode_data.get('episode_num')), | ||
|  |             'categories': episode_data.get('categories'), | ||
|  |             'ie_key': 'Kaltura', | ||
|  |         } | ||
|  | 
 | ||
|  |     def _real_extract(self, url): | ||
|  |         show_id, episode_id = re.match(self._VALID_URL, url).groups() | ||
|  |         if episode_id: | ||
|  |             episode_data = self._call_api('search', episode_id, { | ||
|  |                 'filter': 'episode', | ||
|  |                 'id': episode_id, | ||
|  |             })['objects'][0] | ||
|  |             return self._parse_episode_data(episode_data) | ||
|  |         else: | ||
|  |             show_data = self._call_api('getepisodesbyshow', show_id, { | ||
|  |                 'max': 1000000000, | ||
|  |                 'showid': show_id, | ||
|  |             }) | ||
|  |             entries = [] | ||
|  |             for episode_data in show_data.get('objects', []): | ||
|  |                 entries.append(self._parse_episode_data(episode_data)) | ||
|  |             return self.playlist_result(entries, show_id, show_data.get('show_name')) |