diff --git a/plugin.video.alfa/servers/streamcherry.py b/plugin.video.alfa/servers/streamcherry.py index 76987bee..61b3c28b 100644 --- a/plugin.video.alfa/servers/streamcherry.py +++ b/plugin.video.alfa/servers/streamcherry.py @@ -26,12 +26,16 @@ def get_video_url(page_url, premium=False, user="", password="", video_password= data = httptools.downloadpage(page_url).data video_urls = [] - matches = scrapertools.find_multiple_matches(data, 'type\s*:\s*"([^"]+)"\s*,\s*src:"([^"]+)",height\s*:\s*(\d+)') - for ext, media_url, calidad in matches: - ext = ext.replace("video/", "") + + matches = scrapertools.find_multiple_matches(data, "type:\"video/([^\"]+)\",src:d\('([^']+)',(.*?)\).+?height:(\d+)") + + for ext, encoded, code, quality in matches: + + media_url = decode(encoded, int(code)) + if not media_url.startswith("http"): - media_url = "http:%s" % media_url - video_urls.append([".%s %sp [streamcherry]" % (ext, calidad), media_url]) + media_url = "http:" + media_url + video_urls.append([".%s %sp [streamango]" % (ext, quality), media_url]) video_urls.reverse() for video_url in video_urls: @@ -40,23 +44,36 @@ def get_video_url(page_url, premium=False, user="", password="", video_password= return video_urls -# Encuentra vĂ­deos del servidor en el texto pasado -def find_videos(data): - encontrados = set() - devuelve = [] +def decode(encoded, code): + logger.info("encoded '%s', code '%s'" % (encoded, code)) - patronvideos = 'streamcherry.com/(?:embed|f)/([A-z0-9]+)' - logger.info("#" + patronvideos + "#") - matches = re.compile(patronvideos, re.DOTALL).findall(data) + _0x59b81a = "" + k = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=' + k = k[::-1] - for match in matches: - titulo = "[streamcherry]" - url = "http://streamcherry.com/embed/%s" % match - if url not in encontrados: - logger.info(" url=" + url) - devuelve.append([titulo, url, 'streamcherry']) - encontrados.add(url) - else: - logger.info(" url duplicada=" + url) + count = 0 - return devuelve + for index in range(0, len(encoded) - 1): + while count <= len(encoded) - 1: + _0x4a2f3a = k.index(encoded[count]) + count += 1 + _0x29d5bf = k.index(encoded[count]) + count += 1 + _0x3b6833 = k.index(encoded[count]) + count += 1 + _0x426d70 = k.index(encoded[count]) + count += 1 + + _0x2e4782 = ((_0x4a2f3a << 2) | (_0x29d5bf >> 4)) + _0x2c0540 = (((_0x29d5bf & 15) << 4) | (_0x3b6833 >> 2)) + _0x5a46ef = ((_0x3b6833 & 3) << 6) | _0x426d70 + _0x2e4782 = _0x2e4782 ^ code + + _0x59b81a = str(_0x59b81a) + chr(_0x2e4782) + + if _0x3b6833 != 64: + _0x59b81a = str(_0x59b81a) + chr(_0x2c0540) + if _0x3b6833 != 64: + _0x59b81a = str(_0x59b81a) + chr(_0x5a46ef) + + return _0x59b81a