diff options
| author | Sergey M․ <dstftw@gmail.com> | 2015-07-09 23:52:03 +0600 | 
|---|---|---|
| committer | Sergey M․ <dstftw@gmail.com> | 2015-07-09 23:52:03 +0600 | 
| commit | 675e9f22ea3f43fbade9bbd13ee5de3eb45c538f (patch) | |
| tree | 09dd8a4a1a987776d0dd91056755b049fa3c9cdb | |
| parent | 77c6fb5b24c477c9de022f252dc9958a4b3b8b42 (diff) | |
[vimple] Extract spruto player based extractor class
| -rw-r--r-- | youtube_dl/extractor/vimple.py | 46 | 
1 files changed, 26 insertions, 20 deletions
| diff --git a/youtube_dl/extractor/vimple.py b/youtube_dl/extractor/vimple.py index aa3d6ddfd..92321d66e 100644 --- a/youtube_dl/extractor/vimple.py +++ b/youtube_dl/extractor/vimple.py @@ -4,7 +4,29 @@ from .common import InfoExtractor  from ..utils import int_or_none -class VimpleIE(InfoExtractor): +class SprutoBaseIE(InfoExtractor): +    def _extract_spruto(self, spruto, video_id): +        playlist = spruto['playlist'][0] +        title = playlist['title'] +        video_id = playlist.get('videoId') or video_id +        thumbnail = playlist.get('posterUrl') or playlist.get('thumbnailUrl') +        duration = int_or_none(playlist.get('duration')) + +        formats = [{ +            'url': f['url'], +        } for f in playlist['video']] +        self._sort_formats(formats) + +        return { +            'id': video_id, +            'title': title, +            'thumbnail': thumbnail, +            'duration': duration, +            'formats': formats, +        } + + +class VimpleIE(SprutoBaseIE):      IE_DESC = 'Vimple - one-click video hosting'      _VALID_URL = r'https?://(?:player\.vimple\.ru/iframe|vimple\.ru)/(?P<id>[\da-f-]{32,36})'      _TESTS = [ @@ -30,25 +52,9 @@ class VimpleIE(InfoExtractor):          webpage = self._download_webpage(              'http://player.vimple.ru/iframe/%s' % video_id, video_id) -        playlist = self._parse_json( +        spruto = self._parse_json(              self._search_regex(                  r'sprutoData\s*:\s*({.+?}),\r\n', webpage, 'spruto data'), -            video_id)['playlist'][0] - -        title = playlist['title'] -        video_id = playlist.get('videoId') or video_id -        thumbnail = playlist.get('posterUrl') or playlist.get('thumbnailUrl') -        duration = int_or_none(playlist.get('duration')) - -        formats = [{ -            'url': f['url'], -        } for f in playlist['video']] -        self._sort_formats(formats) +            video_id) -        return { -            'id': video_id, -            'title': title, -            'thumbnail': thumbnail, -            'duration': duration, -            'formats': formats, -        } +        return self._extract_spruto(spruto, video_id) | 
