48 lines
1.8 KiB
Python
48 lines
1.8 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
import re
|
|
|
|
from core import httptools
|
|
from core import scrapertools
|
|
from platformcode import logger
|
|
from lib import jsunpack
|
|
|
|
|
|
def test_video_exists(page_url):
|
|
logger.info("(page_url='%s')" % page_url)
|
|
response = httptools.downloadpage(page_url)
|
|
if response.code != 200 or "No longer available!" in response.data:
|
|
return False, "[vshare] El archivo no existe o ha sido borrado."
|
|
else:
|
|
return True, ""
|
|
|
|
|
|
def get_video_url(page_url, premium=False, user="", password="", video_password=""):
|
|
logger.info("url = " + page_url)
|
|
headers = {"Referer":page_url}
|
|
data = httptools.downloadpage(page_url, headers=headers).data
|
|
flowplayer = re.search("url: [\"']([^\"']+)", data)
|
|
if flowplayer:
|
|
return [["FLV", flowplayer.group(1)]]
|
|
video_urls = []
|
|
try:
|
|
jsUnpack = jsunpack.unpack(data)
|
|
logger.debug(jsUnpack)
|
|
fields = re.search("\[([^\]]+).*?parseInt\(value\)-(\d+)", jsUnpack)
|
|
if fields:
|
|
logger.debug("Values: " + fields.group(1))
|
|
logger.debug("Substract: " + fields.group(2))
|
|
substract = int(fields.group(2))
|
|
arrayResult = [chr(int(value) - substract) for value in fields.group(1).split(",")]
|
|
strResult = "".join(arrayResult)
|
|
logger.debug(strResult)
|
|
videoSources = re.findall("<source[\s]+src=[\"'](?P<url>[^\"']+)[^>]+label=[\"'](?P<label>[^\"']+)", strResult)
|
|
for url, label in videoSources:
|
|
url += "|Referer=%s" %page_url
|
|
video_urls.append([label, url])
|
|
video_urls.sort(key=lambda i: int(i[0].replace("p","")))
|
|
except:
|
|
url = scrapertools.find_single_match(data,'<source src="([^"]+)')
|
|
video_urls.append(["MP4", url])
|
|
return video_urls
|