From b88ef13772ad61b8b380f9dc1811244c6b421a67 Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Wed, 6 Dec 2017 15:55:20 -0500 Subject: [PATCH 01/16] search: fix channels orders --- plugin.video.alfa/channels/search.py | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/plugin.video.alfa/channels/search.py b/plugin.video.alfa/channels/search.py index 9c9f492d..d0bbf80d 100644 --- a/plugin.video.alfa/channels/search.py +++ b/plugin.video.alfa/channels/search.py @@ -267,10 +267,9 @@ def channel_search(search_results, channel_parameters, tecleado): if result is None: result = [] if len(result): - if not channel_parameters["title"] in search_results: - search_results[channel_parameters["title"]] = [] - - search_results[channel_parameters["title"]].append({"item": item, + if not channel_parameters["title"].capitalize() in search_results: + search_results[channel_parameters["title"].capitalize()] = [] + search_results[channel_parameters["title"].capitalize()].append({"item": item, "itemlist": result, "adult": channel_parameters["adult"]}) From 29324c43029898d6abaf7a803627490b90dadf16 Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Wed, 6 Dec 2017 15:57:28 -0500 Subject: [PATCH 02/16] yaske: fix search and get more links --- plugin.video.alfa/channels/yaske.py | 26 +++++++++++++++----------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/plugin.video.alfa/channels/yaske.py b/plugin.video.alfa/channels/yaske.py index c1bd2f1b..ab58b687 100644 --- a/plugin.video.alfa/channels/yaske.py +++ b/plugin.video.alfa/channels/yaske.py @@ -105,7 +105,6 @@ def peliculas(item): patron += 'post(.*?) 0: @@ -131,7 +130,7 @@ def peliculas(item): tmdb.set_infoLabels(itemlist) # Si es necesario añadir paginacion - if url_next_page: + if matches_next_page: itemlist.append( Item(channel=item.channel, action="peliculas", title=">> Página siguiente", thumbnail=thumbnail_host, url=url_next_page, folder=True, text_color=color3, text_bold=True)) @@ -175,18 +174,23 @@ def findvideos(item): mtmdb = scrapertools.find_single_match(item.url, 'yaske.ro/([0-9]+)') patron = '(?s)id="online".*?server="([^"]+)"' mserver = scrapertools.find_single_match(data, patron) - url = "http://olimpo.link/?tmdb=%s&server=%s" %(mtmdb, mserver) - data = httptools.downloadpage(url).data + url_m = "http://olimpo.link/?tmdb=%s&server=%s" %(mtmdb, mserver) patron = '/\?tmdb=[^"]+.*?domain=(?:www\.|)([^\.]+).*?text-overflow.*?href="([^"]+).*?' patron += '\[([^\]]+)\].*?\[([^\]]+)\]' + data = httptools.downloadpage(url_m).data matches = scrapertools.find_multiple_matches(data, patron) - for server, url, idioma, calidad in matches: - if "drive" in server: - server = "gvideo" - sublist.append(item.clone(channel=item.channel, action="play", url=url, folder=False, text_color=color1, quality=calidad.strip(), - language=idioma.strip(), - title="Ver en %s %s" %(server, calidad) - )) + page = 2 + while len(matches)>0: + for server, url, idioma, calidad in matches: + if "drive" in server: + server = "gvideo" + sublist.append(item.clone(channel=item.channel, action="play", url=url, folder=False, text_color=color1, quality=calidad.strip(), + language=idioma.strip(), + title="Ver en %s %s" %(server, calidad) + )) + data = httptools.downloadpage(url_m + "&page=%s" %page).data + matches = scrapertools.find_multiple_matches(data, patron) + page +=1 for k in ["Español", "Latino", "Ingles - Sub Español", "Ingles"]: lista_idioma = filter(lambda i: i.language == k, sublist) if lista_idioma: From b5f1e7180cf6cb1b071cda8d9f3660ea31a5b07c Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Wed, 6 Dec 2017 17:40:04 -0500 Subject: [PATCH 03/16] userscloud: fix --- plugin.video.alfa/servers/userscloud.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/plugin.video.alfa/servers/userscloud.py b/plugin.video.alfa/servers/userscloud.py index d878e510..a2dfc668 100755 --- a/plugin.video.alfa/servers/userscloud.py +++ b/plugin.video.alfa/servers/userscloud.py @@ -2,6 +2,7 @@ from core import httptools from core import scrapertools +from lib import jsunpack from platformcode import logger @@ -21,7 +22,9 @@ def get_video_url(page_url, premium=False, user="", password="", video_password= video_urls = [] data = httptools.downloadpage(page_url).data - media_url = scrapertools.find_single_match(data, '") + unpacked = jsunpack.unpack(packed) + media_url = scrapertools.find_single_match(unpacked, 'src"value="([^"]+)') if not media_url: id_ = page_url.rsplit("/", 1)[1] rand = scrapertools.find_single_match(data, 'name="rand" value="([^"]+)"') From 0caea466194e4160a6ebf8460bf6610774547cde Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Thu, 7 Dec 2017 14:58:39 -0500 Subject: [PATCH 04/16] Update yaske.py --- plugin.video.alfa/channels/yaske.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/plugin.video.alfa/channels/yaske.py b/plugin.video.alfa/channels/yaske.py index ab58b687..e4f320ee 100644 --- a/plugin.video.alfa/channels/yaske.py +++ b/plugin.video.alfa/channels/yaske.py @@ -184,13 +184,15 @@ def findvideos(item): for server, url, idioma, calidad in matches: if "drive" in server: server = "gvideo" - sublist.append(item.clone(channel=item.channel, action="play", url=url, folder=False, text_color=color1, quality=calidad.strip(), + sublist.append(item.clone(action="play", url=url, folder=False, text_color=color1, quality=calidad.strip(), language=idioma.strip(), + server = server, title="Ver en %s %s" %(server, calidad) )) data = httptools.downloadpage(url_m + "&page=%s" %page).data matches = scrapertools.find_multiple_matches(data, patron) page +=1 + sublist = sorted(sublist, key=lambda Item: Item.quality + Item.server) for k in ["Español", "Latino", "Ingles - Sub Español", "Ingles"]: lista_idioma = filter(lambda i: i.language == k, sublist) if lista_idioma: @@ -217,6 +219,6 @@ def play(item): ddd = httptools.downloadpage(item.url).data url = "http://olimpo.link" + scrapertools.find_single_match(ddd, '' + + patron = '
' matches = re.compile(patron, re.DOTALL).findall(data) + # matches = re.compile(patron, re.DOTALL).findall(data) + for option, url in matches: - lang = scrapertools.find_single_match(data, - '
  • <\/b> (.*?)' % option) + datas = httptools.downloadpage(urlparse.urljoin(host, url), + headers={'Referer': item.url}).data + + patron = ']+src="([^"]+)"' + url = scrapertools.find_single_match(datas, patron) + lang = scrapertools.find_single_match( + data, '
  • <\/b> (.*?)' % option) lang = lang.replace('Español ', '').replace('B.S.O. ', '') - data_b = httptools.downloadpage(urlparse.urljoin(host, url), headers={'Referer': item.url}).data - patron = ']+src="([^"]+)"' - matches = re.compile(patron, re.DOTALL).findall(data_b) - url = matches[0] server = servertools.get_server_from_url(url) title = "%s [COLOR yellow](%s) (%s)[/COLOR]" % (item.contentTitle, server.title(), lang) - itemlist.append(item.clone(action='play', url=url, title=title, extra1=title, server=server, language=lang, - text_color=color3)) + itemlist.append(item.clone(action='play', url=url, title=title, extra1=title, + server=server, language = lang, text_color=color3)) itemlist.append(Item(channel=item.channel, title='[COLOR yellow]Añadir esta pelicula a la videoteca[/COLOR]', From 7c887bf5460a4f68f073ab3294a2890538d9dc6b Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Tue, 12 Dec 2017 10:04:16 -0500 Subject: [PATCH 06/16] Update streamplay.py --- plugin.video.alfa/servers/streamplay.py | 54 ++++++++++++++++++++++--- 1 file changed, 48 insertions(+), 6 deletions(-) diff --git a/plugin.video.alfa/servers/streamplay.py b/plugin.video.alfa/servers/streamplay.py index 0a2c6547..316fe259 100644 --- a/plugin.video.alfa/servers/streamplay.py +++ b/plugin.video.alfa/servers/streamplay.py @@ -1,6 +1,9 @@ # -*- coding: utf-8 -*- import re +import base64 +import urllib + from core import httptools from core import scrapertools @@ -25,12 +28,11 @@ def test_video_exists(page_url): def get_video_url(page_url, premium=False, user="", password="", video_password=""): logger.info("(page_url='%s')" % page_url) - referer = re.sub(r"embed-|player-", "", page_url)[:-5] + referer = page_url.replace('iframe', 'preview') data = httptools.downloadpage(page_url, headers={'Referer': referer}).data - packed = scrapertools.find_single_match(data, "") unpacked = jsunpack.unpack(packed) - _0xd003 = scrapertools.find_single_match(data, 'var _0xd003=(\[[^;]+\]);') + _0xd003 = scrapertools.find_single_match(data, 'var _0x[0-f]+=(\[[^;]+\]);') video_urls = [] url = scrapertools.find_single_match(unpacked, '(http[^,]+\.mp4)') @@ -45,7 +47,7 @@ def get_video_url(page_url, premium=False, user="", password="", video_password= class S: - def __init__(self, _0xd003): + def __init__(self, var): self.r = None self.s = None self.k = None @@ -54,8 +56,48 @@ class S: self.b = None self.d = None - _0xd003 = eval(_0xd003) - self.t(_0xd003[13] + _0xd003[14] + _0xd003[13] + _0xd003[14], _0xd003[15]) + var = eval(var) + for x in range(0x1f0, 0, -1): + var.append(var.pop(0)) + + self.var = var + + self.t( + self.decode_index('0x22', '!UJH') + + self.decode_index('0x23', 'NpE)') + + self.decode_index('0x24', '4uT2') + + self.decode_index('0x23', 'NpE)'), + self.decode_index('0x25', '@ZC2') + ) + + def decode_index(self, index, key): + b64_data = self.var[int(index, 16)]; + result = '' + _0xb99338 = 0x0 + _0x25e3f4 = 0x0 + + data = base64.b64decode(b64_data) + data = urllib.unquote(data).decode('utf8') + + _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 def decode(self, url): _hash = re.compile('[A-z0-9_-]{40,}', re.DOTALL).findall(url)[0] From c2b9f1f0098663b879f36906db3c9ebc140e6252 Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Tue, 12 Dec 2017 10:04:56 -0500 Subject: [PATCH 07/16] Update powvideo.py --- plugin.video.alfa/servers/powvideo.py | 402 +++++++++++++++++++++++++- 1 file changed, 401 insertions(+), 1 deletion(-) diff --git a/plugin.video.alfa/servers/powvideo.py b/plugin.video.alfa/servers/powvideo.py index cfb6f977..4ae29447 100755 --- a/plugin.video.alfa/servers/powvideo.py +++ b/plugin.video.alfa/servers/powvideo.py @@ -1 +1,401 @@ -import base64;exec base64.b64decode('IyAtKi0gY29kaW5nOiB1dGYtOCAtKi0NCg0KaW1wb3J0IHJlDQoNCmZyb20gY29yZSBpbXBvcnQgaHR0cHRvb2xzDQpmcm9tIGNvcmUgaW1wb3J0IHNjcmFwZXJ0b29scw0KZnJvbSBsaWIgaW1wb3J0IGpzdW5wYWNrDQojZnJvbSBwbGF0Zm9ybWNvZGUgaW1wb3J0IGxvZ2dlcg0KDQpoZWFkZXJzID0gW1snVXNlci1BZ2VudCcsICdNb3ppbGxhLzUuMCAoV2luZG93cyBOVCAxMC4wOyBXT1c2NDsgcnY6NTMuMCkgR2Vja28vMjAxMDAxMDEgRmlyZWZveC81My4wJ11dDQpob3N0ID0gImh0dHA6Ly9wb3d2aWRlby5uZXQvIg0KDQoNCmRlZiB0ZXN0X3ZpZGVvX2V4aXN0cyhwYWdlX3VybCk6DQogICAgcmVmZXJlciA9IHBhZ2VfdXJsLnJlcGxhY2UoJ2lmcmFtZScsICdwcmV2aWV3JykNCiAgICBkYXRhID0gaHR0cHRvb2xzLmRvd25sb2FkcGFnZShwYWdlX3VybCwgaGVhZGVycz17J3JlZmVyZXInOiByZWZlcmVyfSkuZGF0YQ0KICAgIGlmIGRhdGEgPT0gIkZpbGUgd2FzIGRlbGV0ZWQiOg0KICAgICAgICByZXR1cm4gRmFsc2UsICJbcG93dmlkZW9dIEVsIHZpZGVvIGhhIHNpZG8gYm9ycmFkbyINCiAgICByZXR1cm4gVHJ1ZSwgIiINCg0KDQpkZWYgZ2V0X3ZpZGVvX3VybChwYWdlX3VybCwgcHJlbWl1bT1GYWxzZSwgdXNlcj0iIiwgcGFzc3dvcmQ9IiIsIHZpZGVvX3Bhc3N3b3JkPSIiKToNCiAgICAjbG9nZ2VyLmluZm8oIihwYWdlX3VybD0nJXMnKSIgJSBwYWdlX3VybCkNCg0KICAgIHJlZmVyZXIgPSBwYWdlX3VybC5yZXBsYWNlKCdpZnJhbWUnLCAncHJldmlldycpDQogICAgZGF0YSA9IGh0dHB0b29scy5kb3dubG9hZHBhZ2UocGFnZV91cmwsIGhlYWRlcnM9eydyZWZlcmVyJzogcmVmZXJlcn0pLmRhdGENCg0KICAgIF8weGEzZTggPSBzY3JhcGVydG9vbHMuZmluZF9zaW5nbGVfbWF0Y2goZGF0YSwgJ3ZhciBfMHhmNDc1PShcW1teO10rXF0pOycpDQogICAgI2xvZ2dlci5pbmZvKCJJbnRlbDExICVzIiAlXzB4YTNlOCkNCiAgICAjbG9nZ2VyLmluZm8oIkludGVsMjIgJXMiICVkYXRhKQ0KICAgIHBhY2tlZCA9IHNjcmFwZXJ0b29scy5maW5kX3NpbmdsZV9tYXRjaChkYXRhLCAiPHNjcmlwdCB0eXBlPVtcIidddGV4dC9qYXZhc2NyaXB0W1wiJ10+KGV2YWwuKj8pPC9zY3JpcHQ+IikNCiAgICB1bnBhY2tlZCA9IGpzdW5wYWNrLnVucGFjayhwYWNrZWQpDQoNCiAgICB2aWRlb191cmxzID0gW10NCg0KICAgIHVybCA9IHNjcmFwZXJ0b29scy5maW5kX3NpbmdsZV9tYXRjaCh1bnBhY2tlZCwgIig/OnNyYyk6XFxcXCcoW15cXFxcXSsubXA0KVxcXFwnIikNCiAgICB2aWRlb191cmxzLmFwcGVuZChbIi5tcDQiICsgIiBbcG93dmlkZW9dIiwgUyhfMHhhM2U4KS5kZWNvZGUodXJsKV0pDQoNCiAgICB2aWRlb191cmxzLnNvcnQoa2V5PWxhbWJkYSB4OiB4WzBdLCByZXZlcnNlPVRydWUpDQogICAgcmV0dXJuIHZpZGVvX3VybHMNCg0KDQpjbGFzcyBTOg0KICAgIGRlZiBfX2luaXRfXyhzZWxmLCBfMHhhM2U4KToNCiAgICAgICAgc2VsZi5yID0gTm9uZQ0KICAgICAgICBzZWxmLnMgPSBOb25lDQogICAgICAgIHNlbGYuayA9IE5vbmUNCiAgICAgICAgc2VsZi5uID0gTm9uZQ0KICAgICAgICBzZWxmLmMgPSBOb25lDQogICAgICAgIHNlbGYuYiA9IE5vbmUNCiAgICAgICAgc2VsZi5kID0gTm9uZQ0KDQogICAgICAgIF8weGEzZTggPSBldmFsKF8weGEzZTgpDQogICAgICAgIHNlbGYudChfMHhhM2U4WzE0XSArIF8weGEzZThbMTVdICsgXzB4YTNlOFsxNF0gKyBfMHhhM2U4WzE1XSwgXzB4YTNlOFsxNl0pDQoNCiAgICBkZWYgZGVjb2RlKHNlbGYsIHVybCk6DQogICAgICAgIF9oYXNoID0gcmUuY29tcGlsZSgnW0EtejAtOV8tXXs0MCx9JywgcmUuRE9UQUxMKS5maW5kYWxsKHVybClbMF0NCiAgICAgICAgcmV0dXJuIHVybC5yZXBsYWNlKF9oYXNoLCBzZWxmLnAoX2hhc2gpKQ0KDQogICAgZGVmIHQoc2VsZiwgdCwgaSk6DQogICAgICAgIHNlbGYuciA9IDIwDQogICAgICAgIHNlbGYucyA9IFsxNjM0NzYwODA1LCA4NTc3NjA4NzgsIDIwMzY0NzcyMzQsIDE3OTcyODUyMzZdDQogICAgICAgIHNlbGYuayA9IFtdDQogICAgICAgIHNlbGYubiA9IFswLCAwXQ0KICAgICAgICBzZWxmLmMgPSBbMCwgMF0NCiAgICAgICAgc2VsZi5iID0gW05vbmVdICogNjQNCiAgICAgICAgc2VsZi5kID0gNjQNCg0KICAgICAgICBzZWxmLnNrKHNlbGYuc2EodCkpDQogICAgICAgIHNlbGYuc24oc2VsZi5zYShpKSkNCg0KICAgIGRlZiBlKHNlbGYsIHQpOg0KICAgICAgICBzID0gc2VsZi5nYihsZW4odCkpDQogICAgICAgIGkgPSBbc1toXSBeIHRbaF0gZm9yIGggaW4gcmFuZ2UobGVuKHQpKV0NCiAgICAgICAgcmV0dXJuIGkNCg0KICAgIGRlZiBwKHNlbGYsIHQpOg0KICAgICAgICBpbXBvcnQgYmFzZTY0DQogICAgICAgIHQgKz0gIj0iICogKDQgLSBsZW4odCkgJSA0KQ0KICAgICAgICB0ID0gYmFzZTY0LmI2NGRlY29kZSh0LnJlcGxhY2UoJy0nLCAnKycpLnJlcGxhY2UoJ18nLCAnLycpKQ0KICAgICAgICByZXR1cm4gc2VsZi5fYXMoc2VsZi5lKHNlbGYuc2EodCkpKQ0KDQogICAgQHN0YXRpY21ldGhvZA0KICAgIGRlZiBzYSh0KToNCiAgICAgICAgcyA9IFtvcmQodFtpXSkgZm9yIGkgaW4gcmFuZ2UobGVuKHQpKV0NCiAgICAgICAgcmV0dXJuIHMNCg0KICAgIEBzdGF0aWNtZXRob2QNCiAgICBkZWYgX2FzKHQpOg0KICAgICAgICBzID0gW2Nocih0W2ldKSBmb3IgaSBpbiByYW5nZShsZW4odCkpXQ0KICAgICAgICByZXR1cm4gJycuam9pbihzKQ0KDQogICAgZGVmIHNrKHNlbGYsIHQpOg0KICAgICAgICBzID0gMA0KICAgICAgICBmb3IgaSBpbiByYW5nZSg4KToNCiAgICAgICAgICAgIHNlbGYuay5hcHBlbmQoDQogICAgICAgICAgICAgICAgMjU1ICYgdFtzXSB8IHNlbGYubHNoaWZ0KCgyNTUgJiB0W3MgKyAxXSksIDgpIHwgc2VsZi5sc2hpZnQoKDI1NSAmIHRbcyArIDJdKSwgMTYpIHwgc2VsZi5sc2hpZnQoDQogICAgICAgICAgICAgICAgICAgICgyNTUgJiB0W3MgKyAzXSksIDI0KSkNCiAgICAgICAgICAgIHMgKz0gNA0KICAgICAgICBzZWxmLl9yKCkNCg0KICAgIGRlZiBzbihzZWxmLCB0KToNCiAgICAgICAgc2VsZi5uWzBdID0gMjU1ICYgdFswXSB8IHNlbGYubHNoaWZ0KCgyNTUgJiB0WzFdKSwgOCkgfCBzZWxmLmxzaGlmdCgoMjU1ICYgdFsyXSksIDE2KSB8IHNlbGYubHNoaWZ0KA0KICAgICAgICAgICAgKDI1NSAmIHRbM10pLCAyNCkNCiAgICAgICAgc2VsZi5uWzFdID0gMjU1ICYgdFs0XSB8IHNlbGYubHNoaWZ0KCgyNTUgJiB0WzVdKSwgOCkgfCBzZWxmLmxzaGlmdCgoMjU1ICYgdFs2XSksIDE2KSB8IHNlbGYubHNoaWZ0KA0KICAgICAgICAgICAgKDI1NSAmIHRbN10pLCAyNCkNCiAgICAgICAgc2VsZi5fcigpDQoNCiAgICBkZWYgZ2Ioc2VsZiwgdCk6DQogICAgICAgIGkgPSBbTm9uZV0gKiB0DQoNCiAgICAgICAgZm9yIHMgaW4gcmFuZ2UodCk6DQogICAgICAgICAgICBpZiA2NCA9PSBzZWxmLmQ6DQogICAgICAgICAgICAgICAgc2VsZi5fZygpDQogICAgICAgICAgICAgICAgc2VsZi5faSgpDQogICAgICAgICAgICAgICAgc2VsZi5kID0gMA0KDQogICAgICAgICAgICBpW3NdID0gc2VsZi5iW3NlbGYuZF0NCiAgICAgICAgICAgIHNlbGYuZCArPSAxDQoNCiAgICAgICAgcmV0dXJuIGkNCg0KICAgIGRlZiBnaChzZWxmLCB0KToNCiAgICAgICAgaSA9IFsnMCcsICcxJywgJzInLCAnMycsICc0JywgJzUnLCAnNicsICc3JywgJzgnLCAnOScsICdhJywgJ2InLCAnYycsICdkJywgJ2UnLCAnZiddDQogICAgICAgIGggPSBzZWxmLmdiKHQpDQogICAgICAgIHMgPSBbaVtzZWxmLnJzaGlmdChoW2JdLCA0KSAmIDE1XSBmb3IgYiBpbiByYW5nZShsZW4oaCkpXQ0KICAgICAgICBzLmFwcGVuZChpWzE1ICYgaFtsZW4oaCldXSkNCiAgICAgICAgcmV0dXJuICcnLmpvaW4ocykNCg0KICAgIGRlZiBfcihzZWxmKToNCiAgICAgICAgc2VsZi5jWzBdID0gMA0KICAgICAgICBzZWxmLmNbMV0gPSAwDQogICAgICAgIHNlbGYuZCA9IDY0DQoNCiAgICBkZWYgX2koc2VsZik6DQogICAgICAgIHNlbGYuY1swXSA9IHNlbGYuY1swXSArIDEgJiA0Mjk0OTY3Mjk1DQogICAgICAgIGlmIDAgPT0gc2VsZi5jWzBdOg0KICAgICAgICAgICAgc2VsZi5jWzFdID0gc2VsZi5jWzFdICsgMSAmIDQyOTQ5NjcyOTUNCg0KICAgIGRlZiBfZyhzZWxmKToNCiAgICAgICAgaSA9IHNlbGYuc1swXQ0KICAgICAgICBzID0gc2VsZi5rWzBdDQogICAgICAgIGggPSBzZWxmLmtbMV0NCiAgICAgICAgYiA9IHNlbGYua1syXQ0KICAgICAgICByID0gc2VsZi5rWzNdDQogICAgICAgIG4gPSBzZWxmLnNbMV0NCiAgICAgICAgbyA9IHNlbGYublswXQ0KICAgICAgICBlID0gc2VsZi5uWzFdDQogICAgICAgIGMgPSBzZWxmLmNbMF0NCiAgICAgICAgcCA9IHNlbGYuY1sxXQ0KICAgICAgICBhID0gc2VsZi5zWzJdDQogICAgICAgIGYgPSBzZWxmLmtbNF0NCiAgICAgICAgdSA9IHNlbGYua1s1XQ0KICAgICAgICBnID0gc2VsZi5rWzZdDQogICAgICAgIHkgPSBzZWxmLmtbN10NCiAgICAgICAgayA9IHNlbGYuc1szXQ0KICAgICAgICBsID0gaQ0KICAgICAgICBkID0gcw0KICAgICAgICB2ID0gaA0KICAgICAgICBfID0gYg0KICAgICAgICBBID0gcg0KICAgICAgICB3ID0gbg0KICAgICAgICBDID0gbw0KICAgICAgICBTID0gZQ0KICAgICAgICBqID0gYw0KICAgICAgICBtID0gcA0KICAgICAgICBxID0gYQ0KICAgICAgICB4ID0gZg0KICAgICAgICB6ID0gdQ0KICAgICAgICBCID0gZw0KICAgICAgICBEID0geQ0KICAgICAgICBFID0gaw0KDQogICAgICAgIGZvciBGIGluIHJhbmdlKDAsIHNlbGYuciwgMik6DQogICAgICAgICAgICAjIDANCiAgICAgICAgICAgIHQgPSBsICsgeg0KICAgICAgICAgICAgQSBePSBzZWxmLmxzaGlmdCh0LCA3KSB8IHNlbGYuYnNoaWZ0KHQsIDI1KQ0KICAgICAgICAgICAgdCA9IEEgKyBsDQogICAgICAgICAgICBqIF49IHNlbGYubHNoaWZ0KHQsIDkpIHwgc2VsZi5ic2hpZnQodCwgMjMpDQogICAgICAgICAgICB0ID0gaiArIEENCiAgICAgICAgICAgIHogXj0gc2VsZi5sc2hpZnQodCwgMTMpIHwgc2VsZi5ic2hpZnQodCwgMTkpDQogICAgICAgICAgICB0ID0geiArIGoNCiAgICAgICAgICAgIGwgXj0gc2VsZi5sc2hpZnQodCwgMTgpIHwgc2VsZi5ic2hpZnQodCwgMTQpDQoNCiAgICAgICAgICAgICMgMQ0KICAgICAgICAgICAgdCA9IHcgKyBkDQogICAgICAgICAgICBtIF49IHNlbGYubHNoaWZ0KHQsIDcpIHwgc2VsZi5ic2hpZnQodCwgMjUpDQogICAgICAgICAgICB0ID0gbSArIHcNCiAgICAgICAgICAgIEIgXj0gc2VsZi5sc2hpZnQodCwgOSkgfCBzZWxmLmJzaGlmdCh0LCAyMykNCiAgICAgICAgICAgIHQgPSBCICsgbQ0KICAgICAgICAgICAgZCBePSBzZWxmLmxzaGlmdCh0LCAxMykgfCBzZWxmLmJzaGlmdCh0LCAxOSkNCiAgICAgICAgICAgIHQgPSBkICsgQg0KICAgICAgICAgICAgdyBePSBzZWxmLmxzaGlmdCh0LCAxOCkgfCBzZWxmLmJzaGlmdCh0LCAxNCkNCg0KICAgICAgICAgICAgIyAyDQogICAgICAgICAgICB0ID0gcSArIEMNCiAgICAgICAgICAgIEQgXj0gc2VsZi5sc2hpZnQodCwgNykgfCBzZWxmLmJzaGlmdCh0LCAyNSkNCiAgICAgICAgICAgIHQgPSBEICsgcQ0KICAgICAgICAgICAgdiBePSBzZWxmLmxzaGlmdCh0LCA5KSB8IHNlbGYuYnNoaWZ0KHQsIDIzKQ0KICAgICAgICAgICAgdCA9IHYgKyBEDQogICAgICAgICAgICBDIF49IHNlbGYubHNoaWZ0KHQsIDEzKSB8IHNlbGYuYnNoaWZ0KHQsIDE5KQ0KICAgICAgICAgICAgdCA9IEMgKyB2DQogICAgICAgICAgICBxIF49IHNlbGYubHNoaWZ0KHQsIDE4KSB8IHNlbGYuYnNoaWZ0KHQsIDE0KQ0KDQogICAgICAgICAgICAjIDMNCiAgICAgICAgICAgIHQgPSBFICsgeA0KICAgICAgICAgICAgXyBePSBzZWxmLmxzaGlmdCh0LCA3KSB8IHNlbGYuYnNoaWZ0KHQsIDI1KQ0KICAgICAgICAgICAgdCA9IF8gKyBFDQogICAgICAgICAgICBTIF49IHNlbGYubHNoaWZ0KHQsIDkpIHwgc2VsZi5ic2hpZnQodCwgMjMpDQogICAgICAgICAgICB0ID0gUyArIF8NCiAgICAgICAgICAgIHggXj0gc2VsZi5sc2hpZnQodCwgMTMpIHwgc2VsZi5ic2hpZnQodCwgMTkpDQogICAgICAgICAgICB0ID0geCArIFMNCiAgICAgICAgICAgIEUgXj0gc2VsZi5sc2hpZnQodCwgMTgpIHwgc2VsZi5ic2hpZnQodCwgMTQpDQoNCiAgICAgICAgICAgICMgNA0KICAgICAgICAgICAgdCA9IGwgKyBfDQogICAgICAgICAgICBkIF49IHNlbGYubHNoaWZ0KHQsIDcpIHwgc2VsZi5ic2hpZnQodCwgMjUpDQogICAgICAgICAgICB0ID0gZCArIGwNCiAgICAgICAgICAgIHYgXj0gc2VsZi5sc2hpZnQodCwgOSkgfCBzZWxmLmJzaGlmdCh0LCAyMykNCiAgICAgICAgICAgIHQgPSB2ICsgZA0KICAgICAgICAgICAgXyBePSBzZWxmLmxzaGlmdCh0LCAxMykgfCBzZWxmLmJzaGlmdCh0LCAxOSkNCiAgICAgICAgICAgIHQgPSBfICsgdg0KICAgICAgICAgICAgbCBePSBzZWxmLmxzaGlmdCh0LCAxOCkgfCBzZWxmLmJzaGlmdCh0LCAxNCkNCg0KICAgICAgICAgICAgIyA1DQogICAgICAgICAgICB0ID0gdyArIEENCiAgICAgICAgICAgIEMgXj0gc2VsZi5sc2hpZnQodCwgNykgfCBzZWxmLmJzaGlmdCh0LCAyNSkNCiAgICAgICAgICAgIHQgPSBDICsgdw0KICAgICAgICAgICAgUyBePSBzZWxmLmxzaGlmdCh0LCA5KSB8IHNlbGYuYnNoaWZ0KHQsIDIzKQ0KICAgICAgICAgICAgdCA9IFMgKyBDDQogICAgICAgICAgICBBIF49IHNlbGYubHNoaWZ0KHQsIDEzKSB8IHNlbGYuYnNoaWZ0KHQsIDE5KQ0KICAgICAgICAgICAgdCA9IEEgKyBTDQogICAgICAgICAgICB3IF49IHNlbGYubHNoaWZ0KHQsIDE4KSB8IHNlbGYuYnNoaWZ0KHQsIDE0KQ0KDQogICAgICAgICAgICAjIDYNCiAgICAgICAgICAgIHQgPSBxICsgbQ0KICAgICAgICAgICAgeCBePSBzZWxmLmxzaGlmdCh0LCA3KSB8IHNlbGYuYnNoaWZ0KHQsIDI1KQ0KICAgICAgICAgICAgdCA9IHggKyBxDQogICAgICAgICAgICBqIF49IHNlbGYubHNoaWZ0KHQsIDkpIHwgc2VsZi5ic2hpZnQodCwgMjMpDQogICAgICAgICAgICB0ID0gaiArIHgNCiAgICAgICAgICAgIG0gXj0gc2VsZi5sc2hpZnQodCwgMTMpIHwgc2VsZi5ic2hpZnQodCwgMTkpDQogICAgICAgICAgICB0ID0gbSArIGoNCiAgICAgICAgICAgIHEgXj0gc2VsZi5sc2hpZnQodCwgMTgpIHwgc2VsZi5ic2hpZnQodCwgMTQpDQoNCiAgICAgICAgICAgICMgNw0KICAgICAgICAgICAgdCA9IEUgKyBEDQogICAgICAgICAgICB6IF49IHNlbGYubHNoaWZ0KHQsIDcpIHwgc2VsZi5ic2hpZnQodCwgMjUpDQogICAgICAgICAgICB0ID0geiArIEUNCiAgICAgICAgICAgIEIgXj0gc2VsZi5sc2hpZnQodCwgOSkgfCBzZWxmLmJzaGlmdCh0LCAyMykNCiAgICAgICAgICAgIHQgPSBCICsgeg0KICAgICAgICAgICAgRCBePSBzZWxmLmxzaGlmdCh0LCAxMykgfCBzZWxmLmJzaGlmdCh0LCAxOSkNCiAgICAgICAgICAgIHQgPSBEICsgQg0KICAgICAgICAgICAgRSBePSBzZWxmLmxzaGlmdCh0LCAxOCkgfCBzZWxmLmJzaGlmdCh0LCAxNCkNCg0KICAgICAgICBsICs9IGkNCiAgICAgICAgZCArPSBzDQogICAgICAgIHYgKz0gaA0KICAgICAgICBfICs9IGINCiAgICAgICAgQSArPSByDQogICAgICAgIHcgKz0gbg0KICAgICAgICBDICs9IG8NCiAgICAgICAgUyArPSBlDQogICAgICAgIGogKz0gYw0KICAgICAgICBtICs9IHANCiAgICAgICAgcSArPSBhDQogICAgICAgIHggKz0gZg0KICAgICAgICB6ICs9IHUNCiAgICAgICAgQiArPSBnDQogICAgICAgIEQgKz0geQ0KICAgICAgICBFICs9IGsNCg0KICAgICAgICBzZWxmLmJbMF0gPSBzZWxmLmJzaGlmdChsLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMV0gPSBzZWxmLmJzaGlmdChsLCA4KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMl0gPSBzZWxmLmJzaGlmdChsLCAxNikgJiAyNTUNCiAgICAgICAgc2VsZi5iWzNdID0gc2VsZi5ic2hpZnQobCwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYls0XSA9IHNlbGYuYnNoaWZ0KGQsIDApICYgMjU1DQogICAgICAgIHNlbGYuYls1XSA9IHNlbGYuYnNoaWZ0KGQsIDgpICYgMjU1DQogICAgICAgIHNlbGYuYls2XSA9IHNlbGYuYnNoaWZ0KGQsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbN10gPSBzZWxmLmJzaGlmdChkLCAyNCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzhdID0gc2VsZi5ic2hpZnQodiwgMCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzldID0gc2VsZi5ic2hpZnQodiwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzEwXSA9IHNlbGYuYnNoaWZ0KHYsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMTFdID0gc2VsZi5ic2hpZnQodiwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYlsxMl0gPSBzZWxmLmJzaGlmdChfLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMTNdID0gc2VsZi5ic2hpZnQoXywgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzE0XSA9IHNlbGYuYnNoaWZ0KF8sIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMTVdID0gc2VsZi5ic2hpZnQoXywgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYlsxNl0gPSBzZWxmLmJzaGlmdChBLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMTddID0gc2VsZi5ic2hpZnQoQSwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzE4XSA9IHNlbGYuYnNoaWZ0KEEsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMTldID0gc2VsZi5ic2hpZnQoQSwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYlsyMF0gPSBzZWxmLmJzaGlmdCh3LCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMjFdID0gc2VsZi5ic2hpZnQodywgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzIyXSA9IHNlbGYuYnNoaWZ0KHcsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMjNdID0gc2VsZi5ic2hpZnQodywgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYlsyNF0gPSBzZWxmLmJzaGlmdChDLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMjVdID0gc2VsZi5ic2hpZnQoQywgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzI2XSA9IHNlbGYuYnNoaWZ0KEMsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMjddID0gc2VsZi5ic2hpZnQoQywgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYlsyOF0gPSBzZWxmLmJzaGlmdChTLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMjldID0gc2VsZi5ic2hpZnQoUywgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzMwXSA9IHNlbGYuYnNoaWZ0KFMsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMzFdID0gc2VsZi5ic2hpZnQoUywgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYlszMl0gPSBzZWxmLmJzaGlmdChqLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMzNdID0gc2VsZi5ic2hpZnQoaiwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzM0XSA9IHNlbGYuYnNoaWZ0KGosIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMzVdID0gc2VsZi5ic2hpZnQoaiwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYlszNl0gPSBzZWxmLmJzaGlmdChtLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMzddID0gc2VsZi5ic2hpZnQobSwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzM4XSA9IHNlbGYuYnNoaWZ0KG0sIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbMzldID0gc2VsZi5ic2hpZnQobSwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYls0MF0gPSBzZWxmLmJzaGlmdChxLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNDFdID0gc2VsZi5ic2hpZnQocSwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzQyXSA9IHNlbGYuYnNoaWZ0KHEsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNDNdID0gc2VsZi5ic2hpZnQocSwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYls0NF0gPSBzZWxmLmJzaGlmdCh4LCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNDVdID0gc2VsZi5ic2hpZnQoeCwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzQ2XSA9IHNlbGYuYnNoaWZ0KHgsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNDddID0gc2VsZi5ic2hpZnQoeCwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYls0OF0gPSBzZWxmLmJzaGlmdCh6LCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNDldID0gc2VsZi5ic2hpZnQoeiwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzUwXSA9IHNlbGYuYnNoaWZ0KHosIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNTFdID0gc2VsZi5ic2hpZnQoeiwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYls1Ml0gPSBzZWxmLmJzaGlmdChCLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNTNdID0gc2VsZi5ic2hpZnQoQiwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzU0XSA9IHNlbGYuYnNoaWZ0KEIsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNTVdID0gc2VsZi5ic2hpZnQoQiwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYls1Nl0gPSBzZWxmLmJzaGlmdChELCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNTddID0gc2VsZi5ic2hpZnQoRCwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzU4XSA9IHNlbGYuYnNoaWZ0KEQsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNTldID0gc2VsZi5ic2hpZnQoRCwgMjQpICYgMjU1DQogICAgICAgIHNlbGYuYls2MF0gPSBzZWxmLmJzaGlmdChFLCAwKSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNjFdID0gc2VsZi5ic2hpZnQoRSwgOCkgJiAyNTUNCiAgICAgICAgc2VsZi5iWzYyXSA9IHNlbGYuYnNoaWZ0KEUsIDE2KSAmIDI1NQ0KICAgICAgICBzZWxmLmJbNjNdID0gc2VsZi5ic2hpZnQoRSwgMjQpICYgMjU1DQoNCiAgICBkZWYgbHNoaWZ0KHNlbGYsIG51bSwgb3RoZXIpOg0KICAgICAgICBsbnVtID0gc2VsZi5Ub0ludDMyKG51bSkNCiAgICAgICAgcm51bSA9IHNlbGYuVG9VaW50MzIob3RoZXIpDQogICAgICAgIHNoaWZ0X2NvdW50ID0gcm51bSAmIDB4MUYNCiAgICAgICAgcmV0dXJuIHNlbGYuVG9JbnQzMihsbnVtIDw8IHNoaWZ0X2NvdW50KQ0KDQogICAgZGVmIHJzaGlmdChzZWxmLCBudW0sIG90aGVyKToNCiAgICAgICAgbG51bSA9IHNlbGYuVG9JbnQzMihudW0pDQogICAgICAgIHJudW0gPSBzZWxmLlRvVWludDMyKG90aGVyKQ0KICAgICAgICBzaGlmdF9jb3VudCA9IHJudW0gJiAweDFGDQogICAgICAgIHJldHVybiBzZWxmLlRvSW50MzIobG51bSA+PiBzaGlmdF9jb3VudCkNCg0KICAgIGRlZiBic2hpZnQoc2VsZiwgbnVtLCBvdGhlcik6DQogICAgICAgIGxudW0gPSBzZWxmLlRvVWludDMyKG51bSkNCiAgICAgICAgcm51bSA9IHNlbGYuVG9VaW50MzIob3RoZXIpDQogICAgICAgIHNoaWZ0X2NvdW50ID0gcm51bSAmIDB4MUYNCiAgICAgICAgcmV0dXJuIHNlbGYuVG9VaW50MzIobG51bSA+PiBzaGlmdF9jb3VudCkNCg0KICAgIEBzdGF0aWNtZXRob2QNCiAgICBkZWYgVG9JbnQzMihudW0pOg0KICAgICAgICBpbnQzMiA9IG51bSAlIDIgKiogMzINCiAgICAgICAgcmV0dXJuIGludDMyIC0gMiAqKiAzMiBpZiBpbnQzMiA+PSAyICoqIDMxIGVsc2UgaW50MzINCg0KICAgIEBzdGF0aWNtZXRob2QNCiAgICBkZWYgVG9VaW50MzIobnVtKToNCiAgICAgICAgcmV0dXJuIG51bSAlIDIgKiogMzINCg==') +# -*- 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']] +host = "http://powvideo.net/" + + +def test_video_exists(page_url): + referer = page_url.replace('iframe', 'preview') + data = httptools.downloadpage(page_url, headers={'referer': referer}).data + if data == "File was deleted": + return False, "[powvideo] El video ha sido borrado" + return True, "" + + +def get_video_url(page_url, premium=False, user="", password="", video_password=""): + #logger.info("(page_url='%s')" % page_url) + + referer = page_url.replace('iframe', 'preview') + data = httptools.downloadpage(page_url, headers={'referer': referer}).data + _0xa3e8 = scrapertools.find_single_match(data, 'var _0x[0-f]+=(\[[^;]+\]);') + packed = scrapertools.find_single_match(data, "") + unpacked = jsunpack.unpack(packed) + + video_urls = [] + + url = scrapertools.find_single_match(unpacked, "(?:src):\\\\'([^\\\\]+.mp4)\\\\'") + video_urls.append([".mp4" + " [powvideo]", S(_0xa3e8).decode(url)]) + + video_urls.sort(key=lambda x: x[0], reverse=True) + return video_urls + + +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(0x1f0, 0, -1): + var.append(var.pop(0)) + + self.var = var + + self.t( + self.decode_index('0x22', '!UJH') + + self.decode_index('0x23', 'NpE)') + + self.decode_index('0x24', '4uT2') + + self.decode_index('0x23', 'NpE)'), + self.decode_index('0x25', '@ZC2') + ) + + def decode_index(self, index, key): + b64_data = self.var[int(index, 16)]; + result = '' + _0xb99338 = 0x0 + _0x25e3f4 = 0x0 + + data = base64.b64decode(b64_data) + data = urllib.unquote(data).decode('utf8') + + _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 + + 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 From 94d4244cd18cae565f15be17e2cfb7c1a32ba4dd Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Tue, 12 Dec 2017 10:17:13 -0500 Subject: [PATCH 08/16] Update playpornx.py --- plugin.video.alfa/channels/playpornx.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugin.video.alfa/channels/playpornx.py b/plugin.video.alfa/channels/playpornx.py index 84931128..24e933b6 100644 --- a/plugin.video.alfa/channels/playpornx.py +++ b/plugin.video.alfa/channels/playpornx.py @@ -31,7 +31,7 @@ def lista(item): if item.url == '': item.url = host data = httptools.downloadpage(item.url).data data = re.sub(r'"|\n|\r|\t| |
    |\s{2,}', "", data) - patron = '
    .*?href=(.*?)>(.*?)<\/h2>' + patron = '
    .*?href=(.*?)> Date: Tue, 12 Dec 2017 12:46:14 -0500 Subject: [PATCH 09/16] bdupload: nuevo server --- plugin.video.alfa/servers/bdupload.json | 43 +++++++++++++++++++++++++ plugin.video.alfa/servers/bdupload.py | 36 +++++++++++++++++++++ 2 files changed, 79 insertions(+) create mode 100644 plugin.video.alfa/servers/bdupload.json create mode 100644 plugin.video.alfa/servers/bdupload.py diff --git a/plugin.video.alfa/servers/bdupload.json b/plugin.video.alfa/servers/bdupload.json new file mode 100644 index 00000000..ddb43d24 --- /dev/null +++ b/plugin.video.alfa/servers/bdupload.json @@ -0,0 +1,43 @@ +{ + "active": true, + "find_videos": { + "ignore_urls": [], + "patterns": [ + { + "pattern": "(https://bdupload.info/[A-z0-9]+)", + "url": "\\1" + } + ] + }, + "free": true, + "id": "bdupload", + "name": "bdupload", + "settings": [ + { + "default": false, + "enabled": true, + "id": "black_list", + "label": "Incluir en lista negra", + "type": "bool", + "visible": true + }, + { + "default": 0, + "enabled": true, + "id": "favorites_servers_list", + "label": "Incluir en lista de favoritos", + "lvalues": [ + "No", + "1", + "2", + "3", + "4", + "5" + ], + "type": "list", + "visible": false + } + ], + "thumbnail": "https://s18.postimg.org/68colqvyx/logo-bdupload.png", + "version": 1 +} diff --git a/plugin.video.alfa/servers/bdupload.py b/plugin.video.alfa/servers/bdupload.py new file mode 100644 index 00000000..d88572aa --- /dev/null +++ b/plugin.video.alfa/servers/bdupload.py @@ -0,0 +1,36 @@ +# -*- coding: utf-8 -*- +import time + +from core import httptools +from core import scrapertools +from platformcode import logger + +headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36'} + + +def test_video_exists(page_url): + logger.info("(page_url='%s')" % page_url) + data = httptools.downloadpage(page_url).data + if "Archive no Encontrado" in data: + return False, "[bdupload] El fichero ha sido borrado" + + return True, "" + + +def get_video_url(page_url, user="", password="", video_password=""): + logger.info("(page_url='%s')" % page_url) + data = httptools.downloadpage(page_url).data + post = "" + patron = '(?s)type="hidden" name="([^"]+)".*?value="([^"]*)"' + match = scrapertools.find_multiple_matches(data, patron) + for nombre, valor in match: + post += nombre + "=" + valor + "&" + time.sleep(1) + data1 = httptools.downloadpage(page_url, post = post, headers = headers).data + patron = "window.open\('([^']+)" + file = scrapertools.find_single_match(data1, patron) + file += "|User-Agent=" + headers['User-Agent'] + video_urls = [] + videourl = file + video_urls.append([".MP4 [bdupload]", videourl]) + return video_urls From 27f93b9d988e42447a5a4e98fec08549f4551445 Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Tue, 12 Dec 2017 14:25:33 -0500 Subject: [PATCH 10/16] Update playpornx.py --- plugin.video.alfa/channels/playpornx.py | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/plugin.video.alfa/channels/playpornx.py b/plugin.video.alfa/channels/playpornx.py index 24e933b6..5d52178f 100644 --- a/plugin.video.alfa/channels/playpornx.py +++ b/plugin.video.alfa/channels/playpornx.py @@ -7,7 +7,7 @@ from core import scrapertools from core.item import Item from platformcode import logger -host = "http://www.playpornx.net/" +host = "https://watchfreexxx.net/" def mainlist(item): @@ -17,7 +17,7 @@ def mainlist(item): fanart='https://s18.postimg.org/fwvaeo6qh/todas.png', url =host)) - itemlist.append(Item(channel=item.channel, title="Buscar", action="search", url='http://www.playpornx.net/?s=', + itemlist.append(Item(channel=item.channel, title="Buscar", action="search", url=host+'?s=', thumbnail='https://s30.postimg.org/pei7txpa9/buscar.png', fanart='https://s30.postimg.org/pei7txpa9/buscar.png')) @@ -31,13 +31,21 @@ def lista(item): if item.url == '': item.url = host data = httptools.downloadpage(item.url).data data = re.sub(r'"|\n|\r|\t| |
    |\s{2,}', "", data) - patron = '
    .*?href=(.*?)> Date: Tue, 12 Dec 2017 15:32:11 -0500 Subject: [PATCH 11/16] gnula: actualizado --- plugin.video.alfa/channels/gnula.py | 17 +++++------------ 1 file changed, 5 insertions(+), 12 deletions(-) diff --git a/plugin.video.alfa/channels/gnula.py b/plugin.video.alfa/channels/gnula.py index b34600fb..9a3a36a4 100755 --- a/plugin.video.alfa/channels/gnula.py +++ b/plugin.video.alfa/channels/gnula.py @@ -51,8 +51,6 @@ def generos(item): def peliculas(item): logger.info() - - # Descarga la página data = httptools.downloadpage(item.url).data patron = '([^<]+)(.*?)
    ') item.plot = scrapertools.htmlclean(item.plot).strip() item.contentPlot = item.plot - patron = 'Ver película online.*?>.*?>([^<]+)' + patron = 'Ver película online.*?>.*?>([^<]+)' scrapedopcion = scrapertools.find_single_match(data, patron) titulo_opcional = scrapertools.find_single_match(scrapedopcion, ".*?, (.*)").upper() bloque = scrapertools.find_multiple_matches(data, 'contenedor_tab.*?/table') From 65648bca9b8e0d24bae480aac71f4e91a28f9669 Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Wed, 13 Dec 2017 08:38:39 -0500 Subject: [PATCH 12/16] bitertv: nuevo server --- plugin.video.alfa/servers/bitertv.json | 43 ++++++++++++++++++++++++++ plugin.video.alfa/servers/bitertv.py | 24 ++++++++++++++ 2 files changed, 67 insertions(+) create mode 100644 plugin.video.alfa/servers/bitertv.json create mode 100644 plugin.video.alfa/servers/bitertv.py diff --git a/plugin.video.alfa/servers/bitertv.json b/plugin.video.alfa/servers/bitertv.json new file mode 100644 index 00000000..3c798902 --- /dev/null +++ b/plugin.video.alfa/servers/bitertv.json @@ -0,0 +1,43 @@ +{ + "active": true, + "find_videos": { + "ignore_urls": [], + "patterns": [ + { + "pattern": "(http://biter.tv/v/[A-z0-9]+)", + "url": "\\1" + } + ] + }, + "free": true, + "id": "bitertv", + "name": "Bitertv", + "settings": [ + { + "default": false, + "enabled": true, + "id": "black_list", + "label": "Incluir en lista negra", + "type": "bool", + "visible": true + }, + { + "default": 0, + "enabled": true, + "id": "favorites_servers_list", + "label": "Incluir en lista de favoritos", + "lvalues": [ + "No", + "1", + "2", + "3", + "4", + "5" + ], + "type": "list", + "visible": false + } + ], + "thumbnail": "https://s18.postimg.org/f56rayqq1/logo-bitertv.png", + "version": 1 +} diff --git a/plugin.video.alfa/servers/bitertv.py b/plugin.video.alfa/servers/bitertv.py new file mode 100644 index 00000000..a0e0e145 --- /dev/null +++ b/plugin.video.alfa/servers/bitertv.py @@ -0,0 +1,24 @@ +# -*- coding: utf-8 -*- + +from core import httptools +from core import scrapertools +from platformcode import logger + +headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36'} + +def test_video_exists(page_url): + logger.info("(page_url='%s')" % page_url) + data = httptools.downloadpage(page_url).data + if "Archive no Encontrado" in data: + return False, "[bitertv] El fichero ha sido borrado" + return True, "" + + +def get_video_url(page_url, user="", password="", video_password=""): + logger.info("(page_url='%s')" % page_url) + video_urls = [] + data = httptools.downloadpage(page_url).data + patron = "(?s)file: '([^']+)" + file = scrapertools.find_single_match(data, patron) + video_urls.append([".MP4 [bitertv]", file]) + return video_urls From 98b61f1b50210943bf17f2f2e5f04051c537d6a3 Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Wed, 13 Dec 2017 08:41:33 -0500 Subject: [PATCH 13/16] zpeliculas: no funciona la pagina --- plugin.video.alfa/channels/zpeliculas.json | 38 ---------------------- 1 file changed, 38 deletions(-) delete mode 100755 plugin.video.alfa/channels/zpeliculas.json diff --git a/plugin.video.alfa/channels/zpeliculas.json b/plugin.video.alfa/channels/zpeliculas.json deleted file mode 100755 index 10ad062f..00000000 --- a/plugin.video.alfa/channels/zpeliculas.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "id": "zpeliculas", - "name": "Zpeliculas", - "active": true, - "adult": false, - "language": ["cast", "lat"], - "banner": "zpeliculas.png", - "thumbnail": "zpeliculas.png", - "categories": [ - "movie" - ], - "settings": [ - { - "id": "include_in_global_search", - "type": "bool", - "label": "Incluir en busqueda global", - "default": false, - "enabled": true, - "visible": true - }, - { - "id": "include_in_newest_peliculas", - "type": "bool", - "label": "Incluir en Novedades - Peliculas", - "default": true, - "enabled": true, - "visible": true - }, - { - "id": "include_in_newest_infantiles", - "type": "bool", - "label": "Incluir en Novedades - Infantiles", - "default": true, - "enabled": true, - "visible": true - } - ] -} \ No newline at end of file From 37df471d6050b74fa23f7f4bc7e0cafa709960c4 Mon Sep 17 00:00:00 2001 From: Intel1 <25161862+Intel11@users.noreply.github.com> Date: Wed, 13 Dec 2017 08:41:45 -0500 Subject: [PATCH 14/16] zpeliculas: no funciona la pagina --- plugin.video.alfa/channels/zpeliculas.py | 370 ----------------------- 1 file changed, 370 deletions(-) delete mode 100755 plugin.video.alfa/channels/zpeliculas.py diff --git a/plugin.video.alfa/channels/zpeliculas.py b/plugin.video.alfa/channels/zpeliculas.py deleted file mode 100755 index c8d52fde..00000000 --- a/plugin.video.alfa/channels/zpeliculas.py +++ /dev/null @@ -1,370 +0,0 @@ -# -*- coding: utf-8 -*- - -import re -import urllib - -from core import scrapertools -from core import servertools -from core.item import Item -from platformcode import logger - - -def mainlist(item): - logger.info() - - itemlist = [] - # itemlist.append( Item(channel=item.channel, action="destacadas" , title="Destacadas", url="http://www.zpeliculas.com", fanart="http://www.zpeliculas.com/templates/mytopV2/images/background.png")) - itemlist.append( - Item(channel=item.channel, action="peliculas", title="Últimas peliculas", url="http://www.zpeliculas.com/", - fanart="http://www.zpeliculas.com/templates/mytopV2/images/background.png", viewmode="movie")) - # itemlist.append( Item(channel=item.channel, action="sugeridas" , title="Películas sugeridas", url="http://www.zpeliculas.com", fanart="http://www.zpeliculas.com/templates/mytopV2/images/background.png", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="generos", title="Por género", url="http://www.zpeliculas.com", - fanart="http://www.zpeliculas.com/templates/mytopV2/images/background.png")) - itemlist.append(Item(channel=item.channel, action="alfabetico", title="Listado alfabético", - fanart="http://www.zpeliculas.com/templates/mytopV2/images/background.png")) - itemlist.append(Item(channel=item.channel, action="search", title="Buscador", url="http://www.zpeliculas.com", - fanart="http://www.zpeliculas.com/templates/mytopV2/images/background.png", viewmode="movie")) - - return itemlist - - -def alfabetico(item): - logger.info() - - itemlist = [] - itemlist.append(Item(channel=item.channel, action="peliculas", title="A", url="http://www.zpeliculas.com/cat/a", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="B", url="http://www.zpeliculas.com/cat/b", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="C", url="http://www.zpeliculas.com/cat/c", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="D", url="http://www.zpeliculas.com/cat/d", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="E", url="http://www.zpeliculas.com/cat/e", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="F", url="http://www.zpeliculas.com/cat/f", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="G", url="http://www.zpeliculas.com/cat/g", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="H", url="http://www.zpeliculas.com/cat/h", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="I", url="http://www.zpeliculas.com/cat/i", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="J", url="http://www.zpeliculas.com/cat/j", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="K", url="http://www.zpeliculas.com/cat/k", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="L", url="http://www.zpeliculas.com/cat/l", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="M", url="http://www.zpeliculas.com/cat/m", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="N", url="http://www.zpeliculas.com/cat/n", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="O", url="http://www.zpeliculas.com/cat/o", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="P", url="http://www.zpeliculas.com/cat/p", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Q", url="http://www.zpeliculas.com/cat/q", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="R", url="http://www.zpeliculas.com/cat/r", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="S", url="http://www.zpeliculas.com/cat/s", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="T", url="http://www.zpeliculas.com/cat/t", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="U", url="http://www.zpeliculas.com/cat/u", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="V", url="http://www.zpeliculas.com/cat/v", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="W", url="http://www.zpeliculas.com/cat/w", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="X", url="http://www.zpeliculas.com/cat/x", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Y", url="http://www.zpeliculas.com/cat/y", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Z", url="http://www.zpeliculas.com/cat/z", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="0", url="http://www.zpeliculas.com/cat/0", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="1", url="http://www.zpeliculas.com/cat/1", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="2", url="http://www.zpeliculas.com/cat/2", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="3", url="http://www.zpeliculas.com/cat/3", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="4", url="http://www.zpeliculas.com/cat/4", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="5", url="http://www.zpeliculas.com/cat/5", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="6", url="http://www.zpeliculas.com/cat/6", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="7", url="http://www.zpeliculas.com/cat/7", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="8", url="http://www.zpeliculas.com/cat/8", - viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="9", url="http://www.zpeliculas.com/cat/9", - viewmode="movie")) - - return itemlist - - -def generos(item): - logger.info() - - itemlist = [] - itemlist.append(Item(channel=item.channel, action="peliculas", title="Acción", - url="http://www.zpeliculas.com/peliculas/p-accion/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Animación", - url="http://www.zpeliculas.com/peliculas/p-animacion/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Aventura", - url="http://www.zpeliculas.com/peliculas/p-aventura/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Biografía", - url="http://www.zpeliculas.com/peliculas/p-biografia/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Bélico", - url="http://www.zpeliculas.com/peliculas/p-belico/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Ciencia Ficción", - url="http://www.zpeliculas.com/peliculas/p-cienciaficcion/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Comedia", - url="http://www.zpeliculas.com/peliculas/p-comedia/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Crimen", - url="http://www.zpeliculas.com/peliculas/p-crimen/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Drama", - url="http://www.zpeliculas.com/peliculas/p-drama/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Fantasía", - url="http://www.zpeliculas.com/peliculas/p-fantasia/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Histórico", - url="http://www.zpeliculas.com/peliculas/p-historico/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Intriga", - url="http://www.zpeliculas.com/peliculas/p-intriga/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Musical", - url="http://www.zpeliculas.com/peliculas/p-musical/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Romántica", - url="http://www.zpeliculas.com/peliculas/p-romantica/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Terror", - url="http://www.zpeliculas.com/peliculas/p-terror/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Thriller", - url="http://www.zpeliculas.com/peliculas/p-thriller/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Western", - url="http://www.zpeliculas.com/peliculas/p-western/", viewmode="movie")) - itemlist.append(Item(channel=item.channel, action="peliculas", title="Otros", - url="http://www.zpeliculas.com/peliculas/p-otros/", viewmode="movie")) - return itemlist - - -def search(item, texto): - try: - post = urllib.urlencode({"story": texto, "do": "search", "subaction": "search", "x": "0", "y": "0"}) - data = scrapertools.cache_page("http://www.zpeliculas.com", post=post) - - patron = '') - scrapedidioma = scrapertools.find_single_match(match, 'title="Idioma">([^<]+)
    ') - scrapedcalidad = scrapertools.find_single_match(match, - '
    ]+>([^<]+)
    ') - - title = scrapedtitle + ' (' + scrapedyear + ') [' + scrapedidioma + '] [' + scrapedcalidad + ']' - url = scrapedurl - thumbnail = scrapedthumbnail - plot = "" - logger.debug("title=[" + title + "], url=[" + url + "], thumbnail=[" + thumbnail + "]") - itemlist.append( - Item(channel=item.channel, action="findvideos", title=title, url=url, thumbnail=thumbnail, plot=plot, - show=title, fanart=thumbnail, hasContentDetails=True, contentTitle=title, - contentThumbnail=thumbnail, - contentType="movie", context=["buscar_trailer"])) - - return itemlist - # Se captura la excepción, para no interrumpir al buscador global si un canal falla - except: - import sys - for line in sys.exc_info(): - logger.error("%s" % line) - return [] - - -def newest(categoria): - itemlist = [] - item = Item() - try: - if categoria == 'peliculas': - item.url = "http://www.zpeliculas.com" - - elif categoria == 'infantiles': - item.url = "http://www.zpeliculas.com/peliculas/p-animacion/" - - else: - return [] - - itemlist = peliculas(item) - if itemlist[-1].extra == "next_page": - itemlist.pop() - - # Se captura la excepción, para no interrumpir al canal novedades si un canal falla - except: - import sys - for line in sys.exc_info(): - logger.error("{0}".format(line)) - return [] - - return itemlist - - -def peliculas(item): - logger.info() - - # Descarga la página - body = scrapertools.cachePage(item.url) - data = scrapertools.get_match(body, - '
    (.*?)