StreamingCommunity 2.4.0__py3-none-any.whl → 2.5.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of StreamingCommunity might be problematic. Click here for more details.
- {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/METADATA +9 -6
- StreamingCommunity-2.5.0.dist-info/RECORD +8 -0
- StreamingCommunity/Api/Player/Helper/Vixcloud/js_parser.py +0 -143
- StreamingCommunity/Api/Player/Helper/Vixcloud/util.py +0 -136
- StreamingCommunity/Api/Player/ddl.py +0 -89
- StreamingCommunity/Api/Player/maxstream.py +0 -151
- StreamingCommunity/Api/Player/supervideo.py +0 -194
- StreamingCommunity/Api/Player/vixcloud.py +0 -273
- StreamingCommunity/Api/Site/1337xx/__init__.py +0 -51
- StreamingCommunity/Api/Site/1337xx/costant.py +0 -15
- StreamingCommunity/Api/Site/1337xx/site.py +0 -89
- StreamingCommunity/Api/Site/1337xx/title.py +0 -66
- StreamingCommunity/Api/Site/altadefinizionegratis/__init__.py +0 -51
- StreamingCommunity/Api/Site/altadefinizionegratis/costant.py +0 -19
- StreamingCommunity/Api/Site/altadefinizionegratis/film.py +0 -74
- StreamingCommunity/Api/Site/altadefinizionegratis/site.py +0 -95
- StreamingCommunity/Api/Site/animeunity/__init__.py +0 -51
- StreamingCommunity/Api/Site/animeunity/costant.py +0 -19
- StreamingCommunity/Api/Site/animeunity/film_serie.py +0 -135
- StreamingCommunity/Api/Site/animeunity/site.py +0 -175
- StreamingCommunity/Api/Site/animeunity/util/ScrapeSerie.py +0 -97
- StreamingCommunity/Api/Site/cb01new/__init__.py +0 -52
- StreamingCommunity/Api/Site/cb01new/costant.py +0 -19
- StreamingCommunity/Api/Site/cb01new/film.py +0 -73
- StreamingCommunity/Api/Site/cb01new/site.py +0 -83
- StreamingCommunity/Api/Site/ddlstreamitaly/__init__.py +0 -56
- StreamingCommunity/Api/Site/ddlstreamitaly/costant.py +0 -20
- StreamingCommunity/Api/Site/ddlstreamitaly/series.py +0 -146
- StreamingCommunity/Api/Site/ddlstreamitaly/site.py +0 -99
- StreamingCommunity/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +0 -85
- StreamingCommunity/Api/Site/guardaserie/__init__.py +0 -51
- StreamingCommunity/Api/Site/guardaserie/costant.py +0 -19
- StreamingCommunity/Api/Site/guardaserie/series.py +0 -198
- StreamingCommunity/Api/Site/guardaserie/site.py +0 -90
- StreamingCommunity/Api/Site/guardaserie/util/ScrapeSerie.py +0 -110
- StreamingCommunity/Api/Site/ilcorsaronero/__init__.py +0 -52
- StreamingCommunity/Api/Site/ilcorsaronero/costant.py +0 -19
- StreamingCommunity/Api/Site/ilcorsaronero/site.py +0 -72
- StreamingCommunity/Api/Site/ilcorsaronero/title.py +0 -46
- StreamingCommunity/Api/Site/ilcorsaronero/util/ilCorsarScraper.py +0 -149
- StreamingCommunity/Api/Site/mostraguarda/__init__.py +0 -49
- StreamingCommunity/Api/Site/mostraguarda/costant.py +0 -19
- StreamingCommunity/Api/Site/mostraguarda/film.py +0 -101
- StreamingCommunity/Api/Site/streamingcommunity/__init__.py +0 -56
- StreamingCommunity/Api/Site/streamingcommunity/costant.py +0 -19
- StreamingCommunity/Api/Site/streamingcommunity/film.py +0 -75
- StreamingCommunity/Api/Site/streamingcommunity/series.py +0 -206
- StreamingCommunity/Api/Site/streamingcommunity/site.py +0 -142
- StreamingCommunity/Api/Site/streamingcommunity/util/ScrapeSerie.py +0 -123
- StreamingCommunity/Api/Template/Class/SearchType.py +0 -101
- StreamingCommunity/Api/Template/Util/__init__.py +0 -5
- StreamingCommunity/Api/Template/Util/get_domain.py +0 -203
- StreamingCommunity/Api/Template/Util/manage_ep.py +0 -179
- StreamingCommunity/Api/Template/Util/recall_search.py +0 -37
- StreamingCommunity/Api/Template/__init__.py +0 -3
- StreamingCommunity/Api/Template/site.py +0 -87
- StreamingCommunity/Lib/Downloader/HLS/downloader.py +0 -965
- StreamingCommunity/Lib/Downloader/HLS/proxyes.py +0 -110
- StreamingCommunity/Lib/Downloader/HLS/segments.py +0 -573
- StreamingCommunity/Lib/Downloader/MP4/downloader.py +0 -155
- StreamingCommunity/Lib/Downloader/TOR/downloader.py +0 -296
- StreamingCommunity/Lib/Downloader/__init__.py +0 -5
- StreamingCommunity/Lib/FFmpeg/__init__.py +0 -4
- StreamingCommunity/Lib/FFmpeg/capture.py +0 -170
- StreamingCommunity/Lib/FFmpeg/command.py +0 -296
- StreamingCommunity/Lib/FFmpeg/util.py +0 -249
- StreamingCommunity/Lib/M3U8/__init__.py +0 -6
- StreamingCommunity/Lib/M3U8/decryptor.py +0 -165
- StreamingCommunity/Lib/M3U8/estimator.py +0 -229
- StreamingCommunity/Lib/M3U8/parser.py +0 -666
- StreamingCommunity/Lib/M3U8/url_fixer.py +0 -58
- StreamingCommunity/Lib/TMBD/__init__.py +0 -2
- StreamingCommunity/Lib/TMBD/obj_tmbd.py +0 -39
- StreamingCommunity/Lib/TMBD/tmdb.py +0 -346
- StreamingCommunity/Upload/update.py +0 -67
- StreamingCommunity/Upload/version.py +0 -5
- StreamingCommunity/Util/_jsonConfig.py +0 -228
- StreamingCommunity/Util/call_stack.py +0 -42
- StreamingCommunity/Util/color.py +0 -20
- StreamingCommunity/Util/console.py +0 -12
- StreamingCommunity/Util/ffmpeg_installer.py +0 -368
- StreamingCommunity/Util/headers.py +0 -160
- StreamingCommunity/Util/logger.py +0 -62
- StreamingCommunity/Util/message.py +0 -64
- StreamingCommunity/Util/os.py +0 -507
- StreamingCommunity/Util/table.py +0 -229
- StreamingCommunity-2.4.0.dist-info/RECORD +0 -92
- {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/LICENSE +0 -0
- {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/WHEEL +0 -0
- {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/entry_points.txt +0 -0
- {StreamingCommunity-2.4.0.dist-info → StreamingCommunity-2.5.0.dist-info}/top_level.txt +0 -0
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
# 01.03.24
|
|
2
|
-
|
|
3
|
-
import logging
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# External libraries
|
|
7
|
-
import httpx
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
# Internal utilities
|
|
11
|
-
from StreamingCommunity.Util.headers import get_headers
|
|
12
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
13
|
-
from StreamingCommunity.Api.Player.Helper.Vixcloud.util import EpisodeManager, Episode
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
# Variable
|
|
17
|
-
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
class ScrapeSerieAnime():
|
|
22
|
-
def __init__(self, site_name: str):
|
|
23
|
-
"""
|
|
24
|
-
Initialize the media scraper for a specific website.
|
|
25
|
-
|
|
26
|
-
Args:
|
|
27
|
-
site_name (str): Name of the streaming site to scrape
|
|
28
|
-
"""
|
|
29
|
-
self.is_series = False
|
|
30
|
-
self.headers = {'user-agent': get_headers()}
|
|
31
|
-
self.base_name = site_name
|
|
32
|
-
self.domain = config_manager.get_dict('SITE', self.base_name)['domain']
|
|
33
|
-
|
|
34
|
-
def setup(self, version: str = None, media_id: int = None, series_name: str = None):
|
|
35
|
-
self.version = version
|
|
36
|
-
self.media_id = media_id
|
|
37
|
-
|
|
38
|
-
if series_name is not None:
|
|
39
|
-
self.is_series = True
|
|
40
|
-
self.series_name = series_name
|
|
41
|
-
self.obj_episode_manager: EpisodeManager = EpisodeManager()
|
|
42
|
-
|
|
43
|
-
def get_count_episodes(self):
|
|
44
|
-
"""
|
|
45
|
-
Retrieve total number of episodes for the selected media.
|
|
46
|
-
|
|
47
|
-
Returns:
|
|
48
|
-
int: Total episode count
|
|
49
|
-
"""
|
|
50
|
-
try:
|
|
51
|
-
|
|
52
|
-
response = httpx.get(
|
|
53
|
-
url=f"https://www.{self.base_name}.{self.domain}/info_api/{self.media_id}/",
|
|
54
|
-
headers=self.headers,
|
|
55
|
-
timeout=max_timeout
|
|
56
|
-
)
|
|
57
|
-
response.raise_for_status()
|
|
58
|
-
|
|
59
|
-
# Parse JSON response and return episode count
|
|
60
|
-
return response.json()["episodes_count"]
|
|
61
|
-
|
|
62
|
-
except Exception as e:
|
|
63
|
-
logging.error(f"Error fetching episode count: {e}")
|
|
64
|
-
return None
|
|
65
|
-
|
|
66
|
-
def get_info_episode(self, index_ep: int) -> Episode:
|
|
67
|
-
"""
|
|
68
|
-
Fetch detailed information for a specific episode.
|
|
69
|
-
|
|
70
|
-
Args:
|
|
71
|
-
index_ep (int): Zero-based index of the target episode
|
|
72
|
-
|
|
73
|
-
Returns:
|
|
74
|
-
Episode: Detailed episode information
|
|
75
|
-
"""
|
|
76
|
-
try:
|
|
77
|
-
|
|
78
|
-
params = {
|
|
79
|
-
"start_range": index_ep,
|
|
80
|
-
"end_range": index_ep + 1
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
response = httpx.get(
|
|
84
|
-
url=f"https://www.{self.base_name}.{self.domain}/info_api/{self.media_id}/{index_ep}",
|
|
85
|
-
headers=self.headers,
|
|
86
|
-
params=params,
|
|
87
|
-
timeout=max_timeout
|
|
88
|
-
)
|
|
89
|
-
response.raise_for_status()
|
|
90
|
-
|
|
91
|
-
# Return information about the episode
|
|
92
|
-
json_data = response.json()["episodes"][-1]
|
|
93
|
-
return Episode(json_data)
|
|
94
|
-
|
|
95
|
-
except Exception as e:
|
|
96
|
-
logging.error(f"Error fetching episode information: {e}")
|
|
97
|
-
return None
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
# 09.06.24
|
|
2
|
-
|
|
3
|
-
from urllib.parse import quote_plus
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# Internal utilities
|
|
7
|
-
from StreamingCommunity.Util.console import console, msg
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
# Logic class
|
|
11
|
-
from .site import title_search, run_get_select_title, media_search_manager
|
|
12
|
-
from .film import download_film
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Variable
|
|
16
|
-
indice = 9
|
|
17
|
-
_useFor = "film"
|
|
18
|
-
_deprecate = False
|
|
19
|
-
_priority = 2
|
|
20
|
-
_engineDownload = "mp4"
|
|
21
|
-
from .costant import SITE_NAME
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
def search(string_to_search: str = None, get_onylDatabase: bool = False):
|
|
25
|
-
"""
|
|
26
|
-
Main function of the application for film and series.
|
|
27
|
-
"""
|
|
28
|
-
|
|
29
|
-
if string_to_search is None:
|
|
30
|
-
string_to_search = msg.ask(f"\n[purple]Insert word to search in [green]{SITE_NAME}").strip()
|
|
31
|
-
|
|
32
|
-
# Search on database
|
|
33
|
-
len_database = title_search(quote_plus(string_to_search))
|
|
34
|
-
|
|
35
|
-
# Return list of elements
|
|
36
|
-
if get_onylDatabase:
|
|
37
|
-
return media_search_manager
|
|
38
|
-
|
|
39
|
-
if len_database > 0:
|
|
40
|
-
|
|
41
|
-
# Select title from list
|
|
42
|
-
select_title = run_get_select_title()
|
|
43
|
-
|
|
44
|
-
# !!! ADD TYPE DONT WORK FOR SERIE
|
|
45
|
-
download_film(select_title)
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
else:
|
|
49
|
-
console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
|
|
50
|
-
|
|
51
|
-
# Retry
|
|
52
|
-
search()
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
# 03.07.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# Internal utilities
|
|
7
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
SITE_NAME = os.path.basename(os.path.dirname(os.path.abspath(__file__)))
|
|
11
|
-
ROOT_PATH = config_manager.get('DEFAULT', 'root_path')
|
|
12
|
-
DOMAIN_NOW = config_manager.get_dict('SITE', SITE_NAME)['domain']
|
|
13
|
-
|
|
14
|
-
SERIES_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'serie_folder_name'))
|
|
15
|
-
MOVIE_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'movie_folder_name'))
|
|
16
|
-
|
|
17
|
-
if config_manager.get_bool("DEFAULT", "add_siteName"):
|
|
18
|
-
SERIES_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'serie_folder_name'))
|
|
19
|
-
MOVIE_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'movie_folder_name'))
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
# 03.07.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# Internal utilities
|
|
7
|
-
from StreamingCommunity.Util.console import console
|
|
8
|
-
from StreamingCommunity.Util.os import os_manager
|
|
9
|
-
from StreamingCommunity.Util.message import start_message
|
|
10
|
-
from StreamingCommunity.Util.call_stack import get_call_stack
|
|
11
|
-
from StreamingCommunity.Lib.Downloader import HLS_Downloader
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
# Logic class
|
|
15
|
-
from StreamingCommunity.Api.Template.Util import execute_search
|
|
16
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
# Player
|
|
20
|
-
from StreamingCommunity.Api.Player.maxstream import VideoSource
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
# Config
|
|
24
|
-
from .costant import MOVIE_FOLDER
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
def download_film(select_title: MediaItem) -> str:
|
|
28
|
-
"""
|
|
29
|
-
Downloads a film using the provided obj.
|
|
30
|
-
|
|
31
|
-
Parameters:
|
|
32
|
-
- select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
|
|
33
|
-
|
|
34
|
-
Return:
|
|
35
|
-
- str: output path
|
|
36
|
-
"""
|
|
37
|
-
|
|
38
|
-
# Start message and display film information
|
|
39
|
-
start_message()
|
|
40
|
-
console.print(f"[yellow]Download: [red]{select_title.name} \n")
|
|
41
|
-
|
|
42
|
-
# Setup api manger
|
|
43
|
-
print(select_title.url)
|
|
44
|
-
video_source = VideoSource(select_title.url)
|
|
45
|
-
|
|
46
|
-
# Define output path
|
|
47
|
-
title_name = os_manager.get_sanitize_file(select_title.name) +".mp4"
|
|
48
|
-
mp4_path = os_manager.get_sanitize_path(
|
|
49
|
-
os.path.join(MOVIE_FOLDER, title_name.replace(".mp4", ""))
|
|
50
|
-
)
|
|
51
|
-
|
|
52
|
-
# Get m3u8 master playlist
|
|
53
|
-
master_playlist = video_source.get_playlist()
|
|
54
|
-
|
|
55
|
-
# Download the film using the m3u8 playlist, and output filename
|
|
56
|
-
r_proc = HLS_Downloader(
|
|
57
|
-
m3u8_playlist=master_playlist,
|
|
58
|
-
output_filename=os.path.join(mp4_path, title_name)
|
|
59
|
-
).start()
|
|
60
|
-
|
|
61
|
-
"""if r_proc == 404:
|
|
62
|
-
time.sleep(2)
|
|
63
|
-
|
|
64
|
-
# Re call search function
|
|
65
|
-
if msg.ask("[green]Do you want to continue [white]([red]y[white])[green] or return at home[white]([red]n[white]) ", choices=['y', 'n'], default='y', show_choices=True) == "n":
|
|
66
|
-
frames = get_call_stack()
|
|
67
|
-
execute_search(frames[-4])"""
|
|
68
|
-
|
|
69
|
-
if r_proc != None:
|
|
70
|
-
console.print("[green]Result: ")
|
|
71
|
-
console.print(r_proc)
|
|
72
|
-
|
|
73
|
-
return os.path.join(mp4_path, title_name)
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
# 03.07.24
|
|
2
|
-
|
|
3
|
-
# External libraries
|
|
4
|
-
import httpx
|
|
5
|
-
from bs4 import BeautifulSoup
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
# Internal utilities
|
|
9
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
10
|
-
from StreamingCommunity.Util.headers import get_headers
|
|
11
|
-
from StreamingCommunity.Util.table import TVShowManager
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
# Logic class
|
|
15
|
-
from StreamingCommunity.Api.Template import get_select_title
|
|
16
|
-
from StreamingCommunity.Api.Template.Util import search_domain
|
|
17
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
# Variable
|
|
21
|
-
from .costant import SITE_NAME, DOMAIN_NOW
|
|
22
|
-
media_search_manager = MediaManager()
|
|
23
|
-
table_show_manager = TVShowManager()
|
|
24
|
-
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
25
|
-
disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
def title_search(word_to_search: str) -> int:
|
|
29
|
-
"""
|
|
30
|
-
Search for titles based on a search query.
|
|
31
|
-
|
|
32
|
-
Parameters:
|
|
33
|
-
- title_search (str): The title to search for.
|
|
34
|
-
|
|
35
|
-
Returns:
|
|
36
|
-
- int: The number of titles found.
|
|
37
|
-
"""
|
|
38
|
-
media_search_manager.clear()
|
|
39
|
-
table_show_manager.clear()
|
|
40
|
-
|
|
41
|
-
# Find new domain if prev dont work
|
|
42
|
-
domain_to_use = DOMAIN_NOW
|
|
43
|
-
|
|
44
|
-
if not disable_searchDomain:
|
|
45
|
-
domain_to_use, base_url = search_domain(SITE_NAME, f"https://{SITE_NAME}.{DOMAIN_NOW}")
|
|
46
|
-
|
|
47
|
-
response = httpx.get(
|
|
48
|
-
url=f"https://{SITE_NAME}.{domain_to_use}/?s={word_to_search}",
|
|
49
|
-
headers={'user-agent': get_headers()},
|
|
50
|
-
timeout=max_timeout
|
|
51
|
-
)
|
|
52
|
-
response.raise_for_status()
|
|
53
|
-
|
|
54
|
-
# Create soup and find table
|
|
55
|
-
soup = BeautifulSoup(response.text, "html.parser")
|
|
56
|
-
|
|
57
|
-
for div in soup.find_all("div", class_ = "card-content"):
|
|
58
|
-
try:
|
|
59
|
-
|
|
60
|
-
url = div.find("h3").find("a").get("href")
|
|
61
|
-
title = div.find("h3").find("a").get_text(strip=True)
|
|
62
|
-
desc = div.find("p").find("strong").text
|
|
63
|
-
|
|
64
|
-
title_info = {
|
|
65
|
-
'name': title,
|
|
66
|
-
'desc': desc,
|
|
67
|
-
'url': url
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
media_search_manager.add_media(title_info)
|
|
71
|
-
|
|
72
|
-
except Exception as e:
|
|
73
|
-
print(f"Error parsing a film entry: {e}")
|
|
74
|
-
|
|
75
|
-
# Return the number of titles found
|
|
76
|
-
return media_search_manager.get_length()
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
def run_get_select_title():
|
|
80
|
-
"""
|
|
81
|
-
Display a selection of titles and prompt the user to choose one.
|
|
82
|
-
"""
|
|
83
|
-
return get_select_title(table_show_manager, media_search_manager)
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
# 09.06.24
|
|
2
|
-
|
|
3
|
-
import logging
|
|
4
|
-
from urllib.parse import quote_plus
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
# Internal utilities
|
|
8
|
-
from StreamingCommunity.Util.console import console, msg
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
# Logic class
|
|
12
|
-
from .site import title_search, run_get_select_title, media_search_manager
|
|
13
|
-
from .series import download_thread
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
# Variable
|
|
17
|
-
indice = 3
|
|
18
|
-
_useFor = "serie"
|
|
19
|
-
_deprecate = False
|
|
20
|
-
_priority = 2
|
|
21
|
-
_engineDownload = "mp4"
|
|
22
|
-
from .costant import SITE_NAME
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
def search(string_to_search: str = None, get_onylDatabase: bool = False):
|
|
26
|
-
"""
|
|
27
|
-
Main function of the application for film and series.
|
|
28
|
-
"""
|
|
29
|
-
|
|
30
|
-
if string_to_search is None:
|
|
31
|
-
string_to_search = msg.ask(f"\n[purple]Insert word to search in [green]{SITE_NAME}").strip()
|
|
32
|
-
|
|
33
|
-
# Search on database
|
|
34
|
-
len_database = title_search(quote_plus(string_to_search))
|
|
35
|
-
|
|
36
|
-
# Return list of elements
|
|
37
|
-
if get_onylDatabase:
|
|
38
|
-
return media_search_manager
|
|
39
|
-
|
|
40
|
-
if len_database > 0:
|
|
41
|
-
|
|
42
|
-
# Select title from list
|
|
43
|
-
select_title = run_get_select_title()
|
|
44
|
-
|
|
45
|
-
# Download only film
|
|
46
|
-
if "Serie TV" in str(select_title.type):
|
|
47
|
-
download_thread(select_title)
|
|
48
|
-
|
|
49
|
-
else:
|
|
50
|
-
logging.error(f"Not supported: {select_title.type}")
|
|
51
|
-
|
|
52
|
-
else:
|
|
53
|
-
console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
|
|
54
|
-
|
|
55
|
-
# Retry
|
|
56
|
-
search()
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
# 09.06.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# Internal utilities
|
|
7
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
SITE_NAME = os.path.basename(os.path.dirname(os.path.abspath(__file__)))
|
|
11
|
-
ROOT_PATH = config_manager.get('DEFAULT', 'root_path')
|
|
12
|
-
DOMAIN_NOW = config_manager.get_dict('SITE', SITE_NAME)['domain']
|
|
13
|
-
COOKIE = config_manager.get_dict('SITE', SITE_NAME)['extra']
|
|
14
|
-
|
|
15
|
-
SERIES_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'serie_folder_name'))
|
|
16
|
-
MOVIE_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'movie_folder_name'))
|
|
17
|
-
|
|
18
|
-
if config_manager.get_bool("DEFAULT", "add_siteName"):
|
|
19
|
-
SERIES_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'serie_folder_name'))
|
|
20
|
-
MOVIE_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'movie_folder_name'))
|
|
@@ -1,146 +0,0 @@
|
|
|
1
|
-
# 13.06.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
import sys
|
|
5
|
-
from urllib.parse import urlparse
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
# Internal utilities
|
|
9
|
-
from StreamingCommunity.Util.console import console
|
|
10
|
-
from StreamingCommunity.Util.message import start_message
|
|
11
|
-
from StreamingCommunity.Util.os import os_manager
|
|
12
|
-
from StreamingCommunity.Util.table import TVShowManager
|
|
13
|
-
from StreamingCommunity.Lib.Downloader import MP4_downloader
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
# Logic class
|
|
17
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
|
|
18
|
-
from StreamingCommunity.Api.Template.Util import manage_selection, map_episode_title, validate_episode_selection
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
# Player
|
|
22
|
-
from .util.ScrapeSerie import GetSerieInfo
|
|
23
|
-
from StreamingCommunity.Api.Player.ddl import VideoSource
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
# Variable
|
|
27
|
-
from .costant import SERIES_FOLDER
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
def download_video(index_episode_selected: int, scape_info_serie: GetSerieInfo, video_source: VideoSource) -> str:
|
|
32
|
-
"""
|
|
33
|
-
Download a single episode video.
|
|
34
|
-
|
|
35
|
-
Parameters:
|
|
36
|
-
- tv_name (str): Name of the TV series.
|
|
37
|
-
- index_episode_selected (int): Index of the selected episode.
|
|
38
|
-
|
|
39
|
-
Return:
|
|
40
|
-
- str: output path
|
|
41
|
-
"""
|
|
42
|
-
|
|
43
|
-
start_message()
|
|
44
|
-
|
|
45
|
-
# Get info about episode
|
|
46
|
-
obj_episode = scape_info_serie.list_episodes[index_episode_selected - 1]
|
|
47
|
-
console.print(f"[yellow]Download: [red]{obj_episode.get('name')}")
|
|
48
|
-
print()
|
|
49
|
-
|
|
50
|
-
# Define filename and path for the downloaded video
|
|
51
|
-
title_name = os_manager.get_sanitize_file(
|
|
52
|
-
f"{map_episode_title(scape_info_serie.tv_name, None, index_episode_selected, obj_episode.get('name'))}.mp4"
|
|
53
|
-
)
|
|
54
|
-
mp4_path = os.path.join(SERIES_FOLDER, scape_info_serie.tv_name)
|
|
55
|
-
|
|
56
|
-
# Create output folder
|
|
57
|
-
os_manager.create_path(mp4_path)
|
|
58
|
-
|
|
59
|
-
# Setup video source
|
|
60
|
-
video_source.setup(obj_episode.get('url'))
|
|
61
|
-
|
|
62
|
-
# Get m3u8 master playlist
|
|
63
|
-
master_playlist = video_source.get_playlist()
|
|
64
|
-
|
|
65
|
-
# Parse start page url
|
|
66
|
-
parsed_url = urlparse(obj_episode.get('url'))
|
|
67
|
-
|
|
68
|
-
# Start download
|
|
69
|
-
r_proc = MP4_downloader(
|
|
70
|
-
url=master_playlist,
|
|
71
|
-
path=os.path.join(mp4_path, title_name),
|
|
72
|
-
referer=f"{parsed_url.scheme}://{parsed_url.netloc}/",
|
|
73
|
-
)
|
|
74
|
-
|
|
75
|
-
if r_proc != None:
|
|
76
|
-
console.print("[green]Result: ")
|
|
77
|
-
console.print(r_proc)
|
|
78
|
-
|
|
79
|
-
return os.path.join(mp4_path, title_name)
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
def download_thread(dict_serie: MediaItem):
|
|
83
|
-
"""
|
|
84
|
-
Download all episode of a thread
|
|
85
|
-
"""
|
|
86
|
-
|
|
87
|
-
# Start message and set up video source
|
|
88
|
-
start_message()
|
|
89
|
-
|
|
90
|
-
# Init class
|
|
91
|
-
scape_info_serie = GetSerieInfo(dict_serie)
|
|
92
|
-
video_source = VideoSource()
|
|
93
|
-
|
|
94
|
-
# Collect information about thread
|
|
95
|
-
list_dict_episode = scape_info_serie.get_episode_number()
|
|
96
|
-
episodes_count = len(list_dict_episode)
|
|
97
|
-
|
|
98
|
-
# Display episodes list and manage user selection
|
|
99
|
-
last_command = display_episodes_list(scape_info_serie.list_episodes)
|
|
100
|
-
list_episode_select = manage_selection(last_command, episodes_count)
|
|
101
|
-
|
|
102
|
-
try:
|
|
103
|
-
list_episode_select = validate_episode_selection(list_episode_select, episodes_count)
|
|
104
|
-
except ValueError as e:
|
|
105
|
-
console.print(f"[red]{str(e)}")
|
|
106
|
-
return
|
|
107
|
-
|
|
108
|
-
# Download selected episodes
|
|
109
|
-
for i_episode in list_episode_select:
|
|
110
|
-
download_video(i_episode, scape_info_serie, video_source)
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
def display_episodes_list(obj_episode_manager) -> str:
|
|
114
|
-
"""
|
|
115
|
-
Display episodes list and handle user input.
|
|
116
|
-
|
|
117
|
-
Returns:
|
|
118
|
-
last_command (str): Last command entered by the user.
|
|
119
|
-
"""
|
|
120
|
-
|
|
121
|
-
# Set up table for displaying episodes
|
|
122
|
-
table_show_manager = TVShowManager()
|
|
123
|
-
table_show_manager.set_slice_end(10)
|
|
124
|
-
|
|
125
|
-
# Add columns to the table
|
|
126
|
-
column_info = {
|
|
127
|
-
"Index": {'color': 'red'},
|
|
128
|
-
"Name": {'color': 'magenta'},
|
|
129
|
-
}
|
|
130
|
-
table_show_manager.add_column(column_info)
|
|
131
|
-
|
|
132
|
-
# Populate the table with episodes information
|
|
133
|
-
for i, media in enumerate(obj_episode_manager):
|
|
134
|
-
table_show_manager.add_tv_show({
|
|
135
|
-
'Index': str(i+1),
|
|
136
|
-
'Name': media.get('name'),
|
|
137
|
-
})
|
|
138
|
-
|
|
139
|
-
# Run the table and handle user input
|
|
140
|
-
last_command = table_show_manager.run()
|
|
141
|
-
|
|
142
|
-
if last_command == "q":
|
|
143
|
-
console.print("\n[red]Quit [white]...")
|
|
144
|
-
sys.exit(0)
|
|
145
|
-
|
|
146
|
-
return last_command
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
# 09.06.24
|
|
2
|
-
|
|
3
|
-
import logging
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# External libraries
|
|
7
|
-
import httpx
|
|
8
|
-
from bs4 import BeautifulSoup
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
# Internal utilities
|
|
12
|
-
from StreamingCommunity.Util.console import console
|
|
13
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
14
|
-
from StreamingCommunity.Util.headers import get_headers
|
|
15
|
-
from StreamingCommunity.Util.table import TVShowManager
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
# Logic class
|
|
19
|
-
from StreamingCommunity.Api.Template import get_select_title
|
|
20
|
-
from StreamingCommunity.Api.Template.Util import search_domain
|
|
21
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
# Variable
|
|
25
|
-
from .costant import SITE_NAME, DOMAIN_NOW
|
|
26
|
-
media_search_manager = MediaManager()
|
|
27
|
-
table_show_manager = TVShowManager()
|
|
28
|
-
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
29
|
-
disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
def title_search(word_to_search: str) -> int:
|
|
33
|
-
"""
|
|
34
|
-
Search for titles based on a search query.
|
|
35
|
-
|
|
36
|
-
Parameters:
|
|
37
|
-
- title_search (str): The title to search for.
|
|
38
|
-
|
|
39
|
-
Returns:
|
|
40
|
-
- int: The number of titles found.
|
|
41
|
-
"""
|
|
42
|
-
media_search_manager.clear()
|
|
43
|
-
table_show_manager.clear()
|
|
44
|
-
|
|
45
|
-
# Find new domain if prev dont work
|
|
46
|
-
domain_to_use = DOMAIN_NOW
|
|
47
|
-
|
|
48
|
-
if not disable_searchDomain:
|
|
49
|
-
domain_to_use, base_url = search_domain(SITE_NAME, f"https://{SITE_NAME}.{DOMAIN_NOW}")
|
|
50
|
-
|
|
51
|
-
# Send request to search for titles
|
|
52
|
-
try:
|
|
53
|
-
response = httpx.get(
|
|
54
|
-
url=f"https://{SITE_NAME}.{domain_to_use}/search/?&q={word_to_search}&quick=1&type=videobox_video&nodes=11",
|
|
55
|
-
headers={'user-agent': get_headers()},
|
|
56
|
-
timeout=max_timeout
|
|
57
|
-
)
|
|
58
|
-
response.raise_for_status()
|
|
59
|
-
|
|
60
|
-
except Exception as e:
|
|
61
|
-
console.print(f"Site: {SITE_NAME}, request search error: {e}")
|
|
62
|
-
|
|
63
|
-
# Create soup and find table
|
|
64
|
-
soup = BeautifulSoup(response.text, "html.parser")
|
|
65
|
-
table_content = soup.find('ol', class_="ipsStream")
|
|
66
|
-
|
|
67
|
-
if table_content:
|
|
68
|
-
for title_div in table_content.find_all('li', class_='ipsStreamItem'):
|
|
69
|
-
try:
|
|
70
|
-
|
|
71
|
-
title_type = title_div.find("p", class_="ipsType_reset").find_all("a")[-1].get_text(strip=True)
|
|
72
|
-
name = title_div.find("span", class_="ipsContained").find("a").get_text(strip=True)
|
|
73
|
-
link = title_div.find("span", class_="ipsContained").find("a").get("href")
|
|
74
|
-
|
|
75
|
-
title_info = {
|
|
76
|
-
'name': name,
|
|
77
|
-
'url': link,
|
|
78
|
-
'type': title_type
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
media_search_manager.add_media(title_info)
|
|
82
|
-
|
|
83
|
-
except Exception as e:
|
|
84
|
-
print(f"Error parsing a film entry: {e}")
|
|
85
|
-
|
|
86
|
-
return media_search_manager.get_length()
|
|
87
|
-
|
|
88
|
-
else:
|
|
89
|
-
logging.error("No table content found.")
|
|
90
|
-
return -999
|
|
91
|
-
|
|
92
|
-
return -9999
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
def run_get_select_title():
|
|
96
|
-
"""
|
|
97
|
-
Display a selection of titles and prompt the user to choose one.
|
|
98
|
-
"""
|
|
99
|
-
return get_select_title(table_show_manager, media_search_manager)
|