@@ -1,34 +1,36 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
import base64
|
from core import httptools, scrapertools
|
||||||
|
|
||||||
from core import scrapertools
|
|
||||||
from platformcode import logger
|
from platformcode import logger
|
||||||
|
|
||||||
|
|
||||||
def test_video_exists(page_url):
|
def test_video_exists(page_url):
|
||||||
logger.info("(page_url='%s')" % page_url)
|
logger.info("(page_url='%s')" % page_url)
|
||||||
|
|
||||||
|
data = httptools.downloadpage(page_url).data
|
||||||
|
|
||||||
|
if "File was deleted" in data:
|
||||||
|
return False, "[speedvideo] El archivo no existe o ha sido borrado"
|
||||||
|
|
||||||
return True, ""
|
return True, ""
|
||||||
|
|
||||||
|
|
||||||
def get_video_url(page_url, premium=False, user="", password="", video_password=""):
|
def get_video_url(page_url,
|
||||||
|
premium=False,
|
||||||
|
user="",
|
||||||
|
password="",
|
||||||
|
video_password=""):
|
||||||
logger.info("url=" + page_url)
|
logger.info("url=" + page_url)
|
||||||
video_urls = []
|
video_urls = []
|
||||||
|
|
||||||
data = scrapertools.cachePage(page_url)
|
data = httptools.downloadpage(page_url).data
|
||||||
|
|
||||||
codif = scrapertools.find_single_match(data, 'var [a-z]+ = ([0-9]+);')
|
media_urls = scrapertools.find_multiple_matches(data, r"file:[^']'([^']+)',\s*label:[^\"]\"([^\"]+)\"")
|
||||||
link = scrapertools.find_single_match(data, 'linkfile ="([^"]+)"')
|
|
||||||
numero = int(codif)
|
|
||||||
|
|
||||||
# Decrypt link base64 // python version of speedvideo's base64_decode() [javascript]
|
for media_url, label in media_urls:
|
||||||
|
media_url = httptools.downloadpage(media_url, only_headers=True, follow_redirects=False).headers.get("location", "")
|
||||||
|
|
||||||
link1 = link[:numero]
|
if media_url:
|
||||||
link2 = link[numero + 10:]
|
video_urls.append([label + " " + media_url.rsplit('.', 1)[1] + ' [speedvideo]', media_url])
|
||||||
link = link1 + link2
|
|
||||||
media_url = base64.b64decode(link)
|
|
||||||
|
|
||||||
video_urls.append(["." + media_url.rsplit('.', 1)[1] + ' [speedvideo]', media_url])
|
|
||||||
|
|
||||||
return video_urls
|
return video_urls
|
||||||
|
|||||||
Reference in New Issue
Block a user