411 lines
13 KiB
Python
411 lines
13 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
import re
|
|
import base64
|
|
import urllib
|
|
|
|
from core import httptools
|
|
from core import scrapertools
|
|
from lib import jsunpack
|
|
from platformcode import logger
|
|
|
|
headers = [['User-Agent', 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:53.0) Gecko/20100101 Firefox/53.0']]
|
|
|
|
|
|
def test_video_exists(page_url):
|
|
logger.info("(page_url='%s')" % page_url)
|
|
referer = re.sub(r"embed-|player-", "", page_url)[:-5]
|
|
data = httptools.downloadpage(page_url, headers={'Referer': referer}).data
|
|
if data == "File was deleted":
|
|
return False, "[Streamplay] El archivo no existe o ha sido borrado"
|
|
elif "Video is processing now" in data:
|
|
return False, "[Streamplay] El archivo se está procesando"
|
|
return True, ""
|
|
|
|
|
|
def get_video_url(page_url, premium=False, user="", password="", video_password=""):
|
|
logger.info()
|
|
itemlist = []
|
|
|
|
referer = re.sub(r"embed-|player-", "", page_url)[:-5]
|
|
|
|
data = httptools.downloadpage(page_url, headers={'Referer': referer}).data
|
|
|
|
if data == "File was deleted":
|
|
return "El archivo no existe o ha sido borrado"
|
|
|
|
packed = scrapertools.find_single_match(data, "<script type=[\"']text/javascript[\"']>(eval.*?)</script>")
|
|
unpacked = jsunpack.unpack(packed)
|
|
var = scrapertools.find_single_match(data, 'var _0x[0-f]+=(\[[^;]+\]);')
|
|
|
|
url = scrapertools.find_single_match(unpacked, '(http[^,]+\.mp4)')
|
|
itemlist.append([".mp4" + " [streamplay]", S(var).decode(url)])
|
|
itemlist.sort(key=lambda x: x[0], reverse=True)
|
|
|
|
return itemlist
|
|
|
|
|
|
class S:
|
|
def __init__(self, var):
|
|
self.r = None
|
|
self.s = None
|
|
self.k = None
|
|
self.n = None
|
|
self.c = None
|
|
self.b = None
|
|
self.d = None
|
|
|
|
var = eval(var)
|
|
for x in range(0xf8, 0, -1):
|
|
var.append(var.pop(0))
|
|
|
|
self.var = var
|
|
|
|
self.t(
|
|
self.decode_index('0xb') +
|
|
self.decode_index('0xc') +
|
|
self.decode_index('0xd') +
|
|
self.decode_index('0xe'),
|
|
self.decode_index('0xf')
|
|
)
|
|
|
|
def decode_index(self, index, key=None):
|
|
b64_data = self.var[int(index, 16)]
|
|
result = ''
|
|
_0xb99338 = 0x0
|
|
_0x25e3f4 = 0x0
|
|
|
|
data = base64.b64decode(b64_data)
|
|
data = urllib.unquote(data).decode('utf8')
|
|
|
|
if key:
|
|
_0x5da081 = [x for x in range(0x100)]
|
|
|
|
for x in range(0x100):
|
|
_0xb99338 = (_0xb99338 + _0x5da081[x] + ord(key[x % len(key)])) % 0x100
|
|
_0x139847 = _0x5da081[x]
|
|
_0x5da081[x] = _0x5da081[_0xb99338]
|
|
_0x5da081[_0xb99338] = _0x139847
|
|
|
|
_0xb99338 = 0x0
|
|
|
|
for _0x11ebc5 in range(len(data)):
|
|
_0x25e3f4 = (_0x25e3f4 + 0x1) % 0x100
|
|
_0xb99338 = (_0xb99338 + _0x5da081[_0x25e3f4]) % 0x100
|
|
_0x139847 = _0x5da081[_0x25e3f4]
|
|
_0x5da081[_0x25e3f4] = _0x5da081[_0xb99338]
|
|
_0x5da081[_0xb99338] = _0x139847
|
|
result += chr(ord(data[_0x11ebc5]) ^ _0x5da081[(_0x5da081[_0x25e3f4] + _0x5da081[_0xb99338]) % 0x100])
|
|
|
|
return result
|
|
else:
|
|
return data
|
|
|
|
def decode(self, url):
|
|
_hash = re.compile('[A-z0-9_-]{40,}', re.DOTALL).findall(url)[0]
|
|
return url.replace(_hash, self.p(_hash))
|
|
|
|
def t(self, t, i):
|
|
self.r = 20
|
|
self.s = [1634760805, 857760878, 2036477234, 1797285236]
|
|
self.k = []
|
|
self.n = [0, 0]
|
|
self.c = [0, 0]
|
|
self.b = [None] * 64
|
|
self.d = 64
|
|
|
|
self.sk(self.sa(t))
|
|
self.sn(self.sa(i))
|
|
|
|
def e(self, t):
|
|
s = self.gb(len(t))
|
|
i = [s[h] ^ t[h] for h in range(len(t))]
|
|
return i
|
|
|
|
def p(self, t):
|
|
import base64
|
|
t += "=" * (4 - len(t) % 4)
|
|
t = base64.b64decode(t.replace('-', '+').replace('_', '/'))
|
|
return self._as(self.e(self.sa(t)))
|
|
|
|
@staticmethod
|
|
def sa(t):
|
|
s = [ord(t[i]) for i in range(len(t))]
|
|
return s
|
|
|
|
@staticmethod
|
|
def _as(t):
|
|
s = [chr(t[i]) for i in range(len(t))]
|
|
return ''.join(s)
|
|
|
|
def sk(self, t):
|
|
s = 0
|
|
for i in range(8):
|
|
self.k.append(
|
|
255 & t[s] | self.lshift((255 & t[s + 1]), 8) | self.lshift((255 & t[s + 2]), 16) | self.lshift(
|
|
(255 & t[s + 3]), 24))
|
|
s += 4
|
|
self._r()
|
|
|
|
def sn(self, t):
|
|
self.n[0] = 255 & t[0] | self.lshift((255 & t[1]), 8) | self.lshift((255 & t[2]), 16) | self.lshift(
|
|
(255 & t[3]), 24)
|
|
self.n[1] = 255 & t[4] | self.lshift((255 & t[5]), 8) | self.lshift((255 & t[6]), 16) | self.lshift(
|
|
(255 & t[7]), 24)
|
|
self._r()
|
|
|
|
def gb(self, t):
|
|
i = [None] * t
|
|
|
|
for s in range(t):
|
|
if 64 == self.d:
|
|
self._g()
|
|
self._i()
|
|
self.d = 0
|
|
|
|
i[s] = self.b[self.d]
|
|
self.d += 1
|
|
|
|
return i
|
|
|
|
def gh(self, t):
|
|
i = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f']
|
|
h = self.gb(t)
|
|
s = [i[self.rshift(h[b], 4) & 15] for b in range(len(h))]
|
|
s.append(i[15 & h[len(h)]])
|
|
return ''.join(s)
|
|
|
|
def _r(self):
|
|
self.c[0] = 0
|
|
self.c[1] = 0
|
|
self.d = 64
|
|
|
|
def _i(self):
|
|
self.c[0] = self.c[0] + 1 & 4294967295
|
|
if 0 == self.c[0]:
|
|
self.c[1] = self.c[1] + 1 & 4294967295
|
|
|
|
def _g(self):
|
|
i = self.s[0]
|
|
s = self.k[0]
|
|
h = self.k[1]
|
|
b = self.k[2]
|
|
r = self.k[3]
|
|
n = self.s[1]
|
|
o = self.n[0]
|
|
e = self.n[1]
|
|
c = self.c[0]
|
|
p = self.c[1]
|
|
a = self.s[2]
|
|
f = self.k[4]
|
|
u = self.k[5]
|
|
g = self.k[6]
|
|
y = self.k[7]
|
|
k = self.s[3]
|
|
l = i
|
|
d = s
|
|
v = h
|
|
_ = b
|
|
A = r
|
|
w = n
|
|
C = o
|
|
S = e
|
|
j = c
|
|
m = p
|
|
q = a
|
|
x = f
|
|
z = u
|
|
B = g
|
|
D = y
|
|
E = k
|
|
|
|
for F in range(0, self.r, 2):
|
|
# 0
|
|
t = l + z
|
|
A ^= self.lshift(t, 7) | self.bshift(t, 25)
|
|
t = A + l
|
|
j ^= self.lshift(t, 9) | self.bshift(t, 23)
|
|
t = j + A
|
|
z ^= self.lshift(t, 13) | self.bshift(t, 19)
|
|
t = z + j
|
|
l ^= self.lshift(t, 18) | self.bshift(t, 14)
|
|
|
|
# 1
|
|
t = w + d
|
|
m ^= self.lshift(t, 7) | self.bshift(t, 25)
|
|
t = m + w
|
|
B ^= self.lshift(t, 9) | self.bshift(t, 23)
|
|
t = B + m
|
|
d ^= self.lshift(t, 13) | self.bshift(t, 19)
|
|
t = d + B
|
|
w ^= self.lshift(t, 18) | self.bshift(t, 14)
|
|
|
|
# 2
|
|
t = q + C
|
|
D ^= self.lshift(t, 7) | self.bshift(t, 25)
|
|
t = D + q
|
|
v ^= self.lshift(t, 9) | self.bshift(t, 23)
|
|
t = v + D
|
|
C ^= self.lshift(t, 13) | self.bshift(t, 19)
|
|
t = C + v
|
|
q ^= self.lshift(t, 18) | self.bshift(t, 14)
|
|
|
|
# 3
|
|
t = E + x
|
|
_ ^= self.lshift(t, 7) | self.bshift(t, 25)
|
|
t = _ + E
|
|
S ^= self.lshift(t, 9) | self.bshift(t, 23)
|
|
t = S + _
|
|
x ^= self.lshift(t, 13) | self.bshift(t, 19)
|
|
t = x + S
|
|
E ^= self.lshift(t, 18) | self.bshift(t, 14)
|
|
|
|
# 4
|
|
t = l + _
|
|
d ^= self.lshift(t, 7) | self.bshift(t, 25)
|
|
t = d + l
|
|
v ^= self.lshift(t, 9) | self.bshift(t, 23)
|
|
t = v + d
|
|
_ ^= self.lshift(t, 13) | self.bshift(t, 19)
|
|
t = _ + v
|
|
l ^= self.lshift(t, 18) | self.bshift(t, 14)
|
|
|
|
# 5
|
|
t = w + A
|
|
C ^= self.lshift(t, 7) | self.bshift(t, 25)
|
|
t = C + w
|
|
S ^= self.lshift(t, 9) | self.bshift(t, 23)
|
|
t = S + C
|
|
A ^= self.lshift(t, 13) | self.bshift(t, 19)
|
|
t = A + S
|
|
w ^= self.lshift(t, 18) | self.bshift(t, 14)
|
|
|
|
# 6
|
|
t = q + m
|
|
x ^= self.lshift(t, 7) | self.bshift(t, 25)
|
|
t = x + q
|
|
j ^= self.lshift(t, 9) | self.bshift(t, 23)
|
|
t = j + x
|
|
m ^= self.lshift(t, 13) | self.bshift(t, 19)
|
|
t = m + j
|
|
q ^= self.lshift(t, 18) | self.bshift(t, 14)
|
|
|
|
# 7
|
|
t = E + D
|
|
z ^= self.lshift(t, 7) | self.bshift(t, 25)
|
|
t = z + E
|
|
B ^= self.lshift(t, 9) | self.bshift(t, 23)
|
|
t = B + z
|
|
D ^= self.lshift(t, 13) | self.bshift(t, 19)
|
|
t = D + B
|
|
E ^= self.lshift(t, 18) | self.bshift(t, 14)
|
|
|
|
l += i
|
|
d += s
|
|
v += h
|
|
_ += b
|
|
A += r
|
|
w += n
|
|
C += o
|
|
S += e
|
|
j += c
|
|
m += p
|
|
q += a
|
|
x += f
|
|
z += u
|
|
B += g
|
|
D += y
|
|
E += k
|
|
|
|
self.b[0] = self.bshift(l, 0) & 255
|
|
self.b[1] = self.bshift(l, 8) & 255
|
|
self.b[2] = self.bshift(l, 16) & 255
|
|
self.b[3] = self.bshift(l, 24) & 255
|
|
self.b[4] = self.bshift(d, 0) & 255
|
|
self.b[5] = self.bshift(d, 8) & 255
|
|
self.b[6] = self.bshift(d, 16) & 255
|
|
self.b[7] = self.bshift(d, 24) & 255
|
|
self.b[8] = self.bshift(v, 0) & 255
|
|
self.b[9] = self.bshift(v, 8) & 255
|
|
self.b[10] = self.bshift(v, 16) & 255
|
|
self.b[11] = self.bshift(v, 24) & 255
|
|
self.b[12] = self.bshift(_, 0) & 255
|
|
self.b[13] = self.bshift(_, 8) & 255
|
|
self.b[14] = self.bshift(_, 16) & 255
|
|
self.b[15] = self.bshift(_, 24) & 255
|
|
self.b[16] = self.bshift(A, 0) & 255
|
|
self.b[17] = self.bshift(A, 8) & 255
|
|
self.b[18] = self.bshift(A, 16) & 255
|
|
self.b[19] = self.bshift(A, 24) & 255
|
|
self.b[20] = self.bshift(w, 0) & 255
|
|
self.b[21] = self.bshift(w, 8) & 255
|
|
self.b[22] = self.bshift(w, 16) & 255
|
|
self.b[23] = self.bshift(w, 24) & 255
|
|
self.b[24] = self.bshift(C, 0) & 255
|
|
self.b[25] = self.bshift(C, 8) & 255
|
|
self.b[26] = self.bshift(C, 16) & 255
|
|
self.b[27] = self.bshift(C, 24) & 255
|
|
self.b[28] = self.bshift(S, 0) & 255
|
|
self.b[29] = self.bshift(S, 8) & 255
|
|
self.b[30] = self.bshift(S, 16) & 255
|
|
self.b[31] = self.bshift(S, 24) & 255
|
|
self.b[32] = self.bshift(j, 0) & 255
|
|
self.b[33] = self.bshift(j, 8) & 255
|
|
self.b[34] = self.bshift(j, 16) & 255
|
|
self.b[35] = self.bshift(j, 24) & 255
|
|
self.b[36] = self.bshift(m, 0) & 255
|
|
self.b[37] = self.bshift(m, 8) & 255
|
|
self.b[38] = self.bshift(m, 16) & 255
|
|
self.b[39] = self.bshift(m, 24) & 255
|
|
self.b[40] = self.bshift(q, 0) & 255
|
|
self.b[41] = self.bshift(q, 8) & 255
|
|
self.b[42] = self.bshift(q, 16) & 255
|
|
self.b[43] = self.bshift(q, 24) & 255
|
|
self.b[44] = self.bshift(x, 0) & 255
|
|
self.b[45] = self.bshift(x, 8) & 255
|
|
self.b[46] = self.bshift(x, 16) & 255
|
|
self.b[47] = self.bshift(x, 24) & 255
|
|
self.b[48] = self.bshift(z, 0) & 255
|
|
self.b[49] = self.bshift(z, 8) & 255
|
|
self.b[50] = self.bshift(z, 16) & 255
|
|
self.b[51] = self.bshift(z, 24) & 255
|
|
self.b[52] = self.bshift(B, 0) & 255
|
|
self.b[53] = self.bshift(B, 8) & 255
|
|
self.b[54] = self.bshift(B, 16) & 255
|
|
self.b[55] = self.bshift(B, 24) & 255
|
|
self.b[56] = self.bshift(D, 0) & 255
|
|
self.b[57] = self.bshift(D, 8) & 255
|
|
self.b[58] = self.bshift(D, 16) & 255
|
|
self.b[59] = self.bshift(D, 24) & 255
|
|
self.b[60] = self.bshift(E, 0) & 255
|
|
self.b[61] = self.bshift(E, 8) & 255
|
|
self.b[62] = self.bshift(E, 16) & 255
|
|
self.b[63] = self.bshift(E, 24) & 255
|
|
|
|
def lshift(self, num, other):
|
|
lnum = self.ToInt32(num)
|
|
rnum = self.ToUint32(other)
|
|
shift_count = rnum & 0x1F
|
|
return self.ToInt32(lnum << shift_count)
|
|
|
|
def rshift(self, num, other):
|
|
lnum = self.ToInt32(num)
|
|
rnum = self.ToUint32(other)
|
|
shift_count = rnum & 0x1F
|
|
return self.ToInt32(lnum >> shift_count)
|
|
|
|
def bshift(self, num, other):
|
|
lnum = self.ToUint32(num)
|
|
rnum = self.ToUint32(other)
|
|
shift_count = rnum & 0x1F
|
|
return self.ToUint32(lnum >> shift_count)
|
|
|
|
@staticmethod
|
|
def ToInt32(num):
|
|
int32 = num % 2 ** 32
|
|
return int32 - 2 ** 32 if int32 >= 2 ** 31 else int32
|
|
|
|
@staticmethod
|
|
def ToUint32(num):
|
|
return num % 2 ** 32
|