StreamingCommunity 1.8.0__py3-none-any.whl → 1.9.2__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.

Files changed (98) hide show
  1. StreamingCommunity/run.py +18 -13
  2. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/METADATA +157 -63
  3. StreamingCommunity-1.9.2.dist-info/RECORD +7 -0
  4. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/WHEEL +1 -1
  5. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/entry_points.txt +1 -0
  6. StreamingCommunity/Src/Api/Player/Helper/Vixcloud/js_parser.py +0 -143
  7. StreamingCommunity/Src/Api/Player/Helper/Vixcloud/util.py +0 -166
  8. StreamingCommunity/Src/Api/Player/ddl.py +0 -89
  9. StreamingCommunity/Src/Api/Player/maxstream.py +0 -151
  10. StreamingCommunity/Src/Api/Player/supervideo.py +0 -194
  11. StreamingCommunity/Src/Api/Player/vixcloud.py +0 -224
  12. StreamingCommunity/Src/Api/Site/1337xx/__init__.py +0 -50
  13. StreamingCommunity/Src/Api/Site/1337xx/costant.py +0 -15
  14. StreamingCommunity/Src/Api/Site/1337xx/site.py +0 -84
  15. StreamingCommunity/Src/Api/Site/1337xx/title.py +0 -66
  16. StreamingCommunity/Src/Api/Site/altadefinizione/__init__.py +0 -50
  17. StreamingCommunity/Src/Api/Site/altadefinizione/costant.py +0 -15
  18. StreamingCommunity/Src/Api/Site/altadefinizione/film.py +0 -69
  19. StreamingCommunity/Src/Api/Site/altadefinizione/site.py +0 -86
  20. StreamingCommunity/Src/Api/Site/animeunity/__init__.py +0 -50
  21. StreamingCommunity/Src/Api/Site/animeunity/anime.py +0 -126
  22. StreamingCommunity/Src/Api/Site/animeunity/costant.py +0 -15
  23. StreamingCommunity/Src/Api/Site/animeunity/film_serie.py +0 -131
  24. StreamingCommunity/Src/Api/Site/animeunity/site.py +0 -165
  25. StreamingCommunity/Src/Api/Site/animeunity/util/ScrapeSerie.py +0 -97
  26. StreamingCommunity/Src/Api/Site/bitsearch/__init__.py +0 -51
  27. StreamingCommunity/Src/Api/Site/bitsearch/costant.py +0 -15
  28. StreamingCommunity/Src/Api/Site/bitsearch/site.py +0 -84
  29. StreamingCommunity/Src/Api/Site/bitsearch/title.py +0 -47
  30. StreamingCommunity/Src/Api/Site/cb01new/__init__.py +0 -51
  31. StreamingCommunity/Src/Api/Site/cb01new/costant.py +0 -15
  32. StreamingCommunity/Src/Api/Site/cb01new/film.py +0 -69
  33. StreamingCommunity/Src/Api/Site/cb01new/site.py +0 -74
  34. StreamingCommunity/Src/Api/Site/ddlstreamitaly/Player/ScrapeSerie.py +0 -83
  35. StreamingCommunity/Src/Api/Site/ddlstreamitaly/__init__.py +0 -57
  36. StreamingCommunity/Src/Api/Site/ddlstreamitaly/costant.py +0 -16
  37. StreamingCommunity/Src/Api/Site/ddlstreamitaly/series.py +0 -142
  38. StreamingCommunity/Src/Api/Site/ddlstreamitaly/site.py +0 -93
  39. StreamingCommunity/Src/Api/Site/ddlstreamitaly/util/ScrapeSerie.py +0 -83
  40. StreamingCommunity/Src/Api/Site/guardaserie/Player/ScrapeSerie.py +0 -110
  41. StreamingCommunity/Src/Api/Site/guardaserie/__init__.py +0 -52
  42. StreamingCommunity/Src/Api/Site/guardaserie/costant.py +0 -15
  43. StreamingCommunity/Src/Api/Site/guardaserie/series.py +0 -195
  44. StreamingCommunity/Src/Api/Site/guardaserie/site.py +0 -84
  45. StreamingCommunity/Src/Api/Site/guardaserie/util/ScrapeSerie.py +0 -110
  46. StreamingCommunity/Src/Api/Site/mostraguarda/__init__.py +0 -48
  47. StreamingCommunity/Src/Api/Site/mostraguarda/costant.py +0 -15
  48. StreamingCommunity/Src/Api/Site/mostraguarda/film.py +0 -94
  49. StreamingCommunity/Src/Api/Site/piratebays/__init__.py +0 -50
  50. StreamingCommunity/Src/Api/Site/piratebays/costant.py +0 -15
  51. StreamingCommunity/Src/Api/Site/piratebays/site.py +0 -89
  52. StreamingCommunity/Src/Api/Site/piratebays/title.py +0 -45
  53. StreamingCommunity/Src/Api/Site/streamingcommunity/__init__.py +0 -55
  54. StreamingCommunity/Src/Api/Site/streamingcommunity/costant.py +0 -15
  55. StreamingCommunity/Src/Api/Site/streamingcommunity/film.py +0 -70
  56. StreamingCommunity/Src/Api/Site/streamingcommunity/series.py +0 -203
  57. StreamingCommunity/Src/Api/Site/streamingcommunity/site.py +0 -126
  58. StreamingCommunity/Src/Api/Site/streamingcommunity/util/ScrapeSerie.py +0 -113
  59. StreamingCommunity/Src/Api/Template/Class/SearchType.py +0 -101
  60. StreamingCommunity/Src/Api/Template/Util/__init__.py +0 -5
  61. StreamingCommunity/Src/Api/Template/Util/get_domain.py +0 -137
  62. StreamingCommunity/Src/Api/Template/Util/manage_ep.py +0 -153
  63. StreamingCommunity/Src/Api/Template/Util/recall_search.py +0 -37
  64. StreamingCommunity/Src/Api/Template/__init__.py +0 -3
  65. StreamingCommunity/Src/Api/Template/site.py +0 -87
  66. StreamingCommunity/Src/Lib/Downloader/HLS/downloader.py +0 -968
  67. StreamingCommunity/Src/Lib/Downloader/HLS/proxyes.py +0 -110
  68. StreamingCommunity/Src/Lib/Downloader/HLS/segments.py +0 -540
  69. StreamingCommunity/Src/Lib/Downloader/MP4/downloader.py +0 -156
  70. StreamingCommunity/Src/Lib/Downloader/TOR/downloader.py +0 -222
  71. StreamingCommunity/Src/Lib/Downloader/__init__.py +0 -5
  72. StreamingCommunity/Src/Lib/Driver/driver_1.py +0 -76
  73. StreamingCommunity/Src/Lib/FFmpeg/__init__.py +0 -4
  74. StreamingCommunity/Src/Lib/FFmpeg/capture.py +0 -170
  75. StreamingCommunity/Src/Lib/FFmpeg/command.py +0 -292
  76. StreamingCommunity/Src/Lib/FFmpeg/util.py +0 -242
  77. StreamingCommunity/Src/Lib/M3U8/__init__.py +0 -6
  78. StreamingCommunity/Src/Lib/M3U8/decryptor.py +0 -129
  79. StreamingCommunity/Src/Lib/M3U8/estimator.py +0 -173
  80. StreamingCommunity/Src/Lib/M3U8/parser.py +0 -666
  81. StreamingCommunity/Src/Lib/M3U8/url_fixer.py +0 -52
  82. StreamingCommunity/Src/Lib/TMBD/__init__.py +0 -2
  83. StreamingCommunity/Src/Lib/TMBD/obj_tmbd.py +0 -39
  84. StreamingCommunity/Src/Lib/TMBD/tmdb.py +0 -346
  85. StreamingCommunity/Src/Upload/update.py +0 -64
  86. StreamingCommunity/Src/Upload/version.py +0 -5
  87. StreamingCommunity/Src/Util/_jsonConfig.py +0 -204
  88. StreamingCommunity/Src/Util/call_stack.py +0 -42
  89. StreamingCommunity/Src/Util/color.py +0 -20
  90. StreamingCommunity/Src/Util/console.py +0 -12
  91. StreamingCommunity/Src/Util/headers.py +0 -147
  92. StreamingCommunity/Src/Util/logger.py +0 -53
  93. StreamingCommunity/Src/Util/message.py +0 -46
  94. StreamingCommunity/Src/Util/os.py +0 -417
  95. StreamingCommunity/Src/Util/table.py +0 -163
  96. StreamingCommunity-1.8.0.dist-info/RECORD +0 -97
  97. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/LICENSE +0 -0
  98. {StreamingCommunity-1.8.0.dist-info → StreamingCommunity-1.9.2.dist-info}/top_level.txt +0 -0
@@ -1,224 +0,0 @@
1
- # 01.03.24
2
-
3
- import sys
4
- import logging
5
- from urllib.parse import urlparse, parse_qs, urlencode, urlunparse
6
-
7
-
8
- # External libraries
9
- import httpx
10
- from bs4 import BeautifulSoup
11
-
12
-
13
- # Internal utilities
14
- from StreamingCommunity.Src.Util.headers import get_headers
15
- from StreamingCommunity.Src.Util.console import console, Panel
16
- from StreamingCommunity.Src.Util._jsonConfig import config_manager
17
- from .Helper.Vixcloud.util import WindowVideo, WindowParameter, StreamsCollection
18
- from .Helper.Vixcloud.js_parser import JavaScriptParser
19
-
20
-
21
- # Variable
22
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
23
-
24
-
25
- class VideoSource:
26
- def __init__(self, site_name: str, is_series: bool):
27
- """
28
- Initialize video source for streaming site.
29
-
30
- Args:
31
- site_name (str): Name of streaming site
32
- is_series (bool): Flag for series or movie content
33
- """
34
- self.headers = {'user-agent': get_headers()}
35
- self.base_name = site_name
36
- self.domain = config_manager.get_dict('SITE', self.base_name)['domain']
37
- self.is_series = is_series
38
-
39
- def setup(self, media_id: int):
40
- """
41
- Configure media-specific context.
42
-
43
- Args:
44
- media_id (int): Unique identifier for media item
45
- """
46
- self.media_id = media_id
47
-
48
- def get_iframe(self, episode_id: int) -> None:
49
- """
50
- Retrieve iframe source for specified episode.
51
-
52
- Args:
53
- episode_id (int): Unique identifier for episode
54
- """
55
- params = {}
56
-
57
- if self.is_series:
58
- params = {
59
- 'episode_id': episode_id,
60
- 'next_episode': '1'
61
- }
62
-
63
- try:
64
-
65
- # Make a request to get iframe source
66
- response = httpx.get(
67
- url=f"https://{self.base_name}.{self.domain}/iframe/{self.media_id}",
68
- params=params,
69
- timeout=max_timeout
70
- )
71
- response.raise_for_status()
72
-
73
- # Parse response with BeautifulSoup to get iframe source
74
- soup = BeautifulSoup(response.text, "html.parser")
75
- self.iframe_src = soup.find("iframe").get("src")
76
-
77
- except Exception as e:
78
- logging.error(f"Error getting iframe source: {e}")
79
- raise
80
-
81
- def parse_script(self, script_text: str) -> None:
82
- """
83
- Convert raw script to structured video metadata.
84
-
85
- Args:
86
- script_text (str): Raw JavaScript/HTML script content
87
- """
88
- try:
89
- converter = JavaScriptParser.parse(js_string=str(script_text))
90
-
91
- # Create window video, streams and parameter objects
92
- self.canPlayFHD = bool(converter.get('canPlayFHD'))
93
- self.window_video = WindowVideo(converter.get('video'))
94
- self.window_streams = StreamsCollection(converter.get('streams'))
95
- self.window_parameter = WindowParameter(converter.get('masterPlaylist'))
96
-
97
- except Exception as e:
98
- logging.error(f"Error parsing script: {e}")
99
- raise
100
-
101
- def get_content(self) -> None:
102
- """
103
- Fetch and process video content from iframe source.
104
-
105
- Workflow:
106
- - Validate iframe source
107
- - Retrieve content
108
- - Parse embedded script
109
- """
110
- try:
111
- if self.iframe_src is not None:
112
-
113
- # Make a request to get content
114
- try:
115
- response = httpx.get(
116
- url=self.iframe_src,
117
- headers=self.headers,
118
- timeout=max_timeout
119
- )
120
- response.raise_for_status()
121
-
122
- except Exception as e:
123
- print("\n")
124
- console.print(Panel("[red bold]Coming soon", title="Notification", title_align="left", border_style="yellow"))
125
- sys.exit(0)
126
-
127
- # Parse response with BeautifulSoup to get content
128
- soup = BeautifulSoup(response.text, "html.parser")
129
- script = soup.find("body").find("script").text
130
-
131
- # Parse script to get video information
132
- self.parse_script(script_text=script)
133
-
134
- except Exception as e:
135
- logging.error(f"Error getting content: {e}")
136
- raise
137
-
138
- def get_playlist(self) -> str:
139
- """
140
- Generate authenticated playlist URL.
141
-
142
- Returns:
143
- str: Fully constructed playlist URL with authentication parameters
144
- """
145
- # Initialize parameters dictionary
146
- params = {}
147
-
148
- # Add 'h' parameter if video quality is 1080p
149
- if self.canPlayFHD:
150
- params['h'] = 1
151
-
152
- # Parse the original URL
153
- parsed_url = urlparse(self.window_parameter.url)
154
- query_params = parse_qs(parsed_url.query)
155
-
156
- # Check specifically for 'b=1' in the query parameters
157
- if 'b' in query_params and query_params['b'] == ['1']:
158
- params['b'] = 1
159
-
160
- # Add authentication parameters (token and expiration)
161
- params.update({
162
- "token": self.window_parameter.token,
163
- "expires": self.window_parameter.expires
164
- })
165
-
166
- # Build the updated query string
167
- query_string = urlencode(params)
168
-
169
- # Construct the new URL with updated query parameters
170
- return urlunparse(parsed_url._replace(query=query_string))
171
-
172
-
173
- class VideoSourceAnime(VideoSource):
174
- def __init__(self, site_name: str):
175
- """
176
- Initialize anime-specific video source.
177
-
178
- Args:
179
- site_name (str): Name of anime streaming site
180
-
181
- Extends base VideoSource with anime-specific initialization
182
- """
183
- self.headers = {'user-agent': get_headers()}
184
- self.base_name = site_name
185
- self.domain = config_manager.get_dict('SITE', self.base_name)['domain']
186
- self.src_mp4 = None
187
-
188
- def get_embed(self, episode_id: int):
189
- """
190
- Retrieve embed URL and extract video source.
191
-
192
- Args:
193
- episode_id (int): Unique identifier for episode
194
-
195
- Returns:
196
- str: Parsed script content
197
- """
198
- try:
199
-
200
- response = httpx.get(
201
- url=f"https://www.{self.base_name}.{self.domain}/embed-url/{episode_id}",
202
- headers=self.headers,
203
- timeout=max_timeout
204
- )
205
- response.raise_for_status()
206
-
207
- # Extract and clean embed URL
208
- embed_url = response.text.strip()
209
- self.iframe_src = embed_url
210
-
211
- # Fetch video content using embed URL
212
- video_response = httpx.get(embed_url)
213
- video_response.raise_for_status()
214
-
215
- # Parse response with BeautifulSoup to get content of the scriot
216
- soup = BeautifulSoup(video_response.text, "html.parser")
217
- script = soup.find("body").find("script").text
218
- self.src_mp4 = soup.find("body").find_all("script")[1].text.split(" = ")[1].replace("'", "")
219
-
220
- return script
221
-
222
- except Exception as e:
223
- logging.error(f"Error fetching embed URL: {e}")
224
- return None
@@ -1,50 +0,0 @@
1
- # 02.07.24
2
-
3
- from unidecode import unidecode
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Src.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 +0,0 @@
1
- # 09.06.24
2
-
3
- import os
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Src.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 = "Serie"
15
- MOVIE_FOLDER = "Film"
@@ -1,84 +0,0 @@
1
- # 02.07.24
2
-
3
- # External libraries
4
- import httpx
5
- from bs4 import BeautifulSoup
6
-
7
-
8
- # Internal utilities
9
- from StreamingCommunity.Src.Util.console import console
10
- from StreamingCommunity.Src.Util._jsonConfig import config_manager
11
- from StreamingCommunity.Src.Util.headers import get_headers
12
- from StreamingCommunity.Src.Util.table import TVShowManager
13
-
14
-
15
- # Logic class
16
- from StreamingCommunity.Src.Api.Template import get_select_title
17
- from StreamingCommunity.Src.Api.Template.Util import search_domain
18
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaManager
19
-
20
-
21
- # Variable
22
- from .costant import SITE_NAME
23
- media_search_manager = MediaManager()
24
- table_show_manager = TVShowManager()
25
-
26
-
27
- def title_search(word_to_search: str) -> int:
28
- """
29
- Search for titles based on a search query.
30
-
31
- Parameters:
32
- - title_search (str): The title to search for.
33
-
34
- Returns:
35
- - int: The number of titles found.
36
- """
37
-
38
- # Find new domain if prev dont work
39
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
40
- domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
41
-
42
- # Construct the full site URL and load the search page
43
- try:
44
- response = httpx.get(
45
- url=f"https://{SITE_NAME}.{domain_to_use}/search/{word_to_search}/1/",
46
- headers={'user-agent': get_headers()},
47
- follow_redirects=True,
48
- timeout=max_timeout
49
- )
50
- response.raise_for_status()
51
-
52
- except Exception as e:
53
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
54
-
55
- # Create soup and find table
56
- soup = BeautifulSoup(response.text, "html.parser")
57
-
58
- # Scrape div film in table on single page
59
- for tr in soup.find_all('tr'):
60
- try:
61
-
62
- title_info = {
63
- 'name': tr.find_all("a")[1].get_text(strip=True),
64
- 'url': tr.find_all("a")[1].get("href"),
65
- 'seader': tr.find_all("td")[-5].get_text(strip=True),
66
- 'leacher': tr.find_all("td")[-4].get_text(strip=True),
67
- 'date': tr.find_all("td")[-3].get_text(strip=True).replace("'", ""),
68
- 'size': tr.find_all("td")[-2].get_text(strip=True)
69
- }
70
-
71
- media_search_manager.add_media(title_info)
72
-
73
- except:
74
- continue
75
-
76
- # Return the number of titles found
77
- return media_search_manager.get_length()
78
-
79
-
80
- def run_get_select_title():
81
- """
82
- Display a selection of titles and prompt the user to choose one.
83
- """
84
- return get_select_title(table_show_manager, media_search_manager)
@@ -1,66 +0,0 @@
1
- # 02.07.24
2
-
3
- import os
4
-
5
-
6
- # External libraries
7
- import httpx
8
- from bs4 import BeautifulSoup
9
-
10
-
11
- # Internal utilities
12
- from StreamingCommunity.Src.Util.console import console
13
- from StreamingCommunity.Src.Util.os import os_manager
14
- from StreamingCommunity.Src.Util.message import start_message
15
- from StreamingCommunity.Src.Util.headers import get_headers
16
- from StreamingCommunity.Src.Lib.Downloader import TOR_downloader
17
-
18
-
19
- # Logic class
20
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
21
-
22
-
23
- # Config
24
- from .costant import ROOT_PATH, DOMAIN_NOW, SITE_NAME, MOVIE_FOLDER
25
-
26
-
27
- def download_title(select_title: MediaItem):
28
- """
29
- Downloads a media item and saves it as an MP4 file.
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
-
35
- start_message()
36
- console.print(f"[yellow]Download: [red]{select_title.name} \n")
37
- print()
38
-
39
- # Define output path
40
- title_name = os_manager.get_sanitize_file(select_title.name)
41
- mp4_path = os_manager.get_sanitize_path(
42
- os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
43
- )
44
-
45
- # Create output folder
46
- os_manager.create_path(mp4_path)
47
-
48
- # Make request to page with magnet
49
- full_site_name = f"{SITE_NAME}.{DOMAIN_NOW}"
50
- response = httpx.get(
51
- url="https://" + full_site_name + select_title.url,
52
- headers={
53
- 'user-agent': get_headers()
54
- },
55
- follow_redirects=True
56
- )
57
-
58
- # Create soup and find table
59
- soup = BeautifulSoup(response.text, "html.parser")
60
- final_url = soup.find("a", class_="torrentdown1").get("href")
61
-
62
- # Tor manager
63
- manager = TOR_downloader()
64
- manager.add_magnet_link(final_url)
65
- manager.start_download()
66
- manager.move_downloaded_files(mp4_path)
@@ -1,50 +0,0 @@
1
- # 26.05.24
2
-
3
- from unidecode import unidecode
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Src.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
-
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 only film
44
- download_film(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 +0,0 @@
1
- # 26.05.24
2
-
3
- import os
4
-
5
-
6
- # Internal utilities
7
- from StreamingCommunity.Src.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 = "Movie"
15
- SERIES_FOLDER= "Serie"
@@ -1,69 +0,0 @@
1
- # 26.05.24
2
-
3
- import os
4
- import time
5
-
6
-
7
- # Internal utilities
8
- from StreamingCommunity.Src.Util.console import console, msg
9
- from StreamingCommunity.Src.Util.os import os_manager
10
- from StreamingCommunity.Src.Util.message import start_message
11
- from StreamingCommunity.Src.Util.call_stack import get_call_stack
12
- from StreamingCommunity.Src.Lib.Downloader import HLS_Downloader
13
-
14
-
15
- # Logic class
16
- from StreamingCommunity.Src.Api.Template.Util import execute_search
17
- from StreamingCommunity.Src.Api.Template.Class.SearchType import MediaItem
18
-
19
-
20
- # Player
21
- from StreamingCommunity.Src.Api.Player.supervideo import VideoSource
22
-
23
-
24
- # Config
25
- from .costant import ROOT_PATH, SITE_NAME, MOVIE_FOLDER
26
-
27
-
28
- def download_film(select_title: MediaItem):
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
-
37
- # Start message and display film information
38
- start_message()
39
- console.print(f"[yellow]Download: [red]{select_title.name} \n")
40
-
41
- # Set domain and media ID for the video source
42
- video_source = VideoSource(select_title.url)
43
-
44
- # Define output path
45
- title_name = os_manager.get_sanitize_file(select_title.name) + ".mp4"
46
- mp4_path = os_manager.get_sanitize_path(
47
- os.path.join(ROOT_PATH, SITE_NAME, MOVIE_FOLDER, title_name.replace(".mp4", ""))
48
- )
49
-
50
- # Get m3u8 master playlist
51
- master_playlist = video_source.get_playlist()
52
-
53
- # Download the film using the m3u8 playlist, and output filename
54
- r_proc = HLS_Downloader(
55
- m3u8_playlist=master_playlist,
56
- output_filename=os.path.join(mp4_path, title_name)
57
- ).start()
58
-
59
- if r_proc == 404:
60
- time.sleep(2)
61
-
62
- # Re call search function
63
- 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":
64
- frames = get_call_stack()
65
- execute_search(frames[-4])
66
-
67
- if r_proc != None:
68
- console.print("[green]Result: ")
69
- console.print(r_proc)
@@ -1,86 +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.Src.Util.console import console
10
- from StreamingCommunity.Src.Util._jsonConfig import config_manager
11
- from StreamingCommunity.Src.Util.headers import get_headers
12
- from StreamingCommunity.Src.Util.table import TVShowManager
13
-
14
-
15
- # Logic class
16
- from StreamingCommunity.Src.Api.Template import get_select_title
17
- from StreamingCommunity.Src.Api.Template.Util import search_domain
18
- from StreamingCommunity.Src.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
-
26
-
27
- def title_search(title_search: str) -> int:
28
- """
29
- Search for titles based on a search query.
30
-
31
- Parameters:
32
- - title_search (str): The title to search for.
33
-
34
- Returns:
35
- int: The number of titles found.
36
- """
37
- client = httpx.Client()
38
-
39
- # Find new domain if prev dont work
40
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
41
- #domain_to_use, _ = search_domain(SITE_NAME, f"https://{SITE_NAME}")
42
-
43
- # Send request to search for title
44
- try:
45
- response = client.get(
46
- url=f"https://{SITE_NAME}.{DOMAIN_NOW}/?story={title_search.replace(' ', '+')}&do=search&subaction=search&titleonly=3",
47
- headers={
48
- 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
49
- 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
50
- 'User-Agent': get_headers()
51
- },
52
- timeout=max_timeout
53
- )
54
- response.raise_for_status()
55
-
56
- except Exception as e:
57
- console.print(f"Site: {SITE_NAME}, request search error: {e}")
58
- raise
59
-
60
- # Create soup and find table
61
- soup = BeautifulSoup(response.text, "html.parser")
62
- table_content = soup.find('div', id="dle-content")
63
-
64
- # Scrape div film in table on single page
65
- for film_div in table_content.find_all('div', class_='col-lg-3'):
66
- title = film_div.find('h2', class_='titleFilm').get_text(strip=True)
67
- link = film_div.find('h2', class_='titleFilm').find('a')['href']
68
- imdb_rating = film_div.find('div', class_='imdb-rate').get_text(strip=True).split(":")[-1]
69
-
70
- film_info = {
71
- 'name': title,
72
- 'url': link,
73
- 'score': imdb_rating
74
- }
75
-
76
- media_search_manager.add_media(film_info)
77
-
78
- # Return the number of titles found
79
- return media_search_manager.get_length()
80
-
81
-
82
- def run_get_select_title():
83
- """
84
- Display a selection of titles and prompt the user to choose one.
85
- """
86
- return get_select_title(table_show_manager, media_search_manager)