diff options
| author | Yen Chi Hsuan <yan12125@gmail.com> | 2016-01-20 04:06:09 +0800 | 
|---|---|---|
| committer | Yen Chi Hsuan <yan12125@gmail.com> | 2016-01-20 04:06:09 +0800 | 
| commit | d8024aebe5b77b160006e7f3cfc144e8b9045a6b (patch) | |
| tree | d7499e8d0fd57e0671fcf7d442de04e136c7c5ce /youtube_dl/extractor/letv.py | |
| parent | 485139c15c91af03bdb89c7ac07563d9fb979363 (diff) | |
| parent | 8652bd22f1ee955940793874b5c4060ef8e273b3 (diff) | |
Merge branch 'FounderSG-Weiqitv'
Diffstat (limited to 'youtube_dl/extractor/letv.py')
| -rw-r--r-- | youtube_dl/extractor/letv.py | 80 | 
1 files changed, 80 insertions, 0 deletions
diff --git a/youtube_dl/extractor/letv.py b/youtube_dl/extractor/letv.py index be648000e..08bdae8a2 100644 --- a/youtube_dl/extractor/letv.py +++ b/youtube_dl/extractor/letv.py @@ -4,6 +4,7 @@ from __future__ import unicode_literals  import datetime  import re  import time +import base64  from .common import InfoExtractor  from ..compat import ( @@ -16,7 +17,9 @@ from ..utils import (      parse_iso8601,      sanitized_Request,      int_or_none, +    str_or_none,      encode_data_uri, +    url_basename,  ) @@ -239,3 +242,80 @@ class LetvPlaylistIE(LetvTvIE):          },          'playlist_mincount': 7      }] + + +class LetvCloudIE(InfoExtractor): +    IE_DESC = '乐视云' +    _VALID_URL = r'https?://yuntv\.letv\.com/bcloud.html\?.+' + +    _TESTS = [{ +        'url': 'http://yuntv.letv.com/bcloud.html?uu=p7jnfw5hw9&vu=467623dedf', +        'md5': '26450599afd64c513bc77030ad15db44', +        'info_dict': { +            'id': 'p7jnfw5hw9_467623dedf', +            'ext': 'mp4', +            'title': 'Video p7jnfw5hw9_467623dedf', +        }, +    }, { +        'url': 'http://yuntv.letv.com/bcloud.html?uu=p7jnfw5hw9&vu=ec93197892&pu=2c7cd40209&auto_play=1&gpcflag=1&width=640&height=360', +        'info_dict': { +            'id': 'p7jnfw5hw9_ec93197892', +            'ext': 'mp4', +            'title': 'Video p7jnfw5hw9_ec93197892', +        }, +    }, { +        'url': 'http://yuntv.letv.com/bcloud.html?uu=p7jnfw5hw9&vu=187060b6fd', +        'info_dict': { +            'id': 'p7jnfw5hw9_187060b6fd', +            'ext': 'mp4', +            'title': 'Video p7jnfw5hw9_187060b6fd', +        }, +    }] + +    def _real_extract(self, url): +        uu_mobj = re.search('uu=([\w]+)', url) +        vu_mobj = re.search('vu=([\w]+)', url) + +        if not uu_mobj or not vu_mobj: +            raise ExtractorError('Invalid URL: %s' % url, expected=True) + +        uu = uu_mobj.group(1) +        vu = vu_mobj.group(1) +        media_id = uu + '_' + vu + +        play_json_req = sanitized_Request( +            'http://api.letvcloud.com/gpc.php?cf=html5&sign=signxxxxx&ver=2.2&format=json&' + +            'uu=' + uu + '&vu=' + vu) +        play_json = self._download_json(play_json_req, media_id, 'Downloading playJson data') + +        if not play_json.get('data'): +            if play_json.get('message'): +                raise ExtractorError('Letv cloud said: %s' % play_json['message'], expected=True) +            elif play_json.get('code'): +                raise ExtractorError('Letv cloud returned error %d' % play_json['code'], expected=True) +            else: +                raise ExtractorError('Letv cloud returned an unknwon error') + +        def b64decode(s): +            return base64.b64decode(s.encode('utf-8')).decode('utf-8') + +        formats = [] +        for media in play_json['data']['video_info']['media'].values(): +            play_url = media['play_url'] +            url = b64decode(play_url['main_url']) +            decoded_url = b64decode(url_basename(url)) +            formats.append({ +                'url': url, +                'ext': determine_ext(decoded_url), +                'format_id': int_or_none(play_url.get('vtype')), +                'format_note': str_or_none(play_url.get('definition')), +                'width': int_or_none(play_url.get('vwidth')), +                'height': int_or_none(play_url.get('vheight')), +            }) +        self._sort_formats(formats) + +        return { +            'id': media_id, +            'title': 'Video %s' % media_id, +            'formats': formats, +        }  | 
