Página 1 de 1

Gamovideo da error

Publicado: 14 Abr 2016, 16:21
por Masay90
Solo quería decir que gamovideo a dejado otra vez de funcionar, la gente de ese servidor se aburre.

Un saludo.

Re: Gamovideo da error

Publicado: 15 Abr 2016, 10:29
por robalo
/server/gamovideo.py

Código: Seleccionar todo

# -*- coding: utf-8 -*-
#------------------------------------------------------------
# pelisalacarta - XBMC Plugin
# Conector para gamovideo
# http://blog.tvalacarta.info/plugin-xbmc/pelisalacarta/
#------------------------------------------------------------

import re

from core import scrapertools
from core import logger
from core import config
from core import jsunpack

headers = [
    ["User-Agent","Mozilla/5.0 (Windows NT 6.1; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0"],
    ["Accept-Encoding","gzip, deflate"],
    ["Host","gamovideo.com"]
]

def test_video_exists( page_url ):
    logger.info("pelisalacarta.servers.gamovideo test_video_exists(page_url='%s')" % page_url)

    data = scrapertools.cache_page(page_url, headers=headers)

    if "File was deleted" in data or "File Not Found" in data:
        return False, "[Gamovideo] El archivo no existe o ha sido borrado" 

    return True, ""

def get_video_url( page_url , premium = False , user="" , password="", video_password="" ):
    logger.info("pelisalacarta.servers.gamovideo get_video_url(page_url='%s')" % page_url)

    data = scrapertools.cache_page(page_url, headers=headers)

    packer = scrapertools.find_single_match(data,"<script type='text/javascript'>(eval.function.p,a,c,k,e,d..*?)</script>")
    unpacker = jsunpack.unpack(data) if packer != "" else "" 
    if unpacker != "": data = unpacker

    data = re.sub(r'\n|\t|\s+', '', data)

    host = scrapertools.get_match(data, '\[\{image:"(http://[^/]+/)')
    #rtmp_url = scrapertools.get_match(data, '\[\{file:"([^"]+)"')
    mediaurl = host+scrapertools.get_match(data, ',\{file:"([^"]+)"').split("=")[1]+"/v.flv"

    video_urls = []
    video_urls.append([scrapertools.get_filename_from_url(mediaurl)[-4:]+" [gamovideo]",mediaurl])
    #video_urls.append(["RTMP [gamovideo]",rtmp_url])      

    for video_url in video_urls:
        logger.info("pelisalacarta.servers.gamovideo %s - %s" % (video_url[0],video_url[1]))

    return video_urls

# Encuentra vídeos del servidor en el texto pasado
def find_videos(data):
    encontrados = set()
    devuelve = []

    # http://gamovideo.com/auoxxtvyoy
    # http://gamovideo.com/h1gvpjarjv88
    # http://gamovideo.com/embed-sbb9ptsfqca2-588x360.html
    patronvideos  = 'gamovideo.com/(?:embed-|)([a-z0-9]+)'
    logger.info("pelisalacarta.servers.gamovideo find_videos #"+patronvideos+"#")
    matches = re.compile(patronvideos,re.DOTALL).findall(data)

    for match in matches:
        titulo = "[gamovideo]"
        url = "http://gamovideo.com/"+match
        if url not in encontrados:
            logger.info("  url="+url)
            devuelve.append( [ titulo , url , 'gamovideo' ] )
            encontrados.add(url)
        else:
            logger.info("  url duplicada="+url)
            
    return devuelve

def test():
    video_urls = get_video_url("http://gamovideo.com/91zidptmfqnr")

    return len(video_urls)>0

Re: Gamovideo da error

Publicado: 15 Abr 2016, 11:52
por Cmos
@robalo funciona perfecto, como era de esperar ;)

Yo estaba mirando de volver a habilitar la dirección rtmp, siguiendo con tus cambios quedaría así:

Código: Seleccionar todo

# -*- coding: utf-8 -*-
#------------------------------------------------------------
# pelisalacarta - XBMC Plugin
# Conector para gamovideo
# http://blog.tvalacarta.info/plugin-xbmc/pelisalacarta/
#------------------------------------------------------------

import re

from core import scrapertools
from core import logger
from core import config
from core import jsunpack

headers = [["User-Agent","Mozilla/5.0 (Windows NT 10.0; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0"]]

def test_video_exists( page_url ):
    logger.info("pelisalacarta.servers.gamovideo test_video_exists(page_url='%s')" % page_url)
    data = scrapertools.cache_page(page_url, headers=headers)

    if ("File was deleted" or "Not Found") in data:
        return False, "[Gamovideo] El archivo no existe o ha sido borrado" 

    return True, ""

def get_video_url( page_url , premium = False , user="" , password="", video_password="" ):
    logger.info("pelisalacarta.servers.gamovideo get_video_url(page_url='%s')" % page_url)

    data = scrapertools.cache_page(page_url,headers=headers)
    packer = scrapertools.find_single_match(data,"<script type='text/javascript'>(eval.function.p,a,c,k,e,d..*?)</script>")
    unpacker = jsunpack.unpack(data) if packer != "" else ""
    if unpacker != "": data = unpacker

    data = re.sub(r'\n|\t|\s+', '', data)

    host = scrapertools.get_match(data, '\[\{image:"(http://[^/]+/)')
    mediaurl = host+scrapertools.get_match(data, ',\{file:"([^"]+)"').split("=")[1]+"/v.flv"
	
    rtmp_url = scrapertools.get_match(data, 'file:"(rtmp[^"]+)"')
    playpath = scrapertools.get_match(rtmp_url, 'vod\?h=[\w]+/(.*$)')
    rtmp_url = rtmp_url.split(playpath)[0]+" playpath="+playpath+" swfUrl=http://gamovideo.com/player61/jwplayer.flash.swf"

    video_urls = []
    video_urls.append([scrapertools.get_filename_from_url(mediaurl)[-4:]+" [gamovideo]",mediaurl])
    video_urls.append(["RTMP [gamovideo]",rtmp_url])      

    for video_url in video_urls:
        logger.info("pelisalacarta.servers.gamovideo %s - %s" % (video_url[0],video_url[1]))

    return video_urls

# Encuentra vídeos del servidor en el texto pasado
def find_videos(data):
    encontrados = set()
    devuelve = []

    # http://gamovideo.com/auoxxtvyoy
    # http://gamovideo.com/h1gvpjarjv88
    # http://gamovideo.com/embed-sbb9ptsfqca2-588x360.html
    patronvideos  = 'gamovideo.com/(?:embed-|)([a-z0-9]+)'
    logger.info("pelisalacarta.servers.gamovideo find_videos #"+patronvideos+"#")
    matches = re.compile(patronvideos,re.DOTALL).findall(data)

    for match in matches:
        titulo = "[gamovideo]"
        url = "http://gamovideo.com//embed-%s.html" % match
        if url not in encontrados:
            logger.info("  url="+url)
            devuelve.append( [ titulo , url , 'gamovideo' ] )
            encontrados.add(url)
        else:
            logger.info("  url duplicada="+url)
            
    return devuelve

def test():
    video_urls = get_video_url("http://gamovideo.com/91zidptmfqnr")

    return len(video_urls)>0
Me da la sensación que desde el rtmp carga más rápido, aunque lo mismo solo es un efecto placebo :lol:

Re: Gamovideo da error

Publicado: 15 Abr 2016, 15:03
por robalo
Pensaba que no tiraban los rtmp por eso lo dejé comentado como estaba antes :)
Pues ala, otra opción más que nunca viene mal :)

Re: Gamovideo da error

Publicado: 15 Abr 2016, 18:00
por Cmos
robalo escribió:Pensaba que no tiraban los rtmp por eso lo dejé comentado como estaba antes :)
Pues ala, otra opción más que nunca viene mal :)
Sí, yo pensaba lo mismo viendo que con vlc funcionaba directamente sin necesidad de especificarle el playpath o la swfurl, pero parece que para Kodi es fundamental. Ya he añadido los cambios al macro PR de conectores ;) :mrgreen:

Re: Gamovideo da error

Publicado: 18 Abr 2016, 14:22
por Masay90
Para crear un *. Py copio eso que a puesto robalo a un txt y lo guardo con nombre gamovideo.py y funcionando,sustituyo etc....

Es así el proceso