mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-11-30 07:28:19 +01:00
[funimation] Add FunimationShowIE
(#442)
Closes #436 Authored by: Mevious
This commit is contained in:
parent
15a4fd53d3
commit
125728b038
|
@ -455,7 +455,10 @@
|
||||||
FrontendMastersCourseIE
|
FrontendMastersCourseIE
|
||||||
)
|
)
|
||||||
from .fujitv import FujiTVFODPlus7IE
|
from .fujitv import FujiTVFODPlus7IE
|
||||||
from .funimation import FunimationIE
|
from .funimation import (
|
||||||
|
FunimationIE,
|
||||||
|
FunimationShowIE
|
||||||
|
)
|
||||||
from .funk import FunkIE
|
from .funk import FunkIE
|
||||||
from .fusion import FusionIE
|
from .fusion import FusionIE
|
||||||
from .gaia import GaiaIE
|
from .gaia import GaiaIE
|
||||||
|
|
|
@ -2,12 +2,14 @@
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
import random
|
import random
|
||||||
|
import re
|
||||||
import string
|
import string
|
||||||
|
|
||||||
from .common import InfoExtractor
|
from .common import InfoExtractor
|
||||||
from ..compat import compat_HTTPError
|
from ..compat import compat_HTTPError
|
||||||
from ..utils import (
|
from ..utils import (
|
||||||
determine_ext,
|
determine_ext,
|
||||||
|
dict_get,
|
||||||
int_or_none,
|
int_or_none,
|
||||||
js_to_json,
|
js_to_json,
|
||||||
urlencode_postdata,
|
urlencode_postdata,
|
||||||
|
@ -176,3 +178,53 @@ def _get_subtitles(self, url, video_id, display_id):
|
||||||
language += '_CC'
|
language += '_CC'
|
||||||
subtitles.setdefault(language, []).append(url_element)
|
subtitles.setdefault(language, []).append(url_element)
|
||||||
return subtitles
|
return subtitles
|
||||||
|
|
||||||
|
|
||||||
|
class FunimationShowIE(FunimationIE):
|
||||||
|
IE_NAME = 'funimation:show'
|
||||||
|
_VALID_URL = r'(?P<url>https?://(?:www\.)?funimation(?:\.com|now\.uk)/(?P<locale>[^/]+)?/?shows/(?P<id>[^/?#&]+))/?(?:[?#]|$)'
|
||||||
|
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://www.funimation.com/en/shows/sk8-the-infinity',
|
||||||
|
'info_dict': {
|
||||||
|
'id': 1315000,
|
||||||
|
'title': 'SK8 the Infinity'
|
||||||
|
},
|
||||||
|
'playlist_count': 13,
|
||||||
|
'params': {
|
||||||
|
'skip_download': True,
|
||||||
|
},
|
||||||
|
}, {
|
||||||
|
# without lang code
|
||||||
|
'url': 'https://www.funimation.com/shows/ouran-high-school-host-club/',
|
||||||
|
'info_dict': {
|
||||||
|
'id': 39643,
|
||||||
|
'title': 'Ouran High School Host Club'
|
||||||
|
},
|
||||||
|
'playlist_count': 26,
|
||||||
|
'params': {
|
||||||
|
'skip_download': True,
|
||||||
|
},
|
||||||
|
}]
|
||||||
|
|
||||||
|
def _real_extract(self, url):
|
||||||
|
base_url, locale, display_id = re.match(self._VALID_URL, url).groups()
|
||||||
|
|
||||||
|
show_info = self._download_json(
|
||||||
|
'https://title-api.prd.funimationsvc.com/v2/shows/%s?region=US&deviceType=web&locale=%s'
|
||||||
|
% (display_id, locale or 'en'), display_id)
|
||||||
|
items = self._download_json(
|
||||||
|
'https://prod-api-funimationnow.dadcdigital.com/api/funimation/episodes/?limit=99999&title_id=%s'
|
||||||
|
% show_info.get('id'), display_id).get('items')
|
||||||
|
vod_items = map(lambda k: dict_get(k, ('mostRecentSvod', 'mostRecentAvod')).get('item'), items)
|
||||||
|
|
||||||
|
return {
|
||||||
|
'_type': 'playlist',
|
||||||
|
'id': show_info['id'],
|
||||||
|
'title': show_info['name'],
|
||||||
|
'entries': [
|
||||||
|
self.url_result(
|
||||||
|
'%s/%s' % (base_url, vod_item.get('episodeSlug')), FunimationIE.ie_key(),
|
||||||
|
vod_item.get('episodeId'), vod_item.get('episodeName'))
|
||||||
|
for vod_item in sorted(vod_items, key=lambda x: x.get('episodeOrder'))],
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user