you-get/src/you_get/extractors/letv.py

142 lines
5.3 KiB
Python
Raw Normal View History

2014-01-18 00:58:22 +04:00
#!/usr/bin/env python
2014-10-31 11:14:58 +03:00
__all__ = ['letv_download', 'letvcloud_download', 'letvcloud_download_by_vu']
2014-01-18 00:58:22 +04:00
import json
2014-05-15 18:29:13 +04:00
import random
2014-01-18 00:58:22 +04:00
import xml.etree.ElementTree as ET
2015-02-08 20:07:40 +03:00
import base64, hashlib, urllib, time, re
2014-10-31 11:14:58 +03:00
2014-01-18 00:58:22 +04:00
from ..common import *
2015-02-08 20:07:40 +03:00
#@DEPRECATED
2014-05-15 18:29:13 +04:00
def get_timestamp():
tn = random.random()
url = 'http://api.letv.com/time?tn={}'.format(tn)
result = get_content(url)
return json.loads(result)['stime']
2015-02-08 20:07:40 +03:00
#@DEPRECATED
2014-05-15 18:29:13 +04:00
def get_key(t):
for s in range(0, 8):
e = 1 & t
t >>= 1
e <<= 31
t += e
return t ^ 185025305
2015-02-08 20:07:40 +03:00
def calcTimeKey(t):
ror = lambda val, r_bits, : ((val & (2**32-1)) >> r_bits%32) | (val << (32-(r_bits%32)) & (2**32-1))
return ror(ror(t,773625421%13)^773625421,773625421%17)
def decode(data):
version = data[0:5]
if version.lower() == b'vc_01':
#get real m3u8
loc2 = data[5:]
length = len(loc2)
loc4 = [0]*(2*length)
for i in range(length):
loc4[2*i] = loc2[i] >> 4
loc4[2*i+1]= loc2[i] & 15;
loc6 = loc4[len(loc4)-11:]+loc4[:len(loc4)-11]
loc7 = [0]*length
for i in range(length):
loc7[i] = (loc6[2 * i] << 4) +loc6[2*i+1]
return ''.join([chr(i) for i in loc7])
else:
# directly return
return data
def video_info(vid,**kwargs):
url = 'http://api.letv.com/mms/out/video/playJson?id={}&platid=1&splatid=101&format=1&tkey={}&domain=www.letv.com'.format(vid,calcTimeKey(int(time.time())))
2014-05-15 18:29:13 +04:00
r = get_content(url, decoded=False)
2014-07-14 17:53:35 +04:00
info=json.loads(str(r,"utf-8"))
2015-02-08 20:07:40 +03:00
stream_id = None
support_stream_id = info["playurl"]["dispatch"].keys()
if "stream_id" in kwargs and kwargs["stream_id"].lower() in support_stream_id:
stream_id = kwargs["stream_id"]
else:
print("Current Video Supports:")
for i in support_stream_id:
print("\t--format",i,"<URL>")
if "1080p" in support_stream_id:
stream_id = '1080p'
elif "720p" in support_stream_id:
stream_id = '720p'
else:
stream_id =sorted(support_stream_id,key= lambda i: int(i[1:]))[-1]
url =info["playurl"]["domain"][0]+info["playurl"]["dispatch"][stream_id][0]
ext = info["playurl"]["dispatch"][stream_id][1].split('.')[-1]
url+="&ctv=pc&m3v=1&termid=1&format=1&hwtype=un&ostype=Linux&tag=letv&sign=letv&expect=3&tn={}&pay=0&iscpn=f9051&rateid={}".format(random.random(),stream_id)
2014-08-06 16:41:24 +04:00
r2=get_content(url,decoded=False)
info2=json.loads(str(r2,"utf-8"))
2015-02-08 20:07:40 +03:00
# hold on ! more things to do
# to decode m3u8 (encoded)
m3u8 = get_content(info2["location"],decoded=False)
m3u8_list = decode(m3u8)
2015-02-09 05:31:13 +03:00
urls = re.findall(r'^[^#][^\r]*',m3u8_list,re.MULTILINE)
2015-02-08 20:07:40 +03:00
return ext,urls
def letv_download_by_vid(vid,title, output_dir='.', merge=True, info_only=False,**kwargs):
ext , urls = video_info(vid,**kwargs)
size = 0
for i in urls:
_, _, tmp = url_info(i)
size += tmp
2014-01-18 00:58:22 +04:00
print_info(site_info, title, ext, size)
if not info_only:
2015-02-08 20:07:40 +03:00
download_urls(urls, title, ext, size, output_dir=output_dir, merge=merge)
2014-01-18 00:58:22 +04:00
2014-10-31 11:14:58 +03:00
def letvcloud_download_by_vu(vu, title=None, output_dir='.', merge=True, info_only=False):
str2Hash = 'cfflashformatjsonran0.7214574650861323uu2d8c027396ver2.1vu' + vu + 'bie^#@(%27eib58'
sign = hashlib.md5(str2Hash.encode('utf-8')).hexdigest()
request_info = urllib.request.Request('http://api.letvcloud.com/gpc.php?&sign='+sign+'&cf=flash&vu='+vu+'&ver=2.1&ran=0.7214574650861323&qr=2&format=json&uu=2d8c027396')
response = urllib.request.urlopen(request_info)
data = response.read()
info = json.loads(data.decode('utf-8'))
type_available = []
for i in info['data']['video_info']['media']:
type_available.append({'video_url': info['data']['video_info']['media'][i]['play_url']['main_url'], 'video_quality': int(info['data']['video_info']['media'][i]['play_url']['vtype'])})
urls = [base64.b64decode(sorted(type_available, key = lambda x:x['video_quality'])[-1]['video_url']).decode("utf-8")]
size = urls_size(urls)
ext = 'mp4'
print_info(site_info, title, ext, size)
if not info_only:
download_urls(urls, title, ext, size, output_dir=output_dir, merge=merge)
def letvcloud_download(url, output_dir='.', merge=True, info_only=False):
for i in url.split('&'):
if 'vu=' in i:
vu = i[3:]
if len(vu) == 0:
raise ValueError('Cannot get vu!')
title = "LETV-%s" % vu
letvcloud_download_by_vu(vu, title=title, output_dir=output_dir, merge=merge, info_only=info_only)
2015-02-08 20:07:40 +03:00
def letv_download(url, output_dir='.', merge=True, info_only=False ,**kwargs):
2014-10-31 11:14:58 +03:00
if re.match(r'http://yuntv.letv.com/', url):
letvcloud_download(url, output_dir=output_dir, merge=merge, info_only=info_only)
2014-01-18 00:58:22 +04:00
else:
2014-10-31 11:14:58 +03:00
html = get_content(url)
#to get title
if re.match(r'http://www.letv.com/ptv/vplay/(\d+).html', url):
vid = match1(url, r'http://www.letv.com/ptv/vplay/(\d+).html')
else:
vid = match1(html, r'vid="(\d+)"')
title = match1(html,r'name="irTitle" content="(.*?)"')
2015-02-08 20:07:40 +03:00
letv_download_by_vid(vid, title=title, output_dir=output_dir, merge=merge, info_only=info_only,**kwargs)
2014-01-18 00:58:22 +04:00
2014-10-31 11:14:58 +03:00
site_info = "LeTV.com"
2014-01-18 00:58:22 +04:00
download = letv_download
download_playlist = playlist_not_supported('letv')