mirror of
https://github.com/l1ving/youtube-dl
synced 2024-12-23 03:56:06 +08:00
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'))
|