StreamingCommunity 1.7.6__py3-none-any.whl → 1.9.1__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/{Src/Api → Api}/Player/Helper/Vixcloud/js_parser.py +4 -1
- StreamingCommunity/{Src/Api → Api}/Player/Helper/Vixcloud/util.py +166 -166
- StreamingCommunity/{Src/Api → Api}/Player/ddl.py +89 -89
- StreamingCommunity/{Src/Api → Api}/Player/maxstream.py +151 -151
- StreamingCommunity/{Src/Api → Api}/Player/supervideo.py +193 -193
- StreamingCommunity/{Src/Api → Api}/Player/vixcloud.py +224 -212
- StreamingCommunity/{Src/Api → Api}/Site/1337xx/__init__.py +50 -50
- StreamingCommunity/{Src/Api → Api}/Site/1337xx/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/1337xx/site.py +83 -83
- StreamingCommunity/{Src/Api → Api}/Site/1337xx/title.py +66 -66
- StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/__init__.py +50 -50
- StreamingCommunity/{Src/Api/Site/mostraguarda → Api/Site/altadefinizione}/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/film.py +69 -69
- StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/site.py +86 -86
- StreamingCommunity/{Src/Api → Api}/Site/animeunity/__init__.py +50 -50
- StreamingCommunity/{Src/Api/Site/altadefinizione → Api/Site/animeunity}/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/animeunity/film_serie.py +130 -131
- StreamingCommunity/{Src/Api → Api}/Site/animeunity/site.py +164 -164
- StreamingCommunity/{Src/Api → Api}/Site/animeunity/util/ScrapeSerie.py +3 -3
- StreamingCommunity/{Src/Api → Api}/Site/bitsearch/__init__.py +51 -51
- StreamingCommunity/{Src/Api → Api}/Site/bitsearch/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/bitsearch/site.py +84 -84
- StreamingCommunity/{Src/Api → Api}/Site/bitsearch/title.py +47 -47
- StreamingCommunity/{Src/Api → Api}/Site/cb01new/__init__.py +51 -51
- StreamingCommunity/{Src/Api → Api}/Site/cb01new/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/cb01new/film.py +69 -69
- StreamingCommunity/{Src/Api → Api}/Site/cb01new/site.py +74 -74
- StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/__init__.py +57 -57
- StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/costant.py +16 -16
- StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/series.py +141 -142
- StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/site.py +92 -92
- StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/util/ScrapeSerie.py +84 -82
- StreamingCommunity/{Src/Api → Api}/Site/guardaserie/__init__.py +52 -52
- StreamingCommunity/{Src/Api/Site/piratebays → Api/Site/guardaserie}/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/guardaserie/series.py +195 -195
- StreamingCommunity/{Src/Api → Api}/Site/guardaserie/site.py +84 -84
- StreamingCommunity/{Src/Api → Api}/Site/guardaserie/util/ScrapeSerie.py +110 -110
- StreamingCommunity/{Src/Api → Api}/Site/mostraguarda/__init__.py +48 -48
- StreamingCommunity/{Src/Api/Site/animeunity → Api/Site/mostraguarda}/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/mostraguarda/film.py +94 -94
- StreamingCommunity/{Src/Api → Api}/Site/piratebays/__init__.py +50 -50
- StreamingCommunity/{Src/Api/Site/guardaserie → Api/Site/piratebays}/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/piratebays/site.py +88 -88
- StreamingCommunity/{Src/Api → Api}/Site/piratebays/title.py +45 -45
- StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/__init__.py +55 -55
- StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/costant.py +15 -15
- StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/film.py +70 -70
- StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/series.py +205 -203
- StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/site.py +125 -125
- StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/util/ScrapeSerie.py +3 -3
- StreamingCommunity/{Src/Api → Api}/Template/Class/SearchType.py +101 -101
- StreamingCommunity/{Src/Api → Api}/Template/Util/__init__.py +4 -4
- StreamingCommunity/{Src/Api → Api}/Template/Util/get_domain.py +137 -137
- StreamingCommunity/{Src/Api → Api}/Template/Util/manage_ep.py +153 -153
- StreamingCommunity/{Src/Api → Api}/Template/Util/recall_search.py +37 -37
- StreamingCommunity/Api/Template/__init__.py +3 -0
- StreamingCommunity/{Src/Api → Api}/Template/site.py +87 -87
- StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/downloader.py +968 -968
- StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/proxyes.py +110 -110
- StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/segments.py +538 -540
- StreamingCommunity/{Src/Lib → Lib}/Downloader/MP4/downloader.py +156 -156
- StreamingCommunity/{Src/Lib → Lib}/Downloader/TOR/downloader.py +222 -222
- StreamingCommunity/{Src/Lib → Lib}/Downloader/__init__.py +4 -4
- StreamingCommunity/{Src/Lib → Lib}/Driver/driver_1.py +76 -76
- StreamingCommunity/{Src/Lib → Lib}/FFmpeg/__init__.py +4 -4
- StreamingCommunity/{Src/Lib → Lib}/FFmpeg/capture.py +170 -170
- StreamingCommunity/{Src/Lib → Lib}/FFmpeg/command.py +292 -292
- StreamingCommunity/{Src/Lib → Lib}/FFmpeg/util.py +241 -241
- StreamingCommunity/{Src/Lib → Lib}/M3U8/__init__.py +5 -5
- StreamingCommunity/{Src/Lib → Lib}/M3U8/decryptor.py +164 -129
- StreamingCommunity/{Src/Lib → Lib}/M3U8/estimator.py +175 -172
- StreamingCommunity/{Src/Lib → Lib}/M3U8/parser.py +666 -666
- StreamingCommunity/{Src/Lib → Lib}/M3U8/url_fixer.py +51 -51
- StreamingCommunity/Lib/TMBD/__init__.py +2 -0
- StreamingCommunity/{Src/Lib → Lib}/TMBD/obj_tmbd.py +39 -39
- StreamingCommunity/{Src/Lib → Lib}/TMBD/tmdb.py +345 -345
- StreamingCommunity/{Src/Upload → Upload}/update.py +68 -64
- StreamingCommunity/{Src/Upload → Upload}/version.py +5 -5
- StreamingCommunity/{Src/Util → Util}/_jsonConfig.py +204 -204
- StreamingCommunity/{Src/Util → Util}/call_stack.py +42 -42
- StreamingCommunity/{Src/Util → Util}/color.py +20 -20
- StreamingCommunity/{Src/Util → Util}/console.py +12 -12
- StreamingCommunity/Util/ffmpeg_installer.py +275 -0
- StreamingCommunity/{Src/Util → Util}/headers.py +147 -147
- StreamingCommunity/{Src/Util → Util}/logger.py +53 -53
- StreamingCommunity/{Src/Util → Util}/message.py +46 -46
- StreamingCommunity/{Src/Util → Util}/os.py +514 -417
- StreamingCommunity/{Src/Util → Util}/table.py +163 -163
- StreamingCommunity/run.py +202 -196
- {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/METADATA +126 -60
- StreamingCommunity-1.9.1.dist-info/RECORD +95 -0
- {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/WHEEL +1 -1
- StreamingCommunity/Src/Api/Site/animeunity/anime.py +0 -126
- StreamingCommunity/Src/Api/Site/ddlstreamitaly/Player/ScrapeSerie.py +0 -83
- StreamingCommunity/Src/Api/Site/guardaserie/Player/ScrapeSerie.py +0 -110
- StreamingCommunity/Src/Api/Template/__init__.py +0 -3
- StreamingCommunity/Src/Lib/TMBD/__init__.py +0 -2
- StreamingCommunity-1.7.6.dist-info/RECORD +0 -97
- {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/LICENSE +0 -0
- {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/entry_points.txt +0 -0
- {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/top_level.txt +0 -0
|
@@ -1,94 +1,94 @@
|
|
|
1
|
-
# 17.09.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
import sys
|
|
5
|
-
import time
|
|
6
|
-
import logging
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
# External libraries
|
|
10
|
-
import httpx
|
|
11
|
-
from bs4 import BeautifulSoup
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
# Internal utilities
|
|
15
|
-
from StreamingCommunity.
|
|
16
|
-
from StreamingCommunity.
|
|
17
|
-
from StreamingCommunity.
|
|
18
|
-
from StreamingCommunity.
|
|
19
|
-
from StreamingCommunity.
|
|
20
|
-
from StreamingCommunity.
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
# Logic class
|
|
24
|
-
from StreamingCommunity.
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
# Player
|
|
28
|
-
from StreamingCommunity.
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
# TMBD
|
|
32
|
-
from StreamingCommunity.
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
# Config
|
|
36
|
-
from .costant import ROOT_PATH, SITE_NAME, DOMAIN_NOW, MOVIE_FOLDER
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
def download_film(movie_details: Json_film):
|
|
40
|
-
"""
|
|
41
|
-
Downloads a film using the provided tmbd id.
|
|
42
|
-
|
|
43
|
-
Parameters:
|
|
44
|
-
- movie_details (Json_film): Class with info about film title.
|
|
45
|
-
"""
|
|
46
|
-
|
|
47
|
-
# Start message and display film information
|
|
48
|
-
start_message()
|
|
49
|
-
console.print(f"[yellow]Download: [red]{movie_details.title} \n")
|
|
50
|
-
|
|
51
|
-
# Make request to main site
|
|
52
|
-
try:
|
|
53
|
-
url = f"https://{SITE_NAME}.{DOMAIN_NOW}/set-movie-a/{movie_details.imdb_id}"
|
|
54
|
-
response = httpx.get(url, headers={'User-Agent': get_headers()})
|
|
55
|
-
response.raise_for_status()
|
|
56
|
-
|
|
57
|
-
except:
|
|
58
|
-
logging.error(f"Not found in the server. Dict: {movie_details}")
|
|
59
|
-
raise
|
|
60
|
-
|
|
61
|
-
# Extract supervideo url
|
|
62
|
-
soup = BeautifulSoup(response.text, "html.parser")
|
|
63
|
-
player_links = soup.find("ul", class_ = "_player-mirrors").find_all("li")
|
|
64
|
-
supervideo_url = "https:" + player_links[0].get("data-link")
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
# Set domain and media ID for the video source
|
|
68
|
-
video_source = VideoSource()
|
|
69
|
-
video_source.setup(supervideo_url)
|
|
70
|
-
|
|
71
|
-
# Define output path
|
|
72
|
-
title_name = os_manager.get_sanitize_file(movie_details.title) + ".mp4"
|
|
73
|
-
mp4_path = os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
|
|
74
|
-
|
|
75
|
-
# Get m3u8 master playlist
|
|
76
|
-
master_playlist = video_source.get_playlist()
|
|
77
|
-
|
|
78
|
-
# Download the film using the m3u8 playlist, and output filename
|
|
79
|
-
r_proc = HLS_Downloader(
|
|
80
|
-
m3u8_playlist=master_playlist,
|
|
81
|
-
output_filename=os.path.join(mp4_path, title_name)
|
|
82
|
-
).start()
|
|
83
|
-
|
|
84
|
-
if r_proc == 404:
|
|
85
|
-
time.sleep(2)
|
|
86
|
-
|
|
87
|
-
# Re call search function
|
|
88
|
-
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":
|
|
89
|
-
frames = get_call_stack()
|
|
90
|
-
execute_search(frames[-4])
|
|
91
|
-
|
|
92
|
-
if r_proc != None:
|
|
93
|
-
console.print("[green]Result: ")
|
|
94
|
-
console.print(r_proc)
|
|
1
|
+
# 17.09.24
|
|
2
|
+
|
|
3
|
+
import os
|
|
4
|
+
import sys
|
|
5
|
+
import time
|
|
6
|
+
import logging
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
# External libraries
|
|
10
|
+
import httpx
|
|
11
|
+
from bs4 import BeautifulSoup
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
# Internal utilities
|
|
15
|
+
from StreamingCommunity.Util.console import console, msg
|
|
16
|
+
from StreamingCommunity.Util.os import os_manager
|
|
17
|
+
from StreamingCommunity.Util.message import start_message
|
|
18
|
+
from StreamingCommunity.Util.call_stack import get_call_stack
|
|
19
|
+
from StreamingCommunity.Util.headers import get_headers
|
|
20
|
+
from StreamingCommunity.Lib.Downloader import HLS_Downloader
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
# Logic class
|
|
24
|
+
from StreamingCommunity.Api.Template.Util import execute_search
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
# Player
|
|
28
|
+
from StreamingCommunity.Api.Player.supervideo import VideoSource
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
# TMBD
|
|
32
|
+
from StreamingCommunity.Lib.TMBD import Json_film
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
# Config
|
|
36
|
+
from .costant import ROOT_PATH, SITE_NAME, DOMAIN_NOW, MOVIE_FOLDER
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
def download_film(movie_details: Json_film):
|
|
40
|
+
"""
|
|
41
|
+
Downloads a film using the provided tmbd id.
|
|
42
|
+
|
|
43
|
+
Parameters:
|
|
44
|
+
- movie_details (Json_film): Class with info about film title.
|
|
45
|
+
"""
|
|
46
|
+
|
|
47
|
+
# Start message and display film information
|
|
48
|
+
start_message()
|
|
49
|
+
console.print(f"[yellow]Download: [red]{movie_details.title} \n")
|
|
50
|
+
|
|
51
|
+
# Make request to main site
|
|
52
|
+
try:
|
|
53
|
+
url = f"https://{SITE_NAME}.{DOMAIN_NOW}/set-movie-a/{movie_details.imdb_id}"
|
|
54
|
+
response = httpx.get(url, headers={'User-Agent': get_headers()})
|
|
55
|
+
response.raise_for_status()
|
|
56
|
+
|
|
57
|
+
except:
|
|
58
|
+
logging.error(f"Not found in the server. Dict: {movie_details}")
|
|
59
|
+
raise
|
|
60
|
+
|
|
61
|
+
# Extract supervideo url
|
|
62
|
+
soup = BeautifulSoup(response.text, "html.parser")
|
|
63
|
+
player_links = soup.find("ul", class_ = "_player-mirrors").find_all("li")
|
|
64
|
+
supervideo_url = "https:" + player_links[0].get("data-link")
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
# Set domain and media ID for the video source
|
|
68
|
+
video_source = VideoSource()
|
|
69
|
+
video_source.setup(supervideo_url)
|
|
70
|
+
|
|
71
|
+
# Define output path
|
|
72
|
+
title_name = os_manager.get_sanitize_file(movie_details.title) + ".mp4"
|
|
73
|
+
mp4_path = os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
|
|
74
|
+
|
|
75
|
+
# Get m3u8 master playlist
|
|
76
|
+
master_playlist = video_source.get_playlist()
|
|
77
|
+
|
|
78
|
+
# Download the film using the m3u8 playlist, and output filename
|
|
79
|
+
r_proc = HLS_Downloader(
|
|
80
|
+
m3u8_playlist=master_playlist,
|
|
81
|
+
output_filename=os.path.join(mp4_path, title_name)
|
|
82
|
+
).start()
|
|
83
|
+
|
|
84
|
+
if r_proc == 404:
|
|
85
|
+
time.sleep(2)
|
|
86
|
+
|
|
87
|
+
# Re call search function
|
|
88
|
+
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":
|
|
89
|
+
frames = get_call_stack()
|
|
90
|
+
execute_search(frames[-4])
|
|
91
|
+
|
|
92
|
+
if r_proc != None:
|
|
93
|
+
console.print("[green]Result: ")
|
|
94
|
+
console.print(r_proc)
|
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
# 02.07.24
|
|
2
|
-
|
|
3
|
-
from unidecode import unidecode
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# Internal utilities
|
|
7
|
-
from StreamingCommunity.
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
# Logic class
|
|
11
|
-
from .site import title_search, run_get_select_title, media_search_manager
|
|
12
|
-
from .title import download_title
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Variable
|
|
16
|
-
indice = 8
|
|
17
|
-
_useFor = "film_serie"
|
|
18
|
-
_deprecate = False
|
|
19
|
-
_priority = 2
|
|
20
|
-
_engineDownload = "tor"
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
def search(string_to_search: str = None, get_onylDatabase: bool = False):
|
|
24
|
-
"""
|
|
25
|
-
Main function of the application for film and series.
|
|
26
|
-
"""
|
|
27
|
-
|
|
28
|
-
if string_to_search is None:
|
|
29
|
-
string_to_search = msg.ask("\n[purple]Insert word to search in all site").strip()
|
|
30
|
-
|
|
31
|
-
# Search on database
|
|
32
|
-
len_database = title_search(unidecode(string_to_search))
|
|
33
|
-
|
|
34
|
-
# Return list of elements
|
|
35
|
-
if get_onylDatabase:
|
|
36
|
-
return media_search_manager
|
|
37
|
-
|
|
38
|
-
if len_database > 0:
|
|
39
|
-
|
|
40
|
-
# Select title from list
|
|
41
|
-
select_title = run_get_select_title()
|
|
42
|
-
|
|
43
|
-
# Download title
|
|
44
|
-
download_title(select_title)
|
|
45
|
-
|
|
46
|
-
else:
|
|
47
|
-
console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
|
|
48
|
-
|
|
49
|
-
# Retry
|
|
50
|
-
search()
|
|
1
|
+
# 02.07.24
|
|
2
|
+
|
|
3
|
+
from unidecode import unidecode
|
|
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 .title import download_title
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
# Variable
|
|
16
|
+
indice = 8
|
|
17
|
+
_useFor = "film_serie"
|
|
18
|
+
_deprecate = False
|
|
19
|
+
_priority = 2
|
|
20
|
+
_engineDownload = "tor"
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
def search(string_to_search: str = None, get_onylDatabase: bool = False):
|
|
24
|
+
"""
|
|
25
|
+
Main function of the application for film and series.
|
|
26
|
+
"""
|
|
27
|
+
|
|
28
|
+
if string_to_search is None:
|
|
29
|
+
string_to_search = msg.ask("\n[purple]Insert word to search in all site").strip()
|
|
30
|
+
|
|
31
|
+
# Search on database
|
|
32
|
+
len_database = title_search(unidecode(string_to_search))
|
|
33
|
+
|
|
34
|
+
# Return list of elements
|
|
35
|
+
if get_onylDatabase:
|
|
36
|
+
return media_search_manager
|
|
37
|
+
|
|
38
|
+
if len_database > 0:
|
|
39
|
+
|
|
40
|
+
# Select title from list
|
|
41
|
+
select_title = run_get_select_title()
|
|
42
|
+
|
|
43
|
+
# Download title
|
|
44
|
+
download_title(select_title)
|
|
45
|
+
|
|
46
|
+
else:
|
|
47
|
+
console.print(f"\n[red]Nothing matching was found for[white]: [purple]{string_to_search}")
|
|
48
|
+
|
|
49
|
+
# Retry
|
|
50
|
+
search()
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
# 09.06.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
# Internal utilities
|
|
7
|
-
from StreamingCommunity.
|
|
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 =
|
|
15
|
-
MOVIE_FOLDER =
|
|
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
|
+
|
|
14
|
+
SERIES_FOLDER = config_manager.get('DEFAULT', 'serie_folder_name')
|
|
15
|
+
MOVIE_FOLDER = config_manager.get('DEFAULT', 'movie_folder_name')
|
|
@@ -1,89 +1,89 @@
|
|
|
1
|
-
# 02.07.24
|
|
2
|
-
|
|
3
|
-
# External libraries
|
|
4
|
-
import httpx
|
|
5
|
-
from bs4 import BeautifulSoup
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
# Internal utilities
|
|
9
|
-
from StreamingCommunity.
|
|
10
|
-
from StreamingCommunity.
|
|
11
|
-
from StreamingCommunity.
|
|
12
|
-
from StreamingCommunity.
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
# Logic class
|
|
16
|
-
from StreamingCommunity.
|
|
17
|
-
from StreamingCommunity.
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
# Variable
|
|
21
|
-
from .costant import SITE_NAME, DOMAIN_NOW
|
|
22
|
-
media_search_manager = MediaManager()
|
|
23
|
-
table_show_manager = TVShowManager()
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
def title_search(word_to_search: str) -> int:
|
|
27
|
-
"""
|
|
28
|
-
Search for titles based on a search query.
|
|
29
|
-
|
|
30
|
-
Parameters:
|
|
31
|
-
- title_search (str): The title to search for.
|
|
32
|
-
|
|
33
|
-
Returns:
|
|
34
|
-
- int: The number of titles found.
|
|
35
|
-
"""
|
|
36
|
-
|
|
37
|
-
# Find new domain if prev dont work
|
|
38
|
-
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
39
|
-
|
|
40
|
-
# Construct the full site URL and load the search page
|
|
41
|
-
try:
|
|
42
|
-
response = httpx.get(
|
|
43
|
-
url=f"https://1.{SITE_NAME}.{DOMAIN_NOW}/s/?q={word_to_search}&video=on",
|
|
44
|
-
headers={
|
|
45
|
-
'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
|
46
|
-
'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
|
|
47
|
-
'referer': 'https://wwv.thepiratebay3.co/',
|
|
48
|
-
'user-agent': get_headers()
|
|
49
|
-
},
|
|
50
|
-
follow_redirects=True,
|
|
51
|
-
timeout=max_timeout
|
|
52
|
-
)
|
|
53
|
-
response.raise_for_status()
|
|
54
|
-
|
|
55
|
-
except Exception as e:
|
|
56
|
-
console.print(f"Site: {SITE_NAME}, request search error: {e}")
|
|
57
|
-
|
|
58
|
-
# Create soup and find table
|
|
59
|
-
soup = BeautifulSoup(response.text, "html.parser")
|
|
60
|
-
table = soup.find("tbody")
|
|
61
|
-
|
|
62
|
-
# Scrape div film in table on single page
|
|
63
|
-
for tr in table.find_all('tr'):
|
|
64
|
-
try:
|
|
65
|
-
|
|
66
|
-
title_info = {
|
|
67
|
-
'name': tr.find_all("a")[1].get_text(strip=True),
|
|
68
|
-
'url': tr.find_all("td")[3].find("a").get("href"),
|
|
69
|
-
'upload': tr.find_all("td")[2].get_text(strip=True),
|
|
70
|
-
'size': tr.find_all("td")[4].get_text(strip=True),
|
|
71
|
-
'seader': tr.find_all("td")[5].get_text(strip=True),
|
|
72
|
-
'leacher': tr.find_all("td")[6].get_text(strip=True),
|
|
73
|
-
'by': tr.find_all("td")[7].get_text(strip=True),
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
media_search_manager.add_media(title_info)
|
|
77
|
-
|
|
78
|
-
except:
|
|
79
|
-
continue
|
|
80
|
-
|
|
81
|
-
# Return the number of titles found
|
|
82
|
-
return media_search_manager.get_length()
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
def run_get_select_title():
|
|
86
|
-
"""
|
|
87
|
-
Display a selection of titles and prompt the user to choose one.
|
|
88
|
-
"""
|
|
1
|
+
# 02.07.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.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
|
+
|
|
25
|
+
|
|
26
|
+
def title_search(word_to_search: str) -> int:
|
|
27
|
+
"""
|
|
28
|
+
Search for titles based on a search query.
|
|
29
|
+
|
|
30
|
+
Parameters:
|
|
31
|
+
- title_search (str): The title to search for.
|
|
32
|
+
|
|
33
|
+
Returns:
|
|
34
|
+
- int: The number of titles found.
|
|
35
|
+
"""
|
|
36
|
+
|
|
37
|
+
# Find new domain if prev dont work
|
|
38
|
+
max_timeout = config_manager.get_int("REQUESTS", "timeout")
|
|
39
|
+
|
|
40
|
+
# Construct the full site URL and load the search page
|
|
41
|
+
try:
|
|
42
|
+
response = httpx.get(
|
|
43
|
+
url=f"https://1.{SITE_NAME}.{DOMAIN_NOW}/s/?q={word_to_search}&video=on",
|
|
44
|
+
headers={
|
|
45
|
+
'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
|
|
46
|
+
'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
|
|
47
|
+
'referer': 'https://wwv.thepiratebay3.co/',
|
|
48
|
+
'user-agent': get_headers()
|
|
49
|
+
},
|
|
50
|
+
follow_redirects=True,
|
|
51
|
+
timeout=max_timeout
|
|
52
|
+
)
|
|
53
|
+
response.raise_for_status()
|
|
54
|
+
|
|
55
|
+
except Exception as e:
|
|
56
|
+
console.print(f"Site: {SITE_NAME}, request search error: {e}")
|
|
57
|
+
|
|
58
|
+
# Create soup and find table
|
|
59
|
+
soup = BeautifulSoup(response.text, "html.parser")
|
|
60
|
+
table = soup.find("tbody")
|
|
61
|
+
|
|
62
|
+
# Scrape div film in table on single page
|
|
63
|
+
for tr in table.find_all('tr'):
|
|
64
|
+
try:
|
|
65
|
+
|
|
66
|
+
title_info = {
|
|
67
|
+
'name': tr.find_all("a")[1].get_text(strip=True),
|
|
68
|
+
'url': tr.find_all("td")[3].find("a").get("href"),
|
|
69
|
+
'upload': tr.find_all("td")[2].get_text(strip=True),
|
|
70
|
+
'size': tr.find_all("td")[4].get_text(strip=True),
|
|
71
|
+
'seader': tr.find_all("td")[5].get_text(strip=True),
|
|
72
|
+
'leacher': tr.find_all("td")[6].get_text(strip=True),
|
|
73
|
+
'by': tr.find_all("td")[7].get_text(strip=True),
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
media_search_manager.add_media(title_info)
|
|
77
|
+
|
|
78
|
+
except:
|
|
79
|
+
continue
|
|
80
|
+
|
|
81
|
+
# Return the number of titles found
|
|
82
|
+
return media_search_manager.get_length()
|
|
83
|
+
|
|
84
|
+
|
|
85
|
+
def run_get_select_title():
|
|
86
|
+
"""
|
|
87
|
+
Display a selection of titles and prompt the user to choose one.
|
|
88
|
+
"""
|
|
89
89
|
return get_select_title(table_show_manager, media_search_manager)
|
|
@@ -1,45 +1,45 @@
|
|
|
1
|
-
# 02.07.24
|
|
2
|
-
|
|
3
|
-
import os
|
|
4
|
-
import sys
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
# Internal utilities
|
|
8
|
-
from StreamingCommunity.
|
|
9
|
-
from StreamingCommunity.
|
|
10
|
-
from StreamingCommunity.
|
|
11
|
-
from StreamingCommunity.
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
# Logic class
|
|
15
|
-
from StreamingCommunity.
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
# Config
|
|
19
|
-
from .costant import ROOT_PATH, DOMAIN_NOW, SITE_NAME, MOVIE_FOLDER
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
def download_title(select_title: MediaItem):
|
|
23
|
-
"""
|
|
24
|
-
Downloads a media item and saves it as an MP4 file.
|
|
25
|
-
|
|
26
|
-
Parameters:
|
|
27
|
-
- select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
|
|
28
|
-
"""
|
|
29
|
-
|
|
30
|
-
start_message()
|
|
31
|
-
console.print(f"[yellow]Download: [red]{select_title.name} \n")
|
|
32
|
-
print()
|
|
33
|
-
|
|
34
|
-
# Define output path
|
|
35
|
-
title_name = os_manager.get_sanitize_file(select_title.name.replace("-", "_") + ".mp4")
|
|
36
|
-
mp4_path = os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
|
|
37
|
-
|
|
38
|
-
# Create output folder
|
|
39
|
-
os_manager.create_path(mp4_path)
|
|
40
|
-
|
|
41
|
-
# Tor manager
|
|
42
|
-
manager = TOR_downloader()
|
|
43
|
-
manager.add_magnet_link(select_title.url)
|
|
44
|
-
manager.start_download()
|
|
45
|
-
manager.move_downloaded_files(mp4_path)
|
|
1
|
+
# 02.07.24
|
|
2
|
+
|
|
3
|
+
import os
|
|
4
|
+
import sys
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
# Internal utilities
|
|
8
|
+
from StreamingCommunity.Util.console import console
|
|
9
|
+
from StreamingCommunity.Util.message import start_message
|
|
10
|
+
from StreamingCommunity.Util.os import os_manager
|
|
11
|
+
from StreamingCommunity.Lib.Downloader import TOR_downloader
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
# Logic class
|
|
15
|
+
from StreamingCommunity.Api.Template.Class.SearchType import MediaItem
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
# Config
|
|
19
|
+
from .costant import ROOT_PATH, DOMAIN_NOW, SITE_NAME, MOVIE_FOLDER
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
def download_title(select_title: MediaItem):
|
|
23
|
+
"""
|
|
24
|
+
Downloads a media item and saves it as an MP4 file.
|
|
25
|
+
|
|
26
|
+
Parameters:
|
|
27
|
+
- select_title (MediaItem): The media item to be downloaded. This should be an instance of the MediaItem class, containing attributes like `name` and `url`.
|
|
28
|
+
"""
|
|
29
|
+
|
|
30
|
+
start_message()
|
|
31
|
+
console.print(f"[yellow]Download: [red]{select_title.name} \n")
|
|
32
|
+
print()
|
|
33
|
+
|
|
34
|
+
# Define output path
|
|
35
|
+
title_name = os_manager.get_sanitize_file(select_title.name.replace("-", "_") + ".mp4")
|
|
36
|
+
mp4_path = os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
|
|
37
|
+
|
|
38
|
+
# Create output folder
|
|
39
|
+
os_manager.create_path(mp4_path)
|
|
40
|
+
|
|
41
|
+
# Tor manager
|
|
42
|
+
manager = TOR_downloader()
|
|
43
|
+
manager.add_magnet_link(select_title.url)
|
|
44
|
+
manager.start_download()
|
|
45
|
+
manager.move_downloaded_files(mp4_path)
|