diff --git a/plugin.video.alfa/channels/cinefox.json b/plugin.video.alfa/channels/cinefox.json
index 17b3228f..2edcc04a 100755
--- a/plugin.video.alfa/channels/cinefox.json
+++ b/plugin.video.alfa/channels/cinefox.json
@@ -67,6 +67,23 @@
"enabled": true,
"visible": true
},
+ {
+ "id": "comprueba_enlaces",
+ "type": "bool",
+ "label": "Verificar si los enlaces existen",
+ "default": false,
+ "enabled": true,
+ "visible": true
+ },
+ {
+ "id": "comprueba_enlaces_num",
+ "type": "list",
+ "label": "Número de enlaces a verificar",
+ "default": 1,
+ "enabled": true,
+ "visible": "eq(-1,true)",
+ "lvalues": [ "5", "10", "15", "20" ]
+ },
{
"id": "perfil",
"type": "list",
diff --git a/plugin.video.alfa/channels/cinefox.py b/plugin.video.alfa/channels/cinefox.py
index 115e5d89..264afbd2 100644
--- a/plugin.video.alfa/channels/cinefox.py
+++ b/plugin.video.alfa/channels/cinefox.py
@@ -25,6 +25,8 @@ list_servers = ['openload', 'powvideo', 'rapidvideo', 'streamango', 'streamcloud
__modo_grafico__ = config.get_setting('modo_grafico', 'cinefox')
__perfil__ = int(config.get_setting('perfil', "cinefox"))
__menu_info__ = config.get_setting('menu_info', 'cinefox')
+__comprueba_enlaces__ = config.get_setting('comprueba_enlaces', 'cinefox')
+__comprueba_enlaces_num__ = config.get_setting('comprueba_enlaces_num', 'cinefox')
# Fijar perfil de color
perfil = [['0xFFFFE6CC', '0xFFFFCE9C', '0xFF994D00', '0xFFFE2E2E', '0xFF088A08'],
@@ -685,8 +687,23 @@ def findvideos(item):
autoplay.start(itemlist, item)
+ if __comprueba_enlaces__:
+ for it in itemlist:
+ if it.server != '' and it.url != '':
+ it.url = normalizar_url(it.url, it.server)
+ itemlist = servertools.check_list_links(itemlist, __comprueba_enlaces_num__)
+
return itemlist
+def normalizar_url(url, server):
+ # Pasar por findvideosbyserver para para obtener url a partir de los pattern/url de los json de servidores
+ # Excepciones copiadas de la funcion play
+ url = url.replace("http://miracine.tv/n/?etu=", "http://hqq.tv/player/embed_player.php?vid=")
+ url = url.replace("streamcloud.eu/embed-", "streamcloud.eu/")
+ enlaces = servertools.findvideosbyserver(url, server)[0]
+ if enlaces[1] != '':
+ return enlaces[1]
+ return url
def get_enlaces(item, url, type):
itemlist = []
diff --git a/plugin.video.alfa/channels/newpct.json b/plugin.video.alfa/channels/newpct.json
index 9a3b8e8d..d9d4943f 100755
--- a/plugin.video.alfa/channels/newpct.json
+++ b/plugin.video.alfa/channels/newpct.json
@@ -20,6 +20,23 @@
"default": false,
"enabled": true,
"visible": true
+ },
+ {
+ "id": "comprueba_enlaces",
+ "type": "bool",
+ "label": "Verificar si los enlaces existen",
+ "default": false,
+ "enabled": true,
+ "visible": true
+ },
+ {
+ "id": "comprueba_enlaces_num",
+ "type": "list",
+ "label": "Número de enlaces a verificar",
+ "default": 1,
+ "enabled": true,
+ "visible": "eq(-1,true)",
+ "lvalues": [ "5", "10", "15", "20" ]
}
]
-}
\ No newline at end of file
+}
diff --git a/plugin.video.alfa/channels/newpct.py b/plugin.video.alfa/channels/newpct.py
index 22bf446e..b6833ac6 100755
--- a/plugin.video.alfa/channels/newpct.py
+++ b/plugin.video.alfa/channels/newpct.py
@@ -10,6 +10,10 @@ from core.item import Item
from platformcode import logger
from core import httptools
+from platformcode import config
+__comprueba_enlaces__ = config.get_setting('comprueba_enlaces', 'newpct')
+__comprueba_enlaces_num__ = config.get_setting('comprueba_enlaces_num', 'newpct')
+
Host='http://www.tvsinpagar.com'
@@ -97,4 +101,6 @@ def findvideos(item):
itemlist.extend(new_item)
for it in itemlist:
it.channel = item.channel
+ if __comprueba_enlaces__:
+ itemlist = servertools.check_list_links(itemlist, __comprueba_enlaces_num__)
return itemlist
diff --git a/plugin.video.alfa/channels/peliculasdk.json b/plugin.video.alfa/channels/peliculasdk.json
index 2fed6d4d..8f52c17e 100755
--- a/plugin.video.alfa/channels/peliculasdk.json
+++ b/plugin.video.alfa/channels/peliculasdk.json
@@ -26,6 +26,23 @@
"default": true,
"enabled": true,
"visible": true
+ },
+ {
+ "id": "comprueba_enlaces",
+ "type": "bool",
+ "label": "Verificar si los enlaces existen",
+ "default": false,
+ "enabled": true,
+ "visible": true
+ },
+ {
+ "id": "comprueba_enlaces_num",
+ "type": "list",
+ "label": "Número de enlaces a verificar",
+ "default": 1,
+ "enabled": true,
+ "visible": "eq(-1,true)",
+ "lvalues": [ "5", "10", "15", "20" ]
}
]
-}
\ No newline at end of file
+}
diff --git a/plugin.video.alfa/channels/peliculasdk.py b/plugin.video.alfa/channels/peliculasdk.py
index 24b596da..546cdf52 100644
--- a/plugin.video.alfa/channels/peliculasdk.py
+++ b/plugin.video.alfa/channels/peliculasdk.py
@@ -11,6 +11,9 @@ from platformcode import logger
from platformcode import config
from core import tmdb
+__comprueba_enlaces__ = config.get_setting('comprueba_enlaces', 'peliculasdk')
+__comprueba_enlaces_num__ = config.get_setting('comprueba_enlaces_num', 'peliculasdk')
+
host = "http://www.peliculasdk.com"
def mainlist(item):
@@ -183,6 +186,8 @@ def findvideos(item):
language=idioma, quality=calidad))
tmdb.set_infoLabels(itemlist)
itemlist = servertools.get_servers_itemlist(itemlist, lambda i: i.title % i.server.capitalize())
+ if __comprueba_enlaces__:
+ itemlist = servertools.check_list_links(itemlist, __comprueba_enlaces_num__)
if item.library and config.get_videolibrary_support() and len(itemlist) > 0:
infoLabels = {'tmdb_id': item.infoLabels['tmdb_id'],
'title': item.fulltitle}
diff --git a/plugin.video.alfa/core/cloudflare.py b/plugin.video.alfa/core/cloudflare.py
index b4948b71..5fd485f7 100755
--- a/plugin.video.alfa/core/cloudflare.py
+++ b/plugin.video.alfa/core/cloudflare.py
@@ -9,7 +9,7 @@ import urllib
import urlparse
from platformcode import logger
-from decimal import Decimal, ROUND_UP
+from decimal import Decimal
class Cloudflare:
def __init__(self, response):
@@ -62,18 +62,17 @@ class Cloudflare:
def get_url(self):
# Metodo #1 (javascript)
if self.js_data.get("wait", 0):
- jschl_answer = self.decode2(self.js_data["value"])
+ jschl_answer = self.decode(self.js_data["value"])
for op, v in self.js_data["op"]:
- #jschl_answer = eval(str(jschl_answer) + op + str(self.decode2(v)))
if op == '+':
- jschl_answer = jschl_answer + self.decode2(v)
+ jschl_answer = jschl_answer + self.decode(v)
elif op == '-':
- jschl_answer = jschl_answer - self.decode2(v)
+ jschl_answer = jschl_answer - self.decode(v)
elif op == '*':
- jschl_answer = jschl_answer * self.decode2(v)
+ jschl_answer = jschl_answer * self.decode(v)
elif op == '/':
- jschl_answer = jschl_answer / self.decode2(v)
+ jschl_answer = jschl_answer / self.decode(v)
self.js_data["params"]["jschl_answer"] = round(jschl_answer, 10) + len(self.domain)
@@ -93,7 +92,7 @@ class Cloudflare:
return response
- def decode2(self, data):
+ def decode(self, data):
data = re.sub("\!\+\[\]", "1", data)
data = re.sub("\!\!\[\]", "1", data)
data = re.sub("\[\]", "0", data)
@@ -112,59 +111,4 @@ class Cloudflare:
for n in aux:
num2 += str(eval(n))
- #return float(num1) / float(num2)
- #return Decimal(Decimal(num1) / Decimal(num2)).quantize(Decimal('.0000000000000001'), rounding=ROUND_UP)
return Decimal(Decimal(num1) / Decimal(num2)).quantize(Decimal('.0000000000000001'))
-
- def decode(self, data):
- t = time.time()
- timeout = False
-
- while not timeout:
- data = re.sub("\[\]", "''", data)
- data = re.sub("!\+''", "+1", data)
- data = re.sub("!''", "0", data)
- data = re.sub("!0", "1", data)
-
- if "(" in data:
- x, y = data.rfind("("), data.find(")", data.rfind("(")) + 1
- part = data[x + 1:y - 1]
- else:
- x = 0
- y = len(data)
- part = data
-
- val = ""
-
- if not part.startswith("+"): part = "+" + part
-
- for i, ch in enumerate(part):
- if ch == "+":
- if not part[i + 1] == "'":
- if val == "": val = 0
- if type(val) == str:
- val = val + self.get_number(part, i + 1)
- else:
- val = val + int(self.get_number(part, i + 1))
- else:
- val = str(val)
- val = val + self.get_number(part, i + 1) or "0"
-
- if type(val) == str: val = "'%s'" % val
- data = data[0:x] + str(val) + data[y:]
-
- timeout = time.time() - t > self.timeout
-
- if not "+" in data and not "(" in data and not ")" in data:
- return int(self.get_number(data))
-
- def get_number(self, str, start=0):
- ret = ""
- for chr in str[start:]:
- try:
- int(chr)
- except:
- if ret: break
- else:
- ret += chr
- return ret
diff --git a/plugin.video.alfa/core/servertools.py b/plugin.video.alfa/core/servertools.py
index da799696..f280145c 100644
--- a/plugin.video.alfa/core/servertools.py
+++ b/plugin.video.alfa/core/servertools.py
@@ -705,3 +705,45 @@ def filter_servers(servers_list):
servers_list = servers_list_filter
return servers_list
+
+def check_list_links(itemlist, numero):
+ """
+ Comprueba una lista de enlaces a videos y la devuelve modificando el titulo con la verificacion.
+ El segundo parametro (numero) indica cuantos enlaces hay que verificar (0:5, 1:10, 2:15, 3:20)
+ """
+ numero = ((int(numero) + 1) * 5) if numero != '' else 10
+ for it in itemlist:
+ if numero > 0 and it.server != '' and it.url != '':
+ verificacion = check_video_link(it.url, it.server)
+ it.title = verificacion + ', ' + it.title.strip()
+ numero -= 1
+ return itemlist
+
+def check_video_link(url, server):
+ """
+ Comprueba si el enlace a un video es valido y devuelve un string de 2 posiciones con la verificacion.
+ :param url, server: Link y servidor
+ :return: str(2) '??':No se ha podido comprobar. 'Ok':Parece que el link funciona. 'NO':Parece que no funciona.
+ """
+ try:
+ server_module = __import__('servers.%s' % server, None, None, ["servers.%s" % server])
+ except:
+ server_module = None
+ logger.info("[check_video_link] No se puede importar el servidor! %s" % server)
+ return "??"
+
+ if hasattr(server_module, 'test_video_exists'):
+ try:
+ video_exists, message = server_module.test_video_exists(page_url=url)
+ if not video_exists:
+ logger.info("[check_video_link] No existe! %s %s %s" % (message, server, url))
+ return "NO"
+ else:
+ logger.info("[check_video_link] comprovacion OK %s %s" % (server, url))
+ return "Ok"
+ except:
+ logger.info("[check_video_link] No se puede comprobar ahora! %s %s" % (server, url))
+ return "??"
+
+ logger.info("[check_video_link] No hay test_video_exists para servidor: %s" % server)
+ return "??"
diff --git a/plugin.video.alfa/servers/netutv.py b/plugin.video.alfa/servers/netutv.py
index e17c0fec..df396157 100755
--- a/plugin.video.alfa/servers/netutv.py
+++ b/plugin.video.alfa/servers/netutv.py
@@ -8,6 +8,18 @@ from core import jsontools
from core import scrapertools
from platformcode import logger
+def test_video_exists(page_url):
+ logger.info("(page_url='%s')" % page_url)
+
+ # http://netu.tv/watch_video.php=XX solo contiene una redireccion, ir directamente a http://hqq.tv/player/embed_player.php?vid=XX
+ page_url = page_url.replace("http://netu.tv/watch_video.php?v=", "http://hqq.tv/player/embed_player.php?vid=")
+
+ data = httptools.downloadpage(page_url).data
+
+ if "var userid = '';" in data.lower():
+ return False, "[netutv] El archivo no existe o ha sido borrado"
+
+ return True, ""
def get_video_url(page_url, premium=False, user="", password="", video_password=""):
logger.info("url=" + page_url)
diff --git a/plugin.video.alfa/servers/powvideo.py b/plugin.video.alfa/servers/powvideo.py
index efaf6d4b..c82961ec 100755
--- a/plugin.video.alfa/servers/powvideo.py
+++ b/plugin.video.alfa/servers/powvideo.py
@@ -33,377 +33,16 @@ def get_video_url(page_url, premium=False, user="", password="", video_password=
if 'Video is processing now' in data:
return "El vídeo está siendo procesado, intentalo de nuevo mas tarde"
- var = scrapertools.find_single_match(data, 'var _0x[0-f]{4}=(\[[^;]+\]);')
-
packed = scrapertools.find_single_match(data, "")
unpacked = jsunpack.unpack(packed)
url = scrapertools.find_single_match(unpacked, "(?:src):\\\\'([^\\\\]+.mp4)\\\\'")
- itemlist.append([".mp4" + " [powvideo]", S(var).decode(url)])
+ itemlist.append([".mp4" + " [powvideo]", decode_powvideo_url(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(0xd3, 0, -1):
- var.append(var.pop(0))
-
- self.var = var
-
- self.t(
- self.decode_index('0xc') +
- self.decode_index('0d') +
- self.decode_index('0xe') +
- self.decode_index('0xf'),
- self.decode_index('0x10')
- )
-
- 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
+def decode_powvideo_url(url):
+ tria = re.compile('[0-9a-z]{40,}', re.IGNORECASE).findall(url)[0]
+ gira = tria[::-1]
+ x = gira[:2] + gira[3:]
+ return re.sub(tria, x, url)
diff --git a/plugin.video.alfa/servers/streamplay.py b/plugin.video.alfa/servers/streamplay.py
index 427762b3..9ceae02b 100644
--- a/plugin.video.alfa/servers/streamplay.py
+++ b/plugin.video.alfa/servers/streamplay.py
@@ -36,375 +36,15 @@ def get_video_url(page_url, premium=False, user="", password="", video_password=
packed = scrapertools.find_single_match(data, "")
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.append([".mp4" + " [streamplay]", decode_video_url(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
+def decode_video_url(url):
+ tria = re.compile('[0-9a-z]{40,}', re.IGNORECASE).findall(url)[0]
+ gira = tria[::-1]
+ x = gira[:2] + gira[3:]
+ return re.sub(tria, x, url)