1 from .common
import InfoExtractor
8 class ToonGogglesIE(InfoExtractor
):
9 _VALID_URL
= r
'https?://(?:www\.)?toongoggles\.com/shows/(?P<show_id>\d+)(?:/[^/]+/episodes/(?P<episode_id>\d+))?'
11 'url': 'http://www.toongoggles.com/shows/217143/bernard-season-2/episodes/217147/football',
12 'md5': '18289fc2b951eff6b953a9d8f01e6831',
18 'description': 'Bernard decides to play football in order to be better than Lloyd and tries to beat him no matter how, he even cheats.',
19 'upload_date': '20160718',
20 'timestamp': 1468879330,
23 'url': 'http://www.toongoggles.com/shows/227759/om-nom-stories-around-the-world',
26 'title': 'Om Nom Stories Around The World',
28 'playlist_mincount': 11,
31 def _call_api(self
, action
, page_id
, query
):
38 return self
._download
_json
('http://api.toongoggles.com/' + action
, page_id
, query
=query
)
40 def _parse_episode_data(self
, episode_data
):
41 title
= episode_data
['episode_name']
44 '_type': 'url_transparent',
45 'id': episode_data
['episode_id'],
47 'url': 'kaltura:513551:' + episode_data
['entry_id'],
48 'thumbnail': episode_data
.get('thumbnail_url'),
49 'description': episode_data
.get('description'),
50 'duration': parse_duration(episode_data
.get('hms')),
51 'series': episode_data
.get('show_name'),
52 'season_number': int_or_none(episode_data
.get('season_num')),
53 'episode_id': episode_data
.get('episode_id'),
55 'episode_number': int_or_none(episode_data
.get('episode_num')),
56 'categories': episode_data
.get('categories'),
60 def _real_extract(self
, url
):
61 show_id
, episode_id
= self
._match
_valid
_url
(url
).groups()
63 episode_data
= self
._call
_api
('search', episode_id
, {
67 return self
._parse
_episode
_data
(episode_data
)
69 show_data
= self
._call
_api
('getepisodesbyshow', show_id
, {
74 for episode_data
in show_data
.get('objects', []):
75 entries
.append(self
._parse
_episode
_data
(episode_data
))
76 return self
.playlist_result(entries
, show_id
, show_data
.get('show_name'))