- riorganizzate le impostazioni - aggiunte descrizioni tag qualità su cb01 (presto anche sugli altri) - aggiunto il supporto alle serie di polpotv - fixato server mystream - fix Rinumerazione per episodi Nuovi
97 lines
3.7 KiB
Python
Executable File
97 lines
3.7 KiB
Python
Executable File
# -*- coding: utf-8 -*-
|
|
import sys
|
|
PY3 = False
|
|
if sys.version_info[0] >= 3: PY3 = True; unicode = str; unichr = chr; long = int
|
|
|
|
import json
|
|
import random
|
|
from core import httptools
|
|
from core import scrapertools
|
|
from platformcode import platformtools, logger
|
|
|
|
files = None
|
|
|
|
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, ""
|
|
|
|
def get_video_url(page_url, premium=False, user="", password="", video_password=""):
|
|
page_url = page_url.replace('/embed#', '/#')
|
|
logger.info("(page_url='%s')" % page_url)
|
|
video_urls = []
|
|
|
|
# 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
|