| 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 |