mirror of
https://github.com/ytdl-org/youtube-dl
synced 2025-01-10 21:40:11 +09:00
Merge 74c3ddbfef
into c5098961b0
This commit is contained in:
commit
ec22873a0a
@ -434,7 +434,10 @@ from .frontendmasters import (
|
|||||||
FrontendMastersCourseIE
|
FrontendMastersCourseIE
|
||||||
)
|
)
|
||||||
from .fujitv import FujiTVFODPlus7IE
|
from .fujitv import FujiTVFODPlus7IE
|
||||||
from .funimation import FunimationIE
|
from .funimation import (
|
||||||
|
FunimationIE,
|
||||||
|
FunimationShowPlaylistIE
|
||||||
|
)
|
||||||
from .funk import FunkIE
|
from .funk import FunkIE
|
||||||
from .fusion import FusionIE
|
from .fusion import FusionIE
|
||||||
from .gaia import GaiaIE
|
from .gaia import GaiaIE
|
||||||
|
@ -11,7 +11,8 @@ from ..utils import (
|
|||||||
int_or_none,
|
int_or_none,
|
||||||
js_to_json,
|
js_to_json,
|
||||||
ExtractorError,
|
ExtractorError,
|
||||||
urlencode_postdata
|
urlencode_postdata,
|
||||||
|
urljoin
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -156,3 +157,58 @@ class FunimationIE(InfoExtractor):
|
|||||||
'season_id': title_data.get('seriesId'),
|
'season_id': title_data.get('seriesId'),
|
||||||
'formats': formats,
|
'formats': formats,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class FunimationShowPlaylistIE(FunimationIE):
|
||||||
|
IE_NAME = 'funimation:playlist'
|
||||||
|
_VALID_URL = r'https?://(?:www\.)?funimation(?:\.com|now\.uk)/(?:[^/]+/)?shows/(?P<id>[^/?#&]+)/?$'
|
||||||
|
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://www.funimation.com/shows/hacksign/',
|
||||||
|
'info_dict': {
|
||||||
|
'id': 90646,
|
||||||
|
'title': '.hack//SIGN'
|
||||||
|
},
|
||||||
|
'playlist_count': 28,
|
||||||
|
'params': {
|
||||||
|
'skip_download': True,
|
||||||
|
},
|
||||||
|
}, {
|
||||||
|
'url': 'https://www.funimationnow.uk/shows/puzzle-dragons-x/',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
# with lang code
|
||||||
|
'url': 'https://www.funimation.com/en/shows/hacksign/',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
def _real_extract(self, url):
|
||||||
|
display_id = self._match_id(url)
|
||||||
|
|
||||||
|
webpage = self._download_webpage(url, display_id)
|
||||||
|
title_data = self._parse_json(self._search_regex(
|
||||||
|
r'TITLE_DATA\s*=\s*({[^}]+})',
|
||||||
|
webpage, 'title data', default=''),
|
||||||
|
display_id, js_to_json, fatal=False) or {}
|
||||||
|
|
||||||
|
items = self._download_json(
|
||||||
|
'https://prod-api-funimationnow.dadcdigital.com/api/funimation/episodes/?limit=99999&title_id=%s'
|
||||||
|
% title_data.get('id'), display_id).get('items')
|
||||||
|
|
||||||
|
vod_items = list(map(lambda k:
|
||||||
|
(k.get('mostRecentSvod') or k.get('mostRecentAvod'))
|
||||||
|
.get('item'), items))
|
||||||
|
vod_items = sorted(vod_items, key=lambda k: k.get('episodeOrder'))
|
||||||
|
entries = []
|
||||||
|
for vod_item in vod_items:
|
||||||
|
entries.append(
|
||||||
|
self.url_result(urljoin(url, vod_item.get('episodeSlug')),
|
||||||
|
'Funimation', vod_item.get('episodeId'),
|
||||||
|
vod_item.get('episodeSlug')))
|
||||||
|
|
||||||
|
return {
|
||||||
|
'_type': 'playlist',
|
||||||
|
'id': title_data.get('id'),
|
||||||
|
'title': title_data.get('title'),
|
||||||
|
'entries': entries,
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user