diff options
| author | Sergey M․ <dstftw@gmail.com> | 2018-02-11 21:40:38 +0700 | 
|---|---|---|
| committer | Sergey M․ <dstftw@gmail.com> | 2018-02-11 21:40:38 +0700 | 
| commit | 79080573b5e3c3da2c971eb0f40183876f966a9f (patch) | |
| tree | dba2ebac872571f271ee8197e86a0ced287a40b4 /youtube_dl/extractor/francetv.py | |
| parent | 99892e9908c5366be334f48d5c9ce0044ec37a47 (diff) | |
[francetv] Add support for zouzous.fr and ludo.fr (closes #10454, closes #13087, closes #13103, closes #15012)
Diffstat (limited to 'youtube_dl/extractor/francetv.py')
| -rw-r--r-- | youtube_dl/extractor/francetv.py | 49 | 
1 files changed, 45 insertions, 4 deletions
| diff --git a/youtube_dl/extractor/francetv.py b/youtube_dl/extractor/francetv.py index e0734d59a..491545e1c 100644 --- a/youtube_dl/extractor/francetv.py +++ b/youtube_dl/extractor/francetv.py @@ -20,12 +20,13 @@ from .dailymotion import DailymotionIE  class FranceTVBaseInfoExtractor(InfoExtractor): -    def _make_url_result(self, video_id, catalog=None): -        full_id = 'francetv:%s' % video_id -        if catalog: +    def _make_url_result(self, video_or_full_id, catalog=None): +        full_id = 'francetv:%s' % video_or_full_id +        if '@' not in video_or_full_id and catalog:              full_id += '@%s' % catalog          return self.url_result( -            full_id, ie=FranceTVIE.ie_key(), video_id=video_id) +            full_id, ie=FranceTVIE.ie_key(), +            video_id=video_or_full_id.split('@')[0])  class FranceTVIE(InfoExtractor): @@ -431,3 +432,43 @@ class CultureboxIE(FranceTVBaseInfoExtractor):              webpage, 'video id').split('@')          return self._make_url_result(video_id, catalogue) + + +class FranceTVJeunesseIE(FranceTVBaseInfoExtractor): +    _VALID_URL = r'(?P<url>https?://(?:www\.)?(?:zouzous|ludo)\.fr/heros/(?P<id>[^/?#&]+))' + +    _TESTS = [{ +        'url': 'https://www.zouzous.fr/heros/simon', +        'info_dict': { +            'id': 'simon', +        }, +        'playlist_count': 9, +    }, { +        'url': 'https://www.ludo.fr/heros/ninjago', +        'info_dict': { +            'id': 'ninjago', +        }, +        'playlist_count': 10, +    }, { +        'url': 'https://www.zouzous.fr/heros/simon?abc', +        'only_matching': True, +    }] + +    def _real_extract(self, url): +        mobj = re.match(self._VALID_URL, url) +        playlist_id = mobj.group('id') + +        playlist = self._download_json( +            '%s/%s' % (mobj.group('url'), 'playlist'), playlist_id) + +        if not playlist.get('count'): +            raise ExtractorError( +                '%s is not available' % playlist_id, expected=True) + +        entries = [] +        for item in playlist['items']: +            identity = item.get('identity') +            if identity and isinstance(identity, compat_str): +                entries.append(self._make_url_result(identity)) + +        return self.playlist_result(entries, playlist_id) | 
