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,151 +1,151 @@
1
- # 05.07.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):
24
- """
25
- Sets up the video source with the provided URL.
26
-
27
- Parameters:
28
- - url (str): The URL of the video.
29
- """
30
- self.url = url
31
- self.redirect_url = None
32
- self.maxstream_url = None
33
- self.m3u8_url = None
34
- self.headers = {'user-agent': get_headers()}
35
-
36
- def get_redirect_url(self):
37
- """
38
- Sends a request to the initial URL and extracts the redirect URL.
39
- """
40
- try:
41
-
42
- # Send a GET request to the initial URL
43
- response = httpx.get(self.url, headers=self.headers, follow_redirects=True, timeout=max_timeout)
44
- response.raise_for_status()
45
-
46
- # Extract the redirect URL from the HTML
47
- soup = BeautifulSoup(response.text, "html.parser")
48
- self.redirect_url = soup.find("div", id="iframen1").get("data-src")
49
- logging.info(f"Redirect URL: {self.redirect_url}")
50
-
51
- return self.redirect_url
52
-
53
- except httpx.RequestError as e:
54
- logging.error(f"Error during the initial request: {e}")
55
- raise
56
-
57
- except AttributeError as e:
58
- logging.error(f"Error parsing HTML: {e}")
59
- raise
60
-
61
- def get_maxstream_url(self):
62
- """
63
- Sends a request to the redirect URL and extracts the Maxstream URL.
64
- """
65
- try:
66
-
67
- # Send a GET request to the redirect URL
68
- response = httpx.get(self.redirect_url, headers=self.headers, follow_redirects=True, timeout=max_timeout)
69
- response.raise_for_status()
70
-
71
- # Extract the Maxstream URL from the HTML
72
- soup = BeautifulSoup(response.text, "html.parser")
73
- maxstream_url = soup.find("a")
74
-
75
- if maxstream_url is None:
76
-
77
- # If no anchor tag is found, try the alternative method
78
- logging.warning("Anchor tag not found. Trying the alternative method.")
79
- headers = {
80
- 'origin': 'https://stayonline.pro',
81
- 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36 OPR/111.0.0.0',
82
- 'x-requested-with': 'XMLHttpRequest',
83
- }
84
-
85
- # Make request to stayonline api
86
- data = {'id': self.redirect_url.split("/")[-2], 'ref': ''}
87
- response = httpx.post('https://stayonline.pro/ajax/linkEmbedView.php', headers=headers, data=data)
88
- response.raise_for_status()
89
- uprot_url = response.json()['data']['value']
90
-
91
- # Retry getting maxtstream url
92
- response = httpx.get(uprot_url, headers=self.headers, follow_redirects=True, timeout=max_timeout)
93
- response.raise_for_status()
94
- soup = BeautifulSoup(response.text, "html.parser")
95
- maxstream_url = soup.find("a").get("href")
96
-
97
- else:
98
- maxstream_url = maxstream_url.get("href")
99
-
100
- self.maxstream_url = maxstream_url
101
- logging.info(f"Maxstream URL: {self.maxstream_url}")
102
-
103
- return self.maxstream_url
104
-
105
- except httpx.RequestError as e:
106
- logging.error(f"Error during the request to the redirect URL: {e}")
107
- raise
108
-
109
- except AttributeError as e:
110
- logging.error(f"Error parsing HTML: {e}")
111
- raise
112
-
113
- def get_m3u8_url(self):
114
- """
115
- Sends a request to the Maxstream URL and extracts the .m3u8 file URL.
116
- """
117
- try:
118
-
119
- # Send a GET request to the Maxstream URL
120
- response = httpx.get(self.maxstream_url, headers=self.headers, follow_redirects=True, timeout=max_timeout)
121
- response.raise_for_status()
122
- soup = BeautifulSoup(response.text, "html.parser")
123
-
124
- # Iterate over all script tags in the HTML
125
- for script in soup.find_all("script"):
126
- if "eval(function(p,a,c,k,e,d)" in script.text:
127
-
128
- # Execute the script using
129
- data_js = jsbeautifier.beautify(script.text)
130
-
131
- # Extract the .m3u8 URL from the script's output
132
- match = re.search(r'sources:\s*\[\{\s*src:\s*"([^"]+)"', data_js)
133
-
134
- if match:
135
- self.m3u8_url = match.group(1)
136
- logging.info(f"M3U8 URL: {self.m3u8_url}")
137
- break
138
-
139
- return self.m3u8_url
140
-
141
- except Exception as e:
142
- logging.error(f"Error executing the Node.js script: {e}")
143
- raise
144
-
145
- def get_playlist(self):
146
- """
147
- Executes the entire flow to obtain the final .m3u8 file URL.
148
- """
149
- self.get_redirect_url()
150
- self.get_maxstream_url()
151
- return self.get_m3u8_url()
1
+ # 05.07.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):
24
+ """
25
+ Sets up the video source with the provided URL.
26
+
27
+ Parameters:
28
+ - url (str): The URL of the video.
29
+ """
30
+ self.url = url
31
+ self.redirect_url = None
32
+ self.maxstream_url = None
33
+ self.m3u8_url = None
34
+ self.headers = {'user-agent': get_headers()}
35
+
36
+ def get_redirect_url(self):
37
+ """
38
+ Sends a request to the initial URL and extracts the redirect URL.
39
+ """
40
+ try:
41
+
42
+ # Send a GET request to the initial URL
43
+ response = httpx.get(self.url, headers=self.headers, follow_redirects=True, timeout=max_timeout)
44
+ response.raise_for_status()
45
+
46
+ # Extract the redirect URL from the HTML
47
+ soup = BeautifulSoup(response.text, "html.parser")
48
+ self.redirect_url = soup.find("div", id="iframen1").get("data-src")
49
+ logging.info(f"Redirect URL: {self.redirect_url}")
50
+
51
+ return self.redirect_url
52
+
53
+ except httpx.RequestError as e:
54
+ logging.error(f"Error during the initial request: {e}")
55
+ raise
56
+
57
+ except AttributeError as e:
58
+ logging.error(f"Error parsing HTML: {e}")
59
+ raise
60
+
61
+ def get_maxstream_url(self):
62
+ """
63
+ Sends a request to the redirect URL and extracts the Maxstream URL.
64
+ """
65
+ try:
66
+
67
+ # Send a GET request to the redirect URL
68
+ response = httpx.get(self.redirect_url, headers=self.headers, follow_redirects=True, timeout=max_timeout)
69
+ response.raise_for_status()
70
+
71
+ # Extract the Maxstream URL from the HTML
72
+ soup = BeautifulSoup(response.text, "html.parser")
73
+ maxstream_url = soup.find("a")
74
+
75
+ if maxstream_url is None:
76
+
77
+ # If no anchor tag is found, try the alternative method
78
+ logging.warning("Anchor tag not found. Trying the alternative method.")
79
+ headers = {
80
+ 'origin': 'https://stayonline.pro',
81
+ 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36 OPR/111.0.0.0',
82
+ 'x-requested-with': 'XMLHttpRequest',
83
+ }
84
+
85
+ # Make request to stayonline api
86
+ data = {'id': self.redirect_url.split("/")[-2], 'ref': ''}
87
+ response = httpx.post('https://stayonline.pro/ajax/linkEmbedView.php', headers=headers, data=data)
88
+ response.raise_for_status()
89
+ uprot_url = response.json()['data']['value']
90
+
91
+ # Retry getting maxtstream url
92
+ response = httpx.get(uprot_url, headers=self.headers, follow_redirects=True, timeout=max_timeout)
93
+ response.raise_for_status()
94
+ soup = BeautifulSoup(response.text, "html.parser")
95
+ maxstream_url = soup.find("a").get("href")
96
+
97
+ else:
98
+ maxstream_url = maxstream_url.get("href")
99
+
100
+ self.maxstream_url = maxstream_url
101
+ logging.info(f"Maxstream URL: {self.maxstream_url}")
102
+
103
+ return self.maxstream_url
104
+
105
+ except httpx.RequestError as e:
106
+ logging.error(f"Error during the request to the redirect URL: {e}")
107
+ raise
108
+
109
+ except AttributeError as e:
110
+ logging.error(f"Error parsing HTML: {e}")
111
+ raise
112
+
113
+ def get_m3u8_url(self):
114
+ """
115
+ Sends a request to the Maxstream URL and extracts the .m3u8 file URL.
116
+ """
117
+ try:
118
+
119
+ # Send a GET request to the Maxstream URL
120
+ response = httpx.get(self.maxstream_url, headers=self.headers, follow_redirects=True, timeout=max_timeout)
121
+ response.raise_for_status()
122
+ soup = BeautifulSoup(response.text, "html.parser")
123
+
124
+ # Iterate over all script tags in the HTML
125
+ for script in soup.find_all("script"):
126
+ if "eval(function(p,a,c,k,e,d)" in script.text:
127
+
128
+ # Execute the script using
129
+ data_js = jsbeautifier.beautify(script.text)
130
+
131
+ # Extract the .m3u8 URL from the script's output
132
+ match = re.search(r'sources:\s*\[\{\s*src:\s*"([^"]+)"', data_js)
133
+
134
+ if match:
135
+ self.m3u8_url = match.group(1)
136
+ logging.info(f"M3U8 URL: {self.m3u8_url}")
137
+ break
138
+
139
+ return self.m3u8_url
140
+
141
+ except Exception as e:
142
+ logging.error(f"Error executing the Node.js script: {e}")
143
+ raise
144
+
145
+ def get_playlist(self):
146
+ """
147
+ Executes the entire flow to obtain the final .m3u8 file URL.
148
+ """
149
+ self.get_redirect_url()
150
+ self.get_maxstream_url()
151
+ return self.get_m3u8_url()