|
from tmdbv3api import TMDb, Movie, TV |
|
import requests |
|
import logging |
|
from bs4 import BeautifulSoup,SoupStrainer |
|
from datetime import datetime |
|
import dateparser |
|
from convert import get_TMDb_id_from_IMDb_id |
|
from info import get_info_tmdb, is_movie, get_info_imdb |
|
import config |
|
import json |
|
import re |
|
from urllib.parse import urlparse, parse_qs |
|
|
|
|
|
SC_DOMAIN= config.SC_DOMAIN |
|
SC_FAST_SEARCH = config.SC_FAST_SEARCH |
|
|
|
headers = { |
|
'User-Agent': 'Mozilla/5.0 (Windows NT 10.10; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3', |
|
'Accept-Language': 'en-US,en;q=0.5' |
|
} |
|
|
|
|
|
def get_version(): |
|
|
|
|
|
|
|
try: |
|
base_url = f'https://streamingcommunity.{SC_DOMAIN}/richiedi-un-titolo' |
|
response = requests.get(base_url, headers=headers) |
|
|
|
soup = BeautifulSoup(response.text, "lxml") |
|
|
|
|
|
version = json.loads(soup.find("div", {"id": "app"}).get("data-page"))['version'] |
|
return version |
|
except: |
|
print("Couldn't find the version") |
|
version = "65e52dcf34d64173542cd2dc6b8bb75b" |
|
return version |
|
|
|
def search(query,date,ismovie): |
|
|
|
response = requests.get(query).json() |
|
print(response) |
|
for item in response['data']: |
|
tid = item['id'] |
|
slug = item['slug'] |
|
type = item['type'] |
|
if type == "tv": |
|
type = 0 |
|
elif type == "movie": |
|
type = 1 |
|
if type == ismovie: |
|
|
|
if SC_FAST_SEARCH == "0": |
|
if ismovie == 0: |
|
|
|
response = requests.get ( f'https://streamingcommunity.boston/titles/{tid}-{slug}') |
|
pattern = r'<div[^>]*class="features"[^>]*>.*?<span[^>]*>(.*?)<\/span>' |
|
match = re.search(pattern, response.text) |
|
print(match.group(1).split("-")[0]) |
|
first_air_year = match.group(1).split("-")[0] |
|
date = int(date) |
|
first_air_year = int(first_air_year) |
|
if first_air_year == date: |
|
return tid,slug |
|
elif ismovie == 1: |
|
return tid,slug |
|
elif SC_FAST_SEARCH == "1": |
|
return tid,slug |
|
else: |
|
print("Couldn't find anything") |
|
|
|
|
|
def get_film(tid,version): |
|
headers = { |
|
'user-agent': "Mozilla/5.0 (Windows NT 10.10; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537", |
|
'x-inertia': 'true', |
|
|
|
'x-inertia-version': version |
|
} |
|
|
|
url = f'https://streamingcommunity.{SC_DOMAIN}/iframe/{tid}' |
|
response = requests.get(url, headers=headers) |
|
iframe = BeautifulSoup(response.text, 'lxml') |
|
|
|
iframe = iframe.find('iframe').get("src") |
|
|
|
vixid = iframe.split("/embed/")[1].split("?")[0] |
|
parsed_url = urlparse(iframe) |
|
query_params = parse_qs(parsed_url.query) |
|
|
|
resp = requests.get(iframe, headers = headers) |
|
soup= BeautifulSoup(resp.text, "lxml") |
|
script = soup.find("body").find("script").text |
|
token = re.search(r"'token':\s*'(\w+)'", script).group(1) |
|
expires = re.search(r"'expires':\s*'(\d+)'", script).group(1) |
|
quality = re.search(r'"quality":(\d+)', script).group(1) |
|
|
|
url = f'https://vixcloud.co/playlist/{vixid}?token={token}&expires={expires}' |
|
if 'canPlayFHD' in query_params: |
|
canPlayFHD = 'h=1' |
|
url += "&h=1" |
|
if 'b' in query_params: |
|
b = 'b=1' |
|
url += "&b=1" |
|
url720 = f'https://vixcloud.co/playlist/{vixid}' |
|
return url,url720,quality, |
|
|
|
def get_season_episode_id(tid,slug,season,episode,version): |
|
|
|
headers = { |
|
'user-agent': "Mozilla/5.0 (Windows NT 10.10; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3", |
|
'x-inertia': 'true', |
|
|
|
'x-inertia-version': version |
|
} |
|
|
|
response = requests.get(f'https://streamingcommunity.{SC_DOMAIN}/titles/{tid}-{slug}/stagione-{season}', headers=headers) |
|
|
|
json_response = response.json().get('props', {}).get('loadedSeason', {}).get('episodes', []) |
|
for dict_episode in json_response: |
|
if dict_episode['number'] == episode: |
|
return dict_episode['id'] |
|
|
|
def get_episode_link(episode_id,tid,version): |
|
|
|
params = { |
|
'episode_id': episode_id, |
|
'next_episode': '1' |
|
} |
|
|
|
|
|
response = requests.get(f"https://streamingcommunity.{SC_DOMAIN}/iframe/{tid}", params=params) |
|
|
|
|
|
soup = BeautifulSoup(response.text, "lxml") |
|
iframe = soup.find("iframe").get("src") |
|
vixid = iframe.split("/embed/")[1].split("?")[0] |
|
headers = { |
|
'user-agent': "Mozilla/5.0 (Windows NT 10.10; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537", |
|
'x-inertia': 'true', |
|
|
|
'x-inertia-version': version |
|
} |
|
parsed_url = urlparse(iframe) |
|
query_params = parse_qs(parsed_url.query) |
|
|
|
resp = requests.get(iframe, headers = headers) |
|
soup= BeautifulSoup(resp.text, "lxml") |
|
script = soup.find("body").find("script").text |
|
token = re.search(r"'token':\s*'(\w+)'", script).group(1) |
|
expires = re.search(r"'expires':\s*'(\d+)'", script).group(1) |
|
quality = re.search(r'"quality":(\d+)', script).group(1) |
|
|
|
url = f'https://vixcloud.co/playlist/{vixid}?token={token}&expires={expires}' |
|
if 'canPlayFHD' in query_params: |
|
canPlayFHD = 'h=1' |
|
url += "&h=1" |
|
if 'b' in query_params: |
|
b = 'b=1' |
|
url += "&b=1" |
|
url720 = f'https://vixcloud.co/playlist/{vixid}' |
|
return url,url720,quality |
|
|
|
|
|
def streaming_community(imdb): |
|
try: |
|
general = is_movie(imdb) |
|
ismovie = general[0] |
|
imdb_id = general[1] |
|
type = "StreamingCommunity" |
|
if ismovie == 0 : |
|
season = int(general[2]) |
|
episode = int(general[3]) |
|
|
|
if SC_FAST_SEARCH == "1": |
|
if "tt" in imdb: |
|
|
|
showname = get_info_imdb(imdb_id,ismovie,type) |
|
date = None |
|
else: |
|
|
|
date = None |
|
|
|
tmdba = imdb_id.replace("tmdb:","") |
|
showname = get_info_tmdb(tmdba,ismovie,type) |
|
elif SC_FAST_SEARCH == "0": |
|
tmdba = get_TMDb_id_from_IMDb_id(imdb_id) |
|
showname,date = get_info_tmdb(tmdba,ismovie,type) |
|
|
|
else: |
|
if "tt" in imdb: |
|
|
|
date = None |
|
showname = get_info_imdb(imdb_id,ismovie,type) |
|
else: |
|
|
|
|
|
date = None |
|
tmdba = imdb_id.replace("tmdb:","") |
|
showname = get_info_tmdb(tmdba,ismovie,type) |
|
|
|
showname = showname.replace(" ", "+").replace("–", "+").replace("—","+") |
|
query = f'https://streamingcommunity.{SC_DOMAIN}/api/search?q={showname}' |
|
tid,slug = search(query,date,ismovie) |
|
version = get_version() |
|
if ismovie == 1: |
|
|
|
url,url720,quality = get_film(tid,version) |
|
print(url) |
|
return url,url720,quality |
|
if ismovie == 0: |
|
|
|
episode_id = get_season_episode_id(tid,slug,season,episode,version) |
|
url,url720,quality = get_episode_link(episode_id,tid,version) |
|
print(url) |
|
return url,url720,quality |
|
except Exception as e: |
|
print("StreamingCommunity failed") |
|
return None,None,None |