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('# -*- coding: utf-8 -*-

import re

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 _0xf475=(\[[^;]+\]);')
    #logger.info("Intel11 %s" %_0xa3e8)
    #logger.info("Intel22 %s" %data)
    packed = scrapertools.find_single_match(data, "<script type=[\"']text/javascript[\"']>(eval.*?)</script>")
    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, _0xa3e8):
        self.r = None
        self.s = None
        self.k = None
        self.n = None
        self.c = None
        self.b = None
        self.d = None

        _0xa3e8 = eval(_0xa3e8)
        self.t(_0xa3e8[14] + _0xa3e8[15] + _0xa3e8[14] + _0xa3e8[15], _0xa3e8[16])

    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
') +# -*- 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, - '
    (.*?)