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,51 +0,0 @@
|
|
|
1
|
-
# 26.05.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 = 2
|
|
17
|
-
_useFor = "film"
|
|
18
|
-
_deprecate = False
|
|
19
|
-
_priority = 2
|
|
20
|
-
_engineDownload = "hls"
|
|
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
|
-
# Download only film
|
|
45
|
-
download_film(select_title)
|
|
46
|
-
|
|
47
|
-
else:
|
|
48
|
-
console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
|
|
49
|
-
|
|
50
|
-
# Retry
|
|
51
|
-
search()
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
# 26.05.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,74 +0,0 @@
|
|
|
1
|
-
# 26.05.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
import time
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
# Internal utilities
|
|
8
|
-
from StreamingCommunity.Util.console import console, msg
|
|
9
|
-
from StreamingCommunity.Util.os import os_manager
|
|
10
|
-
from StreamingCommunity.Util.message import start_message
|
|
11
|
-
from StreamingCommunity.Util.call_stack import get_call_stack
|
|
12
|
-
from StreamingCommunity.Lib.Downloader import HLS_Downloader
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Logic class
|
|
16
|
-
from StreamingCommunity.Api.Template.Util import execute_search
|
|
17
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
# Player
|
|
21
|
-
from StreamingCommunity.Api.Player.supervideo import VideoSource
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
# Config
|
|
25
|
-
from .costant import MOVIE_FOLDER
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
def download_film(select_title: MediaItem) -> str:
|
|
29
|
-
"""
|
|
30
|
-
Downloads a film using the provided film ID, title name, and domain.
|
|
31
|
-
|
|
32
|
-
Parameters:
|
|
33
|
-
- title_name (str): The name of the film title.
|
|
34
|
-
- url (str): The url of the video
|
|
35
|
-
|
|
36
|
-
Return:
|
|
37
|
-
- str: output path
|
|
38
|
-
"""
|
|
39
|
-
|
|
40
|
-
# Start message and display film information
|
|
41
|
-
start_message()
|
|
42
|
-
console.print(f"[yellow]Download: [red]{select_title.name} \n")
|
|
43
|
-
|
|
44
|
-
# Set domain and media ID for the video source
|
|
45
|
-
video_source = VideoSource(select_title.url)
|
|
46
|
-
|
|
47
|
-
# Define output path
|
|
48
|
-
title_name = os_manager.get_sanitize_file(select_title.name) + ".mp4"
|
|
49
|
-
mp4_path = os_manager.get_sanitize_path(
|
|
50
|
-
os.path.join(MOVIE_FOLDER, title_name.replace(".mp4", ""))
|
|
51
|
-
)
|
|
52
|
-
|
|
53
|
-
# Get m3u8 master playlist
|
|
54
|
-
master_playlist = video_source.get_playlist()
|
|
55
|
-
|
|
56
|
-
# Download the film using the m3u8 playlist, and output filename
|
|
57
|
-
r_proc = HLS_Downloader(
|
|
58
|
-
m3u8_playlist=master_playlist,
|
|
59
|
-
output_filename=os.path.join(mp4_path, title_name)
|
|
60
|
-
).start()
|
|
61
|
-
|
|
62
|
-
"""if r_proc == 404:
|
|
63
|
-
time.sleep(2)
|
|
64
|
-
|
|
65
|
-
# Re call search function
|
|
66
|
-
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":
|
|
67
|
-
frames = get_call_stack()
|
|
68
|
-
execute_search(frames[-4])"""
|
|
69
|
-
|
|
70
|
-
if r_proc != None:
|
|
71
|
-
console.print("[green]Result: ")
|
|
72
|
-
console.print(r_proc)
|
|
73
|
-
|
|
74
|
-
return os.path.join(mp4_path, title_name)
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
# 26.05.24
|
|
2
|
-
|
|
3
|
-
# External libraries
|
|
4
|
-
import httpx
|
|
5
|
-
from bs4 import BeautifulSoup
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
# Internal utilities
|
|
9
|
-
from StreamingCommunity.Util.console import console
|
|
10
|
-
from StreamingCommunity.Util._jsonConfig import config_manager
|
|
11
|
-
from StreamingCommunity.Util.headers import get_headers
|
|
12
|
-
from StreamingCommunity.Util.table import TVShowManager
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Logic class
|
|
16
|
-
from StreamingCommunity.Api.Template import get_select_title
|
|
17
|
-
from StreamingCommunity.Api.Template.Util import search_domain
|
|
18
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
# Variable
|
|
22
|
-
from .costant import SITE_NAME, DOMAIN_NOW
|
|
23
|
-
media_search_manager = MediaManager()
|
|
24
|
-
table_show_manager = TVShowManager()
|
|
25
|
-
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
26
|
-
disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
def title_search(title_search: str) -> int:
|
|
30
|
-
"""
|
|
31
|
-
Search for titles based on a search query.
|
|
32
|
-
|
|
33
|
-
Parameters:
|
|
34
|
-
- title_search (str): The title to search for.
|
|
35
|
-
|
|
36
|
-
Returns:
|
|
37
|
-
int: The number of titles found.
|
|
38
|
-
"""
|
|
39
|
-
media_search_manager.clear()
|
|
40
|
-
table_show_manager.clear()
|
|
41
|
-
|
|
42
|
-
# Find new domain if prev dont work
|
|
43
|
-
domain_to_use = DOMAIN_NOW
|
|
44
|
-
|
|
45
|
-
if not disable_searchDomain:
|
|
46
|
-
domain_to_use, base_url = search_domain(SITE_NAME, f"https://{SITE_NAME}.{DOMAIN_NOW}")
|
|
47
|
-
|
|
48
|
-
# Send request to search for title
|
|
49
|
-
client = httpx.Client()
|
|
50
|
-
|
|
51
|
-
try:
|
|
52
|
-
response = client.get(
|
|
53
|
-
url=f"https://{SITE_NAME}.{domain_to_use}/?story={title_search.replace(' ', '+')}&do=search&subaction=search&titleonly=3",
|
|
54
|
-
headers={'User-Agent': get_headers()},
|
|
55
|
-
timeout=max_timeout
|
|
56
|
-
)
|
|
57
|
-
response.raise_for_status()
|
|
58
|
-
|
|
59
|
-
except Exception as e:
|
|
60
|
-
console.print(f"Site: {SITE_NAME}, request search error: {e}")
|
|
61
|
-
raise
|
|
62
|
-
|
|
63
|
-
# Create soup and find table
|
|
64
|
-
soup = BeautifulSoup(response.text, "html.parser")
|
|
65
|
-
|
|
66
|
-
for row in soup.find_all('div', class_='col-lg-3 col-md-3 col-xs-4'):
|
|
67
|
-
try:
|
|
68
|
-
|
|
69
|
-
title_element = row.find('h2', class_='titleFilm').find('a')
|
|
70
|
-
title = title_element.get_text(strip=True)
|
|
71
|
-
link = title_element['href']
|
|
72
|
-
|
|
73
|
-
imdb_element = row.find('div', class_='imdb-rate')
|
|
74
|
-
imdb_rating = imdb_element.get_text(strip=True).split(":")[-1]
|
|
75
|
-
|
|
76
|
-
film_info = {
|
|
77
|
-
'name': title,
|
|
78
|
-
'url': link,
|
|
79
|
-
'score': imdb_rating
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
media_search_manager.add_media(film_info)
|
|
83
|
-
|
|
84
|
-
except AttributeError as e:
|
|
85
|
-
print(f"Error parsing a film entry: {e}")
|
|
86
|
-
|
|
87
|
-
# Return the number of titles found
|
|
88
|
-
return media_search_manager.get_length()
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
def run_get_select_title():
|
|
92
|
-
"""
|
|
93
|
-
Display a selection of titles and prompt the user to choose one.
|
|
94
|
-
"""
|
|
95
|
-
return get_select_title(table_show_manager, media_search_manager)
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
# 21.05.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_serie import download_film, download_series
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Variable
|
|
16
|
-
indice = 1
|
|
17
|
-
_useFor = "anime"
|
|
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
|
-
if string_to_search is None:
|
|
27
|
-
string_to_search = msg.ask(f"\n[purple]Insert word to search in [green]{SITE_NAME}").strip()
|
|
28
|
-
|
|
29
|
-
# Search on database
|
|
30
|
-
len_database = title_search(string_to_search)
|
|
31
|
-
|
|
32
|
-
# Return list of elements
|
|
33
|
-
if get_onylDatabase:
|
|
34
|
-
return media_search_manager
|
|
35
|
-
|
|
36
|
-
if len_database > 0:
|
|
37
|
-
|
|
38
|
-
# Select title from list (type: TV \ Movie \ OVA)
|
|
39
|
-
select_title = run_get_select_title()
|
|
40
|
-
|
|
41
|
-
if select_title.type == 'Movie' or select_title.type == 'OVA':
|
|
42
|
-
download_film(select_title)
|
|
43
|
-
|
|
44
|
-
else:
|
|
45
|
-
download_series(select_title)
|
|
46
|
-
|
|
47
|
-
else:
|
|
48
|
-
console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
|
|
49
|
-
|
|
50
|
-
# Retry
|
|
51
|
-
search()
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
# 26.05.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
|
-
MOVIE_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'movie_folder_name'))
|
|
15
|
-
ANIME_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'anime_folder_name'))
|
|
16
|
-
|
|
17
|
-
if config_manager.get_bool("DEFAULT", "add_siteName"):
|
|
18
|
-
MOVIE_FOLDER = os.path.join(ROOT_PATH, SITE_NAME, config_manager.get('DEFAULT', 'movie_folder_name'))
|
|
19
|
-
ANIME_FOLDER = os.path.join(ROOT_PATH, config_manager.get('DEFAULT', 'anime_folder_name'))
|
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
# 11.03.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
import sys
|
|
5
|
-
import logging
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
# Internal utilities
|
|
9
|
-
from StreamingCommunity.Util.console import console, msg
|
|
10
|
-
from StreamingCommunity.Util.os import os_manager
|
|
11
|
-
from StreamingCommunity.Util.message import start_message
|
|
12
|
-
from StreamingCommunity.Lib.Downloader import MP4_downloader
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Logic class
|
|
16
|
-
from .util.ScrapeSerie import ScrapeSerieAnime
|
|
17
|
-
from StreamingCommunity.Api.Template.Util import manage_selection
|
|
18
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
# Player
|
|
22
|
-
from StreamingCommunity.Api.Player.vixcloud import VideoSourceAnime
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
# Variable
|
|
26
|
-
from .costant import SITE_NAME, ANIME_FOLDER, MOVIE_FOLDER
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
def download_episode(index_select: int, scrape_serie: ScrapeSerieAnime, video_source: VideoSourceAnime) -> str:
|
|
31
|
-
"""
|
|
32
|
-
Downloads the selected episode.
|
|
33
|
-
|
|
34
|
-
Parameters:
|
|
35
|
-
- index_select (int): Index of the episode to download.
|
|
36
|
-
|
|
37
|
-
Return:
|
|
38
|
-
- str: output path
|
|
39
|
-
"""
|
|
40
|
-
|
|
41
|
-
# Get information about the selected episode
|
|
42
|
-
obj_episode = scrape_serie.get_info_episode(index_select)
|
|
43
|
-
|
|
44
|
-
if obj_episode is not None:
|
|
45
|
-
|
|
46
|
-
start_message()
|
|
47
|
-
console.print(f"[yellow]Download: [red]EP_{obj_episode.number} \n")
|
|
48
|
-
|
|
49
|
-
# Collect mp4 url
|
|
50
|
-
video_source.get_embed(obj_episode.id)
|
|
51
|
-
|
|
52
|
-
# Create output path
|
|
53
|
-
title_name = f"{obj_episode.number}.mp4"
|
|
54
|
-
|
|
55
|
-
if scrape_serie.is_series:
|
|
56
|
-
mp4_path = os_manager.get_sanitize_path(
|
|
57
|
-
os.path.join(ANIME_FOLDER, scrape_serie.series_name)
|
|
58
|
-
)
|
|
59
|
-
else:
|
|
60
|
-
mp4_path = os_manager.get_sanitize_path(
|
|
61
|
-
os.path.join(MOVIE_FOLDER, scrape_serie.series_name)
|
|
62
|
-
)
|
|
63
|
-
|
|
64
|
-
# Create output folder
|
|
65
|
-
os_manager.create_path(mp4_path)
|
|
66
|
-
|
|
67
|
-
# Start downloading
|
|
68
|
-
r_proc = MP4_downloader(
|
|
69
|
-
url=str(video_source.src_mp4).strip(),
|
|
70
|
-
path=os.path.join(mp4_path, title_name)
|
|
71
|
-
)
|
|
72
|
-
|
|
73
|
-
if r_proc != None:
|
|
74
|
-
console.print("[green]Result: ")
|
|
75
|
-
console.print(r_proc)
|
|
76
|
-
|
|
77
|
-
return os.path.join(mp4_path, title_name)
|
|
78
|
-
|
|
79
|
-
else:
|
|
80
|
-
logging.error(f"Skip index: {index_select} cant find info with api.")
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
def download_series(select_title: MediaItem):
|
|
84
|
-
"""
|
|
85
|
-
Function to download episodes of a TV series.
|
|
86
|
-
|
|
87
|
-
Parameters:
|
|
88
|
-
- tv_id (int): The ID of the TV series.
|
|
89
|
-
- tv_name (str): The name of the TV series.
|
|
90
|
-
"""
|
|
91
|
-
scrape_serie = ScrapeSerieAnime(SITE_NAME)
|
|
92
|
-
video_source = VideoSourceAnime(SITE_NAME)
|
|
93
|
-
|
|
94
|
-
# Set up video source
|
|
95
|
-
scrape_serie.setup(None, select_title.id, select_title.slug)
|
|
96
|
-
|
|
97
|
-
# Get the count of episodes for the TV series
|
|
98
|
-
episoded_count = scrape_serie.get_count_episodes()
|
|
99
|
-
console.print(f"[cyan]Episodes find: [red]{episoded_count}")
|
|
100
|
-
|
|
101
|
-
# Prompt user to select an episode index
|
|
102
|
-
last_command = msg.ask("\n[cyan]Insert media [red]index [yellow]or [red](*) [cyan]to download all media [yellow]or [red][1-2] [cyan]or [red][3-*] [cyan]for a range of media")
|
|
103
|
-
|
|
104
|
-
# Manage user selection
|
|
105
|
-
list_episode_select = manage_selection(last_command, episoded_count)
|
|
106
|
-
|
|
107
|
-
# Download selected episodes
|
|
108
|
-
if len(list_episode_select) == 1 and last_command != "*":
|
|
109
|
-
download_episode(list_episode_select[0]-1, scrape_serie, video_source)
|
|
110
|
-
|
|
111
|
-
# Download all other episodes selecter
|
|
112
|
-
else:
|
|
113
|
-
for i_episode in list_episode_select:
|
|
114
|
-
download_episode(i_episode-1, scrape_serie, video_source)
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
def download_film(select_title: MediaItem):
|
|
118
|
-
"""
|
|
119
|
-
Function to download a film.
|
|
120
|
-
|
|
121
|
-
Parameters:
|
|
122
|
-
- id_film (int): The ID of the film.
|
|
123
|
-
- title_name (str): The title of the film.
|
|
124
|
-
"""
|
|
125
|
-
|
|
126
|
-
# Init class
|
|
127
|
-
scrape_serie = ScrapeSerieAnime(SITE_NAME)
|
|
128
|
-
video_source = VideoSourceAnime(SITE_NAME)
|
|
129
|
-
|
|
130
|
-
# Set up video source
|
|
131
|
-
scrape_serie.setup(None, select_title.id, select_title.slug)
|
|
132
|
-
scrape_serie.is_series = False
|
|
133
|
-
|
|
134
|
-
# Start download
|
|
135
|
-
download_episode(0, scrape_serie, video_source)
|
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
# 10.12.23
|
|
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.table import TVShowManager
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
# Logic class
|
|
18
|
-
from StreamingCommunity.Api.Template import get_select_title
|
|
19
|
-
from StreamingCommunity.Api.Template.Util import search_domain
|
|
20
|
-
from StreamingCommunity.Api.Template.Class.SearchType import MediaManager
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
# Variable
|
|
24
|
-
from .costant import SITE_NAME, DOMAIN_NOW
|
|
25
|
-
media_search_manager = MediaManager()
|
|
26
|
-
table_show_manager = TVShowManager()
|
|
27
|
-
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
28
|
-
disable_searchDomain = config_manager.get_bool("DEFAULT", "disable_searchDomain")
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
def get_token(site_name: str, domain: str) -> dict:
|
|
32
|
-
"""
|
|
33
|
-
Function to retrieve session tokens from a specified website.
|
|
34
|
-
|
|
35
|
-
Parameters:
|
|
36
|
-
- site_name (str): The name of the site.
|
|
37
|
-
- domain (str): The domain of the site.
|
|
38
|
-
|
|
39
|
-
Returns:
|
|
40
|
-
- dict: A dictionary containing session tokens. The keys are 'XSRF_TOKEN', 'animeunity_session', and 'csrf_token'.
|
|
41
|
-
"""
|
|
42
|
-
|
|
43
|
-
# Send a GET request to the specified URL composed of the site name and domain
|
|
44
|
-
response = httpx.get(
|
|
45
|
-
url=f"https://www.{site_name}.{domain}",
|
|
46
|
-
timeout=max_timeout
|
|
47
|
-
)
|
|
48
|
-
response.raise_for_status()
|
|
49
|
-
|
|
50
|
-
# Initialize variables to store CSRF token
|
|
51
|
-
find_csrf_token = None
|
|
52
|
-
|
|
53
|
-
# Parse the HTML response using BeautifulSoup
|
|
54
|
-
soup = BeautifulSoup(response.text, "html.parser")
|
|
55
|
-
|
|
56
|
-
# Loop through all meta tags in the HTML response
|
|
57
|
-
for html_meta in soup.find_all("meta"):
|
|
58
|
-
|
|
59
|
-
# Check if the meta tag has a 'name' attribute equal to "csrf-token"
|
|
60
|
-
if html_meta.get('name') == "csrf-token":
|
|
61
|
-
|
|
62
|
-
# If found, retrieve the content of the meta tag, which is the CSRF token
|
|
63
|
-
find_csrf_token = html_meta.get('content')
|
|
64
|
-
|
|
65
|
-
logging.info(f"Extract: ('animeunity_session': {response.cookies['animeunity_session']}, 'csrf_token': {find_csrf_token})")
|
|
66
|
-
return {
|
|
67
|
-
'animeunity_session': response.cookies['animeunity_session'],
|
|
68
|
-
'csrf_token': find_csrf_token
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
def get_real_title(record):
|
|
73
|
-
"""
|
|
74
|
-
Get the real title from a record.
|
|
75
|
-
|
|
76
|
-
This function takes a record, which is assumed to be a dictionary representing a row of JSON data.
|
|
77
|
-
It looks for a title in the record, prioritizing English over Italian titles if available.
|
|
78
|
-
|
|
79
|
-
Parameters:
|
|
80
|
-
- record (dict): A dictionary representing a row of JSON data.
|
|
81
|
-
|
|
82
|
-
Returns:
|
|
83
|
-
- str: The title found in the record. If no title is found, returns None.
|
|
84
|
-
"""
|
|
85
|
-
|
|
86
|
-
if record['title'] is not None:
|
|
87
|
-
return record['title']
|
|
88
|
-
|
|
89
|
-
elif record['title_eng'] is not None:
|
|
90
|
-
return record['title_eng']
|
|
91
|
-
|
|
92
|
-
else:
|
|
93
|
-
return record['title_it']
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
def title_search(title: str) -> int:
|
|
97
|
-
"""
|
|
98
|
-
Function to perform an anime search using a provided title.
|
|
99
|
-
|
|
100
|
-
Parameters:
|
|
101
|
-
- title_search (str): The title to search for.
|
|
102
|
-
|
|
103
|
-
Returns:
|
|
104
|
-
- int: A number containing the length of media search manager.
|
|
105
|
-
"""
|
|
106
|
-
media_search_manager.clear()
|
|
107
|
-
table_show_manager.clear()
|
|
108
|
-
|
|
109
|
-
# Get token and session value from configuration
|
|
110
|
-
domain_to_use = DOMAIN_NOW
|
|
111
|
-
|
|
112
|
-
if not disable_searchDomain:
|
|
113
|
-
domain_to_use, base_url = search_domain(SITE_NAME, f"https://www.{SITE_NAME}.{DOMAIN_NOW}")
|
|
114
|
-
|
|
115
|
-
data = get_token(SITE_NAME, domain_to_use)
|
|
116
|
-
|
|
117
|
-
# Prepare cookies to be used in the request
|
|
118
|
-
cookies = {
|
|
119
|
-
'animeunity_session': data.get('animeunity_session')
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
# Prepare headers for the request
|
|
123
|
-
headers = {
|
|
124
|
-
'accept': 'application/json, text/plain, */*',
|
|
125
|
-
'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
|
|
126
|
-
'content-type': 'application/json;charset=UTF-8',
|
|
127
|
-
'x-csrf-token': data.get('csrf_token')
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
# Prepare JSON data to be sent in the request
|
|
131
|
-
json_data = {
|
|
132
|
-
'title': title
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
# Send a POST request to the API endpoint for live search
|
|
136
|
-
try:
|
|
137
|
-
response = httpx.post(
|
|
138
|
-
url=f'https://www.{SITE_NAME}.{domain_to_use}/livesearch',
|
|
139
|
-
cookies=cookies,
|
|
140
|
-
headers=headers,
|
|
141
|
-
json=json_data,
|
|
142
|
-
timeout=max_timeout
|
|
143
|
-
)
|
|
144
|
-
response.raise_for_status()
|
|
145
|
-
|
|
146
|
-
except Exception as e:
|
|
147
|
-
console.print(f"Site: {SITE_NAME}, request search error: {e}")
|
|
148
|
-
|
|
149
|
-
for dict_title in response.json()['records']:
|
|
150
|
-
try:
|
|
151
|
-
|
|
152
|
-
# Rename keys for consistency
|
|
153
|
-
dict_title['name'] = get_real_title(dict_title)
|
|
154
|
-
|
|
155
|
-
media_search_manager.add_media({
|
|
156
|
-
'id': dict_title.get('id'),
|
|
157
|
-
'slug': dict_title.get('slug'),
|
|
158
|
-
'name': dict_title.get('name'),
|
|
159
|
-
'type': dict_title.get('type'),
|
|
160
|
-
'score': dict_title.get('score'),
|
|
161
|
-
'episodes_count': dict_title.get('episodes_count')
|
|
162
|
-
})
|
|
163
|
-
|
|
164
|
-
except Exception as e:
|
|
165
|
-
print(f"Error parsing a film entry: {e}")
|
|
166
|
-
|
|
167
|
-
# Return the length of media search manager
|
|
168
|
-
return media_search_manager.get_length()
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
def run_get_select_title():
|
|
172
|
-
"""
|
|
173
|
-
Display a selection of titles and prompt the user to choose one.
|
|
174
|
-
"""
|
|
175
|
-
return get_select_title(table_show_manager, media_search_manager)
|