]> jfr.im git - yt-dlp.git/blob - yt_dlp/extractor/toongoggles.py
[cleanup] Misc
[yt-dlp.git] / yt_dlp / extractor / toongoggles.py
1 # coding: utf-8
2 from __future__ import unicode_literals
3
4
5 from .common import InfoExtractor
6 from ..utils import (
7 int_or_none,
8 parse_duration,
9 )
10
11
12 class ToonGogglesIE(InfoExtractor):
13 _VALID_URL = r'https?://(?:www\.)?toongoggles\.com/shows/(?P<show_id>\d+)(?:/[^/]+/episodes/(?P<episode_id>\d+))?'
14 _TESTS = [{
15 'url': 'http://www.toongoggles.com/shows/217143/bernard-season-2/episodes/217147/football',
16 'md5': '18289fc2b951eff6b953a9d8f01e6831',
17 'info_dict': {
18 'id': '217147',
19 'ext': 'mp4',
20 'title': 'Football',
21 'uploader_id': '1',
22 'description': 'Bernard decides to play football in order to be better than Lloyd and tries to beat him no matter how, he even cheats.',
23 'upload_date': '20160718',
24 'timestamp': 1468879330,
25 }
26 }, {
27 'url': 'http://www.toongoggles.com/shows/227759/om-nom-stories-around-the-world',
28 'info_dict': {
29 'id': '227759',
30 'title': 'Om Nom Stories Around The World',
31 },
32 'playlist_mincount': 11,
33 }]
34
35 def _call_api(self, action, page_id, query):
36 query.update({
37 'for_ng': 1,
38 'for_web': 1,
39 'show_meta': 1,
40 'version': 7.0,
41 })
42 return self._download_json('http://api.toongoggles.com/' + action, page_id, query=query)
43
44 def _parse_episode_data(self, episode_data):
45 title = episode_data['episode_name']
46
47 return {
48 '_type': 'url_transparent',
49 'id': episode_data['episode_id'],
50 'title': title,
51 'url': 'kaltura:513551:' + episode_data['entry_id'],
52 'thumbnail': episode_data.get('thumbnail_url'),
53 'description': episode_data.get('description'),
54 'duration': parse_duration(episode_data.get('hms')),
55 'series': episode_data.get('show_name'),
56 'season_number': int_or_none(episode_data.get('season_num')),
57 'episode_id': episode_data.get('episode_id'),
58 'episode': title,
59 'episode_number': int_or_none(episode_data.get('episode_num')),
60 'categories': episode_data.get('categories'),
61 'ie_key': 'Kaltura',
62 }
63
64 def _real_extract(self, url):
65 show_id, episode_id = self._match_valid_url(url).groups()
66 if episode_id:
67 episode_data = self._call_api('search', episode_id, {
68 'filter': 'episode',
69 'id': episode_id,
70 })['objects'][0]
71 return self._parse_episode_data(episode_data)
72 else:
73 show_data = self._call_api('getepisodesbyshow', show_id, {
74 'max': 1000000000,
75 'showid': show_id,
76 })
77 entries = []
78 for episode_data in show_data.get('objects', []):
79 entries.append(self._parse_episode_data(episode_data))
80 return self.playlist_result(entries, show_id, show_data.get('show_name'))