addedd vcstream server (#116)

This commit is contained in:
dentaku65
2019-10-18 20:28:44 +02:00
committed by mac12m99
parent 5fe5d445c3
commit c80a397d40
2 changed files with 107 additions and 0 deletions

46
servers/vcstream.json Normal file
View File

@@ -0,0 +1,46 @@
{
"active": true,
"find_videos": {
"ignore_urls": [],
"patterns": [
{
"pattern": "vcstream.to/(?:embed|f)/([A-z0-9]+)/([A-z0-9.]+)",
"url": "https://vcstream.to/embed/\\1/\\2"
},
{
"pattern": "https://vidcloud.co/v/([a-z0-9A-Z]+)",
"url": "https:\/\/vidcloud.co\/v\/\\1"
}
]
},
"free": true,
"id": "vcstream",
"name": "vcstream",
"settings": [
{
"default": false,
"enabled": true,
"id": "black_list",
"label": "@60654",
"type": "bool",
"visible": true
},
{
"default": 0,
"enabled": true,
"id": "favorites_servers_list",
"label": "@60655",
"lvalues": [
"No",
"1",
"2",
"3",
"4",
"5"
],
"type": "list",
"visible": false
}
],
"thumbnail": "http://i.imgur.com/l45Tk0G.png"
}

61
servers/vcstream.py Normal file
View File

@@ -0,0 +1,61 @@
# -*- coding: utf-8 -*-
# Icarus pv7
# Fix dentaku65
import urlparse
from core import httptools
from core import scrapertools
from platformcode import logger, config
def test_video_exists(page_url):
logger.info("(page_url='%s')" % page_url)
data = httptools.downloadpage(page_url).data
if "Not Found" in data or "File was deleted" in data:
return False, config.get_localized_string(70292) % "vcstream"
return True, ""
def get_video_url(page_url, premium=False, user="", password="", video_password=""):
logger.info("url=" + page_url)
video_urls = []
data = httptools.downloadpage(page_url).data
url = scrapertools.find_single_match(data, "url: '([^']+)',")
if url:
headers = dict()
headers['X-Requested-With'] = "XMLHttpRequest"
token = scrapertools.find_single_match(data, 'set-cookie: vidcloud_session=(.*?);')
token = token.replace("%3D", "")
if token:
headers['vidcloud_session'] = token
referer = scrapertools.find_single_match(data, "pageUrl = '([^']+)'")
if referer:
headers['Referer'] = referer
page_url = urlparse.urljoin(page_url, url)
data = httptools.downloadpage(page_url, headers=headers, verify=False).data
data = data.replace('\\\\', '\\').replace('\\','')
media_urls = scrapertools.find_multiple_matches(data, '\{"file"\s*:\s*"([^"]+)"\}')
for media_url in media_urls:
ext = "mp4"
if "m3u8" in media_url:
ext = "m3u8"
import urllib2
import ssl
context = ssl._create_unverified_context()
video_urls.append(["%s [vcstream]" % ext, media_url, urllib2.HTTPSHandler(context=context)])
for video_url in video_urls:
logger.info("%s - %s" % (video_url[0], video_url[1]))
return video_urls