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.

Files changed (101) hide show
  1. StreamingCommunity/{Src/Api → Api}/Player/Helper/Vixcloud/js_parser.py +4 -1
  2. StreamingCommunity/{Src/Api → Api}/Player/Helper/Vixcloud/util.py +166 -166
  3. StreamingCommunity/{Src/Api → Api}/Player/ddl.py +89 -89
  4. StreamingCommunity/{Src/Api → Api}/Player/maxstream.py +151 -151
  5. StreamingCommunity/{Src/Api → Api}/Player/supervideo.py +193 -193
  6. StreamingCommunity/{Src/Api → Api}/Player/vixcloud.py +224 -212
  7. StreamingCommunity/{Src/Api → Api}/Site/1337xx/__init__.py +50 -50
  8. StreamingCommunity/{Src/Api → Api}/Site/1337xx/costant.py +15 -15
  9. StreamingCommunity/{Src/Api → Api}/Site/1337xx/site.py +83 -83
  10. StreamingCommunity/{Src/Api → Api}/Site/1337xx/title.py +66 -66
  11. StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/__init__.py +50 -50
  12. StreamingCommunity/{Src/Api/Site/mostraguarda → Api/Site/altadefinizione}/costant.py +15 -15
  13. StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/film.py +69 -69
  14. StreamingCommunity/{Src/Api → Api}/Site/altadefinizione/site.py +86 -86
  15. StreamingCommunity/{Src/Api → Api}/Site/animeunity/__init__.py +50 -50
  16. StreamingCommunity/{Src/Api/Site/altadefinizione → Api/Site/animeunity}/costant.py +15 -15
  17. StreamingCommunity/{Src/Api → Api}/Site/animeunity/film_serie.py +130 -131
  18. StreamingCommunity/{Src/Api → Api}/Site/animeunity/site.py +164 -164
  19. StreamingCommunity/{Src/Api → Api}/Site/animeunity/util/ScrapeSerie.py +3 -3
  20. StreamingCommunity/{Src/Api → Api}/Site/bitsearch/__init__.py +51 -51
  21. StreamingCommunity/{Src/Api → Api}/Site/bitsearch/costant.py +15 -15
  22. StreamingCommunity/{Src/Api → Api}/Site/bitsearch/site.py +84 -84
  23. StreamingCommunity/{Src/Api → Api}/Site/bitsearch/title.py +47 -47
  24. StreamingCommunity/{Src/Api → Api}/Site/cb01new/__init__.py +51 -51
  25. StreamingCommunity/{Src/Api → Api}/Site/cb01new/costant.py +15 -15
  26. StreamingCommunity/{Src/Api → Api}/Site/cb01new/film.py +69 -69
  27. StreamingCommunity/{Src/Api → Api}/Site/cb01new/site.py +74 -74
  28. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/__init__.py +57 -57
  29. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/costant.py +16 -16
  30. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/series.py +141 -142
  31. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/site.py +92 -92
  32. StreamingCommunity/{Src/Api → Api}/Site/ddlstreamitaly/util/ScrapeSerie.py +84 -82
  33. StreamingCommunity/{Src/Api → Api}/Site/guardaserie/__init__.py +52 -52
  34. StreamingCommunity/{Src/Api/Site/piratebays → Api/Site/guardaserie}/costant.py +15 -15
  35. StreamingCommunity/{Src/Api → Api}/Site/guardaserie/series.py +195 -195
  36. StreamingCommunity/{Src/Api → Api}/Site/guardaserie/site.py +84 -84
  37. StreamingCommunity/{Src/Api → Api}/Site/guardaserie/util/ScrapeSerie.py +110 -110
  38. StreamingCommunity/{Src/Api → Api}/Site/mostraguarda/__init__.py +48 -48
  39. StreamingCommunity/{Src/Api/Site/animeunity → Api/Site/mostraguarda}/costant.py +15 -15
  40. StreamingCommunity/{Src/Api → Api}/Site/mostraguarda/film.py +94 -94
  41. StreamingCommunity/{Src/Api → Api}/Site/piratebays/__init__.py +50 -50
  42. StreamingCommunity/{Src/Api/Site/guardaserie → Api/Site/piratebays}/costant.py +15 -15
  43. StreamingCommunity/{Src/Api → Api}/Site/piratebays/site.py +88 -88
  44. StreamingCommunity/{Src/Api → Api}/Site/piratebays/title.py +45 -45
  45. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/__init__.py +55 -55
  46. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/costant.py +15 -15
  47. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/film.py +70 -70
  48. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/series.py +205 -203
  49. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/site.py +125 -125
  50. StreamingCommunity/{Src/Api → Api}/Site/streamingcommunity/util/ScrapeSerie.py +3 -3
  51. StreamingCommunity/{Src/Api → Api}/Template/Class/SearchType.py +101 -101
  52. StreamingCommunity/{Src/Api → Api}/Template/Util/__init__.py +4 -4
  53. StreamingCommunity/{Src/Api → Api}/Template/Util/get_domain.py +137 -137
  54. StreamingCommunity/{Src/Api → Api}/Template/Util/manage_ep.py +153 -153
  55. StreamingCommunity/{Src/Api → Api}/Template/Util/recall_search.py +37 -37
  56. StreamingCommunity/Api/Template/__init__.py +3 -0
  57. StreamingCommunity/{Src/Api → Api}/Template/site.py +87 -87
  58. StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/downloader.py +968 -968
  59. StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/proxyes.py +110 -110
  60. StreamingCommunity/{Src/Lib → Lib}/Downloader/HLS/segments.py +538 -540
  61. StreamingCommunity/{Src/Lib → Lib}/Downloader/MP4/downloader.py +156 -156
  62. StreamingCommunity/{Src/Lib → Lib}/Downloader/TOR/downloader.py +222 -222
  63. StreamingCommunity/{Src/Lib → Lib}/Downloader/__init__.py +4 -4
  64. StreamingCommunity/{Src/Lib → Lib}/Driver/driver_1.py +76 -76
  65. StreamingCommunity/{Src/Lib → Lib}/FFmpeg/__init__.py +4 -4
  66. StreamingCommunity/{Src/Lib → Lib}/FFmpeg/capture.py +170 -170
  67. StreamingCommunity/{Src/Lib → Lib}/FFmpeg/command.py +292 -292
  68. StreamingCommunity/{Src/Lib → Lib}/FFmpeg/util.py +241 -241
  69. StreamingCommunity/{Src/Lib → Lib}/M3U8/__init__.py +5 -5
  70. StreamingCommunity/{Src/Lib → Lib}/M3U8/decryptor.py +164 -129
  71. StreamingCommunity/{Src/Lib → Lib}/M3U8/estimator.py +175 -172
  72. StreamingCommunity/{Src/Lib → Lib}/M3U8/parser.py +666 -666
  73. StreamingCommunity/{Src/Lib → Lib}/M3U8/url_fixer.py +51 -51
  74. StreamingCommunity/Lib/TMBD/__init__.py +2 -0
  75. StreamingCommunity/{Src/Lib → Lib}/TMBD/obj_tmbd.py +39 -39
  76. StreamingCommunity/{Src/Lib → Lib}/TMBD/tmdb.py +345 -345
  77. StreamingCommunity/{Src/Upload → Upload}/update.py +68 -64
  78. StreamingCommunity/{Src/Upload → Upload}/version.py +5 -5
  79. StreamingCommunity/{Src/Util → Util}/_jsonConfig.py +204 -204
  80. StreamingCommunity/{Src/Util → Util}/call_stack.py +42 -42
  81. StreamingCommunity/{Src/Util → Util}/color.py +20 -20
  82. StreamingCommunity/{Src/Util → Util}/console.py +12 -12
  83. StreamingCommunity/Util/ffmpeg_installer.py +275 -0
  84. StreamingCommunity/{Src/Util → Util}/headers.py +147 -147
  85. StreamingCommunity/{Src/Util → Util}/logger.py +53 -53
  86. StreamingCommunity/{Src/Util → Util}/message.py +46 -46
  87. StreamingCommunity/{Src/Util → Util}/os.py +514 -417
  88. StreamingCommunity/{Src/Util → Util}/table.py +163 -163
  89. StreamingCommunity/run.py +202 -196
  90. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/METADATA +126 -60
  91. StreamingCommunity-1.9.1.dist-info/RECORD +95 -0
  92. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/WHEEL +1 -1
  93. StreamingCommunity/Src/Api/Site/animeunity/anime.py +0 -126
  94. StreamingCommunity/Src/Api/Site/ddlstreamitaly/Player/ScrapeSerie.py +0 -83
  95. StreamingCommunity/Src/Api/Site/guardaserie/Player/ScrapeSerie.py +0 -110
  96. StreamingCommunity/Src/Api/Template/__init__.py +0 -3
  97. StreamingCommunity/Src/Lib/TMBD/__init__.py +0 -2
  98. StreamingCommunity-1.7.6.dist-info/RECORD +0 -97
  99. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/LICENSE +0 -0
  100. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/entry_points.txt +0 -0
  101. {StreamingCommunity-1.7.6.dist-info → StreamingCommunity-1.9.1.dist-info}/top_level.txt +0 -0
@@ -1,194 +1,194 @@
1
- # 26.05.24
2
-
3
- import re
4
- import logging
5
-
6
-
7
- # External libraries
8
- import httpx
9
- import jsbeautifier
10
- from bs4 import BeautifulSoup
11
-
12
-
13
- # Internal utilities
14
- from StreamingCommunity.Src.Util._jsonConfig import config_manager
15
- from StreamingCommunity.Src.Util.headers import get_headers
16
-
17
-
18
- # Variable
19
- max_timeout = config_manager.get_int("REQUESTS", "timeout")
20
-
21
-
22
- class VideoSource:
23
- def __init__(self, url: str) -> None:
24
- """
25
- Initializes the VideoSource object with default values.
26
-
27
- Attributes:
28
- - url (str): The URL of the video source.
29
- """
30
- self.headers = {
31
- 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
32
- 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
33
- 'User-Agent': get_headers()
34
- }
35
- self.client = httpx.Client()
36
- self.url = url
37
-
38
- def make_request(self, url: str) -> str:
39
- """
40
- Make an HTTP GET request to the provided URL.
41
-
42
- Parameters:
43
- - url (str): The URL to make the request to.
44
-
45
- Returns:
46
- - str: The response content if successful, None otherwise.
47
- """
48
-
49
- try:
50
- response = self.client.get(
51
- url=url,
52
- headers=self.headers,
53
- follow_redirects=True,
54
- timeout=max_timeout
55
- )
56
- response.raise_for_status()
57
- return response.text
58
-
59
- except Exception as e:
60
- logging.error(f"Request failed: {e}")
61
- return None
62
-
63
- def parse_html(self, html_content: str) -> BeautifulSoup:
64
- """
65
- Parse the provided HTML content using BeautifulSoup.
66
-
67
- Parameters:
68
- - html_content (str): The HTML content to parse.
69
-
70
- Returns:
71
- - BeautifulSoup: Parsed HTML content if successful, None otherwise.
72
- """
73
-
74
- try:
75
- soup = BeautifulSoup(html_content, "html.parser")
76
- return soup
77
-
78
- except Exception as e:
79
- logging.error(f"Failed to parse HTML content: {e}")
80
- return None
81
-
82
- def get_iframe(self, soup):
83
- """
84
- Extracts the source URL of the second iframe in the provided BeautifulSoup object.
85
-
86
- Parameters:
87
- - soup (BeautifulSoup): A BeautifulSoup object representing the parsed HTML.
88
-
89
- Returns:
90
- - str: The source URL of the second iframe, or None if not found.
91
- """
92
- iframes = soup.find_all("iframe")
93
- if iframes and len(iframes) > 1:
94
- return iframes[1].get("src")
95
-
96
- return None
97
-
98
- def find_content(self, url):
99
- """
100
- Makes a request to the specified URL and parses the HTML content.
101
-
102
- Parameters:
103
- - url (str): The URL to fetch content from.
104
-
105
- Returns:
106
- - BeautifulSoup: A BeautifulSoup object representing the parsed HTML content, or None if the request fails.
107
- """
108
- content = self.make_request(url)
109
- if content:
110
- return self.parse_html(content)
111
-
112
- return None
113
-
114
- def get_result_node_js(self, soup):
115
- """
116
- Prepares and runs a Node.js script from the provided BeautifulSoup object to retrieve the video URL.
117
-
118
- Parameters:
119
- - soup (BeautifulSoup): A BeautifulSoup object representing the parsed HTML content.
120
-
121
- Returns:
122
- - str: The output from the Node.js script, or None if the script cannot be found or executed.
123
- """
124
- for script in soup.find_all("script"):
125
- if "eval" in str(script):
126
- return jsbeautifier.beautify(script.text)
127
-
128
- return None
129
-
130
- def get_playlist(self) -> str:
131
- """
132
- Download a video from the provided URL.
133
-
134
- Returns:
135
- str: The URL of the downloaded video if successful, None otherwise.
136
- """
137
- try:
138
- html_content = self.make_request(self.url)
139
- if not html_content:
140
- logging.error("Failed to fetch HTML content.")
141
- return None
142
-
143
- soup = self.parse_html(html_content)
144
- if not soup:
145
- logging.error("Failed to parse HTML content.")
146
- return None
147
-
148
- # Find master playlist
149
- data_js = self.get_result_node_js(soup)
150
-
151
- if data_js is not None:
152
- match = re.search(r'sources:\s*\[\{\s*file:\s*"([^"]+)"', data_js)
153
-
154
- if match:
155
- return match.group(1)
156
-
157
- else:
158
-
159
- iframe_src = self.get_iframe(soup)
160
- if not iframe_src:
161
- logging.error("No iframe found.")
162
- return None
163
-
164
- down_page_soup = self.find_content(iframe_src)
165
- if not down_page_soup:
166
- logging.error("Failed to fetch down page content.")
167
- return None
168
-
169
- pattern = r'data-link="(//supervideo[^"]+)"'
170
- match = re.search(pattern, str(down_page_soup))
171
- if not match:
172
- logging.error("No player available for download.")
173
- return None
174
-
175
- supervideo_url = "https:" + match.group(1)
176
- supervideo_soup = self.find_content(supervideo_url)
177
- if not supervideo_soup:
178
- logging.error("Failed to fetch supervideo content.")
179
- return None
180
-
181
- # Find master playlist
182
- data_js = self.get_result_node_js(supervideo_soup)
183
-
184
- match = re.search(r'sources:\s*\[\{\s*file:\s*"([^"]+)"', data_js)
185
-
186
- if match:
187
- return match.group(1)
188
-
189
- return None
190
-
191
- except Exception as e:
192
- logging.error(f"An error occurred: {e}")
193
- return None
1
+ # 26.05.24
2
+
3
+ import re
4
+ import logging
5
+
6
+
7
+ # External libraries
8
+ import httpx
9
+ import jsbeautifier
10
+ from bs4 import BeautifulSoup
11
+
12
+
13
+ # Internal utilities
14
+ from StreamingCommunity.Util._jsonConfig import config_manager
15
+ from StreamingCommunity.Util.headers import get_headers
16
+
17
+
18
+ # Variable
19
+ max_timeout = config_manager.get_int("REQUESTS", "timeout")
20
+
21
+
22
+ class VideoSource:
23
+ def __init__(self, url: str) -> None:
24
+ """
25
+ Initializes the VideoSource object with default values.
26
+
27
+ Attributes:
28
+ - url (str): The URL of the video source.
29
+ """
30
+ self.headers = {
31
+ 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
32
+ 'accept-language': 'it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7',
33
+ 'User-Agent': get_headers()
34
+ }
35
+ self.client = httpx.Client()
36
+ self.url = url
37
+
38
+ def make_request(self, url: str) -> str:
39
+ """
40
+ Make an HTTP GET request to the provided URL.
41
+
42
+ Parameters:
43
+ - url (str): The URL to make the request to.
44
+
45
+ Returns:
46
+ - str: The response content if successful, None otherwise.
47
+ """
48
+
49
+ try:
50
+ response = self.client.get(
51
+ url=url,
52
+ headers=self.headers,
53
+ follow_redirects=True,
54
+ timeout=max_timeout
55
+ )
56
+ response.raise_for_status()
57
+ return response.text
58
+
59
+ except Exception as e:
60
+ logging.error(f"Request failed: {e}")
61
+ return None
62
+
63
+ def parse_html(self, html_content: str) -> BeautifulSoup:
64
+ """
65
+ Parse the provided HTML content using BeautifulSoup.
66
+
67
+ Parameters:
68
+ - html_content (str): The HTML content to parse.
69
+
70
+ Returns:
71
+ - BeautifulSoup: Parsed HTML content if successful, None otherwise.
72
+ """
73
+
74
+ try:
75
+ soup = BeautifulSoup(html_content, "html.parser")
76
+ return soup
77
+
78
+ except Exception as e:
79
+ logging.error(f"Failed to parse HTML content: {e}")
80
+ return None
81
+
82
+ def get_iframe(self, soup):
83
+ """
84
+ Extracts the source URL of the second iframe in the provided BeautifulSoup object.
85
+
86
+ Parameters:
87
+ - soup (BeautifulSoup): A BeautifulSoup object representing the parsed HTML.
88
+
89
+ Returns:
90
+ - str: The source URL of the second iframe, or None if not found.
91
+ """
92
+ iframes = soup.find_all("iframe")
93
+ if iframes and len(iframes) > 1:
94
+ return iframes[1].get("src")
95
+
96
+ return None
97
+
98
+ def find_content(self, url):
99
+ """
100
+ Makes a request to the specified URL and parses the HTML content.
101
+
102
+ Parameters:
103
+ - url (str): The URL to fetch content from.
104
+
105
+ Returns:
106
+ - BeautifulSoup: A BeautifulSoup object representing the parsed HTML content, or None if the request fails.
107
+ """
108
+ content = self.make_request(url)
109
+ if content:
110
+ return self.parse_html(content)
111
+
112
+ return None
113
+
114
+ def get_result_node_js(self, soup):
115
+ """
116
+ Prepares and runs a Node.js script from the provided BeautifulSoup object to retrieve the video URL.
117
+
118
+ Parameters:
119
+ - soup (BeautifulSoup): A BeautifulSoup object representing the parsed HTML content.
120
+
121
+ Returns:
122
+ - str: The output from the Node.js script, or None if the script cannot be found or executed.
123
+ """
124
+ for script in soup.find_all("script"):
125
+ if "eval" in str(script):
126
+ return jsbeautifier.beautify(script.text)
127
+
128
+ return None
129
+
130
+ def get_playlist(self) -> str:
131
+ """
132
+ Download a video from the provided URL.
133
+
134
+ Returns:
135
+ str: The URL of the downloaded video if successful, None otherwise.
136
+ """
137
+ try:
138
+ html_content = self.make_request(self.url)
139
+ if not html_content:
140
+ logging.error("Failed to fetch HTML content.")
141
+ return None
142
+
143
+ soup = self.parse_html(html_content)
144
+ if not soup:
145
+ logging.error("Failed to parse HTML content.")
146
+ return None
147
+
148
+ # Find master playlist
149
+ data_js = self.get_result_node_js(soup)
150
+
151
+ if data_js is not None:
152
+ match = re.search(r'sources:\s*\[\{\s*file:\s*"([^"]+)"', data_js)
153
+
154
+ if match:
155
+ return match.group(1)
156
+
157
+ else:
158
+
159
+ iframe_src = self.get_iframe(soup)
160
+ if not iframe_src:
161
+ logging.error("No iframe found.")
162
+ return None
163
+
164
+ down_page_soup = self.find_content(iframe_src)
165
+ if not down_page_soup:
166
+ logging.error("Failed to fetch down page content.")
167
+ return None
168
+
169
+ pattern = r'data-link="(//supervideo[^"]+)"'
170
+ match = re.search(pattern, str(down_page_soup))
171
+ if not match:
172
+ logging.error("No player available for download.")
173
+ return None
174
+
175
+ supervideo_url = "https:" + match.group(1)
176
+ supervideo_soup = self.find_content(supervideo_url)
177
+ if not supervideo_soup:
178
+ logging.error("Failed to fetch supervideo content.")
179
+ return None
180
+
181
+ # Find master playlist
182
+ data_js = self.get_result_node_js(supervideo_soup)
183
+
184
+ match = re.search(r'sources:\s*\[\{\s*file:\s*"([^"]+)"', data_js)
185
+
186
+ if match:
187
+ return match.group(1)
188
+
189
+ return None
190
+
191
+ except Exception as e:
192
+ logging.error(f"An error occurred: {e}")
193
+ return None
194
194