from __future__ import unicode_literals
import base64
+import random
+import string
+import time
from .common import InfoExtractor
from ..compat import (
'title': '武媚娘传奇 85',
},
'playlist_count': 11,
+ 'skip': 'Available in China only',
}, {
'url': 'http://v.youku.com/v_show/id_XMTI1OTczNDM5Mg==.html',
'info_dict': {
'title': '花千骨 04',
},
'playlist_count': 13,
- 'skip': 'Available in China only',
}, {
'url': 'http://v.youku.com/v_show/id_XNjA1NzA2Njgw.html',
'note': 'Video protected with password',
return video_urls_dict
+ @staticmethod
+ def get_ysuid():
+ return '%d%s' % (int(time.time()), ''.join([
+ random.choice(string.ascii_letters) for i in range(3)]))
+
def get_hd(self, fm):
hd_id_dict = {
- 'flv': '0',
- 'mp4': '1',
- 'hd2': '2',
- 'hd3': '3',
'3gp': '0',
'3gphd': '1',
+ 'flv': '0',
'flvhd': '0',
+ 'mp4': '1',
'mp4hd': '1',
- 'mp4hd2': '1'
+ 'mp4hd2': '1',
+ 'mp4hd3': '1',
+ 'hd2': '2',
+ 'hd3': '3',
}
return hd_id_dict[fm]
def parse_ext_l(self, fm):
ext_dict = {
+ '3gp': 'flv',
+ '3gphd': 'mp4',
'flv': 'flv',
+ 'flvhd': 'flv',
'mp4': 'mp4',
'mp4hd': 'mp4',
'mp4hd2': 'flv',
'mp4hd3': 'flv',
'hd2': 'flv',
'hd3': 'flv',
- '3gp': 'flv',
- '3gphd': 'mp4',
- 'flvhd': 'flv'
}
return ext_dict[fm]
_dict = {
'3gp': 'h6',
'3gphd': 'h5',
- 'flvhd': 'h4',
'flv': 'h4',
+ 'flvhd': 'h4',
'mp4': 'h3',
- 'hd2': 'h2',
- 'hd3': 'h1',
'mp4hd': 'h3',
+ 'mp4hd2': 'h4',
'mp4hd3': 'h4',
- 'mp4hd2': 'h4'
+ 'hd2': 'h2',
+ 'hd3': 'h1',
}
return _dict[fm]
def _real_extract(self, url):
video_id = self._match_id(url)
+ self._set_cookie('youku.com', '__ysuid', self.get_ysuid())
+
def retrieve_data(req_url, note):
headers = {
'Referer': req_url,
if video_password:
basic_data_url += '&pwd=%s' % video_password
- data = retrieve_data(
- basic_data_url,
- 'Downloading JSON metadata 1')
+ data = retrieve_data(basic_data_url, 'Downloading JSON metadata')
error = data.get('error')
if error:
'Youku said: Sorry, this video is available in China only', expected=True)
else:
msg = 'Youku server reported error %i' % error.get('code')
- if error is not None:
+ if error_note is not None:
msg += ': ' + error_note
raise ExtractorError(msg)