Ejemplo n.º 1
0
def get_video_url(page_url,
                  premium=False,
                  user="",
                  password="",
                  video_password=""):
    logger.info("[mega.py] get_video_url(page_url='%s')" % page_url)
    video_urls = []
    from megaserver import Client

    c = Client(url=page_url, is_playing_fnc=platformtools.is_playing)

    files = c.get_files()

    #si hay mas de 5 archivos crea un playlist con todos
    if len(files) > 5:
        media_url = c.get_play_list()
        video_urls.append([
            scrapertools.get_filename_from_url(media_url)[-4:] + " [mega]",
            media_url
        ])
    else:
        for f in files:
            media_url = f["url"]
            video_urls.append([
                scrapertools.get_filename_from_url(media_url)[-4:] + " [mega]",
                media_url
            ])

    return video_urls
Ejemplo n.º 2
0
def carpeta(item):
    logger.info("pelisalacarta.channels.puyasubs carpeta")
    itemlist = list()
    
    if item.server == "onefichier":
        data = scrapertools.downloadpage(item.url)

        patron = '<tr>.*?<a href="([^"]+)".*?>(.*?)</a>.*?<td class="normal">(.*?)</td>'
        matches = scrapertools.find_multiple_matches(data, patron)
        for scrapedurl, scrapedtitle, size in matches:
            scrapedtitle += "  (%s)   [1fichier]" % size
            itemlist.append(Item(channel=item.channel, title=scrapedtitle, url=scrapedurl, action="play",
                                 server="onefichier", text_color=color1, thumbnail=item.thumbnail,
                                 infoLabels=item.infoLabels))
    else:
        from megaserver import Client
        from platformcode import platformtools
            
        c = Client(url=item.url)
        
        files = c.get_files()
        c.stop()
        for enlace in files:
            file_id = enlace["id"]
            itemlist.append(Item(channel=item.channel, title=enlace["name"], url=item.url+"|"+file_id, action="play",
                                 server="mega", text_color=color1, thumbnail=item.thumbnail,
                                 infoLabels=item.infoLabels))

    itemlist.sort(key=lambda item: item.title)
    return itemlist
Ejemplo n.º 3
0
def carpeta(item):
    logger.info()
    itemlist = list()
    
    if item.server == "onefichier":
        data = httptools.downloadpage(item.url).data

        patron = '<tr>.*?<a href="([^"]+)".*?>(.*?)</a>.*?<td class="normal">(.*?)</td>'
        matches = scrapertools.find_multiple_matches(data, patron)
        for scrapedurl, scrapedtitle, size in matches:
            scrapedtitle += "  (%s)   [1fichier]" % size
            itemlist.append(Item(channel=item.channel, title=scrapedtitle, url=scrapedurl, action="play",
                                 server="onefichier", text_color=color1, thumbnail=item.thumbnail,
                                 infoLabels=item.infoLabels))
    else:
        from megaserver import Client
        from platformcode import platformtools
            
        c = Client(url=item.url)
        
        files = c.get_files()
        c.stop()
        for enlace in files:
            file_id = enlace["id"]
            itemlist.append(Item(channel=item.channel, title=enlace["name"], url=item.url+"|"+file_id, action="play",
                                 server="mega", text_color=color1, thumbnail=item.thumbnail,
                                 infoLabels=item.infoLabels))

    itemlist.sort(key=lambda item: item.title)
    return itemlist
Ejemplo n.º 4
0
def get_video_url(page_url,
                  premium=False,
                  user="",
                  password="",
                  video_password=""):
    logger.info("(page_url='%s')" % page_url)
    video_urls = []

    from megaserver import Client
    c = Client(url=page_url, is_playing_fnc=platformtools.is_playing)
    files = c.get_files()

    # si hay mas de 5 archivos crea un playlist con todos
    # Esta función (la de la playlist) no va, hay que ojear megaserver/handler.py aunque la llamada este en client.py
    if len(files) > 5:
        media_url = c.get_play_list()
        video_urls.append([
            scrapertools.get_filename_from_url(media_url)[-4:] + " [mega]",
            media_url
        ])
    else:
        for f in files:
            media_url = f["url"]
            video_urls.append([
                scrapertools.get_filename_from_url(media_url)[-4:] + " [mega]",
                media_url
            ])

    return video_urls
Ejemplo n.º 5
0
def test_video_exists(page_url):
    from megaserver import Client
    c = Client(url=page_url, is_playing_fnc=platformtools.is_playing)
    global files
    files = c.get_files()
    if isinstance(files, (int, long)):
        return False, "Error codigo %s" % str(files)

    return True, ""
Ejemplo n.º 6
0
def carpeta(item):
    logger.info()
    itemlist = list()
    if item.server == "onefichier":
        data = httptools.downloadpage(item.url).data
        patron = '<tr>.*?<a href="([^"]+)".*?>(.*?)</a>.*?<td class="normal">(.*?)</td>'
        matches = scrapertools.find_multiple_matches(data, patron)
        for scrapedurl, scrapedtitle, size in matches:
            scrapedtitle += "  (%s)   [1fichier]" % size
            itemlist.append(Item(channel=item.channel, title=scrapedtitle, url=scrapedurl, action="play",
                                 server="onefichier", text_color=color1, thumbnail=item.thumbnail,
                                 infoLabels=item.infoLabels))
    elif item.server == "gvideo":
        response = httptools.downloadpage(item.url, cookies=False, headers={"Referer": item.url})
        cookies = ""
        cookie = response.headers["set-cookie"].split("HttpOnly, ")
        for c in cookie:
            cookies += c.split(";", 1)[0] + "; "
        data = response.data
        
        
        patron = "'_DRIVE_ivd'] = '(.*?)'"
        matches = scrapertools.find_single_match(data, patron)
        data = data.decode('unicode-escape')
        data = urllib.unquote_plus(urllib.unquote_plus(data))
        newpatron = ',\["(.*?)",\[".*?,"(.*?)","video'
        newmatches = scrapertools.find_multiple_matches(data, newpatron)
        
        for url, scrapedtitle in newmatches:
            url = "https://drive.google.com/open?id=%s" % url
            
            itemlist.append(Item(channel=item.channel, title=scrapedtitle, url=url, action="play",
                                 server="gvideo", text_color=color1, thumbnail=item.thumbnail,
                                 infoLabels=item.infoLabels))
    else:
        from servers import mega
        check, msg = mega.test_video_exists(item.url)
        if check == False:
            itemlist.append(Item(channel=item.channel, title=msg, url="",
                                 text_color=color1, thumbnail=item.thumbnail,
                                 infoLabels=item.infoLabels))
        else:
            c = Client(url=item.url)
            files = c.get_files()
            c.stop()
            for enlace in files:
                file_id = enlace["id"]
                itemlist.append(
                    Item(channel=item.channel, title=enlace["name"], url=item.url + "|" + file_id, action="play",
                        server="mega", text_color=color1, thumbnail=item.thumbnail,
                        infoLabels=item.infoLabels))
    itemlist.sort(key=lambda item: item.title)
    return itemlist
Ejemplo n.º 7
0
def get_video_url( page_url , premium = False , user="" , password="", video_password="" ):
    logger.info("[mega.py] get_video_url(page_url='%s')" % page_url)
    video_urls = []
    from megaserver import Client
        
    c = Client(url=page_url,is_playing_fnc = platformtools.is_playing)
    
    files = c.get_files()
    
    #si hay mas de 5 archivos crea un playlist con todos
    if len(files) >5:
      media_url = c.get_play_list()
      video_urls.append( [ scrapertools.get_filename_from_url(media_url)[-4:]+" [mega]",media_url])
    else:
      for f in files:
        media_url = f["url"]
        video_urls.append( [ scrapertools.get_filename_from_url(media_url)[-4:]+" [mega]",media_url])

    return video_urls
Ejemplo n.º 8
0
# -*- coding: utf-8 -*-
from core.libs import *


def get_video_url(item):
    logger.trace()
    itemlist = []
    try:
        from megaserver import Client
    except Exception, e:
        return str(e)
    c = Client(url=item.url, is_playing_fnc=platformtools.is_playing)

    files = c.get_files()

    # si hay mas de 5 archivos crea un playlist con todos
    if len(files) > 5:
        itemlist.append(Video(url=c.get_play_list()))
    else:
        for f in files:
            itemlist.append(Video(url=f["url"]))

    return itemlist
Ejemplo n.º 9
0
def test_video_exists(page_url):
    types = "Archivo"
    gen = "o"
    msg = "El link tiene algún problema."
    id_video = None
    get = ""
    seqno = random.randint(0, 0xFFFFFFFF)
    url = page_url.split("#")[1]
    f_id = url.split("!")[1]
    id_video = None
    if "|" in url:
        url, id_video = url.split("|")
    post = {'a': 'g', 'g': 1, 'p': f_id}
    isfolder = False
    if "/#F!" in page_url:
        get = "&n=" + f_id
        post = {"a": "f", "c": 1, "r": 0}
        isfolder = True
        types = "Carpeta"
        gen = "a"
        if id_video:
            #Aqui ya para hacer un check se complica, no hay una manera directa aún teniendo la id del video dentro de la carpeta
            return True, ""

    codes = {
        -1: 'Se ha producido un error interno en Mega.nz',
        -2: 'Error en la petición realizada, Cod -2',
        -3:
        'Un atasco temporal o malfuncionamiento en el servidor de Mega impide que se procese su link',
        -4:
        'Ha excedido la cuota de transferencia permitida. Vuelva a intentarlo más tarde',
        -6: types + ' no encontrad' + gen + ', cuenta eliminada',
        -9: types + ' no encontrad' + gen,
        -11: 'Acceso restringido',
        -13: 'Está intentando acceder a un archivo incompleto',
        -14: 'Una operación de desencriptado ha fallado',
        -15: 'Sesión de usuario expirada o invalida, logueese de nuevo',
        -16: types + ' no disponible, la cuenta del uploader fue baneada',
        -17: 'La petición sobrepasa su cuota de transferiencia permitida',
        -18:
        types + ' temporalmente no disponible, intentelo de nuevo más tarde'
    }
    api = 'https://g.api.mega.co.nz/cs?id=%d%s' % (seqno, get)
    req_api = httptools.downloadpage(api, post=json.dumps([post])).data
    if isfolder:
        req_api = json.loads(req_api)
    else:
        try:
            req_api = json.loads(req_api)[0]
        except:
            req_api = json.loads(req_api)
    logger.error(req_api)
    if isinstance(req_api, (int, long)):
        if req_api in codes:
            msg = codes[req_api]
        return False, msg
    else:
        #Comprobación limite cuota restante
        from megaserver import Client
        c = Client(url=page_url, is_playing_fnc=platformtools.is_playing)
        global files
        files = c.get_files()
        if files == 509:
            msg1 = "[B][COLOR tomato]El video excede el limite de visionado diario que Mega impone a los usuarios Free."
            msg1 += " Prueba en otro servidor o canal.[/B][/COLOR]"
            return False, msg1
        elif isinstance(files, (int, long)):
            return False, "Error codigo %s" % str(files)

        return True, ""