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'))
 |